Subversion Repositories HelenOS

Rev

Go to most recent revision | Blame | Last modification | View Log | Download | RSS feed

  1. /* Copyright (c) 2008, Tim Post <tinkertim@gmail.com>
  2.  * All rights reserved.
  3.  *
  4.  * Redistribution and use in source and binary forms, with or without
  5.  * modification, are permitted provided that the following conditions are met:
  6.  *
  7.  * Redistributions of source code must retain the above copyright notice, this
  8.  * list of conditions and the following disclaimer.
  9.  *
  10.  * Redistributions in binary form must reproduce the above copyright notice,
  11.  * this list of conditions and the following disclaimer in the documentation
  12.  * and/or other materials provided with the distribution.
  13.  *
  14.  * Neither the name of the original program's authors nor the names of its
  15.  * contributors may be used to endorse or promote products derived from this
  16.  * software without specific prior written permission.
  17.  *
  18.  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  19.  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  20.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  21.  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
  22.  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  23.  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  24.  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  25.  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  26.  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  27.  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  28.  * POSSIBILITY OF SUCH DAMAGE.
  29.  */
  30.  
  31. #include <stdio.h>
  32. #include <stdlib.h>
  33. #include <unistd.h>
  34. #include <string.h>
  35. #include <sys/errno.h>
  36. #include "util.h"
  37. #include "errors.h"
  38. #include "entry.h"
  39. #include "cmds.h"
  40. #include "cd.h"
  41.  
  42. static char * cmdname = "cd";
  43.  
  44. void * help_cmd_cd(unsigned int level)
  45. {
  46.     if (level == HELP_SHORT) {
  47.         printf("`%s' changes the current working directory.\n", cmdname);
  48.     } else {
  49.         printf(
  50.         "  %s [-L|-P] [dir]\n"
  51.         "  Your home directory is the default if [dir] is not provided.\n"
  52.         "  The -P option specifies to always use the physical directory\n"
  53.         "  structure instead of following symbolic links. The -L option\n"
  54.         "  is the exact reverse of -P, symbolic links will be forced.\n"
  55.         "  Note: -L|-P are not yet implemented\n", cmdname);
  56.     }
  57.  
  58.     return CMD_VOID;
  59. }
  60.  
  61. /* This is a very rudamentary 'cd' command. It is not 'link smart' (yet) */
  62.  
  63. int * cmd_cd(char *argv[], cliuser_t *usr)
  64. {
  65.     int argc, rc = 0;
  66.     char *dest = NULL;
  67.  
  68.     for (argc = 0; argv[argc] != NULL; argc ++);
  69.  
  70.     /* Someone just typed 'cd' , send them home */
  71.  
  72.     if (argc < 2)
  73.         dest = cli_strdup(usr->home);
  74.  
  75.     /* We don't yet play nice with whitespace, a getopt implementation should
  76.      * protect "quoted\ destination" as a single argument. Its not our job to
  77.      * look for && || or redirection as the tokenizer should have done that
  78.      * (currently, it does not) */
  79.  
  80.     if (argc > 2) {
  81.         cli_error(CL_EFAIL, "Too many arguments to `%s'", cmdname);
  82.         return CMD_FAILURE;
  83.     }
  84.  
  85.     /* We have the correct # of arguments
  86.      * TODO: handle tidle (~) expansion? */
  87.  
  88.     if (argc == 2)
  89.         dest = cli_strdup(argv[1]);
  90.  
  91.     rc = chdir(dest);
  92.     if (rc == 0) {
  93.         free(dest);
  94.         return CMD_SUCCESS;
  95.     } else {
  96.         free(dest);
  97.         switch (rc) {
  98.         case ENOMEM:
  99.             cli_error(CL_EFAIL, "Destination path too long");
  100.             break;
  101.         case ENOENT:
  102.             cli_error(CL_ENOENT, "Invalid directory `%s'", argv[1]);
  103.             break;
  104.         default:
  105.             cli_error(CL_EFAIL, "Unable to change to `%s'", argv[1]);
  106.             break;
  107.         }
  108.     }
  109.  
  110.     return CMD_FAILURE;
  111. }
  112.