Free cookie consent management tool by TermsFeed Policy Generator

source: branches/PersistenceOverhaul/HeuristicLab.ExtLibs/HeuristicLab.EPPlus/4.0.3/EPPlus-4.0.3/FormulaParsing/ExpressionGraph/ExcelAddressExpression.cs @ 13325

Last change on this file since 13325 was 12074, checked in by sraggl, 10 years ago

#2341: Added EPPlus-4.0.3 to ExtLibs

File size: 5.1 KB
Line 
1/*******************************************************************************
2 * You may amend and distribute as you like, but don't remove this header!
3 *
4 * EPPlus provides server-side generation of Excel 2007/2010 spreadsheets.
5 * See http://www.codeplex.com/EPPlus for details.
6 *
7 * Copyright (C) 2011  Jan Källman
8 *
9 * This library is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU Lesser General Public
11 * License as published by the Free Software Foundation; either
12 * version 2.1 of the License, or (at your option) any later version.
13
14 * This library is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 
17 * See the GNU Lesser General Public License for more details.
18 *
19 * The GNU Lesser General Public License can be viewed at http://www.opensource.org/licenses/lgpl-license.php
20 * If you unfamiliar with this license or have questions about it, here is an http://www.gnu.org/licenses/gpl-faq.html
21 *
22 * All code and executables are provided "as is" with no warranty either express or implied.
23 * The author accepts no liability for any damage or loss of business that this product may cause.
24 *
25 * Code change notes:
26 *
27 * Author             Change            Date
28 * ******************************************************************************
29 * Mats Alm                       Added                   2013-03-01 (Prior file history on https://github.com/swmal/ExcelFormulaParser)
30 *******************************************************************************/
31using System;
32using System.Collections.Generic;
33using System.Linq;
34using System.Text;
35using OfficeOpenXml.FormulaParsing;
36using OfficeOpenXml.FormulaParsing.ExcelUtilities;
37using OfficeOpenXml.FormulaParsing.Exceptions;
38using OfficeOpenXml.FormulaParsing.LexicalAnalysis;
39using OfficeOpenXml.FormulaParsing.Utilities;
40
41namespace OfficeOpenXml.FormulaParsing.ExpressionGraph
42{
43    public class ExcelAddressExpression : AtomicExpression
44    {
45        private readonly ExcelDataProvider _excelDataProvider;
46        private readonly ParsingContext _parsingContext;
47        private readonly RangeAddressFactory _rangeAddressFactory;
48        private readonly bool _negate;
49
50        public ExcelAddressExpression(string expression, ExcelDataProvider excelDataProvider, ParsingContext parsingContext)
51            : this(expression, excelDataProvider, parsingContext, new RangeAddressFactory(excelDataProvider), false)
52        {
53
54        }
55        public ExcelAddressExpression(string expression, ExcelDataProvider excelDataProvider, ParsingContext parsingContext, bool negate)
56            : this(expression, excelDataProvider, parsingContext, new RangeAddressFactory(excelDataProvider), negate)
57        {
58
59        }
60
61        public ExcelAddressExpression(string expression, ExcelDataProvider excelDataProvider, ParsingContext parsingContext, RangeAddressFactory rangeAddressFactory, bool negate)
62            : base(expression)
63        {
64            Require.That(excelDataProvider).Named("excelDataProvider").IsNotNull();
65            Require.That(parsingContext).Named("parsingContext").IsNotNull();
66            Require.That(rangeAddressFactory).Named("rangeAddressFactory").IsNotNull();
67            _excelDataProvider = excelDataProvider;
68            _parsingContext = parsingContext;
69            _rangeAddressFactory = rangeAddressFactory;
70            _negate = negate;
71        }
72
73        public override bool IsGroupedExpression
74        {
75            get { return false; }
76        }
77
78        public override CompileResult Compile()
79        {
80            if (ParentIsLookupFunction)
81            {
82                return new CompileResult(ExpressionString, DataType.ExcelAddress);
83            }
84            else
85            {
86                return CompileRangeValues();
87            }
88        }
89
90        private CompileResult CompileRangeValues()
91        {
92            var c = this._parsingContext.Scopes.Current;
93            var result = _excelDataProvider.GetRange(c.Address.Worksheet, c.Address.FromRow, c.Address.FromCol, ExpressionString);
94           
95            if (result == null || result.IsEmpty)
96            {
97                return CompileResult.Empty;
98            }
99            if (result.Address.Rows > 1 || result.Address.Columns > 1)
100            {
101                return new CompileResult(result, DataType.Enumerable);
102            }
103            else
104            {
105                return CompileSingleCell(result);
106            }
107        }
108
109        private CompileResult CompileSingleCell(ExcelDataProvider.IRangeInfo result)
110        {
111            var cell = result.First();
112            var factory = new CompileResultFactory();
113            var compileResult = factory.Create(cell.Value);
114            if (_negate && compileResult.IsNumeric)
115            {
116                compileResult = new CompileResult(compileResult.ResultNumeric * -1, compileResult.DataType);
117            }
118            compileResult.IsHiddenCell = cell.IsHiddenRow;
119            return compileResult;
120        }
121    }
122}
Note: See TracBrowser for help on using the repository browser.