switch 'rm' command away from using Jim
authorZachary T Welch <zw@superlucidity.net>
Fri, 4 Dec 2009 00:22:46 +0000 (16:22 -0800)
committerZachary T Welch <zw@superlucidity.net>
Fri, 4 Dec 2009 11:34:32 +0000 (03:34 -0800)
Commands that do not need to use Jim should be registered as
high-level command handlers.

src/helper/ioutil.c

index ed82ba1cd78fa823476b2ab8cea0dd7d530fad21..27bffad33687667c298238624616b3b4c0fc9f6f 100644 (file)
@@ -401,25 +401,18 @@ void copydir(char *name, char *destdir)
 
 
 
-static int
-zylinjtag_Jim_Command_rm(Jim_Interp *interp,
-                                   int argc,
-               Jim_Obj * const *argv)
+COMMAND_HANDLER(handle_rm_command)
 {
-       int del;
-       if (argc != 2)
-       {
-               Jim_WrongNumArgs(interp, 1, argv, "rm ?dirorfile?");
-               return JIM_ERR;
-       }
+       if (CMD_ARGC != 1)
+               return ERROR_INVALID_ARGUMENTS;
 
-       del = 0;
-       if (unlink(Jim_GetString(argv[1], NULL)) == 0)
-               del = 1;
-       if (rmdir(Jim_GetString(argv[1], NULL)) == 0)
-               del = 1;
+       bool del = false;
+       if (rmdir(CMD_ARGV[0]) == 0)
+               del = true;
+       else if (unlink(CMD_ARGV[0]) == 0)
+               del = true;
 
-       return del ? JIM_OK : JIM_ERR;
+       return del ? ERROR_OK : ERROR_FAIL;
 }
 
 
@@ -658,14 +651,14 @@ static const struct command_registration ioutil_command_handlers[] = {
                .mode = COMMAND_ANY,
                .help = "display available ram memory",
        },
-       // jim handlers
        {
                .name = "rm",
                .mode = COMMAND_ANY,
-               .jim_handler = &zylinjtag_Jim_Command_rm,
+               .handler = &handle_rm_command,
                .help = "remove a file",
                .usage = "<file>",
        },
+       // jim handlers
        {
                .name = "peek",
                .mode = COMMAND_ANY,