⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 changelog

📁 早期freebsd实现
💻
📖 第 1 页 / 共 4 页
字号:
Thu Apr 27 00:14:51 1989  Doug Schmidt  (schmidt at glacier.ics.uci.edu)        * Added the -D option that properly handles keyword sets that          contain duplicate hash values.        * Continued the stylistic changes.  Added the #pragma once          directive to all the *.h files.  Removed all #defines and          replaced them with static consts.  Also moved the key_sort          routine from options.cc into the options class as a           member function.Mon Apr  3 13:26:55 1989  Doug Schmidt  (schmidt at zola.ics.uci.edu)        * Made massive stylistic changes to bring source code into          conformance with GNU style guidelines.Thu Mar 30 23:28:45 1989  Doug Schmidt  (schmidt at crimee.ics.uci.edu)        * Fixed up the output routines so that they generate code          corresponding to the GNU style guidelines.Sat Mar 11 13:12:37 1989  Doug Schmidt  (schmidt at glacier.ics.uci.edu)        * Fixed Stderr constructors so that they wouldn't try to          use the base class initializer syntax for the static           class variable Program_Name.  G++ 1.34 is stricter in          enforcing the rules!Fri Mar 10 11:24:14 1989  Doug Schmidt  (schmidt at glacier.ics.uci.edu)        * Removed -v and ``| more'' from the Makefile to keep rfg happy...Thu Mar  2 12:37:30 1989  Doug Schmidt  (schmidt at crimee.ics.uci.edu)        * Sent latest GNU gperf version 1.5 to Doug Lea for inclusion          into libg++ 1.34.  Note that there is a small bug with          the new %{ ... %} source inclusion facility, since it doesn't          understand comments and will barf if %{ or %} appear nested          inside the outermost delimiters.  This is too trivial of          a defect to fix at the moment...Tue Feb 28 11:19:58 1989  Doug Schmidt  (schmidt at glacier.ics.uci.edu)        * Added the -K option, which allows the user to provide a          alternative name for the keyword structure component.          The default is still ``name.''        * Added the LEX and YACC-like ability to include arbitrary          text at the beginning of the generated C source code output.          This required two new functions Get_Special_Input,           Key_List::Save_Include_Src;        * Fixed memory allocation bug in Key_List::Set_Types.          Variable Return_Type needs 1 additional location          to store the "*" if the -p option is used.                  * Added code to NULL terminate both Struct_Tag and Return_Type,          *after* the strncpy (stupid mistake).          Mon Feb 27 14:39:51 1989  Doug Schmidt  (schmidt at glacier.ics.uci.edu)        * Added a new option -N.  This allows the user to specify the          name to be used for the generated lookup function.  The          default name is still ``in_word_set.''  This makes it          possible to completely automate the perfect hash function          generation process!Mon Feb 20 23:33:14 1989  Doug Schmidt  (schmidt at glacier.ics.uci.edu)        * Corrected the Hash_Table::operator () function so that          *it* is responsible for deciding when a new key has the          same signature as a previously seen key.  The key length           information is now used internally to this function to          decide whether to add to the hash table those keys with          the same key sets, but different lengths.  Before, this          was handled by the Key_List::Read_Keys function.  However,          this failed to work for certain duplicate keys, since          they weren't being entered into the hash table properly.Sun Feb 19 16:02:51 1989  Doug Schmidt  (schmidt at glacier.ics.uci.edu)        * Modified class Options by moving the enum Option_Type out          of the class.  This is to satisfy the new enumeration          scope rules in C++.Sun Jan 15 15:12:09 1989  Doug Schmidt  (schmidt at crimee.ics.uci.edu)        * Incremented the version number upto 1.4 to reflect the new           options that affect the generated code.  Send the new           distribution off to Michael for use with g++ 1.33.        * Added a fix to Key_List::Read_Keys so that it checks for links          properly when the -n option is used.  Previously, it didn't          catch obvious links, which caused it to spend large amount          of time searching for a solution that could never occur!        * Modified the Key_List data structure to record *both* the           minimum and the maximum key lengths.  This information          is now computed in Key_List::Read_Keys, and thus           Key_List::Print_Min_Max doesn't need to bother.        * Modifed the key position iterator scheme in options.cc to          eliminate the need for member function Options::Advance.          Now, the Options::Get function performs the advancement          automatically, obviating the need for an extra function call.        * Added the new function Options::Print_Options, to print out          the user-specified command line options to generated C          output file.        * Added a new function, Key_List::Print_Keylength_Table,          which creates a table of lengths for use in speeding          up the keyword search.  This also meant that a new          option, -l (LENTABLE) is recognized.  It controls           whether the length table is printed and the comparison          made in the generated function ``in_word_set.''        * Added a comment at the top of the generated C code          output file that tells what version of gperf was used.          Next, I'll also dump out the command line options          as a comment too.  Thanks to Michael Tiemann for the          feedback on this.        * Fixed the -n option to make it work correctly with          other parts of the program (most notably the Perfect::Hash          function and the computation of minimum and maximum lengths.Fri Jan 13 21:25:27 1989  Doug Schmidt  (schmidt at siam.ics.uci.edu)        * Realized the the need to add a test that will enable          optimziation of the generated C code in the ``hash'' function          by checking whether all the requested key positions are          guaranteed to exist due to the comparison in `in_word_set.''          I'll put this in soon....Thu Jan 12 20:09:21 1989  Doug Schmidt  (schmidt at glacier.ics.uci.edu)        * Added pascal, modula3, and modula2 tests inputs to the           Makefile                * Recognised that there is a bug with the -n option.  However          I'm too busy to fix it properly, right now.  The problem           is that the generated #define end up being 0, since that's          my hack to make -n work.  This needs complete rethinking!Tue Jan 10 00:08:16 1989  Doug Schmidt  (schmidt at crimee.ics.uci.edu)        * Added a new option, -n, that instructs gperf to not use the          length of an identifier when computing the hash functions.          I'm not sure how useful this is!                  * Retransmitted the distribution to rocky.oswego.edu.  Hopefully,          this will work!        * Began fixing the indentation and capitalization to conform          to the GNU coding guidelines.Mon Jan  9 22:23:18 1989  Doug Schmidt  (schmidt at pompe.ics.uci.edu)        * Fixed horrible bug in Read_Line::Readln_Aux.  This was          a subtle and pernicous off-by-1 error, that overwrote          past the last character of the input string buffer.  I          think this fault was killing the vax!        * Yow, fixed an oversight in List_Node::List_Node, where the          pointer field Next was uninitialized.  Luckily, the new routine          seems to return 0 filled objects the first time through!Sun Jan  8 13:43:14 1989  Doug Schmidt  (schmidt at crimee.ics.uci.edu)        * Modified the ``key linked'' diagnostic in Key_List::Read_Keys          to be more helpful and easy to read.        * Fixed the List_Node::List_Node so that it would ignore trailing          fields if the -t option was not enabled.        * Moved the List_Node declarations out of keylist.h and          into a file of its own, called listnode.cc and listnode.h          Made Set_Sort a member function of class List_Node.        * Massively updated the documentation in the gperf.texinfo file.                * Polished off the major revision to the print functions,          added a few new tests in the Makefile to check for the          validity of the program and ftp'ed the entire distribution          off to Doug Lea for libg++. ( changed it to          1.3 to reflect the major changes with the generated          C code ).        * Fixed Key_List::Print_Switch to deal with the -p and -t options.          This meant that the ``still-born'' function Key_List::          Print_Type_Switch was superflous, so I removed it.          Also, removed the restriction in Option that the -p and          -t options couldn't be used simultaneously.        * Modified List_Node::List_Node, to perform only 1 call to           ``new'' when dynamically allocating memory for the Key_Set          and the Uniq_Set.Sat Jan  7 14:10:51 1989  Doug Schmidt  (schmidt at glacier.ics.uci.edu)        * Fixed a big bug with the new policy of nesting the          wordlist inside of generated function ``in_word_set.''          I'd forgotten to declare the wordlist array as static!          ( arrgh ).        * Added a new function Key_List::Set_Types, that figures out          the return type for generated function ``in_word_set,''          the user-defined ``struct tag,'' if one is used, and also          formates the array type for the static local array.        * Changed the print routines to take advantage of the          new -p option.        * Began adding the hooks to allow the return of a pointer          to a user defined struct location from the generated          ``in_word_set'' function instead of the current 0 or 1          return value.  Created function Key_List::Print_Type_Switch          and added option -p to class Option, allowing the user to           request generation of the aforementioned pointers returned           instead of booleans.        * Put in checks in class Option to make sure that -S and -t          options are not used simultaneously.  This restriction          will be removed in subsequent releases, once I decide on          a clean way to implement it.        * Sent version 1.2 to Doug Lea for possible inclusion into          the libg++ distribution.                  * Moved the static word_list array inside the generated function          in_word_set.  This supports better data hiding.        * Added a texinfo file, gperf.texinfo                  * Revised the Makefile to cleanup the droppings from texinfo          and changed the name of gperf.cc and gperf.h to perfect.cc          and perfect.h.Fri Jan  6 13:04:45 1989  Doug Schmidt  (schmidt at crimee.ics.uci.edu)        * Implemented the switch statement output format.  Much better          for large datasets in terms of space used.        * Added new functions to break up the Key_List::Output function.          Functions added were Key_List::Print_Switch, Key_List::Print_Min_Max,          Key_List::Print_Keyword_Table, Key_List::Print_Hash_Function,          and Key_List::Print_Lookup_Function.  This simplifies the          big mess in Key_List::Output considerably!                  * Added switch statement option to Options, which potentially           trades time for space in the generated lookup code.Thu Jan  5 22:46:34 1989  Doug Schmidt  (schmidt at siam.ics.uci.edu)        * Released version 1.1                * Fixed a bug with Gperf::Merge_Set, it was skipping letters shared          between the Set_1 and Set_2.        * Added the optimal min/max algorithm in Key_List::Output.  This          runs in O ( 3n/2 ), rather than O ( 2n ) time.        * Changed Gperf::Sort_Set to use insertion sort, rather than          bubble sort.                * Added a check in Key_List::Output for the special case where          the keys used are 1,$.  It is possible to generate more          efficient C code in this case.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -