本文整理汇总了C#中Boo.Lang.Compiler.Ast.ExpressionStatement类的典型用法代码示例。如果您正苦于以下问题:C# ExpressionStatement类的具体用法?C# ExpressionStatement怎么用?C# ExpressionStatement使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
ExpressionStatement类属于Boo.Lang.Compiler.Ast命名空间,在下文中一共展示了ExpressionStatement类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: OnExpressionStatement
public override void OnExpressionStatement(ExpressionStatement node)
{
var e = node as ExpressionStatement;
if(null!=e && e.Expression is BinaryExpression){
Visit(e.Expression as BinaryExpression);
}
}
示例2: LeaveExpressionStatement
override public void LeaveExpressionStatement(ExpressionStatement node)
{
// allow interactive evaluation of closures (see booish)
var converted = ConvertExpression(node.Expression);
if (converted != null)
node.Expression = converted;
}
示例3: LeaveExpressionStatement
public override void LeaveExpressionStatement(ExpressionStatement node)
{
IntegerLiteralExpression literal = node.Expression as IntegerLiteralExpression;
if (null == literal)
return;
AssertLiteralInRange(literal, GetExpressionType(literal));
}
示例4: Lift
public static TypeMember Lift(ExpressionStatement stmt)
{
var e = stmt.Expression;
var closure = e as BlockExpression;
if (closure != null)
return TypeMember.Lift(closure);
throw new NotImplementedException(stmt.ToCodeString());
}
示例5: OnExpressionStatement
public override void OnExpressionStatement(ExpressionStatement es)
{
if (es.Expression is MethodInvocationExpression)
es.Expression = ReplaceExpression(es.Expression);
else if (es.Expression is BinaryExpression)
{
BinaryExpression expression = (BinaryExpression)es.Expression;
expression.Right = ReplaceExpression(expression.Right);
}
}
示例6: OnExpressionStatement
public override void OnExpressionStatement(ExpressionStatement node)
{
base.OnExpressionStatement(node);
base.EnsureDocumentInitialized(node);
Expression expression = node.get_Expression();
SourceLocation self = base.doc.TokenSourceLocationFollowing(BooExtensions.AsLexicalInfo(expression.get_EndSourceLocation(), null), ";");
if (self != null)
{
node.set_EndSourceLocation(BooExtensions.OffsetedBy(self, 0, -2));
}
}
示例7: ReplaceWithInitializer
static void ReplaceWithInitializer(DeclarationStatement decl)
{
if (decl.Initializer == null) {
decl.ReplaceBy(null);
} else {
ExpressionStatement statement = new ExpressionStatement(decl.LexicalInfo);
statement.Expression = new BinaryExpression(decl.LexicalInfo, BinaryOperatorType.Assign,
new ReferenceExpression(decl.Declaration.LexicalInfo, decl.Declaration.Name),
decl.Initializer);
decl.ReplaceBy(statement);
}
}
示例8: Expression_statement_is_transformed
public void Expression_statement_is_transformed()
{
LiteralExpression exp = new StringLiteralExpression("arg1");
ExpressionStatement doStuffStatement = new ExpressionStatement(exp);
MacroStatement fixture = new MacroStatement(new LexicalInfo("test", 1, 1));
fixture.Name = "DoStuff";
fixture.Block = new Block();
fixture.Block.Add(doStuffStatement);
BlockToArgumentsTransformer transformer = new BlockToArgumentsTransformer("DoStuff");
transformer.Visit(fixture);
Assert.AreEqual(exp, fixture.Arguments[0]);
Assert.IsFalse(fixture.Block.HasStatements, "MacroStatement block should be empty after transformation.");
}
示例9: OnExpressionStatement
public override void OnExpressionStatement(ExpressionStatement node)
{
if (node.Expression is LiteralExpression)
{
CurrentText.AppendLine( node.Expression.expand());
}
else if(node.Expression is UnaryExpression){
var u = node.Expression as UnaryExpression;
if(u.Operator==UnaryOperatorType.UnaryNegation){
CurrentText.Append("-");
CurrentText.Append(u.Operand.ToCodeString());
}
}else if(node.Expression is ExpressionInterpolationExpression){
CurrentText.Append(node.Expression.expand());
}
else{
base.OnExpressionStatement(node);
}
}
示例10: MacroStatement_with_block_is_transformed_to_MethodInvocationExpression
public void MacroStatement_with_block_is_transformed_to_MethodInvocationExpression()
{
const string methodInBlockName = "some_method";
const string doStuff = "DoStuff";
Expression argInBlockExpression = new StringLiteralExpression("argInBlock");
Statement argInBlockStatement = new ExpressionStatement(argInBlockExpression);
MacroStatement statementInBlock = GetMacroStatement(methodInBlockName, argInBlockStatement);
MacroStatement doStuffStatement = GetMacroStatement(doStuff, statementInBlock);
BlockToArgumentsTransformer transformer = new BlockToArgumentsTransformer(doStuff, methodInBlockName);
transformer.Visit(doStuffStatement);
MethodInvocationExpression mie = doStuffStatement.Arguments[0] as MethodInvocationExpression;
Assert.IsNotNull(mie, "Could not cast argument one of MacroStatement to MethodInvocationExpression.");
Assert.AreEqual(methodInBlockName, (mie.Target as ReferenceExpression).Name);
Assert.IsAssignableFrom(typeof (BlockExpression), mie.Arguments[0]);
}
示例11: OnExpressionStatement
public override void OnExpressionStatement(ExpressionStatement node) {
if(isWrite(node.Expression)) {
var arg = get_arg(node.Expression);
var first = arg;
if (!(arg is ExpressionInterpolationExpression))
{
arg = new ExpressionInterpolationExpression();
}
var block = ((Block) node.ParentNode);
var index = block.Statements.IndexOf(node);
if(index==-1) return;
while (true) {
if (index > block.Statements.Count - 2) break;
var next = block.Statements[index + 1];
if(!(next is ExpressionStatement))break;
if(!isWrite(((ExpressionStatement)next).Expression)) break;
block.Statements.Remove(next);
var nextarg = get_arg(((ExpressionStatement) next).Expression);
if (nextarg is ExpressionInterpolationExpression)
{
foreach (var e in ((ExpressionInterpolationExpression)nextarg).Expressions) {
((ExpressionInterpolationExpression)arg).Expressions.Add(e);
}
}
else {
((ExpressionInterpolationExpression) arg).Expressions.Add(nextarg);
}
}
if(((ExpressionInterpolationExpression)arg).Expressions.Count>0) {
if (first != arg) {
((ExpressionInterpolationExpression) arg).Expressions.Insert(0, first);
}
set_arg(node.Expression, arg);
}
}
}
示例12: EnterExpressionStatement
public override bool EnterExpressionStatement(ExpressionStatement node)
{
EmitDebugInfo(node);
return true;
}
示例13: LeaveExpressionStatement
public override void LeaveExpressionStatement(ExpressionStatement node)
{
// if the type of the inner expression is not
// void we need to pop its return value to leave
// the stack sane
DiscardValueOnStack();
}
示例14: assignment_or_method_invocation_with_block_stmt
//throws RecognitionException, TokenStreamException
protected Statement assignment_or_method_invocation_with_block_stmt()
{
Statement stmt;
IToken op = null;
stmt = null;
Expression lhs = null;
Expression rhs = null;
StatementModifier modifier = null;
BinaryOperatorType binaryOperator = BinaryOperatorType.None;
IToken token = null;
try { // for error handling
lhs=slicing_expression();
{
switch ( LA(1) )
{
case DEF:
case DO:
case COLON:
{
{
lhs=method_invocation_block(lhs);
if (0==inputState.guessing)
{
stmt = new ExpressionStatement(lhs);
}
}
break;
}
case ASSIGN:
{
{
{
op = LT(1);
match(ASSIGN);
if (0==inputState.guessing)
{
token = op; binaryOperator = OperatorParser.ParseAssignment(op.getText());
}
{
switch ( LA(1) )
{
case DEF:
case DO:
case COLON:
{
rhs=callable_expression();
break;
}
case ESEPARATOR:
case CAST:
case CHAR:
case FALSE:
case NOT:
case NULL:
case SELF:
case SUPER:
case TRUE:
case TYPEOF:
case ID:
case TRIPLE_QUOTED_STRING:
case LPAREN:
case DOUBLE_QUOTED_STRING:
case SINGLE_QUOTED_STRING:
case LBRACK:
case SUBTRACT:
case COMMA:
case SPLICE_BEGIN:
case DOT:
case MULTIPLY:
case LBRACE:
case QQ_BEGIN:
case LONG:
case INCREMENT:
case DECREMENT:
case ONES_COMPLEMENT:
case INT:
case RE_LITERAL:
case DOUBLE:
case FLOAT:
case TIMESPAN:
{
{
rhs=array_or_expression();
{
switch ( LA(1) )
{
case DEF:
case DO:
case COLON:
{
rhs=method_invocation_block(rhs);
break;
}
case IF:
case UNLESS:
case WHILE:
//.........这里部分代码省略.........
示例15: expression_stmt
//throws RecognitionException, TokenStreamException
protected ExpressionStatement expression_stmt()
{
ExpressionStatement s;
s = null;
Expression e = null;
try { // for error handling
e=assignment_expression();
if (0==inputState.guessing)
{
s = new ExpressionStatement(e);
}
}
catch (RecognitionException ex)
{
if (0 == inputState.guessing)
{
reportError(ex, "expression_stmt");
recover(ex,tokenSet_21_);
}
else
{
throw ex;
}
}
return s;
}