Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   ***** BEGIN LICENSE BLOCK *****
   * Version: EPL 1.0/GPL 2.0/LGPL 2.1
   *
   * The contents of this file are subject to the Eclipse Public
   * License Version 1.0 (the "License"); you may not use this file
   * except in compliance with the License. You may obtain a copy of
   * the License at http://www.eclipse.org/legal/epl-v10.html
   *
  * Software distributed under the License is distributed on an "AS
  * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
  * implied. See the License for the specific language governing
  * rights and limitations under the License.
  *
  * Copyright (C) 2002 Benoit Cerrina <b.cerrina@wanadoo.fr>
  * Copyright (C) 2002 Jan Arne Petersen <jpetersen@uni-bonn.de>
  * Copyright (C) 2002-2004 Anders Bengtsson <ndrsbngtssn@yahoo.se>
  * Copyright (C) 2004 Thomas E Enebo <enebo@acm.org>
  * Copyright (C) 2004 Stefan Matthias Aust <sma@3plus4.de>
  * 
  * Alternatively, the contents of this file may be used under the terms of
  * either of the GNU General Public License Version 2 or later (the "GPL"),
  * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
  * in which case the provisions of the GPL or the LGPL are applicable instead
  * of those above. If you wish to allow use of your version of this file only
  * under the terms of either the GPL or the LGPL, and not to allow others to
  * use your version of this file under the terms of the EPL, indicate your
  * decision by deleting the provisions above and replace them with the notice
  * and other provisions required by the GPL or the LGPL. If you do not delete
  * the provisions above, a recipient may use your version of this file under
  * the terms of any one of the EPL, the GPL or the LGPL.
  ***** END LICENSE BLOCK *****/
 package org.jruby.ast;
 
 import java.util.List;
 
 import org.jruby.Ruby;
A Range in a boolean expression (named after a FlipFlop component in electronic?).
 
 public class FlipNode extends Node {
     private final Node beginNode;
     private final Node endNode;
     private final boolean exclusive;
     // A scoped location of this variable (high 16 bits is how many scopes down and low 16 bits
     // is what index in the right scope to set the value.
     private final int location;
     
     public FlipNode(ISourcePosition positionNode beginNodeNode endNodeboolean exclusiveint location) {
         super(position);
         
         assert beginNode != null : "beginNode is not null";
         assert endNode != null : "endNode is not null";
         
         this. = beginNode;
         this. = endNode;
         this. = exclusive;
         this. = location;
     }
 
     public NodeType getNodeType() {
         return .;
     }

    
Accept for the visitor pattern.

Parameters:
iVisitor the visitor
 
     public Object accept(NodeVisitor iVisitor) {
         return iVisitor.visitFlipNode(this);
     }

    
Gets the beginNode. beginNode will set the FlipFlop the first time it is true

Returns:
Returns a Node
 
     public Node getBeginNode() {
         return ;
     }

    
Gets the endNode. endNode will reset the FlipFlop when it is true while the FlipFlop is set.

Returns:
Returns a Node
 
     public Node getEndNode() {
         return ;
     }

    
Gets the exclusive. if the range is a 2 dot range it is false if it is a three dot it is true

Returns:
Returns a boolean
    public boolean isExclusive() {
        return ;
    }

    
How many scopes should we burrow down to until we need to set the block variable value.

Returns:
0 for current scope, 1 for one down, ...
    public int getDepth() {
        return  >> 16;
    }
    
    
Gets the index within the scope construct that actually holds the eval'd value of this local variable

Returns:
Returns an int offset into storage structure
    public int getIndex() {
        return  & 0xffff;
    }
    
    public List<NodechildNodes() {
        return Node.createList();
    }
    
    @Override
    public IRubyObject interpret(Ruby runtimeThreadContext contextIRubyObject selfBlock aBlock) {
        DynamicScope scope = context.getCurrentScope();
        IRubyObject nil = runtime.getNil();
        int index = getIndex();
        // Make sure the appropriate scope has proper size. See JRUBY-2046.
        DynamicScope flipScope = scope.getFlipScope();
        flipScope.growIfNeeded();
        
        IRubyObject result = flipScope.getValueDepthZeroOrNil(indexnil);
   
        if () {
            if (result == null || !result.isTrue()) {
                result = trueIfTrue(runtime.interpret(runtimecontextselfaBlock));
                flipScope.setValueDepthZero(resultindex);
                return result;
            } else {
                if (.interpret(runtimecontextselfaBlock).isTrue()) {
                    flipScope.setValueDepthZero(runtime.getFalse(), index);
                }
                
                return runtime.getTrue();
            }
        } else {
            if (result == null || !result.isTrue()) {
                if (.interpret(runtimecontextselfaBlock).isTrue()) {
                    flipScope.setValueDepthZero(falseIfTrue(runtime.interpret(runtimecontextselfaBlock)), index);
                    return runtime.getTrue();
                } 
                return runtime.getFalse();
            } else {
                if (.interpret(runtimecontextselfaBlock).isTrue()) {
                    flipScope.setValueDepthZero(runtime.getFalse(), index);
                }
                return runtime.getTrue();
            }
        }
    }
    
    private static RubyBoolean trueIfTrue(Ruby runtimeIRubyObject truish) {
        return truish.isTrue() ? runtime.getTrue() : runtime.getFalse();
    }
    
    private static RubyBoolean falseIfTrue(Ruby runtimeIRubyObject truish) {
        return truish.isTrue() ? runtime.getFalse() : runtime.getTrue();
    }
New to GrepCode? Check out our FAQ X