The AC package
is an internal set of scripts for
managing the acedb source code. The Acedb code is under CVS
management. For ease of use and safety several scripts have been
written to control the cvs functions. The CVS system is only
accessible on the local system to users in the 'acedb' user-group. For
consistency reasons, users are being discouraged from using cvs
commands directly.
All AC commands have a command line argument <file(s)>. It allows to perform the same action on multiple files. There are various ways is to specify the filename and its subdirectory, e.g. :
aco w2/graphxt.c graph.h graphsubs.c
This will check out w2/graphxt.c wh/graph.h and w2/graphsubs.c. The subdirectory is optional. The script will first try to find the find the file in the current directory or look for it across all subdirectories (might take slightly longer).
aco
- checkout
aco <file(s)> checks out a file for editing.
First grabs the latest version from the repository, then registers
the user as an editor and gives permission to edit the files locally.
aci
- checkin
aci <file(s)> checks in a file to the repository after editing.
The user is prompted for log information about the nature of the changes.
The environment variable $CVSEDITOR
specifies an editor to be
used to enter the change-log text.
The modified user's copy is comitted to the repository and edit permissions
are removed form the user's working directory. Other users editing this
file at the same time are notified by mail about this action.
NOTE: Just in case the file was created in a DOS/Windows environment, all redundant PC-style control characters are removed prior to the "commit" action.
acu
- unedit
acu <file(s)> removes edit permissions on a file.
The user's local working copy is reverted back to the
latest repository version and his edit permissions are revoked.
Any modifications since checkout are therefor lost.
acg
- get latest
acg <file(s)> update/get new version of file from repository.
If the file already exists locally, the user's working copy is brought
up to the date with the repository version. The user is warned
if the file is being edited locally at the time.
If the file doesn't yet exist locally (another user has just recently created the file)
the subdirectory in which it is supposed to appear has to be specified.
Warnings are given if such file doesn't exist in the repository.
acr
- create
acr <file(s)> adds the new file to the repository.
The file is expected to already exist locally. A new repository
entry is committed for the file with a default log message saying
"initial revision"
.
The file is then set to read-only premissions locally. And from then
on, aco
has to be used to check out a editable copy
of this file.
NOTE: Just in case the file was created in a DOS/Windows environment, all redundant PC-style control characters are removed prior to the "commit" action.
acx
- remove
acx <file(s)> removes the file locally and from the repository.
The user is queried for safety, and after a positive answer
the file is removed in the user's working copy and then marked
deleted from the repository.
NOTE: The files doesn't realy disappear. All its old changelogs
will continue to reside in the so-called attic of the
repository, but it won't show up in the active copy.
acetree
will remove a local copy of a dead file
in another user's working copy to reflect that change throughout
all copies of the source tree.
acd
- diffacd <file(s)> reports the differences between the users local working copy of the file(s) and the repository version.
acm
- move/rename
amv <newpath> <file(s)> moves/renames the the file
This command behaves similarly to the UNIX command 'mv
', but
the new path is specified first. This is slightly unusual, but it
brings this command in line with all the others in term of the variable-length
<file(s)> parameter list.
If a file is to be renamed, only one filename is allowed in this parameter-list.
amv <wnew> file1.c w2/file2.c - finds which subdir file1.c is in and moves it to wnew, then moves w2/file2.c to wnew
amv <wnew/newfile.c> oldfile.c - finds the subdir of oldfile.c, then moves it to wnew and renames it. If no new directory is specified, oldfile.c is renamed within its present directory.
aclog
- logaclog -d"timeformat" <file> will report all log reports for this file during the timeformat. If no timeformat then all log reports are given.
aprs -d"<10/19/97" call.c
gives all log reports before 19th October 1997 for file call.c
acw
- set watch
acw <file> sets a watch on the files.
Watches will cause the system to send out an email to the
watcher if anything is being done about that
file (e.g. a file is being edited, unedited, checked in etc.)
Although it does introduce some kind of ownership
over a file it might be useful.
Any user who is trying to edit (check out) a watched
file will be informed of who is watching it.
Although the user is given the choice to abort the
attempt to edit, it doens't impede anyone's right to
edit a file anyway.
acwx
- remove watch
acx <file> removes the watch on the files.
This command will fail, if you are not currently watching the file.
In addition to the AC commands which operate on single files there is a set of commands, that operate on entire directories or even the entire tree.
All ACE commands have an optional parameter list :-
Use -a option as the <dir> parameter to include all system-defined directories in the operation.
By default, the list specified in the user-defined file $ACEDB_SRC/DIRECTORIES is used.
If no such user-defined default exists, the list in ~acedb/ALL_DIRECTORIES is used instead (as for the -a option)
acetree
- updateacetree [<dir(s)>] Updates user-copy of acedb-sourcetree from the CVS repository. Reports change-logs and gets new CVS master-versions. Lists currently checked out files.
aceinfo
- changelogaceinfo [<dir(s)>] reports any differences between your version of the code and the repository's. It will also list who currently has checked out any of those files.
acegrep
- source-code search
acegrep <searchword> [<dir(s)>] performs global
source-code search for
If only lower-case letters are used in the searchword, grep is
run with the -i flag (case-insensitivity). Upper-case letter
force a case-sensitive search (similar to the regular search in emacs).
NOTE: for this command the optional <dir(s)> list
starts with the second command line argument.
lists all files containing a main function over
all directories in the local tree (overriding the
personal DIRECTORIES list).
acewho
- who has what?
acewho [<searchword>] [<dir(s)>] - list the
editors of all files.
The check-out signatures of all files in the specified (or all)
directories are listed. Optionally the output list can be search for
a string or regex (passed on to grep internally).
NOTE: If command line arguments are specified, the first one
is takend to be the <searchword> parameter, if it isn't
a local directory name.
acewho w1
lists all files in w1/ that being edited.
acewho edgrif -a
lists files edited by edgrif across all local directories
(overriding the personal DIRECTORIES list).