summaryrefslogtreecommitdiffstats
path: root/bin/ls
diff options
context:
space:
mode:
Diffstat (limited to 'bin/ls')
-rw-r--r--bin/ls/Makefile1
-rw-r--r--bin/ls/extern.h2
-rw-r--r--bin/ls/lomac.c4
-rw-r--r--bin/ls/ls.c97
-rw-r--r--bin/ls/ls.h16
-rw-r--r--bin/ls/print.c25
-rw-r--r--bin/ls/util.c11
7 files changed, 84 insertions, 72 deletions
diff --git a/bin/ls/Makefile b/bin/ls/Makefile
index 851d9de..484137e 100644
--- a/bin/ls/Makefile
+++ b/bin/ls/Makefile
@@ -3,7 +3,6 @@
PROG= ls
SRCS= cmp.c lomac.c ls.c print.c util.c
-WARNS?= 0
DPADD= ${LIBM}
LDADD= -lm
diff --git a/bin/ls/extern.h b/bin/ls/extern.h
index ec147de..e0d4b6a 100644
--- a/bin/ls/extern.h
+++ b/bin/ls/extern.h
@@ -47,7 +47,7 @@ void printcol(DISPLAY *);
void printlong(DISPLAY *);
void printscol(DISPLAY *);
void usage(void);
-int len_octal(const char *, int);
+size_t len_octal(const char *, int);
int prn_octal(const char *);
int prn_printable(const char *);
#ifdef COLORLS
diff --git a/bin/ls/lomac.c b/bin/ls/lomac.c
index 62fdc4e..2505da2 100644
--- a/bin/ls/lomac.c
+++ b/bin/ls/lomac.c
@@ -55,8 +55,8 @@
#define LOMAC_DEVICE "/dev/lomac"
-int devlomac; /* file descriptor for LOMAC_DEVICE */
-struct lomac_fioctl2 ioctl_args;
+static int devlomac; /* file descriptor for LOMAC_DEVICE */
+static struct lomac_fioctl2 ioctl_args;
/* lomac_start()
*
diff --git a/bin/ls/ls.c b/bin/ls/ls.c
index e135240..c5216f3 100644
--- a/bin/ls/ls.c
+++ b/bin/ls/ls.c
@@ -91,33 +91,32 @@ long blocksize; /* block size units */
int termwidth = 80; /* default terminal width */
/* flags */
-int f_accesstime; /* use time of last access */
-int f_column; /* columnated format */
-int f_flags; /* show flags associated with a file */
-int f_humanval; /* show human-readable file sizes */
-int f_inode; /* print inode */
-int f_kblocks; /* print size in kilobytes */
-int f_listdir; /* list actual directory, not contents */
-int f_listdot; /* list files beginning with . */
-int f_longform; /* long listing format */
-int f_nonprint; /* show unprintables as ? */
-int f_nosort; /* don't sort output */
-int f_notabs; /* don't use tab-separated multi-col output */
-int f_numericonly; /* don't convert uid/gid to name */
-int f_octal; /* show unprintables as \xxx */
-int f_octal_escape; /* like f_octal but use C escapes if possible */
-int f_recursive; /* ls subdirectories also */
-int f_reversesort; /* reverse whatever sort is used */
-int f_sectime; /* print the real time for all files */
-int f_singlecol; /* use single column output */
-int f_size; /* list size in short listing */
-int f_statustime; /* use time of last mode change */
-int f_timesort; /* sort by time vice name */
-int f_type; /* add type character for non-regular files */
-int f_whiteout; /* show whiteout entries */
-int f_lomac; /* show LOMAC attributes */
+ int f_accesstime; /* use time of last access */
+ int f_flags; /* show flags associated with a file */
+ int f_humanval; /* show human-readable file sizes */
+ int f_inode; /* print inode */
+static int f_kblocks; /* print size in kilobytes */
+static int f_listdir; /* list actual directory, not contents */
+static int f_listdot; /* list files beginning with . */
+ int f_longform; /* long listing format */
+ int f_nonprint; /* show unprintables as ? */
+static int f_nosort; /* don't sort output */
+ int f_notabs; /* don't use tab-separated multi-col output */
+static int f_numericonly; /* don't convert uid/gid to name */
+ int f_octal; /* show unprintables as \xxx */
+ int f_octal_escape; /* like f_octal but use C escapes if possible */
+static int f_recursive; /* ls subdirectories also */
+static int f_reversesort; /* reverse whatever sort is used */
+ int f_sectime; /* print the real time for all files */
+static int f_singlecol; /* use single column output */
+ int f_size; /* list size in short listing */
+ int f_statustime; /* use time of last mode change */
+static int f_timesort; /* sort by time vice name */
+ int f_type; /* add type character for non-regular files */
+static int f_whiteout; /* show whiteout entries */
+ int f_lomac; /* show LOMAC attributes */
#ifdef COLORLS
-int f_color; /* add type in color for non-regular files */
+ int f_color; /* add type in color for non-regular files */
char *ansi_bgcol; /* ANSI sequence to set background colour */
char *ansi_fgcol; /* ANSI sequence to set foreground colour */
@@ -126,7 +125,7 @@ char *attrs_off; /* ANSI sequence to turn off attributes */
char *enter_bold; /* ANSI sequence to set color to bold mode */
#endif
-int rval;
+static int rval;
int
main(int argc, char *argv[])
@@ -151,11 +150,12 @@ main(int argc, char *argv[])
termwidth = atoi(p);
} else
termwidth = win.ws_col;
- f_column = f_nonprint = 1;
+ f_nonprint = 1;
} else {
f_singlecol = 1;
/* retrieve environment variable, in case of explicit -C */
- if ((p = getenv("COLUMNS")))
+ p = getenv("COLUMNS");
+ if (p)
termwidth = atoi(p);
}
@@ -172,7 +172,7 @@ main(int argc, char *argv[])
*/
case '1':
f_singlecol = 1;
- f_column = f_longform = 0;
+ f_longform = 0;
break;
case 'B':
f_nonprint = 0;
@@ -180,12 +180,11 @@ main(int argc, char *argv[])
f_octal_escape = 0;
break;
case 'C':
- f_column = 1;
f_longform = f_singlecol = 0;
break;
case 'l':
f_longform = 1;
- f_column = f_singlecol = 0;
+ f_singlecol = 0;
break;
/* The -c and -u options override each other. */
case 'c':
@@ -459,6 +458,7 @@ traverse(int argc, char *argv[], int options)
if (!f_recursive && chp != NULL)
(void)fts_set(ftsp, p, FTS_SKIP);
break;
+ default:
}
if (errno)
err(1, "fts_read");
@@ -476,12 +476,15 @@ display(FTSENT *p, FTSENT *list)
DISPLAY d;
FTSENT *cur;
NAMES *np;
- u_quad_t maxsize;
- u_long btotal, maxblock, maxinode, maxlen, maxnlink, maxlattr;
- int bcfile, flen, glen, ulen, lattrlen, maxflags, maxgroup, maxuser;
+ off_t maxsize;
+ u_long btotal, lattrlen, maxblock, maxinode, maxlen, maxnlink, maxlattr;
+ int bcfile, maxflags;
+ gid_t maxgroup;
+ uid_t maxuser;
+ size_t flen, ulen, glen;
char *initmax;
int entries, needstats;
- char *user, *group, *flags, *lattr;
+ char *user, *group, *flags, *lattr = NULL;
char buf[STRBUF_SIZEOF(u_quad_t) + 1];
char ngroup[STRBUF_SIZEOF(uid_t) + 1];
char nuser[STRBUF_SIZEOF(gid_t) + 1];
@@ -501,6 +504,8 @@ display(FTSENT *p, FTSENT *list)
btotal = 0;
initmax = getenv("LS_COLWIDTHS");
/* Fields match -lios order. New ones should be added at the end. */
+ maxlattr = maxblock = maxinode = maxlen = maxnlink =
+ maxuser = maxgroup = maxflags = maxsize = 0;
if (initmax != NULL && *initmax != '\0') {
char *initmax2, *jinitmax;
int ninitmax;
@@ -527,41 +532,50 @@ display(FTSENT *p, FTSENT *list)
strcpy(initmax2, "0");
ninitmax = sscanf(jinitmax,
- " %lu : %lu : %lu : %i : %i : %i : %qu : %lu : %lu ",
+ " %lu : %lu : %lu : %i : %i : %i : %llu : %lu : %lu ",
&maxinode, &maxblock, &maxnlink, &maxuser,
&maxgroup, &maxflags, &maxsize, &maxlen, &maxlattr);
f_notabs = 1;
switch (ninitmax) {
case 0:
maxinode = 0;
+ /* fall through */
case 1:
maxblock = 0;
+ /* fall through */
case 2:
maxnlink = 0;
+ /* fall through */
case 3:
maxuser = 0;
+ /* fall through */
case 4:
maxgroup = 0;
+ /* fall through */
case 5:
maxflags = 0;
+ /* fall through */
case 6:
maxsize = 0;
+ /* fall through */
case 7:
maxlen = 0;
+ /* fall through */
case 8:
maxlattr = 0;
+ /* fall through */
#ifdef COLORLS
if (!f_color)
#endif
f_notabs = 0;
+ /* fall through */
+ default:
}
maxinode = makenines(maxinode);
maxblock = makenines(maxblock);
maxnlink = makenines(maxnlink);
maxsize = makenines(maxsize);
- } else if (initmax == NULL || *initmax == '\0')
- maxlattr = maxblock = maxinode = maxlen = maxnlink =
- maxuser = maxgroup = maxflags = maxsize = 0;
+ }
if (f_lomac)
lomac_start();
bcfile = 0;
@@ -635,7 +649,8 @@ display(FTSENT *p, FTSENT *list)
}
if (flags == NULL)
err(1, NULL);
- if ((flen = strlen(flags)) > maxflags)
+ flen = strlen(flags);
+ if (flen > (size_t)maxflags)
maxflags = flen;
} else
flen = 0;
diff --git a/bin/ls/ls.h b/bin/ls/ls.h
index dfb54ea..e206c56 100644
--- a/bin/ls/ls.h
+++ b/bin/ls/ls.h
@@ -66,14 +66,14 @@ typedef struct {
int bcfile;
int entries;
int maxlen;
- int s_block;
- int s_flags;
- int s_lattr;
- int s_group;
- int s_inode;
- int s_nlink;
- int s_size;
- int s_user;
+ u_int s_block;
+ u_int s_flags;
+ u_int s_lattr;
+ u_int s_group;
+ u_int s_inode;
+ u_int s_nlink;
+ u_int s_size;
+ u_int s_user;
} DISPLAY;
typedef struct {
diff --git a/bin/ls/print.c b/bin/ls/print.c
index 82a609d..c4ebbc0 100644
--- a/bin/ls/print.c
+++ b/bin/ls/print.c
@@ -56,7 +56,6 @@ static const char rcsid[] =
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
-#include <time.h>
#include <unistd.h>
#ifdef COLORLS
#include <ctype.h>
@@ -78,7 +77,6 @@ static int colortype(mode_t);
#endif
#define IS_NOPRINT(p) ((p)->fts_number == NO_PRINT)
-#define UNITS_2 2
#define KILO_SZ(n) (n)
#define MEGA_SZ(n) ((n) * (n))
@@ -92,14 +90,14 @@ static int colortype(mode_t);
#define TERA_2_SZ (TERA_SZ(1024ULL))
#define PETA_2_SZ (PETA_SZ(1024ULL))
-unsigned long long vals_base2[] = {1, KILO_2_SZ, MEGA_2_SZ, GIGA_2_SZ, TERA_2_SZ, PETA_2_SZ};
+static unsigned long long vals_base2[] = {1, KILO_2_SZ, MEGA_2_SZ, GIGA_2_SZ, TERA_2_SZ, PETA_2_SZ};
typedef enum {
NONE, KILO, MEGA, GIGA, TERA, PETA, UNIT_MAX
} unit_t;
static unit_t unit_adjust(off_t *);
-int unitp[] = {NONE, KILO, MEGA, GIGA, TERA, PETA};
+static int unitp[] = {NONE, KILO, MEGA, GIGA, TERA, PETA};
#ifdef COLORLS
/* Most of these are taken from <sys/stat.h> */
@@ -120,7 +118,7 @@ typedef enum Colors {
C_NUMCOLORS /* just a place-holder */
} Colors;
-const char *defcolors = "exfxcxdxbxegedabagacad";
+static const char *defcolors = "exfxcxdxbxegedabagacad";
/* colors for file types */
static struct {
@@ -177,9 +175,9 @@ printlong(DISPLAY *dp)
if (f_inode)
(void)printf("%*lu ", dp->s_inode, (u_long)sp->st_ino);
if (f_size)
- (void)printf("%*qd ",
+ (void)printf("%*lld ",
dp->s_block, howmany(sp->st_blocks, blocksize));
- (void)strmode(sp->st_mode, buf);
+ strmode(sp->st_mode, buf);
np = p->fts_pointer;
(void)printf("%s %*u %-*s %-*s ", buf, dp->s_nlink,
sp->st_nlink, dp->s_user, np->user, dp->s_group,
@@ -197,7 +195,7 @@ printlong(DISPLAY *dp)
(void)printf("%3d, %3d ",
major(sp->st_rdev), minor(sp->st_rdev));
else if (dp->bcfile)
- (void)printf("%*s%*qd ",
+ (void)printf("%*s%*lld ",
8 - dp->s_size, "", dp->s_size, sp->st_size);
else
printsize(dp->s_size, sp->st_size);
@@ -320,7 +318,7 @@ printaname(FTSENT *p, u_long inodefield, u_long sizefield)
if (f_inode)
chcnt += printf("%*lu ", (int)inodefield, (u_long)sp->st_ino);
if (f_size)
- chcnt += printf("%*qd ",
+ chcnt += printf("%*lld ",
(int)sizefield, howmany(sp->st_blocks, blocksize));
#ifdef COLORLS
if (f_color)
@@ -382,6 +380,7 @@ printtype(u_int mode)
case S_IFWHT:
(void)putchar('%');
return (1);
+ default:
}
if (mode & (S_IXUSR | S_IXGRP | S_IXOTH)) {
(void)putchar('*');
@@ -554,7 +553,7 @@ printlink(FTSENT *p)
}
path[lnklen] = '\0';
(void)printf(" -> ");
- printname(path);
+ (void)printname(path);
}
static void
@@ -568,10 +567,10 @@ printsize(size_t width, off_t bytes)
if (bytes == 0)
(void)printf("%*s ", width, "0B");
else
- (void)printf("%*qd%c ", width - 1, bytes,
+ (void)printf("%*lld%c ", width - 1, bytes,
"BKMGTPE"[unit]);
} else
- (void)printf("%*qd ", width, bytes);
+ (void)printf("%*lld ", width, bytes);
}
/*
@@ -587,7 +586,7 @@ unit_adjust(off_t *val)
unit_t unit;
unsigned int unit_sz;
- abval = fabs(*val);
+ abval = fabs((double)*val);
unit_sz = abval ? ilogb(abval) / 10 : 0;
diff --git a/bin/ls/util.c b/bin/ls/util.c
index 39ee382..34b5b18 100644
--- a/bin/ls/util.c
+++ b/bin/ls/util.c
@@ -59,7 +59,7 @@ static const char rcsid[] =
int
prn_printable(const char *s)
{
- unsigned char c;
+ char c;
int n;
for (n = 0; (c = *s) != '\0'; ++s, ++n)
@@ -83,13 +83,13 @@ prn_printable(const char *s)
* DES 1998/04/23
*/
-int
+size_t
len_octal(const char *s, int len)
{
- int r = 0;
+ size_t r = 0;
while (len--)
- if (isprint((unsigned char)*s++)) r++; else r += 4;
+ if (isprint((unsigned const char)*s++)) r++; else r += 4;
return r;
}
@@ -99,8 +99,7 @@ prn_octal(const char *s)
unsigned char ch;
int len = 0;
- while ((ch = *s++))
- {
+ while ((ch = (unsigned char)*s++)) {
if (isprint(ch) && (ch != '\"') && (ch != '\\'))
putchar(ch), len++;
else if (f_octal_escape) {
OpenPOWER on IntegriCloud