home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 22 gnu / 22-gnu.zip / rcs567s.zip / rcs / NEWS < prev    next >
Text File  |  1994-03-17  |  24KB  |  527 lines

  1. Recent changes to RCS (and possible future changes)
  2.  
  3.     $Id: NEWS,v 1.3 1994/03/17 14:05:48 eggert Exp $
  4.  
  5.     Copyright 1991, 1992, 1993, 1994 Paul Eggert
  6.     Distributed under license by the Free Software Foundation, Inc.
  7.  
  8.     This file is part of RCS.
  9.  
  10.     RCS is free software; you can redistribute it and/or modify it
  11.     under the terms of the GNU General Public License as published
  12.     by the Free Software Foundation; either version 2, or (at your
  13.     option) any later version.
  14.  
  15.     RCS is distributed in the hope that it will be useful, but
  16.     WITHOUT ANY WARRANTY; without even the implied warranty of
  17.     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  18.     GNU General Public License for more details.
  19.  
  20.     You should have received a copy of the GNU General Public
  21.     License along with RCS; see the file COPYING.  If not, write to
  22.     the Free Software Foundation, 675 Mass Ave, Cambridge, MA
  23.     02139, USA.
  24.  
  25.     Report problems and direct all questions to:
  26.  
  27.         rcs-bugs@cs.purdue.edu
  28.  
  29.  
  30. Features new to RCS version 5.6.7 (beta) include:
  31.  
  32.   Inserted log lines now have the same prefix as the preceding `$Log' line.
  33.   E.g. if a $Log line starts with `// $Log', log lines are prefixed with `// '.
  34.   RCS still records the (now obsolescent) comment leader inside RCS files,
  35.   but it ignores the comment leader unless it is emulating older RCS versions.
  36.   If you plan to access a file with both old and new versions of RCS,
  37.   make sure its comment leader matches its `$Log' line prefix.
  38.  
  39.   Log lines are now inserted even if -kk is specified.
  40.  
  41.   ci's -rR option (with a nonempty R) now just specifies a revision number R.
  42.   Formerly, it also reestablished the default behavior of releasing a lock and
  43.   removing the working file.  Now, only the bare -r option does this.
  44.  
  45.   With an empty extension, any appearance of a directory named `RCS'
  46.   in a pathname identifies the pathname as being that of an RCS file.
  47.   For example, `a/RCS/b/c' is now an RCS file with an empty extension.
  48.   Formerly, `RCS' had to be the last directory in the pathname.
  49.  
  50.   merge now takes up to three -L options, one for each input file.
  51.   Formerly, it took at most two -L options, for the 1st and 3rd input files.
  52.  
  53.   merge and rcsmerge now pass -A, -E, and -e options to the subsidiary diff3.
  54.   If diff3 supports -A, it is now the default instead of -E,
  55.   since it generates better conflict notifications.
  56.  
  57.   rlog's -d option by default now uses exclusive time ranges.
  58.   E.g. `rlog -d"<T"' now excludes revisions whose times equal T exactly.
  59.   Use `rlog -d"<=T"' to get the old behavior.
  60.  
  61.   The following new options are used by GNU Emacs 19's version control package:
  62.  
  63.     rcs's new -M option causes it to not send mail when you break somebody
  64.     else's lock.  This is not meant for casual use; see rcs(1).
  65.  
  66.     ci's new -i option causes an error if the RCS file already exists.
  67.     Similarly, -j causes an error if the RCS file does not already exist.
  68.  
  69.   The new keyword `Name' is supported; its value is the name, if any,
  70.   used to check out the revision.  E.g. `co -rN foo' causes foo's
  71.   $Name...$ keyword strings to end in `: N $'.
  72.  
  73.   The new -zZONE option causes an RCS command to output dates using ISO 8601
  74.   date format with ZONE as the time zone, and to use ZONE as the default time
  75.   zone for input.  Its most common use is the -zLT option, which causes RCS
  76.   to use local time externally.  You can also specify foreign time zones;
  77.   e.g. -z+0530 causes RCS to use India time (5 hours 30 minutes east of UTC).
  78.   This option does not affect RCS files themselves, which always use UTC;
  79.   it affects only output (e.g. rlog output, keyword expansion, diff -c times)
  80.   and interpretation of options (e.g. the -d option of ci, co, and rlog).
  81.   Bare -z restores the default behavior of UTC with no time zone indication,
  82.   and the traditional RCS date separator `/' instead of the ISO 8601 `-'.
  83.   RCSINIT may contain a -z option.  ci -k parses UTC offsets.
  84.  
  85.   The new -T option of ci, co, rcs, and rcsclean preserves the modification
  86.   time of the RCS file unless a revision is added or removed.
  87.   ci -T sets the RCS file's modification time to the new revision's time
  88.   if the former precedes the latter and there is a new revision;
  89.   otherwise, it preserves the RCS file's modification time.
  90.   Use this option with care, as it can confuse `make'; see ci(1).
  91.  
  92.   The new -N option of rlog omits symbolic names from the output.
  93.  
  94.   A revision number that starts with `.' is considered to be relative to
  95.   the default branch (normally the trunk).  A branch number followed by `.'
  96.   stands for the last revision on that branch.
  97.  
  98.   If someone else already holds the lock, rcs -l now asks whether you want
  99.   to break it, instead of immediately reporting an error.
  100.  
  101.   ci now always unlocks a revision like 3.5 if you check in a revision
  102.   like 3.5.2.1 that is the first of a new branch of that revision.
  103.   Formerly it was inconsistent.
  104.  
  105.   File names may now contain tab, newline, space, and '$'.
  106.   They are represented in keyword strings with \t, \n, \040, and \044.
  107.   \ in a file name is now represented by \\ in a keyword string.
  108.  
  109.   Identifiers may now start with a digit and (unless they are symbolic names)
  110.   may contain `.'.  This permits author names like `john.doe' and `4tran'.
  111.  
  112.   A bare -V option now prints the current version number.
  113.  
  114.   rcsdiff outputs more readable context diff headers if diff -L works.
  115.  
  116.   rcsdiff -rN -rN now suppresses needless checkout and comparison
  117.   of identical revisions.
  118.  
  119.   Error messages now contain the names of files to which they apply.
  120.  
  121.   $Log string `Revision' times now use the same format as other times.
  122.  
  123.  
  124. Features new to RCS version 5.6 include:
  125.  
  126.   Security holes have been plugged; setgid use is no longer supported.
  127.  
  128.   co can retrieve old revisions much more efficiently.
  129.   To generate the Nth youngest revision on the trunk,
  130.   the old method used up to N passes through copies of the working file;
  131.   the new method uses a piece table to generate the working file in one pass.
  132.  
  133.   When ci finds no changes in the working file,
  134.   it automatically reverts to the previous revision unless -f is given.
  135.  
  136.   RCS follows symbolic links to RCS files instead of breaking them,
  137.   and warns when it breaks hard links to RCS files.
  138.  
  139.   `$' stands for the revision number taken from working file keyword strings.
  140.   E.g. if F contains an Id keyword string,
  141.   `rcsdiff -r$ F' compares F to its checked-in revision, and
  142.   `rcs -nL:$ F' gives the symbolic name L to F's revision.
  143.  
  144.   co and ci's new -M option sets the modification time
  145.   of the working file to be that of the revision.
  146.   Without -M, ci now tries to avoid changing the working file's
  147.   modification time if its contents are unchanged.
  148.  
  149.   rcs's new -m option changes the log message of an old revision.
  150.  
  151.   RCS is portable to hosts that do not permit `,' in filenames.
  152.   (`,' is not part of the Posix portable filename character set.)
  153.   A new -x option specifies extensions other than `,v' for RCS files.
  154.   The Unix default is `-x,v/', so that the working file `w' corresponds
  155.   to the first file in the list `RCS/w,v', `w,v', `RCS/w' that works.
  156.   The non-Unix default is `-x', so that only `RCS/w' is tried.
  157.   Eventually, the Unix default should change to `-x/,v'
  158.   to encourage interoperability among all Posix hosts.
  159.  
  160.   A new RCSINIT environment variable specifies defaults for options like -x.
  161.  
  162.   The separator for revision ranges has been changed from `-' to `:', because
  163.   the range `A-B' is ambiguous if `A', `B' and `A-B' are all symbolic names.
  164.   E.g. the old `rlog -r1.5-1.7' is now `rlog -r1.5:1.7'; ditto for `rcs -o'.
  165.   For a while RCS will still support (but warn about) the old `-' separator.
  166.  
  167.   RCS manipulates its lock files using a method that is more reliable under NFS.
  168.  
  169.   Experimental support for MS-DOS and OS/2 is available as part of a separate
  170.   software distribution.
  171.  
  172.  
  173. Features new to RCS version 5 include:
  174.  
  175.   RCS can check in arbitrary files, not just text files, if diff -a works.
  176.   RCS can merge lines containing just a single `.' if diff3 -m works.
  177.   GNU diff supports the -a and -m options.
  178.  
  179.   RCS can now be used as a setuid program.
  180.   See ci(1) for how users can employ setuid copies of ci, co, and rcsclean.
  181.   Setuid privileges yield extra security if the effective user owns RCS files
  182.   and directories, and if only the effective user can write RCS directories.
  183.   RCS uses the real user for all accesses other than writing RCS directories.
  184.   As described in ci(1), there are three levels of setuid support.
  185.  
  186.     1.  Setuid works fully if the seteuid() system call lets any
  187.     process switch back and forth between real and effective users,
  188.     as specified in Posix 1003.1a Draft 5.
  189.  
  190.     2.  On hosts with saved setuids (a Posix 1003.1-1990 option) and without
  191.     a modern seteuid(), setuid works unless the real or effective user is root.
  192.  
  193.     3.  On hosts that lack both modern seteuid() and saved setuids,
  194.     setuid does not work, and RCS uses the effective user for all accesses;
  195.     formerly it was inconsistent.
  196.  
  197.   New options to co, rcsdiff, and rcsmerge give more flexibility to keyword
  198.   substitution.
  199.  
  200.     -kkv substitutes the default `$Keyword: value $' for keyword strings.
  201.     However, a locker's name is inserted only as a file is being locked,
  202.     i.e. by `ci -l' and `co -l'.  This is normally the default.
  203.  
  204.     -kkvl acts like -kkv, except that a locker's name is always inserted
  205.     if the given revision is currently locked.  This was the default in
  206.     version 4.  It is now the default only with when using rcsdiff to
  207.     compare a revision to a working file whose mode is that of a file
  208.     checked out for changes.
  209.  
  210.     -kk substitutes just `$Keyword$', which helps to ignore keyword values
  211.     when comparing revisions.
  212.  
  213.     -ko retrieves the old revision's keyword string, thus bypassing keyword
  214.     substitution.
  215.  
  216.     -kv retrieves just `value'.  This can ease the use of keyword values, but
  217.     it is dangerous because it causes RCS to lose track of where the keywords
  218.     are, so for safety the owner write permission of the working file is
  219.     turned off when -kv is used; to edit the file later, check it out again
  220.     without -kv.
  221.  
  222.   rcs -ko sets the default keyword substitution to be in the style of co -ko,
  223.   and similarly for the other -k options.  This can be useful with binary file
  224.   formats that cannot tolerate changing the lengths of keyword strings.
  225.   However it also renders a RCS file readable only by RCS version 5 or later.
  226.   Use rcs -kkv to restore the usual default substitution.
  227.  
  228.   RCS can now be used by development groups that span time zone boundaries.
  229.   All times are now displayed in UTC, and UTC is the default time zone.
  230.   To use local time with co -d, append ` LT' to the time.
  231.   When interchanging RCS files with sites running older versions of RCS,
  232.   time stamp discrepancies may prevent checkins; to work around this,
  233.   use `ci -d' with a time slightly in the future.
  234.  
  235.   Dates are now displayed using four-digit years, not two-digit years.
  236.   Years given in -d options must now have four digits.
  237.   This change is required for RCS to continue to work after 1999/12/31.
  238.   The form of dates in version 5 RCS files will not change until 2000/01/01,
  239.   so in the meantime RCS files can still be interchanged with sites
  240.   running older versions of RCS.  To make room for the longer dates,
  241.   rlog now outputs `lines: +A -D' instead of `lines added/del: A/D'.
  242.  
  243.   To help prevent diff programs that are broken or have run out of memory
  244.   from trashing an RCS file, ci now checks diff output more carefully.
  245.  
  246.   ci -k now handles the Log keyword, so that checking in a file
  247.   with -k does not normally alter the file's contents.
  248.  
  249.   RCS no longer outputs white space at the ends of lines
  250.   unless the original working file had it.
  251.   For consistency with other keywords,
  252.   a space, not a tab, is now output after `$Log:'.
  253.   Rlog now puts lockers and symbolic names on separate lines in the output
  254.   to avoid generating lines that are too long.
  255.   A similar fix has been made to lists in the RCS files themselves.
  256.  
  257.   RCS no longer outputs the string `Locker: ' when expanding Header or Id
  258.   keywords.  This saves space and reverts back to version 3 behavior.
  259.  
  260.   The default branch is not put into the RCS file unless it is nonempty.
  261.   Therefore, files generated by RCS version 5 can be read by RCS version 3
  262.   unless they use the default branch feature introduced in version 4.
  263.   This fixes a compatibility problem introduced by version 4.
  264.  
  265.   RCS can now emulate older versions of RCS; see `co -V'.
  266.   This may be useful to overcome compatibility problems
  267.   due to the above changes.
  268.  
  269.   Programs like Emacs can now interact with RCS commands via a pipe:
  270.   the new -I option causes ci, co, and rcs to run interactively,
  271.   even if standard input is not a terminal.
  272.   These commands now accept multiple inputs from stdin separated by `.' lines.
  273.  
  274.   ci now silently ignores the -t option if the RCS file already exists.
  275.   This simplifies some shell scripts and improves security in setuid sites.
  276.  
  277.   Descriptive text may be given directly in an argument of the form -t-string.
  278.  
  279.   The character set for symbolic names has been upgraded
  280.   from Ascii to ISO 8859.
  281.  
  282.   rcsdiff now passes through all options used by GNU diff;
  283.   this is a longer list than 4.3BSD diff.
  284.  
  285.   merge's new -L option gives tags for merge's overlap report lines.
  286.   This ability used to be present in a different, undocumented form;
  287.   the new form is chosen for compatibility with GNU diff3's -L option.
  288.  
  289.   rcsmerge and merge now have a -q option, just like their siblings do.
  290.  
  291.   RCS now attempts to ignore parts of an RCS file that look like they come
  292.   from a future version of RCS.
  293.  
  294.   When properly configured, RCS now strictly conforms with Posix 1003.1-1990.
  295.   RCS can still be compiled in non-Posix traditional Unix environments,
  296.   and can use common BSD and USG extensions to Posix.
  297.   RCS is a conforming Standard C program, and also compiles under traditional C.
  298.  
  299.   Arbitrary limits on internal table sizes have been removed.
  300.   The only limit now is the amount of memory available via malloc().
  301.  
  302.   File temporaries, lock files, signals, and system call return codes
  303.   are now handled more cleanly, portably, and quickly.
  304.   Some race conditions have been removed.
  305.  
  306.   A new compile-time option RCSPREFIX lets administrators avoid absolute path
  307.   names for subsidiary programs, trading speed for flexibility.
  308.  
  309.   The configuration procedure is now more automatic.
  310.  
  311.   Snooping has been removed.
  312.  
  313.  
  314. Version 4 was the first version distributed by FSF.
  315. Beside bug fixes, features new to RCS version 4 include:
  316.  
  317.   The notion of default branch has been added; see rcs -b.
  318.  
  319.  
  320. Version 3 was included in the 4.3BSD distribution.
  321.  
  322.  
  323. Here are some possible future changes for RCS:
  324.  
  325.   Bring back sccstorcs.
  326.  
  327.   Add an option to `rcsmerge' so that it can use an arbitrary program
  328.   to do the 3-way merge, instead of the default `merge'.
  329.  
  330.   Add format options for finer control over the output of ident and rlog.
  331.   E.g. there should be an easy way for rlog to output lines like
  332.   `src/main.c 2.4 wft', one for each locked revision.
  333.   rlog options should have three orthogonal types: selecting files,
  334.   selecting revisions, and selecting rlog format.
  335.  
  336.   Add format options for finer control over the output of keyword strings.
  337.   E.g. there should be some way to prepend @(#), and there should be some
  338.   way to change $ to some other character to disable further substitution.
  339.   These options should make the resulting files uneditable, like -kv.
  340.  
  341.   rlog -rM:N should work even if M and N have different numbers of fields,
  342.   so long as M is an ancestor of N or vice versa.
  343.  
  344.   rcs should evaluate options in order; this allows rcs -oS -nS.
  345.  
  346.   rcs should be able to fix minor mistakes in checkin dates and authors.
  347.  
  348.   Be able to redo your most recent checkin with minor changes.
  349.  
  350.   co -u shouldn't complain about a writable working file if it won't change
  351.   its contents.
  352.  
  353.   Configure the Makefile automatically, as well as conf.h.
  354.  
  355.   Add a new option to rcs that behaves like -o, but that doesn't lose the
  356.   nonempty log messages, but instead merges them with the next revision
  357.   if it exists, perhaps with a 1-line header containing author, date, etc.
  358.  
  359.   Add a `-' option to take the list of pathnames from standard input.
  360.   Perhaps the pathnames should be null-terminated, not newline-terminated,
  361.   so that pathnames that contain newlines are handled properly.
  362.  
  363.   Add general options so that rcsdiff and rcsmerge can pass arbitrary options
  364.   to its subsidiary co and diff processes.  E.g.
  365.  
  366.     -.OPTION to pass OPTION to the subsidiary `co'
  367.     -/OPTION to pass OPTION to the subsidiary `diff' (for rcsdiff only)
  368.  
  369.   For example:
  370.  
  371.     rcsdiff -.-d"1991/02/09 18:09" -.-sRel -/+unified -/-C -/5 -/-d foo.c
  372.  
  373.   invokes `co -d"1991/02/09 18:09" -sRel ...' and `diff +unified -C 5 -d ...'.
  374.   To pass an option to just one subsidiary `co', put the -. option
  375.   after the corresponding -r option.  For example:
  376.  
  377.     rcsmerge -r1.4 -.-ko -r1.8 -.-kkv foo.c
  378.  
  379.   passes `-ko' to the first subsidiary `co', and `-kkv' to the second one.
  380.  
  381.  
  382.   Permit multiple option-pathname pairs, e.g. co -r1.4 a -r1.5 b.
  383.  
  384.   Add options to allow arbitrary combinations of working file names
  385.   with RCS file names -- they shouldn't have to match.
  386.  
  387.   Add ways to specify the earliest revision, the most recent revision,
  388.   the earliest or latest revision on a particular branch, and
  389.   the parent or child of some other revision.
  390.  
  391.   If a user has multiple locks, perhaps ci should fall back on ci -k's
  392.   method to figure out which revision to use.
  393.  
  394.   Symbolic names need not refer to existing branches and revisions.
  395.   rcs(1)'s BUGS section says this is a bug.  Is it?  If so, it should be fixed.
  396.  
  397.   Add an option to rcs -o so that old log messages are not deleted if
  398.   the next undeleted revision exists, but are merely appended to the log
  399.   message of that revision.
  400.  
  401.   ci -k should be able to get keyword values from the first `$Log' entry.
  402.  
  403.   Add an option to rcsclean to clean directories recursively.
  404.  
  405.   Write an rcsck program that repairs corrupted RCS files,
  406.   much as fsck repairs corrupted file systems.
  407.   For example, it should remove stale lock files.
  408.  
  409.   Clean up the source code with a consistent indenting style.
  410.  
  411.   Update the date parser to use the more modern getdate.y by Bellovin,
  412.   Salz, and Berets, or the even more modern getdate by Moraes.  None of
  413.   these getdate implementations are as robust as RCS's old warhorse in
  414.   avoiding problems like arithmetic overflow, so they'll have to be
  415.   fixed first.
  416.  
  417.   Break up the code into a library so that it's easier to write new programs
  418.   that manipulate RCS files, and so that useless code is removed from the
  419.   existing programs.  For example, the rcs command contains unnecessary
  420.   keyword substitution baggage, and the merge command can be greatly pruned.
  421.  
  422.   Make it easier to use your favorite text editor to edit log messages,
  423.   etc. instead of having to type them in irretrievably at the terminal.
  424.  
  425.   Let the user specify a search path for default branches,
  426.   e.g. to use L as the default branch if it works, and M otherwise.
  427.   Let the user require that at least one entry in the default branch path works.
  428.   Let the user say that later entries in the default branch path are read only,
  429.   i.e. one cannot check in changes to them.
  430.   This should be an option settable by RCSINIT.
  431.  
  432.   Add a way for a user to see which revisions affected which lines.
  433.  
  434.   Have `rlog -nN F' print just the revision number that N translates to.
  435.   E.g. `rlog -nB. F' would print the highest revision on the branch B.
  436.   Use this to add an option -bB to rcsbranch, to freeze the named branch.
  437.   This should interact well with default branches.
  438.  
  439.   Add a co option that prints the revision number before each line,
  440.   as SCCS's `get -m' does.
  441.  
  442. The following projects require a change to RCS file format.
  443.  
  444.   Allow keyword expansion to be changed on a per-revision basis,
  445.   not on a per-file basis as now.  This would allow -ko to be used
  446.   on imported revisions, with the default -kkv otherwise.
  447.  
  448.   When two or more branches are merged, record all the ancestors
  449.   of the new revision.  The hard part of this is keeping track of all
  450.   the ancestors of a working file while it's checked out.
  451.  
  452.   Add loose locking, which is like non-strict but applies to all users,
  453.   not just the owner of the RCS file.
  454.  
  455.   Be able to store RCS files in compressed format.
  456.   Don't bother to use a .Z extension that would exceed file name length limits;
  457.   just look at the magic number.
  458.  
  459.   Add locker commentary, e.g. `co -l -m"checkout to fix merge bug" foo'
  460.   to tell others why you checked out `foo'.
  461.   Also record the time when the revision was locked,
  462.   and perhaps the working pathname (if applicable).
  463.  
  464.   Let the user mark an RCS revision as deleted; checking out such a revision
  465.   would result in no working file.  Similarly, using `co -d' with a date either
  466.   before the initial revision or after the file was marked deleted should
  467.   remove the working file.  For extra credit, extend the notion of `deleted' to
  468.   include `renamed'.  RCS should support arbitrary combinations of renaming and
  469.   deletion, e.g. renaming A to B and B to A, checking in new revisions to both
  470.   files, and then renaming them back.
  471.  
  472.   Be able to check in an entire directory structure into a single RCS file.
  473.  
  474.   Use a better scheme for locking revisions; the current scheme requires
  475.   changing the RCS file just to lock or unlock a revision.
  476.   The new scheme should coexist as well as possible with older versions of RCS,
  477.   and should avoid the rare NFS bugs mentioned in rcsedit.c.
  478.   E.g. if there's a reliable lockd running, RCS should use it
  479.   instead of relying on NFS.
  480.  
  481.   Add rcs options for changing keyword names, e.g. XConsortium instead of Id.
  482.  
  483.   Add a way to put only the interesting part of the path into the $Header
  484.   keyword expansion.
  485.  
  486.   Add a `$Description' keyword; but this may be tricky, since descriptions can
  487.   contain newlines and $s.
  488.  
  489.   Add a `$Copyright' keyword that expands to a copyright notice.
  490.  
  491.   Add frozen branches a la SCCS.  In general, be able to emulate all of
  492.   SCCS, so that an SCCS-to-RCS program can be practical.  For example,
  493.   there should be an equivalent to the SCCS prt command.
  494.  
  495.   Add support for distributed RCS, where widely separated
  496.   users cannot easily access each others' RCS files,
  497.   and must periodically distribute and reconcile new revisions.
  498.  
  499.   Be able to create empty branches.
  500.  
  501.   Be able to store just deltas from a read-only principal copy,
  502.   e.g. from source on CD-ROM.
  503.  
  504.   Improve RCS's method for storing binary files.
  505.   Although it is more efficient than SCCS's,
  506.   the diff algorithm is still line oriented,
  507.   and often generates long output for minor changes to an executable file.
  508.  
  509.   Add a new `-kb' expansion for binary files on non-Posix hosts
  510.   that distinguish between text and binary I/O.
  511.   The current `text_work_stdio' compile-time switch is too inflexible.
  512.   This fix either requires nonstandard primitives like DOS's setmode(),
  513.   or requires that `-kb' be specified on initial checkin and never changed.
  514.   From the user's point of view, it would be best if
  515.   RCS detected and handled binary files without human intervention,
  516.   switching expansion methods as needed from revision to revision.
  517.  
  518.   Allow RCS to determine automagically whether -ko or -kb should be the default
  519.   by inspecting the file's contents or name.  The magic should be optional
  520.   and user-programmable.
  521.  
  522.   Extend the grammar of RCS files so that keywords need not be in a fixed order.
  523.  
  524.   Internationalize messages; unfortunately, there's no common standard yet.
  525.   This requires a change in RCS file format because of the
  526.   `empty log message' and `checked in with -k' hacks inside RCS files.
  527.