122 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			122 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
/**
 | 
						|
 * This file is part of the Peast package
 | 
						|
 *
 | 
						|
 * (c) Marco Marchiò <marco.mm89@gmail.com>
 | 
						|
 *
 | 
						|
 * For the full copyright and license information refer to the LICENSE file
 | 
						|
 * distributed with this source code
 | 
						|
 */
 | 
						|
namespace Peast\Syntax\Node;
 | 
						|
 | 
						|
/**
 | 
						|
 * A node that represents an update expression.
 | 
						|
 * For example: a++
 | 
						|
 * 
 | 
						|
 * @author Marco Marchiò <marco.mm89@gmail.com>
 | 
						|
 */
 | 
						|
class UpdateExpression extends Node implements Expression
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * Map of node properties
 | 
						|
     * 
 | 
						|
     * @var array 
 | 
						|
     */
 | 
						|
    protected $propertiesMap = array(
 | 
						|
        "argument" => true,
 | 
						|
        "operator" => false,
 | 
						|
        "prefix" => false
 | 
						|
    );
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Expression's operator
 | 
						|
     * 
 | 
						|
     * @var string
 | 
						|
     */
 | 
						|
    protected $operator;
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Prefix flag that is true when the operator precedes the argument
 | 
						|
     * 
 | 
						|
     * @var bool
 | 
						|
     */
 | 
						|
    protected $prefix = false;
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Expression's argument
 | 
						|
     * 
 | 
						|
     * @var Expression 
 | 
						|
     */
 | 
						|
    protected $argument;
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Returns the expression's operator
 | 
						|
     * 
 | 
						|
     * @return string
 | 
						|
     */
 | 
						|
    public function getOperator()
 | 
						|
    {
 | 
						|
        return $this->operator;
 | 
						|
    }
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Sets the expression's operator
 | 
						|
     * 
 | 
						|
     * @param string $operator Operator
 | 
						|
     * 
 | 
						|
     * @return $this
 | 
						|
     */
 | 
						|
    public function setOperator($operator)
 | 
						|
    {
 | 
						|
        $this->operator = $operator;
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Returns the prefix flag that is true when the operator precedes the
 | 
						|
     * argument
 | 
						|
     * 
 | 
						|
     * @return bool
 | 
						|
     */
 | 
						|
    public function getPrefix()
 | 
						|
    {
 | 
						|
        return $this->prefix;
 | 
						|
    }
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Sets the prefix flag that is true when the operator precedes the
 | 
						|
     * argument
 | 
						|
     * 
 | 
						|
     * @param bool $prefix Prefix flag
 | 
						|
     * 
 | 
						|
     * @return $this
 | 
						|
     */
 | 
						|
    public function setPrefix($prefix)
 | 
						|
    {
 | 
						|
        $this->prefix = $prefix;
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Returns the expression's argument
 | 
						|
     * 
 | 
						|
     * @return Expression
 | 
						|
     */
 | 
						|
    public function getArgument()
 | 
						|
    {
 | 
						|
        return $this->argument;
 | 
						|
    }
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * Sets the expression's argument
 | 
						|
     * 
 | 
						|
     * @param Expression $argument Argument
 | 
						|
     * 
 | 
						|
     * @return $this
 | 
						|
     */
 | 
						|
    public function setArgument(Expression $argument)
 | 
						|
    {
 | 
						|
        $this->argument = $argument;
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
} |