Package com.caucho.quercus.expr

Source Code of com.caucho.quercus.expr.ListHeadExpr

/*
* Copyright (c) 1998-2010 Caucho Technology -- all rights reserved
*
* This file is part of Resin(R) Open Source
*
* Each copy or derived work must preserve the copyright notice and this
* notice unmodified.
*
* Resin Open Source is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* Resin Open Source is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty
* of NON-INFRINGEMENT.  See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License
* along with Resin Open Source; if not, write to the
*
*   Free Software Foundation, Inc.
*   59 Temple Place, Suite 330
*   Boston, MA 02111-1307  USA
*
* @author Scott Ferguson
*/

package com.caucho.quercus.expr;

import com.caucho.quercus.env.ArrayValue;
import com.caucho.quercus.env.Env;
import com.caucho.quercus.env.LongValue;
import com.caucho.quercus.env.NullValue;
import com.caucho.quercus.env.Value;
import com.caucho.util.L10N;

import java.util.ArrayList;

/**
* Represents a list assignment expression.
*/
public class ListHeadExpr extends Expr {
  private static final L10N L = new L10N(ListHeadExpr.class);
 
  protected final Expr []_varList;
  protected final Value []_keyList;

  private String _varName;

  public ListHeadExpr(ArrayList<Expr> varList)
  {
    _varList = new Expr[varList.size()];
    varList.toArray(_varList);

    _keyList = new Value[varList.size()];

    for (int i = 0; i < varList.size(); i++)
      _keyList[i] = LongValue.create(i);
  }

  public Expr []getVarList()
  {
    return _varList;
  }

  /**
   * Evaluates the expression.
   *
   * @param env the calling environment.
   *
   * @return the expression value.
   */
  public Value eval(Env env)
  {
    throw new UnsupportedOperationException();
  }

  /**
   * Evaluates the expression.
   *
   * @param env the calling environment.
   *
   * @return the expression value.
   */
  public Value evalAssignValue(Env env, Value value)
  {
    int len = _varList.length;

    for (int i = 0; i < len; i++) {
      if (_varList[i] != null)
        _varList[i].evalAssignValue(env, value.get(_keyList[i]).copy());
    }
   
    return value;
  }
 
  public Value evalAssignEachValue(Env env, Value value)
  {
    if (! (value instanceof ArrayValue)) {
      env.error(L.l("variable passed to each must reference an array"));
      return NullValue.NULL;
    }

    ArrayValue array = (ArrayValue) value;
   
    if (_varList.length > 0 && _varList[0] != null)
      _varList[0].evalAssignValue(env, array.key());

    if (_varList.length > 1 && _varList[1] != null)
      _varList[1].evalAssignValue(env, array.current().copy());
     
    return array.each();
  }
 
  public boolean evalEachBoolean(Env env, Value value)
  {
    if (! (value instanceof ArrayValue)) {
      env.error(L.l("variable passed to each must reference an array"));
      return false;
    }

    ArrayValue array = (ArrayValue) value;
   
    if (! array.hasCurrent())
      return false;
   
    if (_varList.length > 0 && _varList[0] != null)
      _varList[0].evalAssignValue(env, array.key());

    if (_varList.length > 1 && _varList[1] != null)
      _varList[1].evalAssignValue(env, array.current().copy());

    array.next();

    return true;
  }
}
TOP

Related Classes of com.caucho.quercus.expr.ListHeadExpr

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.