Free cookie consent management tool by TermsFeed Policy Generator

source: trunk/HeuristicLab.ExtLibs/HeuristicLab.EPPlus/4.0.3/EPPlus-4.0.3/FormulaParsing/ExpressionGraph/CompileResultFactory.cs @ 15888

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

#2341: Added EPPlus-4.0.3 to ExtLibs

File size: 3.3 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;
35
36namespace OfficeOpenXml.FormulaParsing.ExpressionGraph
37{
38    public class CompileResultFactory
39    {
40        public virtual CompileResult Create(object obj)
41        {
42            if ((obj is ExcelDataProvider.INameInfo))
43            {
44                obj = ((ExcelDataProvider.INameInfo)obj).Value;
45            }
46            if (obj is ExcelDataProvider.IRangeInfo)
47            {
48                obj = ((ExcelDataProvider.IRangeInfo)obj).GetOffset(0, 0);
49            }
50            if (obj == null) return new CompileResult(null, DataType.Empty);
51            if (obj.GetType().Equals(typeof(string)))
52            {
53                return new CompileResult(obj, DataType.String);
54            }
55            if (obj.GetType().Equals(typeof(double)) || obj is decimal)
56            {
57                return new CompileResult(obj, DataType.Decimal);
58            }
59            if (obj.GetType().Equals(typeof(int)) || obj is long || obj is short)
60            {
61                return new CompileResult(obj, DataType.Integer);
62            }
63            if (obj.GetType().Equals(typeof(bool)))
64            {
65                return new CompileResult(obj, DataType.Boolean);
66            }
67            if (obj.GetType().Equals(typeof (ExcelErrorValue)))
68            {
69                return new CompileResult(obj, DataType.ExcelError);
70            }
71            if (obj.GetType().Equals(typeof(System.DateTime)))
72            {
73                return new CompileResult(((System.DateTime)obj).ToOADate(), DataType.Date);
74            }
75            throw new ArgumentException("Non supported type " + obj.GetType().FullName);
76        }
77    }
78}
Note: See TracBrowser for help on using the repository browser.