summaryrefslogtreecommitdiffstats
path: root/src/Components/SetOperation.php
diff options
context:
space:
mode:
Diffstat (limited to 'src/Components/SetOperation.php')
-rw-r--r--src/Components/SetOperation.php122
1 files changed, 122 insertions, 0 deletions
diff --git a/src/Components/SetOperation.php b/src/Components/SetOperation.php
new file mode 100644
index 0000000..dad91e5
--- /dev/null
+++ b/src/Components/SetOperation.php
@@ -0,0 +1,122 @@
+<?php
+
+/**
+ * `SET` keyword parser.
+ *
+ * @package SqlParser
+ * @subpackage Components
+ */
+namespace SqlParser\Components;
+
+use SqlParser\Component;
+use SqlParser\Parser;
+use SqlParser\Token;
+use SqlParser\TokensList;
+
+/**
+ * `SET` keyword parser.
+ *
+ * @category Keywords
+ * @package SqlParser
+ * @subpackage Components
+ * @author Dan Ungureanu <udan1107@gmail.com>
+ * @license http://opensource.org/licenses/GPL-2.0 GNU Public License
+ */
+class SetOperation extends Component
+{
+
+ /**
+ * The name of the column that is being updated.
+ *
+ * @var string
+ */
+ public $column;
+
+ /**
+ * The new value.
+ *
+ * @var string
+ */
+ public $value;
+
+ /**
+ * @param Parser $parser The parser that serves as context.
+ * @param TokensList $list The list of tokens that are being parsed.
+ * @param array $options Parameters for parsing.
+ *
+ * @return SetOperation[]
+ */
+ public static function parse(Parser $parser, TokensList $list, array $options = array())
+ {
+ $ret = array();
+
+ $expr = new SetOperation();
+
+ /**
+ * The state of the parser.
+ *
+ * Below are the states of the parser.
+ *
+ * 0 -------------------[ field name ]--------------------> 1
+ *
+ * 1 ------------------------[ , ]------------------------> 0
+ * 1 ----------------------[ value ]----------------------> 1
+ *
+ * @var int
+ */
+ $state = 0;
+
+ for (; $list->idx < $list->count; ++$list->idx) {
+ /**
+ * Token parsed at this moment.
+ * @var Token $token
+ */
+ $token = $list->tokens[$list->idx];
+
+ // End of statement.
+ if ($token->type === Token::TYPE_DELIMITER) {
+ break;
+ }
+
+ // Skipping whitespaces and comments.
+ if (($token->type === Token::TYPE_WHITESPACE) || ($token->type === Token::TYPE_COMMENT)) {
+ continue;
+ }
+
+ // No keyword is expected.
+ if (($token->type === Token::TYPE_KEYWORD) && ($token->flags & Token::FLAG_KEYWORD_RESERVED)) {
+ break;
+ }
+
+ if ($token->type === Token::TYPE_OPERATOR) {
+ if ($token->value === ',') {
+ $expr->column = trim($expr->column);
+ $expr->value = trim($expr->value);
+ $ret[] = $expr;
+ $expr = new SetOperation();
+ $state = 0;
+ continue;
+ } elseif ($token->value === '=') {
+ $state = 1;
+ continue;
+ }
+ }
+
+ if ($state === 0) {
+ $expr->column .= $token->token;
+ } else { // } else if ($state === 1) {
+ $expr->value .= $token->token;
+ }
+ }
+
+ // Last iteration was not saved.
+ if (!empty($expr->column)) {
+ $expr->column = trim($expr->column);
+ $expr->value = trim($expr->value);
+ $ret[] = $expr;
+ }
+
+ --$list->idx;
+ return $ret;
+ }
+}