作者:krakjo
项目:php-compile
protected function compileExpr(Op\Expr $op, $indent)
{
$phi = '';
foreach ($op->result->usages as $usage) {
if ($usage instanceof Op\Phi) {
$phi .= $indent . $this->getVarName($usage->result) . " = " . $this->getVarName($op->result) . ";\n";
}
}
$result = '';
switch ($op->getType()) {
case 'Expr_ArrayDimFetch':
$var = $this->getVarName($op->var);
$dim = $this->getVarName($op->dim);
$result = $this->getVarName($op->result);
switch ($this->mapToCType($op->var->type)) {
case 'zend_string*':
assert($this->mapToCType($op->dim->type) === 'zend_long');
$safety = $indent . "if ({$dim} < 0 || {$dim} >= ZSTR_LEN({$var})) {\n";
$safety .= $indent . "\t{$result} = ZSTR_EMPTY_ALLOC();\n";
$safety .= $indent . "\tzend_error(E_NOTICE, \"Uninitialized string offset: %pd\", {$dim});\n";
$safety .= $indent . "} else if (CG(one_char_string)[(unsigned char) ZSTR_VAL({$var})[{$dim}]]) {\n";
$safety .= $indent . "\t{$result} = CG(one_char_string)[(unsigned char) ZSTR_VAL({$var})[{$dim}]];\n";
$safety .= $indent . "} else {\n";
$safety .= $indent . "\t{$result} = zend_string_init(ZSTR_VAL({$var}) + {$dim}, 1, 0);\n";
$safety .= $indent . "\tfree_{$result} = 1;\n";
$safety .= $indent . "}\n{$phi}";
return $safety;
case 'HashTable*':
$dimType = $this->mapToCType($op->dim->type);
$resultType = $this->mapToCType($op->result->type);
if ($dimType === 'zend_long') {
$safety = $indent . "do {\n";
$safety .= $indent . "\tzval* tmp = zend_hash_index_find({$var}, {$dim});\n";
$safety .= $indent . "\tif (tmp == NULL) {\n";
if ($resultType === 'zval') {
$safety .= $indent . "\t\tZVAL_NULL(&{$result});\n";
$safety .= $indent . "\t\tzend_error(E_NOTICE, \"Uninitialized offset: %pd\", {$dim});\n";
$safety .= $indent . "\t} else {\n";
$safety .= $indent . "\t\t{$result} = *tmp;\n";
$safety .= $indent . "\t}\n";
$safety .= $indent . "} while(0);\n";
return $safety;
} else {
$typeInfo = $this->getTypeInfo($resultType);
$safety .= $indent . "\t\t" . $typeInfo['default']($result) . ";\n";
$safety .= $indent . "\t\tzend_error(E_NOTICE, \"Uninitialized offset: %pd\", {$dim});\n";
$safety .= $indent . "\t} else if (Z_TYPE_P(tmp) != {$typeInfo['ztype']}) {\n";
$safety .= $indent . "\t\tzend_throw_error(NULL, \"Offset is not an {$typeInfo['stringtype']}: %pd\", {$dim});\n";
$safety .= $indent . "\t} else {\n";
$safety .= $indent . "\t\t{$result} = {$typeInfo['ztypefetch']}(tmp);\n";
$safety .= $indent . "\t}\n";
$safety .= $indent . "} while(0); \n";
return $safety;
}
}
default:
throw new \LogicException("Unknown array dim fetch type {$op->var->type}");
}
break;
case 'Expr_Assign':
$result = $this->getVarName($op->var) . ' = ' . $this->getVarName($op->expr);
foreach ($op->var->usages as $usage) {
if ($usage instanceof Op\Phi) {
$phi .= $indent . $this->getVarName($usage->result) . " = " . $this->getVarName($op->var) . ";\n";
}
}
break;
case 'Expr_BinaryOp_BitwiseAnd':
$result = $this->getVarName($op->left) . " & " . $this->getVarName($op->right);
break;
case 'Expr_BinaryOp_BitwiseOr':
$result = $this->getVarName($op->left) . " | " . $this->getVarName($op->right);
break;
case 'Expr_BinaryOp_BitwiseXor':
$result = $this->getVarName($op->left) . " ^ " . $this->getVarName($op->right);
break;
case 'Expr_BinaryOp_Coalesce':
throw new \LogicException("TODO");
break;
case 'Expr_BinaryOp_Concat':
$result = $this->getVarName($op->left) . " . " . $this->getVarName($op->right);
break;
case 'Expr_BinaryOp_Div':
$result = $this->getVarName($op->left) . " / " . $this->getVarName($op->right);
break;
case 'Expr_BinaryOp_Equal':
throw new \LogicException("TODO");
break;
case 'Expr_BinaryOp_Greater':
$result = $this->getVarName($op->left) . " > " . $this->getVarName($op->right);
break;
case 'Expr_BinaryOp_GreaterOrEqual':
$result = $this->getVarName($op->left) . " >= " . $this->getVarName($op->right);
break;
case 'Expr_BinaryOp_Identical':
throw new \LogicException("TODO");
break;
case 'Expr_BinaryOp_LogicalXor':
throw new \LogicException("TODO");
break;
//.........这里部分代码省略.........
作者:ircmaxel
项目:php-cf
public function __construct(array $keys, array $values, array $byRef, array $attributes = [])
{
parent::__construct($attributes);
$this->keys = $this->addReadRef($keys);
$this->values = $this->addReadRef($values);
$this->byRef = $byRef;
}
作者:ircmaxel
项目:php-cf
public function __construct(Operand $read, Operand $write, Assert $assertion, array $attributes = [])
{
parent::__construct($attributes);
$this->expr = $this->addReadRef($read);
$this->assertion = $this->addReadRef($assertion);
$this->result = $this->addWriteRef($write);
}
作者:niki
项目:php-cf
public function __construct(array $keys, array $values, array $byRef, array $attributes = array())
{
parent::__construct($attributes);
$this->keys = $keys;
$this->values = $values;
$this->byRef = $byRef;
}
作者:ircmaxel
项目:php-cf
public function __construct(Operand $name, Operand $nsName, array $args, array $attributes = [])
{
parent::__construct($attributes);
$this->nsName = $this->addReadRef($nsName);
$this->name = $this->addReadRef($name);
$this->args = $this->addReadRef($args);
}
作者:royop
项目:php-cf
public function __construct(Operand $class, Operand $name, array $args, array $attributes = array())
{
parent::__construct($attributes);
$this->class = $class;
$this->name = $name;
$this->args = $args;
}
作者:niki
项目:php-cf
public function __construct(Variable $var, Variable $name, array $args, array $attributes = array())
{
parent::__construct($attributes);
$this->var = $var;
$this->name = $name;
$this->args = $args;
}
作者:niki
项目:php-cf
public function __construct(array $params, $byRef, $returnType, Block $stmts, array $attributes = array())
{
parent::__construct($attributes);
$this->params = $params;
$this->byRef = (bool) $byRef;
$this->returnType = $returnType;
$this->stmts = $stmts;
}
作者:RustJaso
项目:php-cf
public function __construct(array $params, array $useVars, $byRef, $returnType, Block $stmts, array $attributes = [])
{
parent::__construct($attributes);
$this->params = $this->addReadRef($params);
$this->useVars = $this->addReadRef($useVars);
$this->byRef = (bool) $byRef;
$this->returnType = $returnType;
$this->stmts = $stmts;
}
作者:royop
项目:php-cf
public function __construct(Operand $name, $type, $byRef, $variadic, Operand $defaultVar = null, Block $defaultBlock = null, array $attributes = array())
{
parent::__construct($attributes);
$this->result->name = $name;
$this->name = $name;
$this->type = $type;
$this->byRef = (bool) $byRef;
$this->variadic = (bool) $variadic;
$this->defaultVar = $defaultVar;
$this->defaultBlock = $defaultBlock;
}
作者:royop
项目:php-cf
public function __construct(Operand $left, Operand $right, array $attributes = array())
{
parent::__construct($attributes);
$this->left = $left;
$this->right = $right;
}
作者:niki
项目:php-cf
public function __construct(Variable $expr, $type, array $attributes = array())
{
parent::__construct($attributes);
$this->expr = $expr;
$this->type = $type;
}
作者:royop
项目:php-cf
public function __construct(Operand $var, Operand $name, array $attributes = array())
{
parent::__construct($attributes);
$this->var = $var;
$this->name = $name;
}
作者:RustJaso
项目:php-cf
public function __construct(array $list, array $attributes = [])
{
parent::__construct($attributes);
$this->list = $this->addWriteRef($list);
}
作者:ircmaxel
项目:php-cf
public function __construct(array $vars, array $attributes = [])
{
parent::__construct($attributes);
$this->vars = $this->addReadRef($vars);
}
作者:niki
项目:php-cf
public function __construct(Variable $class, array $args, array $attributes = array())
{
parent::__construct($attributes);
$this->class = $class;
$this->args = $args;
}
作者:royop
项目:php-cf
public function __construct(Operand $var, $byRef, array $attributes = array())
{
parent::__construct($attributes);
$this->var = $var;
$this->byRef = $byRef;
}
作者:royop
项目:php-cf
public function __construct(Operand $expr, array $attributes = array())
{
parent::__construct($attributes);
$this->expr = $expr;
}
作者:ircmaxel
项目:php-cf
public function __construct(Operand $left, Operand $right, array $attributes = [])
{
parent::__construct($attributes);
$this->left = $this->addReadRef($left);
$this->right = $this->addReadRef($right);
}
作者:niki
项目:php-cf
public function __construct(Variable $expr, Variable $class, array $attributes = array())
{
parent::__construct($attributes);
$this->expr = $expr;
$this->class = $class;
}