|
|
DataMuseum.dkPresents historical artifacts from the history of: DKUUG/EUUG Conference tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about DKUUG/EUUG Conference tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - downloadIndex: T o
Length: 8240 (0x2030)
Types: TextFile
Names: »options.h«
└─⟦a05ed705a⟧ Bits:30007078 DKUUG GNU 2/12/89
└─⟦cc8755de2⟧ »./libg++-1.36.1.tar.Z«
└─⟦23757c458⟧
└─⟦this⟧ »libg++/gperf/src/options.h«
/* This may look like C code, but it is really -*- C++ -*- */
/* Handles parsing the Options provided to the user.
Copyright (C) 1989 Free Software Foundation, Inc.
written by Douglas C. Schmidt (schmidt@ics.uci.edu)
This file is part of GNU GPERF.
GNU GPERF is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 1, or (at your option)
any later version.
GNU GPERF is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with GNU GPERF; see the file COPYING. If not, write to
the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
/* This module provides a uniform interface to the various Options available
to a user of the Gen_Perf.hash function generator. In addition to the
run-time Options, found in the Option_Type below, there is also the
hash table Size and the Keys to be used in the hashing.
The overall design of this module was an experiment in using C++
classes as a mechanism to enhance centralization of option and
and error handling, which tend to get out of hand in a C program. */
#pragma once
#include "std-err.h"
/* Enumerate the potential debugging Options. */
enum Option_Type
{
DEBUG = 01, /* Enable debugging (prints diagnostics to Std_Err). */
ORDER = 02, /* Apply ordering heuristic to speed-up search time. */
ANSI = 04, /* Generate ANSI prototypes. */
ALLCHARS = 010, /* Use all characters in hash function. */
GNU = 020, /* Assume GNU extensions (primarily function inline). */
TYPE = 040, /* Handle user-defined type structured keyword input. */
RANDOM = 0100, /* Randomly initialize the associated values table. */
DEFAULTCHARS = 0200, /* Make default char positions be 1,$ (end of keyword). */
SWITCH = 0400, /* Generate switch output to save space. */
POINTER = 01000, /* Have in_word_set function return pointer, not boolean. */
NOLENGTH = 02000, /* Don't include keyword length in hash computations. */
LENTABLE = 04000, /* Generate a length table for string comparison. */
DUP = 010000, /* Handle duplicate hash values for keywords. */
FAST = 020000, /* Generate the hash function ``fast.'' */
NOTYPE = 040000, /* Don't include user-defined type definition
* in output -- it's already defined elsewhere. */
COMP = 0100000, /* Generate strncmp rather than strcmp. */
GLOBAL = 0200000, /* Make the keyword table a global variable. */
CONST = 0400000, /* Make the generated tables readonly (const). */
};
/* Define some useful constants (these don't really belong here, but I'm
not sure where else to put them!). These should be consts, but g++
doesn't seem to do the right thing with them at the moment... ;-( */
enum
{
MAX_KEY_POS = 128 - 1, /* Max size of each word's key set. */
WORD_START = 1, /* Signals the start of a word. */
WORD_END = 0, /* Signals the end of a word. */
EOS = MAX_KEY_POS, /* Signals end of the key list. */
};
/* Class manager for gperf program Options. */
class Options : private Std_Err
{
public:
Options (void);
~Options (void);
int operator[] (Option_Type option);
void operator() (int argc, char *argv[]);
void operator= (enum Option_Type);
void operator!= (enum Option_Type);
static void reset (void);
static void set_asso_max (int r);
static void print_options (void);
static int get (void);
static int get_asso_max (void);
static int get_iterations (void);
static int total_positions (void);
static int get_jump (void);
static int initial_value (void);
static const char *get_function_name (void);
static const char *get_key_name (void);
static const char *get_hash_name (void);
private:
const int DEFAULT_JUMP_VALUE = 5; /* Size to jump on a collision. */
const char *const DEFAULT_NAME = "in_word_set"; /* Default name for generated lookup function. */
const char *const DEFAULT_KEY = "name"; /* Default name for the key component. */
const char *const DEFAULT_HASH_NAME = "hash"; /* Default name for generated hash function. */
static int option_word; /* Holds the user-specified Options. */
static int total_key_positions; /* Total number of distinct key_positions. */
static int size; /* Range of the hash table. */
static int key_pos; /* Tracks current key position for Iterator. */
static int jump; /* Jump length when trying alternative values. */
static int initial_asso_value; /* Initial value for asso_values table. */
static int argument_count; /* Records count of command-line arguments. */
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 *key_name; /* Name used for keyword key. */
static const char *hash_name; /* Name used for generated hash function. */
static char key_positions[MAX_KEY_POS]; /* Contains user-specified key choices. */
static int key_sort (char *base, int len); /* Sorts key positions in REVERSE order. */
static void usage (void); /* Prints proper program usage. */
};
/* Global option coordinator for the entire program. */
extern Options option;
#ifdef __OPTIMIZE__
inline int
Options::operator[] (Option_Type option) /* True if option enable, else false. */
{
return option_word & option;
}
inline void
Options::operator = (enum Option_Type opt) /* Enables option OPT. */
{
option_word |= opt;
}
inline void
Options::operator != (enum Option_Type opt) /* Disables option OPT. */
{
option_word &= ~opt;
}
inline void
Options::reset (void) /* Initializes the key Iterator. */
{
key_pos = 0;
}
inline int
Options::get (void) /* Returns current key_position and advanced index. */
{
return key_positions[key_pos++];
}
inline void
Options::set_asso_max (int r) /* Sets the size of the table size. */
{
size = r;
}
inline int
Options::get_asso_max (void) /* Returns the size of the table size. */
{
return size;
}
inline int
Options::total_positions (void) /* Returns total distinct key positions. */
{
return total_key_positions;
}
inline int
Options::get_jump (void) /* Returns the jump value. */
{
return jump;
}
inline const char *
Options::get_function_name (void) /* Returns the jump value. */
{
return function_name;
}
inline const char *
Options::get_key_name (void) /* Returns the keyword key name. */
{
return key_name;
}
inline const char *
Options::get_hash_name (void) /* Returns the hash function name. */
{
return hash_name;
}
inline int
Options::initial_value (void) /* Returns the initial associated character value. */
{
return initial_asso_value;
}
inline int
Options::get_iterations (void) /* Returns the iterations value. */
{
return iterations;
}
#endif