/* Automatically generated by mknewcmd on Mon Aug 11 00:22:09 PHT 2008
* This is machine generated output. The author of mknewcmd claims no
* copyright over the contents of this file. Where legally permitted, the
* contents herein are donated to the public domain.
*
* You should apply any license and copyright that you wish to this file,
* replacing this header in its entirety. */
/* Extremely primitive 'ls' implementation. Does not sort or stat files,
* just here for convenience */
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <dirent.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <string.h>
#include "errors.h"
#include "config.h"
#include "util.h"
#include "entry.h"
#include "ls.h"
#include "cmds.h"
static char *cmdname = "ls";
unsigned int ls_scope(const char *path)
{
int fd;
DIR *dirp;
dirp = opendir(path);
if (dirp) {
closedir(dirp);
return LS_DIR;
}
fd = open(path, O_RDONLY);
if (fd > 0) {
close(fd);
return LS_FILE;
}
return LS_BOGUS;
}
void ls_print(const char *f)
{
if (ls_scope(f) == LS_FILE)
else
return;
}
/* Dispays help for ls in various levels */
void * help_cmd_ls(unsigned int level)
{
printf("This is the %s help for '%s'.\n",
level ? EXT_HELP : SHORT_HELP, cmdname);
return CMD_VOID;
}
int * cmd_ls(char **argv)
{
unsigned int argc;
unsigned int scope;
char *buff;
DIR *dirp;
struct dirent *dp;
/* Count the arguments */
for (argc = 0; argv[argc] != NULL; argc ++);
if (argc > 2) {
printf("%s - Too many arguments. Try `help %s extended'\n",
cmdname, cmdname);
return CMD_FAILURE;
}
buff
= (char *) malloc(PATH_MAX
);
if (NULL == buff) {
cli_error(CL_ENOMEM, "%s: ", cmdname);
return CMD_FAILURE;
}
memset(buff
, 0, sizeof(buff
));
if (argc == 1)
getcwd(buff, PATH_MAX);
else
scope = ls_scope(buff);
switch (scope) {
case LS_BOGUS:
cli_error(CL_ENOENT, buff);
return CMD_FAILURE;
case LS_FILE:
ls_print(buff);
break;
case LS_DIR:
dirp = opendir(buff);
while ((dp = readdir(dirp)))
ls_print(dp->d_name);
closedir(dirp);
break;
}
return CMD_SUCCESS;
}