DeveelDB  20151217
complete SQL database system, primarly developed for .NET/Mono frameworks
OpenCursorStatementNode.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.Collections.Generic;
19 using System.Linq;
20 
21 using Deveel.Data.Index;
24 
25 namespace Deveel.Data.Sql.Parser {
27  public string CursorName { get; private set; }
28 
29  public IEnumerable<IExpressionNode> Arguments { get; private set; }
30 
31  protected override ISqlNode OnChildNode(ISqlNode node) {
32  if (node is IdentifierNode) {
33  CursorName = ((IdentifierNode) node).Text;
34  } else if (node.NodeName.Equals("args_opt")) {
35  GetArguments(node);
36  }
37 
38  return base.OnChildNode(node);
39  }
40 
41  private void GetArguments(ISqlNode node) {
42  var listNode = node.FindByName("arg_list");
43  if (listNode == null)
44  return;
45 
46  var args = new List<IExpressionNode>();
47 
48  foreach (var childNode in listNode.ChildNodes) {
49  if (childNode is IExpressionNode)
50  args.Add((IExpressionNode)childNode);
51  }
52 
53  Arguments = args.AsEnumerable();
54  }
55 
56  protected override void BuildStatement(StatementBuilder builder) {
57  var args = new List<SqlExpression>();
58  if (Arguments != null) {
59  args = Arguments.Select(ExpressionBuilder.Build).ToList();
60  }
61 
62  builder.Statements.Add(new OpenStatement(CursorName, args.ToArray()));
63  }
64  }
65 }
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)
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
override void BuildStatement(StatementBuilder builder)
This interface acts like a marker that indicates if a ISqlNode represents a SQL expression.