diff options
author | Tim Yamin <plasmaroo@gentoo.org> | 2003-10-17 23:40:43 +0000 |
---|---|---|
committer | Tim Yamin <plasmaroo@gentoo.org> | 2003-10-17 23:40:43 +0000 |
commit | 3d460b93dc7938e3c6717c1d1b4e509fb6843a6b (patch) | |
tree | 2164cc2eb8a7dce37abf74a9f4e4df820f606cfa /app-shells/sash/files | |
parent | Added sash-3.6 to the tree. Bug 26272. (diff) | |
download | historical-3d460b93dc7938e3c6717c1d1b4e509fb6843a6b.tar.gz historical-3d460b93dc7938e3c6717c1d1b4e509fb6843a6b.tar.bz2 historical-3d460b93dc7938e3c6717c1d1b4e509fb6843a6b.zip |
Added sash-3.6 to the tree. Bug 26272.
Diffstat (limited to 'app-shells/sash/files')
-rw-r--r-- | app-shells/sash/files/digest-sash-3.6 | 1 | ||||
-rw-r--r-- | app-shells/sash/files/sash-3.6-fix-includes.patch | 39 | ||||
-rw-r--r-- | app-shells/sash/files/sash-3.6-readline.patch | 291 |
3 files changed, 331 insertions, 0 deletions
diff --git a/app-shells/sash/files/digest-sash-3.6 b/app-shells/sash/files/digest-sash-3.6 new file mode 100644 index 000000000000..c9843356511c --- /dev/null +++ b/app-shells/sash/files/digest-sash-3.6 @@ -0,0 +1 @@ +MD5 56dd73d91374e1f0c59b9860b2855119 sash-3.6.tar.gz 50270 diff --git a/app-shells/sash/files/sash-3.6-fix-includes.patch b/app-shells/sash/files/sash-3.6-fix-includes.patch new file mode 100644 index 000000000000..1537ffb1b1fd --- /dev/null +++ b/app-shells/sash/files/sash-3.6-fix-includes.patch @@ -0,0 +1,39 @@ +diff -ruN sash-3.6.orig/Makefile sash-3.6/Makefile +--- sash-3.6.orig/Makefile 2002-07-22 01:24:47.000000000 +0200 ++++ sash-3.6/Makefile 2003-10-17 14:25:00.306848712 +0200 +@@ -21,7 +21,7 @@ + -DHAVE_BSD_MOUNT=$(HAVE_BSD_MOUNT) \ + -DMOUNT_TYPE=$(MOUNT_TYPE) + +-LDFLAGS = -static -s ++LDFLAGS = -all-static -s + LIBS = -lz + + +diff -ruN sash-3.6.orig/cmd_chattr.c sash-3.6/cmd_chattr.c +--- sash-3.6.orig/cmd_chattr.c 2002-03-08 08:21:03.000000000 +0100 ++++ sash-3.6/cmd_chattr.c 2003-10-17 14:24:47.559786560 +0200 +@@ -12,7 +12,7 @@ + + #include <sys/ioctl.h> + #include <sys/types.h> +-#include <linux/ext2_fs.h> ++#include <ext2fs/ext2_fs.h> + + #include "sash.h" + +diff -ruN sash-3.6.orig/cmds.c sash-3.6/cmds.c +--- sash-3.6.orig/cmds.c 2002-07-22 00:28:19.000000000 +0200 ++++ sash-3.6/cmds.c 2003-10-17 14:24:31.013302008 +0200 +@@ -17,11 +17,6 @@ + #include <utime.h> + #include <errno.h> + +-#if HAVE_LINUX_MOUNT +-#include <linux/fs.h> +-#endif +- +- + void + do_echo(int argc, const char ** argv) + { diff --git a/app-shells/sash/files/sash-3.6-readline.patch b/app-shells/sash/files/sash-3.6-readline.patch new file mode 100644 index 000000000000..a2830b875408 --- /dev/null +++ b/app-shells/sash/files/sash-3.6-readline.patch @@ -0,0 +1,291 @@ +diff -ruN sash-3.6/Makefile sash-3.6.readline/Makefile +--- sash-3.6/Makefile 2003-10-17 14:25:00.306848712 +0200 ++++ sash-3.6.readline/Makefile 2003-10-17 14:27:34.529403320 +0200 +@@ -19,10 +19,11 @@ + -DHAVE_LINUX_ATTR=$(HAVE_LINUX_ATTR) \ + -DHAVE_LINUX_MOUNT=$(HAVE_LINUX_MOUNT) \ + -DHAVE_BSD_MOUNT=$(HAVE_BSD_MOUNT) \ +- -DMOUNT_TYPE=$(MOUNT_TYPE) ++ -DMOUNT_TYPE=$(MOUNT_TYPE) \ ++ -DHAVE_READLINE + + LDFLAGS = -all-static -s +-LIBS = -lz ++LIBS = -lz -lreadline -lncurses + + + BINDIR = /bin +diff -ruN sash-3.6/sash.c sash-3.6.readline/sash.c +--- sash-3.6/sash.c 2002-07-22 00:55:28.000000000 +0200 ++++ sash-3.6.readline/sash.c 2003-10-17 14:26:26.184793280 +0200 +@@ -384,6 +384,201 @@ + static void usage(void); + static Alias * findAlias(const char * name); + ++#ifdef HAVE_READLINE ++/*--- Interface of readline 4.0 by vlk@vinf.ru ---*/ ++ ++#include <readline/readline.h> ++#include <readline/history.h> ++#include <dirent.h> ++ ++char * dupstr (char *s); ++void initialize_readline (void); ++char ** fileman_completion (char *text, int start, int end); ++char *command_generator (char *text, int state); ++void err_alloc(int ErrorNumber); ++extern char *xmalloc (); ++ ++static char ** listBase; ++static long listSize; ++ ++void ++err_alloc(int ErrorNumber) ++{ ++ fprintf(stderr, "Memory space failed: %d\n",ErrorNumber); ++ return; ++} ++ ++/* Add a one item to exec-command array */ ++static int ++listAdd(const char * new_item) ++{ ++ if ((listBase = realloc(listBase, sizeof(char *) * ( listSize + 1 ))) == 0 ) ++ { ++ err_alloc(3); exit(1); ++ } ++ listBase[listSize] = strdup(new_item); ++ listSize++; ++ return(0); ++} ++ ++static int ++genExecList(void) ++{ ++ char * dirName; ++ char * path; ++ char * endPath; ++ char * fullName; ++ struct dirent **namelist; ++ int n; ++ ++ if (getenv("PATH") == 0) ++ return(1); ++ else ++ { ++ if ((path = strdup(getenv("PATH"))) == 0) ++ { ++ err_alloc(4); ++ return(1); ++ } ++ } ++ /* ++ * Check out each path to see if the program exists and is ++ * executable in that path. ++ */ ++ for ( ; path; path = endPath) ++ { ++ /* ++ * Find the end of the next path and NULL terminate ++ * it if necessary. ++ */ ++ endPath = strchr(path, ':'); ++ ++ if (endPath) ++ *endPath++ = '\0'; ++ ++ /* ++ * Get the directory name, defaulting it to DOT if ++ * it is null. ++ */ ++ dirName = path; ++ ++ /* ++ * See if the program exists and is executable. ++ */ ++ if (access(dirName, F_OK) < 0) ++ { ++ if (errno != ENOENT) ++ printf("%s: %s\n", dirName, strerror(errno)); ++ ++ continue; ++ } ++ n = scandir(dirName, &namelist, 0, alphasort); ++ if (n < 0) ++ perror("scandir"); ++ else ++ while(n--) ++ { ++ if (strncmp(namelist[n]->d_name,".",1) != 0) ++ { ++ fullName = malloc(sizeof(dirName) + 1 \ ++ + sizeof(namelist[n]->d_name)); ++ strcpy(fullName, dirName); ++ strcat(fullName, "/"); ++ strcat(fullName, namelist[n]->d_name); ++ if (access(fullName,X_OK|F_OK) == 0) ++ listAdd(namelist[n]->d_name); ++ } ++ } ++ } ++return(0); ++} ++ ++/******************************************************************/ ++/* BEGIN Interface to Readline Completion */ ++/******************************************************************/ ++ ++char * dupstr (char *s) ++{ ++ char *r; ++ ++ r = xmalloc (strlen (s) + 1); ++ strcpy (r, s); ++ return (r); ++} ++ ++/* Tell the GNU Readline library how to complete. We want to try to complete ++ on command names if this is the first word in the line, or on filenames ++ if not. */ ++void initialize_readline (void) ++{ ++ /* Allow conditional parsing of the ~/.inputrc file. */ ++ rl_readline_name = "readline"; ++ ++ /* Tell the completer that we want a crack first. */ ++ rl_attempted_completion_function = (CPPFunction *)fileman_completion; ++} ++ ++/* Attempt to complete on the contents of TEXT. START and END bound the ++ region of rl_line_buffer that contains the word to complete. TEXT is ++ the word to complete. We can use the entire contents of rl_line_buffer ++ in case we want to do some simple parsing. Return the array of matches, ++ or NULL if there aren't any. */ ++char ** fileman_completion (char *text, int start, int end) ++{ ++ char **matches; ++ ++ matches = (char **)NULL; ++ ++ /* If this word is at the start of the line, then it is a command ++ to complete. Otherwise it is the name of a file in the current ++ directory. */ ++ if (start == 0) // is it the begin of string ? ++ matches = completion_matches (text, command_generator); ++ return (matches); ++} ++ ++/* Generator function for command completion. STATE lets us know whether ++ to start from scratch; without any state (i.e. STATE == 0), then we ++ start at the top of the list. */ ++char * command_generator (char *text, int state) ++{ ++ static int list_index, len; ++ char *ename; ++ static long exec_count; ++ ++ /* If this is a new word to complete, initialize now. This includes ++ saving the length of TEXT for efficiency, and initializing the index ++ variable to 0. */ ++ if (!state) ++ { ++ exec_count = 0; ++ list_index = 0; ++ len = strlen (text); ++ } ++ ++ /* Return the next name which partially matches from the command list. */ ++ ++ while (ename = (char*)commandEntryTable[list_index].name) ++ { ++ list_index++; ++ if (strncmp (ename, text, len) == 0) ++ return (dupstr(ename)); ++ } ++ ++ while (exec_count < listSize) ++ { ++ ename = listBase[exec_count]; ++ exec_count++; ++ if (strncmp (ename, text, len) == 0) ++ return(dupstr(ename)); ++ } ++ /* If no names matched, then return NULL. */ ++ return ((char *)NULL); ++} ++/******************************************************************/ ++/* END Interface to Readline Completion */ ++/******************************************************************/ ++#endif + + /* + * Global interrupt flag. +@@ -405,7 +600,16 @@ + commandFile = NULL; + quietFlag = FALSE; + aliasFlag = FALSE; ++#ifdef HAVE_READLINE ++ /* ++ * Default our path if it is not set. ++ */ ++ if (getenv("PATH") == NULL) ++ putenv("PATH=/bin:/usr/bin:/sbin:/usr/sbin"); + ++ genExecList(); ++ initialize_readline (); /* Bind our completer. */ ++#endif + /* + * Look for options. + */ +@@ -554,6 +758,9 @@ + static void + readFile(const char * name) + { ++#ifdef HAVE_READLINE ++ char *input_line = NULL; ++#endif + FILE * fp; + int cc; + BOOL ttyFlag; +@@ -586,9 +793,10 @@ + + while (TRUE) + { +- if (ttyFlag) ++#ifndef HAVE_READLINE ++ if (ttyFlag) + showPrompt(); +- ++#endif + if (intFlag && !ttyFlag && (fp != stdin)) + { + fclose(fp); +@@ -596,6 +804,19 @@ + + return; + } ++#ifdef HAVE_READLINE ++ if (name == NULL) ++ { ++ input_line = readline(prompt ? prompt : "$ "); ++ if (input_line) ++ { ++ if (*input_line) ++ add_history(input_line); ++ strcpy(buf,input_line); ++ } ++ free(input_line); ++ } ++#else + + if (fgets(buf, CMD_LEN - 1, fp) == NULL) + { +@@ -608,7 +829,7 @@ + + break; + } +- ++#endif + cc = strlen(buf); + + if (buf[cc - 1] == '\n') |