openbsd-ports/misc/fileutils/patches/patch-src_ls_c
2010-11-03 06:56:37 +00:00

64 lines
2.3 KiB
Plaintext

$OpenBSD: patch-src_ls_c,v 1.4 2010/11/03 06:56:37 jasper Exp $
--- src/ls.c.orig Sun Apr 29 11:42:47 2001
+++ src/ls.c Wed Nov 3 07:55:57 2010
@@ -510,13 +510,13 @@ enum color_type
enum indicator_no
{
C_LEFT, C_RIGHT, C_END, C_NORM, C_FILE, C_DIR, C_LINK, C_FIFO, C_SOCK,
- C_BLK, C_CHR, C_MISSING, C_ORPHAN, C_EXEC, C_DOOR
+ C_BLK, C_CHR, C_MISSING, C_ORPHAN, C_EXEC, C_DOOR, C_UID, C_GID, C_WRO, C_WT
};
static const char *const indicator_name[]=
{
"lc", "rc", "ec", "no", "fi", "di", "ln", "pi", "so",
- "bd", "cd", "mi", "or", "ex", "do", NULL
+ "bd", "cd", "mi", "or", "ex", "do", "su", "sg", "wo", "wt", NULL
};
struct color_ext_type
@@ -542,7 +542,11 @@ static struct bin_str color_indicator[] =
{ 0, NULL }, /* mi: Missing file: undefined */
{ 0, NULL }, /* or: Orphanned symlink: undefined */
{ LEN_STR_PAIR ("01;32") }, /* ex: Executable: bright green */
- { LEN_STR_PAIR ("01;35") } /* do: Door: bright magenta */
+ { LEN_STR_PAIR ("01;35") }, /* do: Door: bright magenta */
+ { LEN_STR_PAIR ("37;41") }, /* su: setuid: white on red */
+ { LEN_STR_PAIR ("30;43") }, /* sg: setgid: black on yellow */
+ { LEN_STR_PAIR ("37;44") }, /* wo: writeable-other:white on blue */
+ { LEN_STR_PAIR ("37;42") }, /* wt: wo w/ sticky: white on green */
};
/* FIXME: comment */
@@ -2883,7 +2887,14 @@ print_color_indicator (const char *name, unsigned int
else
{
if (S_ISDIR (mode))
- type = C_DIR;
+ {
+ if ((mode && MODE_WT) == MODE_WT)
+ type = C_WT;
+ else if ((mode && MODE_WRO) == MODE_WRO)
+ type = C_WRO;
+ else
+ type = C_DIR;
+ }
else if (S_ISLNK (mode))
type = ((!linkok && color_indicator[C_ORPHAN].string)
? C_ORPHAN : C_LINK);
@@ -2898,7 +2909,13 @@ print_color_indicator (const char *name, unsigned int
else if (S_ISDOOR (mode))
type = C_DOOR;
- if (type == C_FILE && (mode & S_IXUGO) != 0)
+ if ((type == C_FILE) && ((mode & S_ISUID) != 0))
+ type = C_UID;
+
+ else if ((type == C_FILE) && ((mode & S_ISGID) != 0))
+ type = C_GID;
+
+ else if (type == C_FILE && (mode & S_IXUGO) != 0)
type = C_EXEC;
/* Check the file's suffix only if still classified as C_FILE. */