| @@ 228-244 (lines=17) @@ | ||
| 225 | $this->columns = ExpressionArray::parse($parser, $list); |
|
| 226 | $state = 1; |
|
| 227 | } |
|
| 228 | } elseif ($state === 1) { |
|
| 229 | if ($token->type === Token::TYPE_KEYWORD |
|
| 230 | && $token->value !== 'FROM' |
|
| 231 | ) { |
|
| 232 | $parser->error(__('Unexpected keyword.'), $token); |
|
| 233 | break; |
|
| 234 | } elseif ($token->type === Token::TYPE_KEYWORD |
|
| 235 | && $token->value === 'FROM' |
|
| 236 | ) { |
|
| 237 | ++$list->idx; // Skip 'FROM' |
|
| 238 | $this->from = ExpressionArray::parse($parser, $list); |
|
| 239 | $state = 2; |
|
| 240 | } else { |
|
| 241 | $parser->error(__('Unexpected token.'), $token); |
|
| 242 | break; |
|
| 243 | } |
|
| 244 | } elseif ($state === 2) { |
|
| 245 | if ($token->type === Token::TYPE_KEYWORD |
|
| 246 | && $token->value === 'USING' |
|
| 247 | ) { |
|
| @@ 275-289 (lines=15) @@ | ||
| 272 | $parser->error(__('Unexpected keyword.'), $token); |
|
| 273 | break; |
|
| 274 | } |
|
| 275 | } elseif ($state === 3) { |
|
| 276 | if ($token->type === Token::TYPE_KEYWORD |
|
| 277 | && $token->value === 'WHERE' |
|
| 278 | ) { |
|
| 279 | ++$list->idx; // Skip 'WHERE' |
|
| 280 | $this->where = Condition::parse($parser, $list); |
|
| 281 | $state = 4; |
|
| 282 | } elseif ($token->type === Token::TYPE_KEYWORD) { |
|
| 283 | $parser->error(__('Unexpected keyword.'), $token); |
|
| 284 | break; |
|
| 285 | } else { |
|
| 286 | $parser->error(__('Unexpected token.'), $token); |
|
| 287 | break; |
|
| 288 | } |
|
| 289 | } elseif ($state === 4) { |
|
| 290 | if ($multiTable === true |
|
| 291 | && $token->type === Token::TYPE_KEYWORD |
|
| 292 | ) { |
|