Changeset 26e7d6d in mainline for uspace/app/bdsh/exec.c


Ignore:
Timestamp:
2011-09-19T16:31:00Z (13 years ago)
Author:
Vojtech Horky <vojtechhorky@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
a347a11
Parents:
3842a955 (diff), 086290d (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

Merge mainline changes

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/app/bdsh/exec.c

    r3842a955 r26e7d6d  
    4040#include <str_error.h>
    4141#include <errno.h>
     42#include <vfs/vfs.h>
    4243
    4344#include "config.h"
     
    5152static char *find_command(char *);
    5253static int try_access(const char *);
     54
     55const char *search_dir[] = { "/app", "/srv", NULL };
    5356
    5457/* work-around for access() */
     
    6972static char *find_command(char *cmd)
    7073{
    71         char *path_tok;
    72         char *path[PATH_MAX];
    73         int n = 0, i = 0;
    74         size_t x = str_size(cmd) + 2;
     74        size_t i;
    7575
    7676        found = (char *)malloc(PATH_MAX);
     
    8181        }
    8282
    83         path_tok = str_dup(PATH);
    84 
    85         /* Extract the PATH env to a path[] array */
    86         path[n] = strtok(path_tok, PATH_DELIM);
    87         while (NULL != path[n]) {
    88                 if ((str_size(path[n]) + x ) > PATH_MAX) {
    89                         cli_error(CL_ENOTSUP,
    90                                 "Segment %d of path is too large, search ends at segment %d",
    91                                 n, n-1);
    92                         break;
    93                 }
    94                 path[++n] = strtok(NULL, PATH_DELIM);
    95         }
    96 
    9783        /* We now have n places to look for the command */
    98         for (i=0; path[i]; i++) {
     84        for (i = 0; search_dir[i] != NULL; i++) {
    9985                memset(found, 0, sizeof(found));
    100                 snprintf(found, PATH_MAX, "%s/%s", path[i], cmd);
     86                snprintf(found, PATH_MAX, "%s/%s", search_dir[i], cmd);
    10187                if (-1 != try_access(found)) {
    102                         free(path_tok);
    10388                        return (char *) found;
    10489                }
     
    10691
    10792        /* We didn't find it, just give it back as-is. */
    108         free(path_tok);
    10993        return (char *) cmd;
    11094}
     
    116100        char *tmp;
    117101        int rc, retval, i;
    118         fdi_node_t file_nodes[3];
    119         fdi_node_t *file_nodes_p[4];
     102        int file_handles[3];
     103        int *file_handles_p[4];
    120104        FILE *files[3];
    121105
     
    128112       
    129113        for (i = 0; i < 3 && files[i] != NULL; i++) {
    130                 if (fnode(files[i], &file_nodes[i]) == EOK) {
    131                         file_nodes_p[i] = &file_nodes[i];
     114                if (fhandle(files[i], &file_handles[i]) == EOK) {
     115                        file_handles_p[i] = &file_handles[i];
    132116                }
    133117                else {
    134                         file_nodes_p[i] = NULL;
     118                        file_handles_p[i] = NULL;
    135119                }
    136120        }
    137         file_nodes_p[i] = NULL;
     121        file_handles_p[i] = NULL;
    138122
    139         rc = task_spawnvf(&tid, tmp, (const char **) argv, file_nodes_p);
     123        rc = task_spawnvf(&tid, tmp, (const char **) argv, file_handles_p);
    140124        free(tmp);
    141125
     
    150134                printf("%s: Failed waiting for command (%s)\n", progname,
    151135                    str_error(rc));
     136                return 1;
    152137        } else if (texit != TASK_EXIT_NORMAL) {
    153138                printf("%s: Command failed (unexpectedly terminated)\n", progname);
     139                return 1;
    154140        } else if (retval != 0) {
    155141                printf("%s: Command failed (exit code %d)\n",
    156142                    progname, retval);
     143                return 1;
    157144        }
    158145
Note: See TracChangeset for help on using the changeset viewer.