summaryrefslogtreecommitdiff
path: root/client
diff options
context:
space:
mode:
authorunknown <msvensson@neptunus.(none)>2006-11-29 23:09:57 +0100
committerunknown <msvensson@neptunus.(none)>2006-11-29 23:09:57 +0100
commit2b58a8ec48ea5b5cf14798106b1ce6eff9dc787d (patch)
tree7bb763da1c2df6c52aedb8e0e98b75f6b0f415cc /client
parent6981993e4798009f8ef8072ad18700dde5ba7767 (diff)
parente5bfeab3fd659f37b8363abd32e77d4fe29716f9 (diff)
downloadmariadb-git-2b58a8ec48ea5b5cf14798106b1ce6eff9dc787d.tar.gz
Merge neptunus.(none):/home/msvensson/mysql/bug19731/my51-bug19731
into neptunus.(none):/home/msvensson/mysql/mysql-5.1-maint mysql-test/r/mysqltest.result: Auto merged mysql-test/t/mysqltest.test: Auto merged sql/handler.cc: Auto merged client/mysqltest.c: Manual merge
Diffstat (limited to 'client')
-rw-r--r--client/mysqltest.c45
1 files changed, 45 insertions, 0 deletions
diff --git a/client/mysqltest.c b/client/mysqltest.c
index 6871701e691..1d7c3f0575d 100644
--- a/client/mysqltest.c
+++ b/client/mysqltest.c
@@ -264,6 +264,7 @@ enum enum_commands {
Q_DISABLE_PARSING, Q_ENABLE_PARSING,
Q_REPLACE_REGEX, Q_REMOVE_FILE, Q_FILE_EXIST,
Q_WRITE_FILE, Q_COPY_FILE, Q_PERL, Q_DIE, Q_EXIT,
+ Q_CHMOD_FILE,
Q_UNKNOWN, /* Unknown command. */
Q_COMMENT, /* Comments, ignored. */
@@ -346,6 +347,7 @@ const char *command_names[]=
"die",
/* Don't execute any more commands, compare result */
"exit",
+ "chmod",
0
};
@@ -1754,6 +1756,48 @@ void do_copy_file(struct st_command *command)
/*
SYNOPSIS
+ do_chmod_file
+ command command handle
+
+ DESCRIPTION
+ chmod <octal> <file>
+ Change file permission of <file>
+
+ NOTE! Simplified version, only supports +r, -r, +w, -w
+*/
+
+void do_chmod_file(struct st_command *command)
+{
+ mode_t mode= 0;
+ static DYNAMIC_STRING ds_mode;
+ static DYNAMIC_STRING ds_file;
+ const struct command_arg chmod_file_args[] = {
+ "mode", ARG_STRING, TRUE, &ds_mode, "Mode of file",
+ "file", ARG_STRING, TRUE, &ds_file, "Filename of file to modify"
+ };
+ DBUG_ENTER("do_chmod_file");
+
+ check_command_args(command, command->first_argument,
+ chmod_file_args,
+ sizeof(chmod_file_args)/sizeof(struct command_arg),
+ ' ');
+
+ /* Parse what mode to set */
+ if (ds_mode.length != 4)
+ die("You must write a 4 digit octal number for mode");
+
+ str2int(ds_mode.str, 8, 0, INT_MAX, (long*)&mode);
+
+ DBUG_PRINT("info", ("chmod %o %s", mode, ds_file.str));
+ handle_command_error(command, chmod(ds_file.str, mode));
+ dynstr_free(&ds_mode);
+ dynstr_free(&ds_file);
+ DBUG_VOID_RETURN;
+}
+
+
+/*
+ SYNOPSIS
do_file_exists
command called command
@@ -5624,6 +5668,7 @@ int main(int argc, char **argv)
case Q_FILE_EXIST: do_file_exist(command); break;
case Q_WRITE_FILE: do_write_file(command); break;
case Q_COPY_FILE: do_copy_file(command); break;
+ case Q_CHMOD_FILE: do_chmod_file(command); break;
case Q_PERL: do_perl(command); break;
case Q_DELIMITER:
do_delimiter(command);