diff options
author | Satoshi Asami <asami@FreeBSD.org> | 2000-06-16 19:16:36 +0000 |
---|---|---|
committer | Satoshi Asami <asami@FreeBSD.org> | 2000-06-16 19:16:36 +0000 |
commit | ad52f33b880f816076631935440794fe3117ac0b (patch) | |
tree | b0ce25582f505fe26feef0bedef0307bf1d0d0eb | |
parent | cab18ae662340a8c8489666ff3df202cbe17ac07 (diff) |
Update colorls to use a new tarball (now 3-stable based) and use ache's
improvements instead of my own hack.
Note that you need a "color-capable" terminal to use it -- in
particular, this means set your TERM to "xterm-color" or "kterm-color"
when using normal xterm or kterm, not "xterm" or "kterm" (which
termcap doesn't know that are color-capable).
Notes
Notes:
svn path=/head/; revision=29646
-rw-r--r-- | misc/colorls/Makefile | 6 | ||||
-rw-r--r-- | misc/colorls/distinfo | 2 | ||||
-rw-r--r-- | misc/colorls/files/patch-aa | 410 |
3 files changed, 308 insertions, 110 deletions
diff --git a/misc/colorls/Makefile b/misc/colorls/Makefile index 26e397904c25..ac438144b8fb 100644 --- a/misc/colorls/Makefile +++ b/misc/colorls/Makefile @@ -1,5 +1,5 @@ # New ports collection makefile for: colorls -# Version required: FreeBSD-2.2-stable (around August '98) +# Version required: FreeBSD-3-stable (around June 2000) # Date created: 8 March 1995 # Whom: Satoshi Asami # @@ -7,10 +7,10 @@ # PORTNAME= colorls -PORTVERSION= 2.2.7 +PORTVERSION= 3.4 CATEGORIES= misc MASTER_SITES= ${MASTER_SITE_LOCAL} -MASTER_SITE_SUBDIR= asami +MASTER_SITE_SUBDIR= asami/colorls DISTFILES= ls-${PORTVERSION}.tar.gz MAINTAINER= asami@FreeBSD.org diff --git a/misc/colorls/distinfo b/misc/colorls/distinfo index 63b049082694..14c3394ad2fd 100644 --- a/misc/colorls/distinfo +++ b/misc/colorls/distinfo @@ -1 +1 @@ -MD5 (ls-2.2.7.tar.gz) = 60b6a15d9f2470f66607d22e15746d60 +MD5 (ls-3.4.tar.gz) = fd98746a9541c72a5110da77650f2ab6 diff --git a/misc/colorls/files/patch-aa b/misc/colorls/files/patch-aa index 64f89c92561c..909706da555e 100644 --- a/misc/colorls/files/patch-aa +++ b/misc/colorls/files/patch-aa @@ -1,14 +1,51 @@ ---- ls.c.orig Sun Jul 19 23:29:17 1998 -+++ ls.c Sun Nov 21 11:51:18 1999 -@@ -94,6 +94,7 @@ - int f_statustime; /* use time of last mode change */ +Index: ls.c +=================================================================== +RCS file: /usr/cvs/src/bin/ls/ls.c,v +retrieving revision 1.32 +retrieving revision 1.40 +diff -u -r1.32 -r1.40 +--- ls.c 2000/02/05 18:42:27 1.32 ++++ ls.c 2000/06/06 13:02:52 1.40 +@@ -63,7 +63,11 @@ + #include <stdlib.h> + #include <string.h> + #include <unistd.h> + #include <locale.h> ++#ifdef COLORLS ++#include <termcap.h> ++#include <signal.h> ++#endif + + #include "ls.h" + #include "extern.h" +@@ -111,6 +115,13 @@ int f_timesort; /* sort by time vice name */ int f_type; /* add type character for non-regular files */ + int f_whiteout; /* show whiteout entries */ ++#ifdef COLORLS +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 */ ++char *ansi_coloff; /* ANSI sequence to reset colours */ ++#endif int rval; -@@ -131,7 +132,7 @@ +@@ -124,6 +135,12 @@ + int ch, fts_options, notused; + char *p; + ++#ifdef COLORLS ++ char termcapbuf[1024]; /* termcap definition buffer */ ++ char tcapbuf[512]; /* capability buffer */ ++ char *bp = tcapbuf; ++#endif ++ + (void) setlocale(LC_ALL, ""); + + /* Terminal defaults to -Cq, non-terminal defaults to -1. */ +@@ -148,7 +165,7 @@ f_listdot = 1; fts_options = FTS_PHYSICAL; @@ -17,57 +54,149 @@ switch (ch) { /* * The -1, -C and -l options all override each other so shell -@@ -169,6 +170,10 @@ +@@ -186,6 +203,26 @@ case 'H': fts_options |= FTS_COMFOLLOW; break; + case 'G': + if (isatty(STDOUT_FILENO)) -+ f_color = 1; ++#ifdef COLORLS ++ if (tgetent(termcapbuf, getenv("TERM")) == 1) { ++ ansi_fgcol = tgetstr("AF", &bp); ++ ansi_bgcol = tgetstr("AB", &bp); ++ ++ /* To switch colours off use 'op' if ++ * available, otherwise use 'oc', or ++ * don't do colours at all. */ ++ ansi_coloff = tgetstr("op", &bp); ++ if (!ansi_coloff) ++ ansi_coloff = tgetstr("oc", &bp); ++ if (ansi_fgcol && ansi_bgcol && ansi_coloff) ++ f_color = 1; ++ } ++#else ++ (void)fprintf(stderr, "Color support not compiled in.\n"); ++#endif + break; case 'L': fts_options &= ~FTS_PHYSICAL; fts_options |= FTS_LOGICAL; -@@ -236,18 +241,21 @@ +@@ -259,11 +296,30 @@ argc -= optind; argv += optind; -+ parsecolors(getenv("LSCOLORS")); ++#ifdef COLORLS ++ if (f_color) { ++ /* ++ * We can't put tabs and color sequences together: ++ * column number will be incremented incorrectly ++ * for "stty oxtabs" mode. ++ */ ++ f_notabs = 1; ++ (void) signal(SIGINT, colorquit); ++ (void) signal(SIGQUIT, colorquit); ++ parsecolors(getenv("LSCOLORS")); ++ } ++#endif + /* * If not -F, -i, -l, -s or -t options, don't require stat - * information. +- * information. ++ * information, unless in color mode in which case we do ++ * need this to determine which colors to display. */ - if (!f_inode && !f_longform && !f_size && !f_timesort && !f_type) + if (!f_inode && !f_longform && !f_size && !f_timesort && !f_type -+ && !f_color) ++#ifdef COLORLS ++ && !f_color ++#endif ++ ) fts_options |= FTS_NOSTAT; /* - * If not -F, -d or -l options, follow any symbolic links listed on - * the command line. - */ -- if (!f_longform && !f_listdir && !f_type) -+ if (!f_longform && !f_listdir && !f_type && !f_color) - fts_options |= FTS_COMFOLLOW; - - /* If -l or -s, figure out block size. */ ---- ./ls.h.org Sun Jul 19 23:29:17 1998 -+++ ./ls.h Mon Aug 24 01:24:27 1998 -@@ -52,6 +52,7 @@ - extern int f_size; /* list size in short listing */ +@@ -471,7 +527,11 @@ + case 4: maxgroup = 0; + case 5: maxflags = 0; + case 6: maxsize = 0; +- case 7: maxlen = 0, f_notabs = 0; ++ case 7: maxlen = 0; ++#ifdef COLORLS ++ if (!f_color) ++#endif ++ f_notabs = 0; + } + maxinode = makenines(maxinode); + maxblock = makenines(maxblock); +Index: ls.h +=================================================================== +RCS file: /usr/cvs/src/bin/ls/ls.h,v +retrieving revision 1.11 +retrieving revision 1.13 +diff -u -r1.11 -r1.13 +--- ls.h 1999/08/27 23:14:32 1.11 ++++ ls.h 2000/06/05 02:14:01 1.13 +@@ -53,6 +53,9 @@ extern int f_statustime; /* use time of last mode change */ + extern int f_notabs; /* don't use tab-separated multi-col output */ extern int f_type; /* add type character for non-regular files */ ++#ifdef COLORLS +extern int f_color; /* add type in color for non-regular files */ ++#endif typedef struct { FTSENT *list; ---- ./print.c.org Sun Jul 19 23:29:17 1998 -+++ ./print.c Mon Aug 24 01:29:28 1998 -@@ -64,6 +64,26 @@ +Index: extern.h +=================================================================== +RCS file: /usr/cvs/src/bin/ls/extern.h,v +retrieving revision 1.7 +retrieving revision 1.12 +diff -u -r1.7 -r1.12 +--- extern.h 1999/08/27 23:14:31 1.7 ++++ extern.h 2000/06/06 07:14:01 1.12 +@@ -51,3 +51,11 @@ + void usage __P((void)); + int len_octal __P((char *, int)); + int prn_octal __P((char *)); ++#ifdef COLORLS ++void parsecolors __P((char *cs)); ++void colorquit __P((int)); ++ ++extern char *ansi_fgcol; ++extern char *ansi_bgcol; ++extern char *ansi_coloff; ++#endif +Index: print.c +=================================================================== +RCS file: /usr/cvs/src/bin/ls/print.c,v +retrieving revision 1.19 +retrieving revision 1.33 +diff -u -r1.19 -r1.33 +--- print.c 2000/01/06 14:40:10 1.19 ++++ print.c 2000/06/06 16:39:24 1.33 +@@ -56,6 +56,11 @@ + #include <string.h> + #include <time.h> + #include <unistd.h> ++#ifdef COLORLS ++#include <ctype.h> ++#include <termcap.h> ++#include <signal.h> ++#endif + + #include "ls.h" + #include "extern.h" +@@ -64,9 +69,35 @@ + static void printlink __P((FTSENT *)); + static void printtime __P((time_t)); + static int printtype __P((u_int)); ++#ifdef COLORLS ++static void endcolor __P((int)); ++static int colortype __P((mode_t)); ++#endif #define IS_NOPRINT(p) ((p)->fts_number == NO_PRINT) ++#ifdef COLORLS +/* Most of these are taken from <sys/stat.h> */ +typedef enum Colors { + C_DIR, /* directory */ @@ -87,84 +216,115 @@ +char *defcolors = "4x5x2x3x1x464301060203"; + +static int colors[C_NUMCOLORS][2]; ++#endif + void printscol(dp) DISPLAY *dp; -@@ -124,10 +144,14 @@ +@@ -89,6 +120,9 @@ + FTSENT *p; + NAMES *np; + char buf[20]; ++#ifdef COLORLS ++ int color_printed = 0; ++#endif + + if (dp->list->fts_level != FTS_ROOTLEVEL && (f_longform || f_size)) + (void)printf("total %lu\n", howmany(dp->btotal, blocksize)); +@@ -128,8 +162,16 @@ printtime(sp->st_ctime); else printtime(sp->st_mtime); ++#ifdef COLORLS + if (f_color) -+ (void)colortype(sp->st_mode); ++ color_printed = colortype(sp->st_mode); ++#endif if (f_octal || f_octal_escape) (void)prn_octal(p->fts_name); else (void)printf("%s", p->fts_name); ++#ifdef COLORLS ++ if (f_color && color_printed) ++ endcolor(0); ++#endif if (f_type) (void)printtype(sp->st_mode); -+ if (f_color) -+ (void)printf("\033[m"); if (S_ISLNK(sp->st_mode)) - printlink(p); - (void)putchar('\n'); -@@ -191,10 +215,22 @@ - dp->s_block); - if ((base += numrows) >= num) - break; -- while ((cnt = ((chcnt + TAB) & ~(TAB - 1))) <= endcol){ -- (void)putchar('\t'); -- chcnt = cnt; -- } -+ -+ /* -+ * some terminals get confused if we mix tabs -+ * with color sequences -+ */ -+ if (f_color) -+ while ((cnt = (chcnt + 1)) <= endcol) { -+ (void)putchar(' '); -+ chcnt = cnt; -+ } -+ else -+ while ((cnt = ((chcnt + TAB) & ~(TAB - 1))) -+ <= endcol) { -+ (void)putchar('\t'); -+ chcnt = cnt; -+ } - endcol += colwidth; - } - (void)putchar('\n'); -@@ -220,8 +256,12 @@ +@@ -221,6 +263,9 @@ + { + struct stat *sp; + int chcnt; ++#ifdef COLORLS ++ int color_printed = 0; ++#endif + + sp = p->fts_statp; + chcnt = 0; +@@ -229,8 +274,16 @@ if (f_size) chcnt += printf("%*qd ", (int)sizefield, howmany(sp->st_blocks, blocksize)); ++#ifdef COLORLS + if (f_color) -+ (void)colortype(sp->st_mode); ++ color_printed = colortype(sp->st_mode); ++#endif chcnt += (f_octal || f_octal_escape) ? prn_octal(p->fts_name) : printf("%s", p->fts_name); -+ if (f_color) -+ printf("\033[m"); ++#ifdef COLORLS ++ if (f_color && color_printed) ++ endcolor(0); ++#endif if (f_type) chcnt += printtype(sp->st_mode); return (chcnt); -@@ -282,6 +322,95 @@ +@@ -294,6 +347,138 @@ return (0); } -+void ++#ifdef COLORLS ++static int ++putch(c) ++ int c; ++{ ++ (void) putchar(c); ++ return 0; ++} ++ ++static int ++writech(c) ++ int c; ++{ ++ char tmp = c; ++ ++ (void) write(STDOUT_FILENO, &tmp, 1); ++ return 0; ++} ++ ++static void +printcolor(c) + Colors c; +{ -+ printf("\033["); ++ char *ansiseq; ++ + if (colors[c][0] != -1) { -+ printf("3%d", colors[c][0]); -+ if (colors[c][1] != -1) -+ printf(";"); ++ ansiseq = tgoto(ansi_fgcol, 0, colors[c][0]); ++ if (ansiseq) ++ tputs(ansiseq, 1, putch); ++ } ++ ++ if (colors[c][1] != -1) { ++ ansiseq = tgoto(ansi_bgcol, 0, colors[c][1]); ++ if (ansiseq) ++ tputs(ansiseq, 1, putch); + } -+ if (colors[c][1] != -1) -+ printf("4%d", colors[c][1]); -+ printf("m"); +} + ++static void ++endcolor(sig) ++ int sig; ++{ ++ tputs(ansi_coloff, 1, sig ? writech : putch); ++} ++ ++static int +colortype(mode) + mode_t mode; +{ @@ -212,6 +372,7 @@ +{ + int i, j, len; + char c[2]; ++ + if (cs == NULL) cs = ""; /* LSCOLORS not set */ + len = strlen(cs); + for (i = 0 ; i < C_NUMCOLORS ; i++) { @@ -225,53 +386,92 @@ + } + for (j = 0 ; j < 2 ; j++) { + if ((c[j] < '0' || c[j] > '7') && -+ tolower(c[j]) != 'x') { ++ tolower((unsigned char)c[j]) != 'x') { + fprintf(stderr, + "error: invalid character '%c' in LSCOLORS env var\n", + c[j]); + c[j] = defcolors[2*i+j]; + } -+ if (c[j] == 'x') ++ if (tolower((unsigned char)c[j]) == 'x') + colors[i][j] = -1; + else + colors[i][j] = c[j]-'0'; + } + } +} ++ ++void ++colorquit(sig) ++ int sig; ++{ ++ endcolor(sig); ++ ++ (void) signal(sig, SIG_DFL); ++ (void) kill(getpid(), sig); ++} ++#endif /*COLORLS*/ + static void printlink(p) FTSENT *p; ---- ./Makefile.org Mon Jul 7 03:02:47 1997 -+++ ./Makefile Mon Aug 24 01:24:27 1998 -@@ -1,7 +1,9 @@ - # @(#)Makefile 8.1 (Berkeley) 6/2/93 - # $Id: Makefile,v 1.2 1994/09/24 02:55:51 davidg Exp $ - +Index: util.c +=================================================================== +RCS file: /usr/cvs/src/bin/ls/util.c,v +retrieving revision 1.20 +retrieving revision 1.21 +diff -u -r1.20 -r1.21 +--- util.c 1999/08/27 23:14:33 1.20 ++++ util.c 2000/06/06 07:29:43 1.21 +@@ -158,7 +158,12 @@ + void + usage() + { +- (void)fprintf(stderr, "usage: ls [-ACFHLPRTWacdfgikloqrstu1]" ++ (void)fprintf(stderr, ++#ifdef COLORLS ++ "usage: ls [-ACFGHLPRTWacdfgikloqrstu1]" ++#else ++ "usage: ls [-ACFHLPRTWacdfgikloqrstu1]" ++#endif + " [file ...]\n"); + exit(1); + } +Index: Makefile +=================================================================== +RCS file: /usr/cvs/src/bin/ls/Makefile,v +retrieving revision 1.9 +retrieving revision 1.12 +diff -u -r1.9 -r1.12 +--- Makefile 2000/02/05 18:42:27 1.9 ++++ Makefile 2000/06/05 19:34:31 1.12 +@@ -4,5 +4,13 @@ + -PROG= ls +PROG= colorls SRCS= cmp.c stat_flags.c ls.c print.c util.c +BINDIR= ${PREFIX}/bin +MANDIR= ${PREFIX}/man/man ++.if !defined(RELEASE_BUILD_FIXIT) ++CFLAGS+= -DCOLORLS ++LDADD+= -ltermcap ++DPADD+= ${LIBTERMCAP} ++.endif ++ .include <bsd.prog.mk> ---- ./colorls.1.org Mon Aug 24 01:24:27 1998 -+++ ./colorls.1 Mon Aug 24 01:27:33 1998 -@@ -36,16 +36,24 @@ - .\" $Id: ls.1,v 1.5.2.6 1998/07/15 02:01:34 jkh Exp $ - .\" - .Dd April 18, 1994 --.Dt LS 1 -+.Dt COLORLS 1 - .Os - .Sh NAME - .Nm ls --.Nd list directory contents -+.Nd list directory contents in color +Index: colorls.1 +=================================================================== +RCS file: /usr/cvs/src/bin/ls/ls.1,v +retrieving revision 1.33 +retrieving revision 1.35 +diff -u -r1.33 -r1.35 +--- colorls.1 2000/03/02 14:53:20 1.33 ++++ colorls.1 2000/06/06 00:42:24 1.35 +@@ -43,7 +43,15 @@ + .Nd list directory contents .Sh SYNOPSIS --.Nm ls + .Nm ls -.Op Fl ABCFHLPRTWabcdfgikloqrstu1 -+.Nm colorls +.Op Fl ABCFGHLPRTWabcdfgikloqrstu1 .Op Ar file ... .Sh DESCRIPTION @@ -284,22 +484,20 @@ +is for color display.) +.Pp For each operand that names a - .Ar file - of a type other than -@@ -90,6 +98,12 @@ +@@ -90,6 +90,12 @@ a percent sign (%) after each whiteout, and a vertical bar (|) after each that is a .Tn FIFO . +.It Fl G -+Use ANSI color sequences to distinguish file types. (See ++Use termcap color sequences to distinguish file types. (See +.Ev LSCOLORS -+below.) In addition to those mentioned above in ++below.) In addition to those mentioned above in +.Fl F , +some extra attributes (setuid bit set, etc.) are also displayed. .It Fl H Symbolic links on the command line are followed. This option is assumed if none of the -@@ -373,6 +387,74 @@ +@@ -386,6 +392,74 @@ See .Xr environ 7 for more information. @@ -325,7 +523,7 @@ +.It Sy 2 +green +.It Sy 3 -+yellow ++brown +.It Sy 4 +blue +.It Sy 5 @@ -333,7 +531,7 @@ +.It Sy 6 +cyan +.It Sy 7 -+white ++light grey +.It Sy x +default foreground or background +.El @@ -371,6 +569,6 @@ +The default is "4x5x2x3x1x464301060203", i.e., blue foreground and +default background for regular directories, black foreground and red +background for setuid executables, etc. - .El - .Sh COMPATIBILITY - The group field is now automatically included in the long listing for + .It Ev LS_COLWIDTHS + If this variable is set, it is considered to be a + colon-delimited list of minimum column widths. Unreasonable |