summaryrefslogtreecommitdiff
path: root/contrib
diff options
context:
space:
mode:
Diffstat (limited to 'contrib')
-rw-r--r--contrib/ChangeLog4
-rw-r--r--contrib/gperf-2.7-19981006.pat148
2 files changed, 152 insertions, 0 deletions
diff --git a/contrib/ChangeLog b/contrib/ChangeLog
index 1e7c1e474f1..05498343012 100644
--- a/contrib/ChangeLog
+++ b/contrib/ChangeLog
@@ -1,3 +1,7 @@
+Wed Oct 7 13:00:40 1998 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
+
+ * gperf-2.7-19981006.pat: New file, patch for egcs-local gperf.
+
Mon Oct 5 14:19:48 1998 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
* warn_summary (subdirectoryFilter): New shell function to
diff --git a/contrib/gperf-2.7-19981006.pat b/contrib/gperf-2.7-19981006.pat
new file mode 100644
index 00000000000..c20168ac535
--- /dev/null
+++ b/contrib/gperf-2.7-19981006.pat
@@ -0,0 +1,148 @@
+Tue Oct 6 16:18:10 1998 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
+
+ * key-list.cc (output_keyword_blank_entries): Output
+ get_fill_default() in the blank entries of keywords as a trailing
+ list of initializers.
+
+ * options.cc: Add support for fill_default.
+
+ * options.h: Likewise.
+
+ * options.icc: Likewise.
+
+ * version.cc: Update to indicate forked version.
+
+
+diff -rup orig/gperf-2.7/src/key-list.cc gperf-2.7/src/key-list.cc
+--- orig/gperf-2.7/src/key-list.cc Wed Apr 15 18:02:51 1998
++++ gperf-2.7/src/key-list.cc Tue Oct 6 15:38:54 1998
+@@ -1069,7 +1069,7 @@ output_keyword_blank_entries (int count,
+ printf (", ");
+ }
+ if (option[TYPE])
+- printf ("{\"\"}");
++ printf ("{\"\"%s}", option.get_fill_default());
+ else
+ printf ("\"\"");
+ column++;
+diff -rup orig/gperf-2.7/src/options.cc gperf-2.7/src/options.cc
+--- orig/gperf-2.7/src/options.cc Sat May 2 06:35:16 1998
++++ gperf-2.7/src/options.cc Tue Oct 6 15:20:03 1998
+@@ -40,6 +40,9 @@ static const int DEFAULT_JUMP_VALUE = 5;
+ /* Default name for generated lookup function. */
+ static const char *const DEFAULT_NAME = "in_word_set";
+
++/* Default filler for keyword table. */
++static const char *const DEFAULT_FILL = "";
++
+ /* Default name for the key component. */
+ static const char *const DEFAULT_KEY = "name";
+
+@@ -66,6 +69,7 @@ int Options::argument_count;
+ int Options::iterations;
+ char **Options::argument_vector;
+ const char *Options::function_name;
++const char *Options::fill_default;
+ const char *Options::key_name;
+ const char *Options::class_name;
+ const char *Options::hash_name;
+@@ -265,6 +269,7 @@ Options::Options (void)
+ jump = DEFAULT_JUMP_VALUE;
+ option_word = DEFAULTCHARS | C;
+ function_name = DEFAULT_NAME;
++ fill_default = DEFAULT_FILL;
+ key_name = DEFAULT_KEY;
+ hash_name = DEFAULT_HASH_NAME;
+ wordlist_name = DEFAULT_WORDLIST_NAME;
+@@ -306,6 +311,7 @@ Options::~Options (void)
+ "\nSEVENBIT is....: %s"
+ "\niterations = %d"
+ "\nlookup function name = %s"
++ "\nfill default = %s"
+ "\nhash function name = %s"
+ "\nword list name = %s"
+ "\nkey name = %s"
+@@ -336,7 +342,7 @@ Options::~Options (void)
+ option_word & INCLUDE ? "enabled" : "disabled",
+ option_word & SEVENBIT ? "enabled" : "disabled",
+ iterations,
+- function_name, hash_name, wordlist_name, key_name,
++ function_name, fill_default, hash_name, wordlist_name, key_name,
+ jump, size - 1, initial_asso_value, delimiters, total_switches);
+ if (option_word & ALLCHARS)
+ fprintf (stderr, "all characters are used in the hash function\n");
+@@ -379,6 +385,7 @@ static const struct option long_options[
+ { "compare-strlen", no_argument, 0, 'l' },
+ { "duplicates", no_argument, 0, 'D' },
+ { "fast", required_argument, 0, 'f' },
++ { "fill-default", required_argument, 0, 'F' },
+ { "initial-asso", required_argument, 0, 'i' },
+ { "jump", required_argument, 0, 'j' },
+ { "no-strlen", no_argument, 0, 'n' },
+@@ -403,7 +410,7 @@ Options::operator() (int argc, char *arg
+
+ while ((option_char =
+ getopt_long (argument_count, argument_vector,
+- "adcCDe:Ef:gGhH:i:Ij:k:K:lL:nN:oprs:S:tTvW:Z:7",
++ "adcCDe:Ef:F:gGhH:i:Ij:k:K:lL:nN:oprs:S:tTvW:Z:7",
+ long_options, (int *)0))
+ != -1)
+ {
+@@ -575,6 +582,11 @@ Options::operator() (int argc, char *arg
+ case 'N': /* Make generated lookup function name be optarg */
+ {
+ function_name = /*getopt*/optarg;
++ break;
++ }
++ case 'F': /* Make fill_default be optarg */
++ {
++ fill_default = /*getopt*/optarg;
+ break;
+ }
+ case 'o': /* Order input by frequency of key set occurrence. */
+diff -rup orig/gperf-2.7/src/options.h gperf-2.7/src/options.h
+--- orig/gperf-2.7/src/options.h Tue Apr 14 06:55:28 1998
++++ gperf-2.7/src/options.h Tue Oct 6 15:12:46 1998
+@@ -97,6 +97,7 @@ public:
+ static int initial_value (void);
+ static int get_total_switches (void);
+ static const char *get_function_name (void);
++ static const char *get_fill_default (void);
+ static const char *get_key_name (void);
+ static const char *get_class_name (void);
+ static const char *get_hash_name (void);
+@@ -115,6 +116,7 @@ private:
+ static int iterations; /* Amount to iterate when a collision occurs. */
+ static char **argument_vector; /* Stores a pointer to command-line vector. */
+ static const char *function_name; /* Names used for generated lookup function. */
++ static const char *fill_default; /* Expression used to assign default values in keyword table. */
+ static const char *key_name; /* Name used for keyword key. */
+ static const char *class_name; /* Name used for generated C++ class. */
+ static const char *hash_name; /* Name used for generated hash function. */
+diff -rup orig/gperf-2.7/src/options.icc gperf-2.7/src/options.icc
+--- orig/gperf-2.7/src/options.icc Sat Mar 21 07:51:17 1998
++++ gperf-2.7/src/options.icc Tue Oct 6 15:27:36 1998
+@@ -110,6 +110,14 @@ Options::get_function_name (void)
+ return function_name;
+ }
+
++/* Returns the fill default. */
++INLINE const char *
++Options::get_fill_default (void)
++{
++ T (Trace t ("Options::get_fill_default");)
++ return fill_default;
++}
++
+ /* Returns the keyword key name. */
+ INLINE const char *
+ Options::get_key_name (void)
+diff -rup orig/gperf-2.7/src/version.cc gperf-2.7/src/version.cc
+--- orig/gperf-2.7/src/version.cc Sat May 2 06:29:43 1998
++++ gperf-2.7/src/version.cc Tue Oct 6 16:04:56 1998
+@@ -19,4 +19,4 @@ You should have received a copy of the G
+ along with GNU GPERF; see the file COPYING. If not, write to the Free
+ Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111, USA. */
+
+-const char *version_string = "2.7";
++const char *version_string = "2.7.1 (19981006 egcs)";