DeveelDB  20151217
complete SQL database system, primarly developed for .NET/Mono frameworks
DeclareVariableNode.cs
Go to the documentation of this file.
1 //
2 // Copyright 2010-2015 Deveel
3 //
4 // Licensed under the Apache License, Version 2.0 (the "License");
5 // you may not use this file except in compliance with the License.
6 // You may obtain a copy of the License at
7 //
8 // http://www.apache.org/licenses/LICENSE-2.0
9 //
10 // Unless required by applicable law or agreed to in writing, software
11 // distributed under the License is distributed on an "AS IS" BASIS,
12 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 // See the License for the specific language governing permissions and
14 // limitations under the License.
15 //
16 
17 using System;
18 using System.Linq;
19 
21 
22 namespace Deveel.Data.Sql.Parser {
24  public string VariableName { get; private set; }
25 
26  public DataTypeNode Type { get; private set; }
27 
28  public bool IsConstant { get; private set; }
29 
30  public bool IsNotNull { get; private set; }
31 
32  public IExpressionNode DefaultExpression { get; private set; }
33 
34  protected override ISqlNode OnChildNode(ISqlNode node) {
35  if (node is IdentifierNode) {
36  VariableName = ((IdentifierNode) node).Text;
37  } else if (node is DataTypeNode) {
38  Type = (DataTypeNode)node;
39  } else if (node.NodeName.Equals("constant_opt")) {
40  IsConstant = node.ChildNodes.Any();
41  } else if (node.NodeName.Equals("var_not_null_opt")) {
42  IsNotNull = node.ChildNodes.Any();
43  } else if (node.NodeName.Equals("var_default_opt")) {
44  GetDefaultExpression(node);
45  }
46 
47  return base.OnChildNode(node);
48  }
49 
50  private void GetDefaultExpression(ISqlNode node) {
51  foreach (var childNode in node.ChildNodes) {
52  if (childNode is IExpressionNode)
53  DefaultExpression = (IExpressionNode) childNode;
54  }
55  }
56 
57  protected override void BuildStatement(StatementBuilder builder) {
58  var varType = DataTypeBuilder.Build(builder.TypeResolver, Type);
59  var statement = new DeclareVariableStatement(VariableName, varType);
60  if (DefaultExpression != null)
61  statement.DefaultExpression = ExpressionBuilder.Build(DefaultExpression);
62 
63  statement.IsConstant = IsConstant;
64  statement.IsNotNull = IsConstant || IsNotNull;
65  builder.Statements.Add(statement);
66  }
67  }
68 }
This is a simple identifier within a SQL grammar.
Defines the contract for nodes in an AST model for a SQL grammar analysis and parsing.
Definition: ISqlNode.cs:25
string NodeName
Gets the name of the node analyzed from the parser.
Definition: ISqlNode.cs:29
static SqlExpression Build(IExpressionNode node)
static SqlType Build(ITypeResolver resolver, ISqlNode sqlNode)
override ISqlNode OnChildNode(ISqlNode node)
During the initialization of the node from the parser, this method is called for every child node add...
ICollection< IStatement > Statements
A user-defined TYPE that holds complex objects in a database column.
IEnumerable< ISqlNode > ChildNodes
Gets a read-only enumeration of the children nodes, if any.
Definition: ISqlNode.cs:39
override void BuildStatement(StatementBuilder builder)
Describes the information of a data type as found in a SQL string.
Definition: DataTypeNode.cs:28
This interface acts like a marker that indicates if a ISqlNode represents a SQL expression.