]> git.joonet.de Git - adminer.git/commitdiff
Upload error only if not other error
authorjakubvrana <jakubvrana@7c3ca157-0c34-0410-bff1-cbf682f78f5c>
Tue, 30 Sep 2008 12:22:24 +0000 (12:22 +0000)
committerjakubvrana <jakubvrana@7c3ca157-0c34-0410-bff1-cbf682f78f5c>
Tue, 30 Sep 2008 12:22:24 +0000 (12:22 +0000)
git-svn-id: https://adminer.svn.sourceforge.net/svnroot/adminer/trunk@507 7c3ca157-0c34-0410-bff1-cbf682f78f5c

sql.inc.php

index e75c89832448008711f02fa21d88f8979f1a24c4..40e371cb6880ddced98eef1f09b97561d43bca86 100644 (file)
@@ -5,48 +5,50 @@ if (isset($_POST["query"])) {
 }
 page_header(lang('SQL command'), $error);
 
-if (!$error && $_POST && is_string($query = (isset($_POST["query"]) ? $_POST["query"] : get_file("sql_file")))) {
-       $delimiter = ";";
-       $offset = 0;
-       $empty = true;
-       while (rtrim($query)) {
-               if (!$offset && preg_match('~^\\s*DELIMITER\\s+(.+)~i', $query, $match)) {
-                       $delimiter = preg_quote($match[1], '~');
-                       $query = substr($query, strlen($match[0]));
-               } elseif (preg_match("~$delimiter|['`\"]|/\\*|-- |#|\$~", $query, $match, PREG_OFFSET_CAPTURE, $offset)) {
-                       if ($match[0][0] && $match[0][0] != $delimiter) {
-                               $pattern = ($match[0][0] == "-- " || $match[0][0] == "#" ? '~.*~' : ($match[0][0] == "/*" ? '~.*\\*/~sU' : '~\\G([^\\\\' . $match[0][0] . ']+|\\\\.)*(' . $match[0][0] . '|$)~s'));
-                               preg_match($pattern, $query, $match, PREG_OFFSET_CAPTURE, $match[0][1] + 1);
-                               $offset = $match[0][1] + strlen($match[0][0]);
-                       } else {
-                               $empty = false;
-                               echo "<pre class='jush-sql'>" . htmlspecialchars(substr($query, 0, $match[0][1])) . "</pre>\n";
-                               //! don't allow changing of character_set_results, convert encoding of displayed query
-                               if (!$mysql->multi_query(substr($query, 0, $match[0][1]))) {
-                                       echo "<p class='error'>" . lang('Error in query') . ": " . htmlspecialchars($mysql->error) . "</p>\n";
+if (!$error && $_POST) {
+       if (is_string($query = (isset($_POST["query"]) ? $_POST["query"] : get_file("sql_file")))) {
+               $delimiter = ";";
+               $offset = 0;
+               $empty = true;
+               while (rtrim($query)) {
+                       if (!$offset && preg_match('~^\\s*DELIMITER\\s+(.+)~i', $query, $match)) {
+                               $delimiter = preg_quote($match[1], '~');
+                               $query = substr($query, strlen($match[0]));
+                       } elseif (preg_match("~$delimiter|['`\"]|/\\*|-- |#|\$~", $query, $match, PREG_OFFSET_CAPTURE, $offset)) {
+                               if ($match[0][0] && $match[0][0] != $delimiter) {
+                                       $pattern = ($match[0][0] == "-- " || $match[0][0] == "#" ? '~.*~' : ($match[0][0] == "/*" ? '~.*\\*/~sU' : '~\\G([^\\\\' . $match[0][0] . ']+|\\\\.)*(' . $match[0][0] . '|$)~s'));
+                                       preg_match($pattern, $query, $match, PREG_OFFSET_CAPTURE, $match[0][1] + 1);
+                                       $offset = $match[0][1] + strlen($match[0][0]);
                                } else {
-                                       do {
-                                               $result = $mysql->store_result();
-                                               if (is_object($result)) {
-                                                       select($result);
-                                               } else {
-                                                       if (preg_match("~^\\s*(CREATE|DROP)(\\s+|/\\*.*\\*/|(#|-- )[^\n]*\n)+(DATABASE|SCHEMA)\\b~isU", $query)) {
-                                                               unset($_SESSION["databases"][$_GET["server"]]);
+                                       $empty = false;
+                                       echo "<pre class='jush-sql'>" . htmlspecialchars(substr($query, 0, $match[0][1])) . "</pre>\n";
+                                       //! don't allow changing of character_set_results, convert encoding of displayed query
+                                       if (!$mysql->multi_query(substr($query, 0, $match[0][1]))) {
+                                               echo "<p class='error'>" . lang('Error in query') . ": " . htmlspecialchars($mysql->error) . "</p>\n";
+                                       } else {
+                                               do {
+                                                       $result = $mysql->store_result();
+                                                       if (is_object($result)) {
+                                                               select($result);
+                                                       } else {
+                                                               if (preg_match("~^\\s*(CREATE|DROP)(\\s+|/\\*.*\\*/|(#|-- )[^\n]*\n)+(DATABASE|SCHEMA)\\b~isU", $query)) {
+                                                                       unset($_SESSION["databases"][$_GET["server"]]);
+                                                               }
+                                                               echo "<p class='message'>" . lang('Query executed OK, %d row(s) affected.', $mysql->affected_rows) . "</p>\n";
                                                        }
-                                                       echo "<p class='message'>" . lang('Query executed OK, %d row(s) affected.', $mysql->affected_rows) . "</p>\n";
-                                               }
-                                       } while ($mysql->next_result());
+                                               } while ($mysql->next_result());
+                                       }
+                                       $query = substr($query, $match[0][1] + strlen($match[0][0]));
+                                       $offset = 0;
                                }
-                               $query = substr($query, $match[0][1] + strlen($match[0][0]));
-                               $offset = 0;
                        }
                }
+               if ($empty) {
+                       echo "<p class='message'>" . lang('No commands to execute.') . "</p>\n";
+               }
+       } else {
+               echo "<p class='error'>" . lang('Unable to upload a file.') . "</p>\n";
        }
-       if ($empty) {
-               echo "<p class='message'>" . lang('No commands to execute.') . "</p>\n";
-       }
-} elseif ($_POST) {
-       echo "<p class='error'>" . lang('Unable to upload a file.') . "</p>\n";
 }
 ?>