- merge local changes
- provide reach-over infrastructure
This commit is contained in:
parent
04c6fc8e93
commit
fa28c6faa1
3
external/gpl2/rcs/Makefile
vendored
Normal file
3
external/gpl2/rcs/Makefile
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
SUBDIR = lib .WAIT bin
|
||||||
|
.include <bsd.subdir.mk>
|
12
external/gpl2/rcs/Makefile.inc
vendored
Normal file
12
external/gpl2/rcs/Makefile.inc
vendored
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
# $NetBSD: Makefile.inc,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
|
||||||
|
.include <bsd.own.mk>
|
||||||
|
|
||||||
|
BINDIR=/usr/bin
|
||||||
|
DIST=${NETBSDSRCDIR}/external/gpl2/rcs
|
||||||
|
IDIST=${DIST}/dist
|
||||||
|
|
||||||
|
PROGDPLIBS+= rcs ${DIST}/lib
|
||||||
|
CPPFLAGS+= -I${DIST}/include
|
||||||
|
|
||||||
|
.PATH: ${IDIST}/src ${IDIST}/man
|
3
external/gpl2/rcs/bin/Makefile
vendored
Normal file
3
external/gpl2/rcs/bin/Makefile
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
SUBDIR = ci co ident merge rcs rcsclean rcsdiff rcsfreeze rcsmerge rlog
|
||||||
|
.include <bsd.subdir.mk>
|
2
external/gpl2/rcs/bin/Makefile.inc
vendored
Normal file
2
external/gpl2/rcs/bin/Makefile.inc
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
# $NetBSD: Makefile.inc,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
.include "${.PARSEDIR}/../Makefile.inc"
|
5
external/gpl2/rcs/bin/ci/Makefile
vendored
Normal file
5
external/gpl2/rcs/bin/ci/Makefile
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
|
||||||
|
PROG= ci
|
||||||
|
|
||||||
|
.include <bsd.prog.mk>
|
7
external/gpl2/rcs/bin/co/Makefile
vendored
Normal file
7
external/gpl2/rcs/bin/co/Makefile
vendored
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
|
||||||
|
PROG= co
|
||||||
|
|
||||||
|
CWARNFLAGS.clang+= -Wno-format-extra-args
|
||||||
|
|
||||||
|
.include <bsd.prog.mk>
|
5
external/gpl2/rcs/bin/ident/Makefile
vendored
Normal file
5
external/gpl2/rcs/bin/ident/Makefile
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
|
||||||
|
PROG= ident
|
||||||
|
|
||||||
|
.include <bsd.prog.mk>
|
5
external/gpl2/rcs/bin/merge/Makefile
vendored
Normal file
5
external/gpl2/rcs/bin/merge/Makefile
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
|
||||||
|
PROG= merge
|
||||||
|
|
||||||
|
.include <bsd.prog.mk>
|
6
external/gpl2/rcs/bin/rcs/Makefile
vendored
Normal file
6
external/gpl2/rcs/bin/rcs/Makefile
vendored
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
|
||||||
|
PROG= rcs
|
||||||
|
MAN= rcs.1 rcsfile.5 rcsintro.1
|
||||||
|
|
||||||
|
.include <bsd.prog.mk>
|
5
external/gpl2/rcs/bin/rcsclean/Makefile
vendored
Normal file
5
external/gpl2/rcs/bin/rcsclean/Makefile
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
|
||||||
|
PROG= rcsclean
|
||||||
|
|
||||||
|
.include <bsd.prog.mk>
|
5
external/gpl2/rcs/bin/rcsdiff/Makefile
vendored
Normal file
5
external/gpl2/rcs/bin/rcsdiff/Makefile
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
|
||||||
|
PROG= rcsdiff
|
||||||
|
|
||||||
|
.include <bsd.prog.mk>
|
6
external/gpl2/rcs/bin/rcsfreeze/Makefile
vendored
Normal file
6
external/gpl2/rcs/bin/rcsfreeze/Makefile
vendored
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
|
||||||
|
MAN= rcsfreeze.1
|
||||||
|
SCRIPTS=rcsfreeze.sh
|
||||||
|
|
||||||
|
.include <bsd.prog.mk>
|
5
external/gpl2/rcs/bin/rcsmerge/Makefile
vendored
Normal file
5
external/gpl2/rcs/bin/rcsmerge/Makefile
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
|
||||||
|
PROG= rcsmerge
|
||||||
|
|
||||||
|
.include <bsd.prog.mk>
|
9
external/gpl2/rcs/bin/rlog/Makefile
vendored
Normal file
9
external/gpl2/rcs/bin/rlog/Makefile
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:39 christos Exp $
|
||||||
|
|
||||||
|
PROG= rlog
|
||||||
|
LINKS= ${BINDIR}/rlog ${BINDIR}/rcslog
|
||||||
|
MLINKS= rlog.1 rcslog.1
|
||||||
|
|
||||||
|
CWARNFLAGS.clang+= -Wno-string-plus-int
|
||||||
|
|
||||||
|
.include <bsd.prog.mk>
|
10
external/gpl2/rcs/dist/man/ci.1
vendored
10
external/gpl2/rcs/dist/man/ci.1
vendored
@ -1,4 +1,4 @@
|
|||||||
.\" $NetBSD: ci.1,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $
|
.\" $NetBSD: ci.1,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\"
|
.\"
|
||||||
.de Id
|
.de Id
|
||||||
.ds Rv \\$3
|
.ds Rv \\$3
|
||||||
@ -483,7 +483,7 @@ The default for
|
|||||||
.IR suffixes
|
.IR suffixes
|
||||||
is installation-dependent; normally it is
|
is installation-dependent; normally it is
|
||||||
.B ,v/
|
.B ,v/
|
||||||
for hosts like Unix that permit commas in filenames,
|
for hosts like UNIX that permit commas in filenames,
|
||||||
and is empty (i.e. just the empty suffix) for other hosts.
|
and is empty (i.e. just the empty suffix) for other hosts.
|
||||||
.TP
|
.TP
|
||||||
.BI \-z zone
|
.BI \-z zone
|
||||||
@ -708,14 +708,14 @@ Check that the host supports \*r setuid use.
|
|||||||
Consult a trustworthy expert if there are any doubts.
|
Consult a trustworthy expert if there are any doubts.
|
||||||
It is best if the
|
It is best if the
|
||||||
.B seteuid
|
.B seteuid
|
||||||
system call works as described in Posix 1003.1a Draft 5,
|
system call works as described in POSIX 1003.1a Draft 5,
|
||||||
because \*r can switch back and forth easily
|
because \*r can switch back and forth easily
|
||||||
between real and effective users, even if the real user is
|
between real and effective users, even if the real user is
|
||||||
.BR root .
|
.BR root .
|
||||||
If not, the second best is if the
|
If not, the second best is if the
|
||||||
.B setuid
|
.B setuid
|
||||||
system call supports saved setuid
|
system call supports saved setuid
|
||||||
(the {\s-1_POSIX_SAVED_IDS\s0} behavior of Posix 1003.1-1990);
|
(the {\s-1_POSIX_SAVED_IDS\s0} behavior of POSIX 1003.1-1990);
|
||||||
this fails only if the real or effective user is
|
this fails only if the real or effective user is
|
||||||
.BR root .
|
.BR root .
|
||||||
If \*r detects any failure in setuid, it quits immediately.
|
If \*r detects any failure in setuid, it quits immediately.
|
||||||
@ -895,7 +895,7 @@ rcsintro(1), rcsmerge(1), rlog(1), setuid(2), rcsfile(5)
|
|||||||
.br
|
.br
|
||||||
Walter F. Tichy,
|
Walter F. Tichy,
|
||||||
\*r\*-A System for Version Control,
|
\*r\*-A System for Version Control,
|
||||||
.I "Software\*-Practice & Experience"
|
.I "Software\*-Practice \*[Am] Experience"
|
||||||
.BR 15 ,
|
.BR 15 ,
|
||||||
7 (July 1985), 637-654.
|
7 (July 1985), 637-654.
|
||||||
.br
|
.br
|
||||||
|
12
external/gpl2/rcs/dist/man/co.1
vendored
12
external/gpl2/rcs/dist/man/co.1
vendored
@ -1,4 +1,4 @@
|
|||||||
.\" $NetBSD: co.1,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $
|
.\" $NetBSD: co.1,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\"
|
.\"
|
||||||
.de Id
|
.de Id
|
||||||
.ds Rv \\$3
|
.ds Rv \\$3
|
||||||
@ -36,7 +36,7 @@ fails if the revision to be checked out is currently locked by another user.
|
|||||||
Checkout with locking also requires the caller to be on the access list of
|
Checkout with locking also requires the caller to be on the access list of
|
||||||
the \*r file, unless he is the owner of the
|
the \*r file, unless he is the owner of the
|
||||||
file or the superuser, or the access list is empty.
|
file or the superuser, or the access list is empty.
|
||||||
Checkout without locking is not subject to accesslist restrictions, and is
|
Checkout without locking is not subject to access list restrictions, and is
|
||||||
not affected by the presence of locks.
|
not affected by the presence of locks.
|
||||||
.PP
|
.PP
|
||||||
A revision is selected by options for revision or branch number,
|
A revision is selected by options for revision or branch number,
|
||||||
@ -217,7 +217,7 @@ Generate a binary image of the old keyword string.
|
|||||||
This acts like
|
This acts like
|
||||||
.BR \-ko ,
|
.BR \-ko ,
|
||||||
except it performs all working file input and output in binary mode.
|
except it performs all working file input and output in binary mode.
|
||||||
This makes little difference on Posix and Unix hosts,
|
This makes little difference on POSIX and UNIX hosts,
|
||||||
but on DOS-like hosts one should use
|
but on DOS-like hosts one should use
|
||||||
.B "rcs\ \-i\ \-kb"
|
.B "rcs\ \-i\ \-kb"
|
||||||
to initialize an \*r file intended to be used for binary files.
|
to initialize an \*r file intended to be used for binary files.
|
||||||
@ -397,7 +397,7 @@ and
|
|||||||
are the ends of two branches that have
|
are the ends of two branches that have
|
||||||
.I rev2
|
.I rev2
|
||||||
as a common ancestor. If
|
as a common ancestor. If
|
||||||
.IR rev1 < rev2 < rev3
|
.IR rev1 \*[Lt] rev2 \*[Lt] rev3
|
||||||
on the same branch,
|
on the same branch,
|
||||||
joining generates a new revision which is like
|
joining generates a new revision which is like
|
||||||
.I rev3,
|
.I rev3,
|
||||||
@ -724,7 +724,7 @@ rcsfile(5)
|
|||||||
.br
|
.br
|
||||||
Walter F. Tichy,
|
Walter F. Tichy,
|
||||||
\*r\*-A System for Version Control,
|
\*r\*-A System for Version Control,
|
||||||
.I "Software\*-Practice & Experience"
|
.I "Software\*-Practice \*[Am] Experience"
|
||||||
.BR 15 ,
|
.BR 15 ,
|
||||||
7 (July 1985), 637-654.
|
7 (July 1985), 637-654.
|
||||||
.SH LIMITS
|
.SH LIMITS
|
||||||
@ -733,6 +733,6 @@ Links to the \*r and working files are not preserved.
|
|||||||
There is no way to selectively suppress the expansion of keywords, except
|
There is no way to selectively suppress the expansion of keywords, except
|
||||||
by writing them differently. In nroff and troff, this is done by embedding the
|
by writing them differently. In nroff and troff, this is done by embedding the
|
||||||
null-character
|
null-character
|
||||||
.B \e&
|
.B \e\*[Am]
|
||||||
into the keyword.
|
into the keyword.
|
||||||
.br
|
.br
|
||||||
|
6
external/gpl2/rcs/dist/man/ident.1
vendored
6
external/gpl2/rcs/dist/man/ident.1
vendored
@ -1,4 +1,4 @@
|
|||||||
.\" $NetBSD: ident.1,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $
|
.\" $NetBSD: ident.1,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\"
|
.\"
|
||||||
.de Id
|
.de Id
|
||||||
.ds Rv \\$3
|
.ds Rv \\$3
|
||||||
@ -48,7 +48,7 @@ For example, if the C program in
|
|||||||
contains
|
contains
|
||||||
.IP
|
.IP
|
||||||
.ft 3
|
.ft 3
|
||||||
#include <stdio.h>
|
#include \*[Lt]stdio.h\*[Gt]
|
||||||
.br
|
.br
|
||||||
static char const rcsid[] =
|
static char const rcsid[] =
|
||||||
.br
|
.br
|
||||||
@ -179,6 +179,6 @@ rcsfile(5)
|
|||||||
.br
|
.br
|
||||||
Walter F. Tichy,
|
Walter F. Tichy,
|
||||||
\*r\*-A System for Version Control,
|
\*r\*-A System for Version Control,
|
||||||
.I "Software\*-Practice & Experience"
|
.I "Software\*-Practice \*[Am] Experience"
|
||||||
.BR 15 ,
|
.BR 15 ,
|
||||||
7 (July 1985), 637-654.
|
7 (July 1985), 637-654.
|
||||||
|
13
external/gpl2/rcs/dist/man/merge.1
vendored
13
external/gpl2/rcs/dist/man/merge.1
vendored
@ -1,4 +1,4 @@
|
|||||||
.\" $NetBSD: merge.1,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $
|
.\" $NetBSD: merge.1,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\"
|
.\"
|
||||||
.de Id
|
.de Id
|
||||||
.ds Rv \\$3
|
.ds Rv \\$3
|
||||||
@ -45,19 +45,19 @@ have changes in a common segment of lines.
|
|||||||
If a conflict is found,
|
If a conflict is found,
|
||||||
.B merge
|
.B merge
|
||||||
normally outputs a warning and brackets the conflict with
|
normally outputs a warning and brackets the conflict with
|
||||||
.B <<<<<<<
|
.B \*[Lt]\*[Lt]\*[Lt]\*[Lt]\*[Lt]\*[Lt]\*[Lt]
|
||||||
and
|
and
|
||||||
.B >>>>>>>
|
.B \*[Gt]\*[Gt]\*[Gt]\*[Gt]\*[Gt]\*[Gt]\*[Gt]
|
||||||
lines.
|
lines.
|
||||||
A typical conflict will look like this:
|
A typical conflict will look like this:
|
||||||
.LP
|
.LP
|
||||||
.RS
|
.RS
|
||||||
.nf
|
.nf
|
||||||
.BI <<<<<<< " file A"
|
.BI \*[Lt]\*[Lt]\*[Lt]\*[Lt]\*[Lt]\*[Lt]\*[Lt] " file A"
|
||||||
.I "lines in file A"
|
.I "lines in file A"
|
||||||
.B "======="
|
.B "======="
|
||||||
.I "lines in file B"
|
.I "lines in file B"
|
||||||
.BI >>>>>>> " file B"
|
.BI \*[Gt]\*[Gt]\*[Gt]\*[Gt]\*[Gt]\*[Gt]\*[Gt] " file B"
|
||||||
.RE
|
.RE
|
||||||
.fi
|
.fi
|
||||||
.LP
|
.LP
|
||||||
@ -116,8 +116,9 @@ Send results to standard output instead of overwriting
|
|||||||
.TP
|
.TP
|
||||||
.BI \-q
|
.BI \-q
|
||||||
Quiet; do not warn about conflicts.
|
Quiet; do not warn about conflicts.
|
||||||
|
.TP
|
||||||
.BI \-V
|
.BI \-V
|
||||||
Print \*r's version number.
|
Print version number.
|
||||||
.SH DIAGNOSTICS
|
.SH DIAGNOSTICS
|
||||||
Exit status is 0 for no conflicts, 1 for some conflicts, 2 for trouble.
|
Exit status is 0 for no conflicts, 1 for some conflicts, 2 for trouble.
|
||||||
.SH IDENTIFICATION
|
.SH IDENTIFICATION
|
||||||
|
90
external/gpl2/rcs/dist/man/rcs.1
vendored
90
external/gpl2/rcs/dist/man/rcs.1
vendored
@ -1,24 +1,6 @@
|
|||||||
.\" $NetBSD: rcs.1,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $
|
.\" $NetBSD: rcs.1,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\"
|
.\"
|
||||||
.de Id
|
.TH RCS 1 "" GNU
|
||||||
.ds Rv \\$3
|
|
||||||
.ds Dt \\$4
|
|
||||||
..
|
|
||||||
.Id Id: rcs.1,v 5.13 1995/06/05 08:28:35 eggert Exp
|
|
||||||
.ds r \&\s-1RCS\s0
|
|
||||||
.if n .ds - \%--
|
|
||||||
.if t .ds - \(em
|
|
||||||
.if !\n(.g \{\
|
|
||||||
. if !\w|\*(lq| \{\
|
|
||||||
. ds lq ``
|
|
||||||
. if \w'\(lq' .ds lq "\(lq
|
|
||||||
. \}
|
|
||||||
. if !\w|\*(rq| \{\
|
|
||||||
. ds rq ''
|
|
||||||
. if \w'\(rq' .ds rq "\(rq
|
|
||||||
. \}
|
|
||||||
.\}
|
|
||||||
.TH RCS 1 \*(Dt GNU
|
|
||||||
.SH NAME
|
.SH NAME
|
||||||
rcs \- change RCS file attributes
|
rcs \- change RCS file attributes
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
@ -26,8 +8,8 @@ rcs \- change RCS file attributes
|
|||||||
.IR "options file " .\|.\|.
|
.IR "options file " .\|.\|.
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
.B rcs
|
.B rcs
|
||||||
creates new \*r files or changes attributes of existing ones.
|
creates new RCS files or changes attributes of existing ones.
|
||||||
An \*r file contains multiple revisions of text,
|
An RCS file contains multiple revisions of text,
|
||||||
an access list, a change log,
|
an access list, a change log,
|
||||||
descriptive text,
|
descriptive text,
|
||||||
and some control attributes.
|
and some control attributes.
|
||||||
@ -40,7 +22,7 @@ the
|
|||||||
.B \-i
|
.B \-i
|
||||||
option is present.
|
option is present.
|
||||||
.PP
|
.PP
|
||||||
Pathnames matching an \*r suffix denote \*r files;
|
Pathnames matching an RCS suffix denote RCS files;
|
||||||
all others denote working files.
|
all others denote working files.
|
||||||
Names are paired as explained in
|
Names are paired as explained in
|
||||||
.BR ci (1).
|
.BR ci (1).
|
||||||
@ -49,28 +31,28 @@ Revision numbers use the syntax described in
|
|||||||
.SH OPTIONS
|
.SH OPTIONS
|
||||||
.TP
|
.TP
|
||||||
.B \-i
|
.B \-i
|
||||||
Create and initialize a new \*r file, but do not deposit any revision.
|
Create and initialize a new RCS file, but do not deposit any revision.
|
||||||
If the \*r file has no path prefix, try to place it
|
If the RCS file has no path prefix, try to place it
|
||||||
first into the subdirectory
|
first into the subdirectory
|
||||||
.BR ./RCS ,
|
.BR ./RCS ,
|
||||||
and then into the current directory.
|
and then into the current directory.
|
||||||
If the \*r file
|
If the RCS file
|
||||||
already exists, print an error message.
|
already exists, print an error message.
|
||||||
.TP
|
.TP
|
||||||
.BI \-a "logins"
|
.BI \-a "logins"
|
||||||
Append the login names appearing in the comma-separated list
|
Append the login names appearing in the comma-separated list
|
||||||
.I logins
|
.I logins
|
||||||
to the access list of the \*r file.
|
to the access list of the RCS file.
|
||||||
.TP
|
.TP
|
||||||
.BI \-A "oldfile"
|
.BI \-A "oldfile"
|
||||||
Append the access list of
|
Append the access list of
|
||||||
.I oldfile
|
.I oldfile
|
||||||
to the access list of the \*r file.
|
to the access list of the RCS file.
|
||||||
.TP
|
.TP
|
||||||
.BR \-e [\f2logins\fP]
|
.BR \-e [\f2logins\fP]
|
||||||
Erase the login names appearing in the comma-separated list
|
Erase the login names appearing in the comma-separated list
|
||||||
.I logins
|
.I logins
|
||||||
from the access list of the \*r file.
|
from the access list of the RCS file.
|
||||||
If
|
If
|
||||||
.I logins
|
.I logins
|
||||||
is omitted, erase the entire access list.
|
is omitted, erase the entire access list.
|
||||||
@ -95,14 +77,14 @@ without
|
|||||||
guesses the comment leader from the suffix of the working filename.
|
guesses the comment leader from the suffix of the working filename.
|
||||||
.RS
|
.RS
|
||||||
.PP
|
.PP
|
||||||
This option is obsolescent, since \*r normally uses the preceding
|
This option is obsolescent, since RCS normally uses the preceding
|
||||||
.B $\&Log$
|
.B $\&Log$
|
||||||
line's prefix when inserting log lines during checkout (see
|
line's prefix when inserting log lines during checkout (see
|
||||||
.BR co (1)).
|
.BR co (1)).
|
||||||
However, older versions of \*r use the comment leader instead of the
|
However, older versions of RCS use the comment leader instead of the
|
||||||
.B $\&Log$
|
.B $\&Log$
|
||||||
line's prefix, so
|
line's prefix, so
|
||||||
if you plan to access a file with both old and new versions of \*r,
|
if you plan to access a file with both old and new versions of RCS,
|
||||||
make sure its comment leader matches its
|
make sure its comment leader matches its
|
||||||
.B $\&Log$
|
.B $\&Log$
|
||||||
line prefix.
|
line prefix.
|
||||||
@ -162,7 +144,7 @@ itself.
|
|||||||
Set locking to
|
Set locking to
|
||||||
.IR strict .
|
.IR strict .
|
||||||
Strict locking means that the owner
|
Strict locking means that the owner
|
||||||
of an \*r file is not exempt from locking for checkin.
|
of an RCS file is not exempt from locking for checkin.
|
||||||
This option should be used for files that are shared.
|
This option should be used for files that are shared.
|
||||||
.TP
|
.TP
|
||||||
.B \-U
|
.B \-U
|
||||||
@ -219,7 +201,7 @@ For example,
|
|||||||
.BI "rcs\ \-n" name ":\ RCS/*"
|
.BI "rcs\ \-n" name ":\ RCS/*"
|
||||||
associates
|
associates
|
||||||
.I name
|
.I name
|
||||||
with the current latest revision of all the named \*r files;
|
with the current latest revision of all the named RCS files;
|
||||||
this contrasts with
|
this contrasts with
|
||||||
.BI "rcs\ \-n" name ":$\ RCS/*"
|
.BI "rcs\ \-n" name ":$\ RCS/*"
|
||||||
which associates
|
which associates
|
||||||
@ -297,7 +279,7 @@ sets the state of a revision to
|
|||||||
.BR \-t [\f2file\fP]
|
.BR \-t [\f2file\fP]
|
||||||
Write descriptive text from the contents of the named
|
Write descriptive text from the contents of the named
|
||||||
.I file
|
.I file
|
||||||
into the \*r file, deleting the existing text.
|
into the RCS file, deleting the existing text.
|
||||||
The
|
The
|
||||||
.IR file
|
.IR file
|
||||||
pathname cannot begin with
|
pathname cannot begin with
|
||||||
@ -320,23 +302,23 @@ is not given.
|
|||||||
.BI \-t\- string
|
.BI \-t\- string
|
||||||
Write descriptive text from the
|
Write descriptive text from the
|
||||||
.I string
|
.I string
|
||||||
into the \*r file, deleting the existing text.
|
into the RCS file, deleting the existing text.
|
||||||
.TP
|
.TP
|
||||||
.B \-T
|
.B \-T
|
||||||
Preserve the modification time on the \*r file
|
Preserve the modification time on the RCS file
|
||||||
unless a revision is removed.
|
unless a revision is removed.
|
||||||
This option can suppress extensive recompilation caused by a
|
This option can suppress extensive recompilation caused by a
|
||||||
.BR make (1)
|
.BR make (1)
|
||||||
dependency of some copy of the working file on the \*r file.
|
dependency of some copy of the working file on the RCS file.
|
||||||
Use this option with care; it can suppress recompilation even when it is needed,
|
Use this option with care; it can suppress recompilation even when it is needed,
|
||||||
i.e. when a change to the \*r file
|
i.e. when a change to the RCS file
|
||||||
would mean a change to keyword strings in the working file.
|
would mean a change to keyword strings in the working file.
|
||||||
.TP
|
.TP
|
||||||
.BI \-V
|
.BI \-V
|
||||||
Print \*r's version number.
|
Print RCS's version number.
|
||||||
.TP
|
.TP
|
||||||
.BI \-V n
|
.BI \-V n
|
||||||
Emulate \*r version
|
Emulate RCS version
|
||||||
.IR n .
|
.IR n .
|
||||||
See
|
See
|
||||||
.BR co (1)
|
.BR co (1)
|
||||||
@ -345,7 +327,7 @@ for details.
|
|||||||
.BI \-x "suffixes"
|
.BI \-x "suffixes"
|
||||||
Use
|
Use
|
||||||
.I suffixes
|
.I suffixes
|
||||||
to characterize \*r files.
|
to characterize RCS files.
|
||||||
See
|
See
|
||||||
.BR ci (1)
|
.BR ci (1)
|
||||||
for details.
|
for details.
|
||||||
@ -355,7 +337,7 @@ Use
|
|||||||
.I zone
|
.I zone
|
||||||
as the default time zone.
|
as the default time zone.
|
||||||
This option has no effect;
|
This option has no effect;
|
||||||
it is present for compatibility with other \*r commands.
|
it is present for compatibility with other RCS commands.
|
||||||
.PP
|
.PP
|
||||||
At least one explicit option must be given,
|
At least one explicit option must be given,
|
||||||
to ensure compatibility with future planned extensions
|
to ensure compatibility with future planned extensions
|
||||||
@ -365,26 +347,26 @@ command.
|
|||||||
.SH COMPATIBILITY
|
.SH COMPATIBILITY
|
||||||
The
|
The
|
||||||
.BI \-b rev
|
.BI \-b rev
|
||||||
option generates an \*r file that cannot be parsed by \*r version 3 or earlier.
|
option generates an RCS file that cannot be parsed by RCS version 3 or earlier.
|
||||||
.PP
|
.PP
|
||||||
The
|
The
|
||||||
.BI \-k subst
|
.BI \-k subst
|
||||||
options (except
|
options (except
|
||||||
.BR \-kkv )
|
.BR \-kkv )
|
||||||
generate an \*r file that cannot be parsed by \*r version 4 or earlier.
|
generate an RCS file that cannot be parsed by RCS version 4 or earlier.
|
||||||
.PP
|
.PP
|
||||||
Use
|
Use
|
||||||
.BI "rcs \-V" n
|
.BI "rcs \-V" n
|
||||||
to make an \*r file acceptable to \*r version
|
to make an RCS file acceptable to RCS version
|
||||||
.I n
|
.I n
|
||||||
by discarding information that would confuse version
|
by discarding information that would confuse version
|
||||||
.IR n .
|
.IR n .
|
||||||
.PP
|
.PP
|
||||||
\*r version 5.5 and earlier does not support the
|
RCS version 5.5 and earlier does not support the
|
||||||
.B \-x
|
.B \-x
|
||||||
option, and requires a
|
option, and requires a
|
||||||
.B ,v
|
.B ,v
|
||||||
suffix on an \*r pathname.
|
suffix on an RCS pathname.
|
||||||
.SH FILES
|
.SH FILES
|
||||||
.B rcs
|
.B rcs
|
||||||
accesses files much as
|
accesses files much as
|
||||||
@ -403,7 +385,7 @@ See
|
|||||||
.BR ci (1)
|
.BR ci (1)
|
||||||
for details.
|
for details.
|
||||||
.SH DIAGNOSTICS
|
.SH DIAGNOSTICS
|
||||||
The \*r pathname and the revisions outdated are written to
|
The RCS pathname and the revisions outdated are written to
|
||||||
the diagnostic output.
|
the diagnostic output.
|
||||||
The exit status is zero if and only if all operations were successful.
|
The exit status is zero if and only if all operations were successful.
|
||||||
.SH IDENTIFICATION
|
.SH IDENTIFICATION
|
||||||
@ -419,14 +401,14 @@ rcsintro(1), co(1), ci(1), ident(1), rcsclean(1), rcsdiff(1),
|
|||||||
rcsmerge(1), rlog(1), rcsfile(5)
|
rcsmerge(1), rlog(1), rcsfile(5)
|
||||||
.br
|
.br
|
||||||
Walter F. Tichy,
|
Walter F. Tichy,
|
||||||
\*r\*-A System for Version Control,
|
RCS\(emA System for Version Control,
|
||||||
.I "Software\*-Practice & Experience"
|
.I "Software\(emPractice \*[Am] Experience"
|
||||||
.BR 15 ,
|
.BR 15 ,
|
||||||
7 (July 1985), 637-654.
|
7 (July 1985), 637-654.
|
||||||
.SH BUGS
|
.SH BUGS
|
||||||
A catastrophe (e.g. a system crash) can cause \*r to leave behind
|
A catastrophe (e.g. a system crash) can cause RCS to leave behind
|
||||||
a semaphore file that causes later invocations of \*r to claim
|
a semaphore file that causes later invocations of RCS to claim
|
||||||
that the \*r file is in use.
|
that the RCS file is in use.
|
||||||
To fix this, remove the semaphore file.
|
To fix this, remove the semaphore file.
|
||||||
A semaphore file's name typically begins with
|
A semaphore file's name typically begins with
|
||||||
.B ,
|
.B ,
|
||||||
|
4
external/gpl2/rcs/dist/man/rcsclean.1
vendored
4
external/gpl2/rcs/dist/man/rcsclean.1
vendored
@ -1,4 +1,4 @@
|
|||||||
.\" $NetBSD: rcsclean.1,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $
|
.\" $NetBSD: rcsclean.1,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\"
|
.\"
|
||||||
.de Id
|
.de Id
|
||||||
.ds Rv \\$3
|
.ds Rv \\$3
|
||||||
@ -194,7 +194,7 @@ rcsfile(5)
|
|||||||
.br
|
.br
|
||||||
Walter F. Tichy,
|
Walter F. Tichy,
|
||||||
\*r\*-A System for Version Control,
|
\*r\*-A System for Version Control,
|
||||||
.I "Software\*-Practice & Experience"
|
.I "Software\*-Practice \*[Am] Experience"
|
||||||
.BR 15 ,
|
.BR 15 ,
|
||||||
7 (July 1985), 637-654.
|
7 (July 1985), 637-654.
|
||||||
.SH BUGS
|
.SH BUGS
|
||||||
|
4
external/gpl2/rcs/dist/man/rcsdiff.1
vendored
4
external/gpl2/rcs/dist/man/rcsdiff.1
vendored
@ -1,4 +1,4 @@
|
|||||||
.\" $NetBSD: rcsdiff.1,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $
|
.\" $NetBSD: rcsdiff.1,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\"
|
.\"
|
||||||
.de Id
|
.de Id
|
||||||
.ds Rv \\$3
|
.ds Rv \\$3
|
||||||
@ -154,7 +154,7 @@ ci(1), co(1), diff(1), ident(1), rcs(1), rcsintro(1), rcsmerge(1), rlog(1)
|
|||||||
.br
|
.br
|
||||||
Walter F. Tichy,
|
Walter F. Tichy,
|
||||||
\*r\*-A System for Version Control,
|
\*r\*-A System for Version Control,
|
||||||
.I "Software\*-Practice & Experience"
|
.I "Software\*-Practice \*[Am] Experience"
|
||||||
.BR 15 ,
|
.BR 15 ,
|
||||||
7 (July 1985), 637-654.
|
7 (July 1985), 637-654.
|
||||||
.br
|
.br
|
||||||
|
6
external/gpl2/rcs/dist/man/rcsfile.5
vendored
6
external/gpl2/rcs/dist/man/rcsfile.5
vendored
@ -1,4 +1,4 @@
|
|||||||
.\" $NetBSD: rcsfile.5,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $
|
.\" $NetBSD: rcsfile.5,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\"
|
.\"
|
||||||
.lf 1 ./rcsfile.5in
|
.lf 1 ./rcsfile.5in
|
||||||
.\" Set p to 1 if your formatter can handle pic output.
|
.\" Set p to 1 if your formatter can handle pic output.
|
||||||
@ -163,7 +163,7 @@ All
|
|||||||
nodes whose numbers consist of
|
nodes whose numbers consist of
|
||||||
.RI 2 n
|
.RI 2 n
|
||||||
fields
|
fields
|
||||||
.RI ( n \(>=2)
|
.RI ( n \*[Ge]2)
|
||||||
(e.g., 3.1.1.1, 2.1.2.2, etc.)
|
(e.g., 3.1.1.1, 2.1.2.2, etc.)
|
||||||
are linked as follows.
|
are linked as follows.
|
||||||
All nodes whose first
|
All nodes whose first
|
||||||
@ -423,6 +423,6 @@ rcsmerge(1), rlog(1)
|
|||||||
.br
|
.br
|
||||||
Walter F. Tichy,
|
Walter F. Tichy,
|
||||||
\*r\*-A System for Version Control,
|
\*r\*-A System for Version Control,
|
||||||
.I "Software\*-Practice & Experience"
|
.I "Software\*-Practice \*[Am] Experience"
|
||||||
.BR 15 ,
|
.BR 15 ,
|
||||||
7 (July 1985), 637-654.
|
7 (July 1985), 637-654.
|
||||||
|
2
external/gpl2/rcs/dist/man/rcsfreeze.1
vendored
2
external/gpl2/rcs/dist/man/rcsfreeze.1
vendored
@ -1,4 +1,4 @@
|
|||||||
.\" $NetBSD: rcsfreeze.1,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $
|
.\" $NetBSD: rcsfreeze.1,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\"
|
.\"
|
||||||
.de Id
|
.de Id
|
||||||
.ds Rv \\$3
|
.ds Rv \\$3
|
||||||
|
89
external/gpl2/rcs/dist/man/rcsintro.1
vendored
89
external/gpl2/rcs/dist/man/rcsintro.1
vendored
@ -1,34 +1,13 @@
|
|||||||
.\" $NetBSD: rcsintro.1,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $
|
.\" $NetBSD: rcsintro.1,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\"
|
.\"
|
||||||
.de Id
|
.TH RCSINTRO 1 "" GNU
|
||||||
.ds Rv \\$3
|
|
||||||
.ds Dt \\$4
|
|
||||||
..
|
|
||||||
.Id Id: rcsintro.1,v 5.3 1993/11/03 17:42:27 eggert Exp
|
|
||||||
.ds r \&\s-1RCS\s0
|
|
||||||
.if n .ds - \%--
|
|
||||||
.if t .ds - \(em
|
|
||||||
.if !\n(.g \{\
|
|
||||||
. if !\w|\*(lq| \{\
|
|
||||||
. ds lq ``
|
|
||||||
. if \w'\(lq' .ds lq "\(lq
|
|
||||||
. \}
|
|
||||||
. if !\w|\*(rq| \{\
|
|
||||||
. ds rq ''
|
|
||||||
. if \w'\(rq' .ds rq "\(rq
|
|
||||||
. \}
|
|
||||||
.\}
|
|
||||||
.am SS
|
|
||||||
.LP
|
|
||||||
..
|
|
||||||
.TH RCSINTRO 1 \*(Dt GNU
|
|
||||||
.SH NAME
|
.SH NAME
|
||||||
rcsintro \- introduction to RCS commands
|
rcsintro \- introduction to RCS commands
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
The Revision Control System (\*r) manages multiple revisions of files.
|
|
||||||
\*r automates the storing, retrieval, logging, identification, and merging
|
|
||||||
of revisions. \*r is useful for text that is revised frequently, for example
|
|
||||||
programs, documentation, graphics, papers, and form letters.
|
programs, documentation, graphics, papers, and form letters.
|
||||||
|
The Revision Control System (RCS) manages multiple revisions of files.
|
||||||
|
RCS automates the storing, retrieval, logging, identification, and merging
|
||||||
|
of revisions. RCS is useful for text that is revised frequently, for example
|
||||||
.PP
|
.PP
|
||||||
The basic user interface is extremely simple. The novice only needs
|
The basic user interface is extremely simple. The novice only needs
|
||||||
to learn two commands:
|
to learn two commands:
|
||||||
@ -37,13 +16,13 @@ and
|
|||||||
.BR co (1).
|
.BR co (1).
|
||||||
.BR ci ,
|
.BR ci ,
|
||||||
short for \*(lqcheck in\*(rq, deposits the contents of a
|
short for \*(lqcheck in\*(rq, deposits the contents of a
|
||||||
file into an archival file called an \*r file. An \*r file
|
file into an archival file called an RCS file. An RCS file
|
||||||
contains all revisions of a particular file.
|
contains all revisions of a particular file.
|
||||||
.BR co ,
|
.BR co ,
|
||||||
short for \*(lqcheck out\*(rq, retrieves revisions from an \*r file.
|
short for \*(lqcheck out\*(rq, retrieves revisions from an RCS file.
|
||||||
.SS "Functions of \*r"
|
.SS "Functions of RCS"
|
||||||
.IP \(bu
|
.IP \(bu
|
||||||
Store and retrieve multiple revisions of text. \*r saves all old
|
Store and retrieve multiple revisions of text. RCS saves all old
|
||||||
revisions in a space efficient way.
|
revisions in a space efficient way.
|
||||||
Changes no longer destroy the original, because the
|
Changes no longer destroy the original, because the
|
||||||
previous revisions remain accessible. Revisions can be retrieved according to
|
previous revisions remain accessible. Revisions can be retrieved according to
|
||||||
@ -51,24 +30,24 @@ ranges of revision numbers, symbolic names, dates, authors, and
|
|||||||
states.
|
states.
|
||||||
.IP \(bu
|
.IP \(bu
|
||||||
Maintain a complete history of changes.
|
Maintain a complete history of changes.
|
||||||
\*r logs all changes automatically.
|
RCS logs all changes automatically.
|
||||||
Besides the text of each revision, \*r stores the author, the date and time of
|
Besides the text of each revision, RCS stores the author, the date and time of
|
||||||
check-in, and a log message summarizing the change.
|
check-in, and a log message summarizing the change.
|
||||||
The logging makes it easy to find out
|
The logging makes it easy to find out
|
||||||
what happened to a module, without having to compare
|
what happened to a module, without having to compare
|
||||||
source listings or having to track down colleagues.
|
source listings or having to track down colleagues.
|
||||||
.IP \(bu
|
.IP \(bu
|
||||||
Resolve access conflicts. When two or more programmers wish to
|
Resolve access conflicts. When two or more programmers wish to
|
||||||
modify the same revision, \*r alerts the programmers and prevents one
|
modify the same revision, RCS alerts the programmers and prevents one
|
||||||
modification from corrupting the other.
|
modification from corrupting the other.
|
||||||
.IP \(bu
|
.IP \(bu
|
||||||
Maintain a tree of revisions. \*r can maintain separate lines of development
|
Maintain a tree of revisions. RCS can maintain separate lines of development
|
||||||
for each module. It stores a tree structure that represents the
|
for each module. It stores a tree structure that represents the
|
||||||
ancestral relationships among revisions.
|
ancestral relationships among revisions.
|
||||||
.IP \(bu
|
.IP \(bu
|
||||||
Merge revisions and resolve conflicts.
|
Merge revisions and resolve conflicts.
|
||||||
Two separate lines of development of a module can be coalesced by merging.
|
Two separate lines of development of a module can be coalesced by merging.
|
||||||
If the revisions to be merged affect the same sections of code, \*r alerts the
|
If the revisions to be merged affect the same sections of code, RCS alerts the
|
||||||
user about the overlapping changes.
|
user about the overlapping changes.
|
||||||
.IP \(bu
|
.IP \(bu
|
||||||
Control releases and configurations.
|
Control releases and configurations.
|
||||||
@ -84,14 +63,14 @@ in the text of a revision.
|
|||||||
The identification makes it simple to determine which
|
The identification makes it simple to determine which
|
||||||
revisions of which modules make up a given configuration.
|
revisions of which modules make up a given configuration.
|
||||||
.IP \(bu
|
.IP \(bu
|
||||||
Minimize secondary storage. \*r needs little extra space for
|
Minimize secondary storage. RCS needs little extra space for
|
||||||
the revisions (only the differences). If intermediate revisions are
|
the revisions (only the differences). If intermediate revisions are
|
||||||
deleted, the corresponding deltas are compressed accordingly.
|
deleted, the corresponding deltas are compressed accordingly.
|
||||||
.SS "Getting Started with \*r"
|
.SS "Getting Started with RCS"
|
||||||
Suppose you have a file
|
Suppose you have a file
|
||||||
.B f.c
|
.B f.c
|
||||||
that you wish to put under control of \*r.
|
that you wish to put under control of RCS.
|
||||||
If you have not already done so, make an \*r directory with the command
|
If you have not already done so, make an RCS directory with the command
|
||||||
.IP
|
.IP
|
||||||
.B "mkdir RCS"
|
.B "mkdir RCS"
|
||||||
.LP
|
.LP
|
||||||
@ -99,7 +78,7 @@ Then invoke the check-in command
|
|||||||
.IP
|
.IP
|
||||||
.B "ci f.c"
|
.B "ci f.c"
|
||||||
.LP
|
.LP
|
||||||
This command creates an \*r file in the
|
This command creates an RCS file in the
|
||||||
.B RCS
|
.B RCS
|
||||||
directory,
|
directory,
|
||||||
stores
|
stores
|
||||||
@ -112,7 +91,7 @@ should be a synopsis of the contents of the file. All later check-in
|
|||||||
commands will ask you for a log entry, which should summarize the
|
commands will ask you for a log entry, which should summarize the
|
||||||
changes that you made.
|
changes that you made.
|
||||||
.PP
|
.PP
|
||||||
Files in the \*r directory are called \*r files;
|
Files in the RCS directory are called RCS files;
|
||||||
the others are called working files.
|
the others are called working files.
|
||||||
To get back the working file
|
To get back the working file
|
||||||
.B f.c
|
.B f.c
|
||||||
@ -121,7 +100,7 @@ command
|
|||||||
.IP
|
.IP
|
||||||
.B "co f.c"
|
.B "co f.c"
|
||||||
.LP
|
.LP
|
||||||
This command extracts the latest revision from the \*r file
|
This command extracts the latest revision from the RCS file
|
||||||
and writes
|
and writes
|
||||||
it into
|
it into
|
||||||
.BR f.c .
|
.BR f.c .
|
||||||
@ -173,26 +152,26 @@ prevents is a
|
|||||||
.I "check-in"
|
.I "check-in"
|
||||||
by anybody but the locker.
|
by anybody but the locker.
|
||||||
.PP
|
.PP
|
||||||
If your \*r file is private, i.e., if you are the only person who is going
|
If your RCS file is private, i.e., if you are the only person who is going
|
||||||
to deposit revisions into it, strict locking is not needed and you
|
to deposit revisions into it, strict locking is not needed and you
|
||||||
can turn it off.
|
can turn it off.
|
||||||
If strict locking is turned off,
|
If strict locking is turned off,
|
||||||
the owner of the \*r file need not have a lock for check-in; all others
|
the owner of the RCS file need not have a lock for check-in; all others
|
||||||
still do. Turning strict locking off and on is done with the commands
|
still do. Turning strict locking off and on is done with the commands
|
||||||
.IP
|
.IP
|
||||||
.BR "rcs \-U f.c" " and " "rcs \-L f.c"
|
.BR "rcs \-U f.c" " and " "rcs \-L f.c"
|
||||||
.LP
|
.LP
|
||||||
If you don't want to clutter your working directory with \*r files, create
|
If you don't want to clutter your working directory with RCS files, create
|
||||||
a subdirectory called
|
a subdirectory called
|
||||||
.B RCS
|
.B RCS
|
||||||
in your working directory, and move all your \*r
|
in your working directory, and move all your RCS
|
||||||
files there. \*r commands will look first into that directory to find
|
files there. RCS commands will look first into that directory to find
|
||||||
needed files. All the commands discussed above will still work, without any
|
needed files. All the commands discussed above will still work, without any
|
||||||
modification.
|
modification.
|
||||||
(Actually, pairs of \*r and working files can be specified in three ways:
|
(Actually, pairs of RCS and working files can be specified in three ways:
|
||||||
(a) both are given, (b) only the working file is given, (c) only the
|
(a) both are given, (b) only the working file is given, (c) only the
|
||||||
\*r file is given. Both \*r and working files may have arbitrary path prefixes;
|
RCS file is given. Both RCS and working files may have arbitrary path prefixes;
|
||||||
\*r commands pair them up intelligently.)
|
RCS commands pair them up intelligently.)
|
||||||
.PP
|
.PP
|
||||||
To avoid the deletion of the working file during check-in (in case you want to
|
To avoid the deletion of the working file during check-in (in case you want to
|
||||||
continue editing or compiling), invoke
|
continue editing or compiling), invoke
|
||||||
@ -247,19 +226,19 @@ the number 1.3.1.1 to the new revision. For more information about
|
|||||||
branches, see
|
branches, see
|
||||||
.BR rcsfile (5).
|
.BR rcsfile (5).
|
||||||
.SS "Automatic Identification"
|
.SS "Automatic Identification"
|
||||||
\*r can put special strings for identification into your source and object
|
RCS can put special strings for identification into your source and object
|
||||||
code. To obtain such identification, place the marker
|
code. To obtain such identification, place the marker
|
||||||
.IP
|
.IP
|
||||||
.B "$\&Id$"
|
.B "$\&Id$"
|
||||||
.LP
|
.LP
|
||||||
into your text, for instance inside a comment.
|
into your text, for instance inside a comment.
|
||||||
\*r will replace this marker with a string of the form
|
RCS will replace this marker with a string of the form
|
||||||
.IP
|
.IP
|
||||||
.BI $\&Id: " filename revision date time author state " $
|
.BI $\&Id: " filename revision date time author state " $
|
||||||
.LP
|
.LP
|
||||||
With such a marker on the first page of each module, you can
|
With such a marker on the first page of each module, you can
|
||||||
always see with which revision you are working.
|
always see with which revision you are working.
|
||||||
\*r keeps the markers up to date automatically.
|
RCS keeps the markers up to date automatically.
|
||||||
To propagate the markers into your object code, simply put
|
To propagate the markers into your object code, simply put
|
||||||
them into literal character strings. In C, this is done as follows:
|
them into literal character strings. In C, this is done as follows:
|
||||||
.IP
|
.IP
|
||||||
@ -297,8 +276,8 @@ Copyright \(co 1990, 1991, 1992, 1993 Paul Eggert.
|
|||||||
ci(1), co(1), ident(1), rcs(1), rcsdiff(1), rcsintro(1), rcsmerge(1), rlog(1)
|
ci(1), co(1), ident(1), rcs(1), rcsdiff(1), rcsintro(1), rcsmerge(1), rlog(1)
|
||||||
.br
|
.br
|
||||||
Walter F. Tichy,
|
Walter F. Tichy,
|
||||||
\*r\*-A System for Version Control,
|
RCS\(emA System for Version Control,
|
||||||
.I "Software\*-Practice & Experience"
|
.I "Software\(emPractice \*[Am] Experience"
|
||||||
.BR 15 ,
|
.BR 15 ,
|
||||||
7 (July 1985), 637-654.
|
7 (July 1985), 637-654.
|
||||||
.br
|
.br
|
||||||
|
6
external/gpl2/rcs/dist/man/rcsmerge.1
vendored
6
external/gpl2/rcs/dist/man/rcsmerge.1
vendored
@ -1,4 +1,4 @@
|
|||||||
.\" $NetBSD: rcsmerge.1,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $
|
.\" $NetBSD: rcsmerge.1,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\"
|
.\"
|
||||||
.de Id
|
.de Id
|
||||||
.ds Rv \\$3
|
.ds Rv \\$3
|
||||||
@ -139,7 +139,7 @@ updates to release 2.8 from someone else.
|
|||||||
To combine the updates to 2.8 and your changes between 2.8 and 3.4,
|
To combine the updates to 2.8 and your changes between 2.8 and 3.4,
|
||||||
put the updates to 2.8 into file f.c and execute
|
put the updates to 2.8 into file f.c and execute
|
||||||
.LP
|
.LP
|
||||||
.B " rcsmerge \-p \-r2.8 \-r3.4 f.c >f.merged.c"
|
.B " rcsmerge \-p \-r2.8 \-r3.4 f.c \*[Gt]f.merged.c"
|
||||||
.PP
|
.PP
|
||||||
Then examine
|
Then examine
|
||||||
.BR f.merged.c .
|
.BR f.merged.c .
|
||||||
@ -185,7 +185,7 @@ rcsfile(5)
|
|||||||
.br
|
.br
|
||||||
Walter F. Tichy,
|
Walter F. Tichy,
|
||||||
\*r\*-A System for Version Control,
|
\*r\*-A System for Version Control,
|
||||||
.I "Software\*-Practice & Experience"
|
.I "Software\*-Practice \*[Am] Experience"
|
||||||
.BR 15 ,
|
.BR 15 ,
|
||||||
7 (July 1985), 637-654.
|
7 (July 1985), 637-654.
|
||||||
.br
|
.br
|
||||||
|
26
external/gpl2/rcs/dist/man/rlog.1
vendored
26
external/gpl2/rcs/dist/man/rlog.1
vendored
@ -1,4 +1,4 @@
|
|||||||
.\" $NetBSD: rlog.1,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $
|
.\" $NetBSD: rlog.1,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\"
|
.\"
|
||||||
.de Id
|
.de Id
|
||||||
.ds Rv \\$3
|
.ds Rv \\$3
|
||||||
@ -48,6 +48,8 @@ The options below restrict this output.
|
|||||||
.ds n \nn
|
.ds n \nn
|
||||||
.if \n(.g .if r an-tag-sep .ds n \w'\f3\-V\fP\f2n\fP'u+\n[an-tag-sep]u
|
.if \n(.g .if r an-tag-sep .ds n \w'\f3\-V\fP\f2n\fP'u+\n[an-tag-sep]u
|
||||||
.TP \*n
|
.TP \*n
|
||||||
|
.B \-c
|
||||||
|
Print the commitid if available.
|
||||||
.B \-L
|
.B \-L
|
||||||
Ignore \*r files that have no locks set.
|
Ignore \*r files that have no locks set.
|
||||||
This is convenient in combination with
|
This is convenient in combination with
|
||||||
@ -83,32 +85,32 @@ Print information about revisions with a checkin date/time in the ranges given b
|
|||||||
the semicolon-separated list of
|
the semicolon-separated list of
|
||||||
.IR dates .
|
.IR dates .
|
||||||
A range of the form
|
A range of the form
|
||||||
.IB d1 < d2
|
.IB d1 \*[Lt] d2
|
||||||
or
|
or
|
||||||
.IB d2 > d1
|
.IB d2 \*[Gt] d1
|
||||||
selects the revisions that were deposited between
|
selects the revisions that were deposited between
|
||||||
.I d1
|
.I d1
|
||||||
and
|
and
|
||||||
.I d2
|
.I d2
|
||||||
exclusive.
|
exclusive.
|
||||||
A range of the form
|
A range of the form
|
||||||
.BI < d
|
.BI \*[Lt] d
|
||||||
or
|
or
|
||||||
.IB d >
|
.IB d \*[Gt]
|
||||||
selects
|
selects
|
||||||
all revisions earlier than
|
all revisions earlier than
|
||||||
.IR d .
|
.IR d .
|
||||||
A range of the form
|
A range of the form
|
||||||
.IB d <
|
.IB d \*[Lt]
|
||||||
or
|
or
|
||||||
.BI > d
|
.BI \*[Gt] d
|
||||||
selects
|
selects
|
||||||
all revisions dated later than
|
all revisions dated later than
|
||||||
.IR d .
|
.IR d .
|
||||||
If
|
If
|
||||||
.B <
|
.B \*[Lt]
|
||||||
or
|
or
|
||||||
.B >
|
.B \*[Gt]
|
||||||
is followed by
|
is followed by
|
||||||
.B =
|
.B =
|
||||||
then the ranges are inclusive, not exclusive.
|
then the ranges are inclusive, not exclusive.
|
||||||
@ -125,9 +127,9 @@ and
|
|||||||
are in the free format explained in
|
are in the free format explained in
|
||||||
.BR co (1).
|
.BR co (1).
|
||||||
Quoting is normally necessary, especially for
|
Quoting is normally necessary, especially for
|
||||||
.B <
|
.B \*[Lt]
|
||||||
and
|
and
|
||||||
.BR > .
|
.BR \*[Gt] .
|
||||||
Note that the separator is
|
Note that the separator is
|
||||||
a semicolon.
|
a semicolon.
|
||||||
.TP
|
.TP
|
||||||
@ -296,7 +298,7 @@ rcsfile(5)
|
|||||||
.br
|
.br
|
||||||
Walter F. Tichy,
|
Walter F. Tichy,
|
||||||
\*r\*-A System for Version Control,
|
\*r\*-A System for Version Control,
|
||||||
.I "Software\*-Practice & Experience"
|
.I "Software\*-Practice \*[Am] Experience"
|
||||||
.BR 15 ,
|
.BR 15 ,
|
||||||
7 (July 1985), 637-654.
|
7 (July 1985), 637-654.
|
||||||
.SH BUGS
|
.SH BUGS
|
||||||
|
2
external/gpl2/rcs/dist/rcs.ms
vendored
2
external/gpl2/rcs/dist/rcs.ms
vendored
@ -1,4 +1,4 @@
|
|||||||
.\" Format this file with:
|
.\" $NetBSD: rcs.ms,v 1.2 2016/01/14 04:22:39 christos Exp $
|
||||||
.\" pic file | tbl | troff -ms
|
.\" pic file | tbl | troff -ms
|
||||||
.\"
|
.\"
|
||||||
.\" \*s stands for $, and avoids problems when this file is checked in.
|
.\" \*s stands for $, and avoids problems when this file is checked in.
|
||||||
|
5
external/gpl2/rcs/dist/src/ci.c
vendored
5
external/gpl2/rcs/dist/src/ci.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: ci.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: ci.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Check in revisions of RCS files from working files. */
|
/* Check in revisions of RCS files from working files. */
|
||||||
|
|
||||||
@ -1138,7 +1138,7 @@ struct hshentry * delta;
|
|||||||
|
|
||||||
num=delta->num;
|
num=delta->num;
|
||||||
for (trail = &Locks; (next = *trail); trail = &next->nextlock)
|
for (trail = &Locks; (next = *trail); trail = &next->nextlock)
|
||||||
if (next->delta == delta)
|
if (next->delta == delta) {
|
||||||
if (strcmp(getcaller(), next->login) == 0) {
|
if (strcmp(getcaller(), next->login) == 0) {
|
||||||
/* We found a lock on delta by caller; delete it. */
|
/* We found a lock on delta by caller; delete it. */
|
||||||
*trail = next->nextlock;
|
*trail = next->nextlock;
|
||||||
@ -1148,6 +1148,7 @@ struct hshentry * delta;
|
|||||||
rcserror("revision %s locked by %s", num, next->login);
|
rcserror("revision %s locked by %s", num, next->login);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (!StrictLocks && myself(RCSstat.st_uid))
|
if (!StrictLocks && myself(RCSstat.st_uid))
|
||||||
return 0;
|
return 0;
|
||||||
rcserror("no lock set by %s for revision %s", getcaller(), num);
|
rcserror("no lock set by %s for revision %s", getcaller(), num);
|
||||||
|
2
external/gpl2/rcs/dist/src/co.c
vendored
2
external/gpl2/rcs/dist/src/co.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: co.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: co.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Check out working files from revisions of RCS files. */
|
/* Check out working files from revisions of RCS files. */
|
||||||
|
|
||||||
|
12
external/gpl2/rcs/dist/src/ident.c
vendored
12
external/gpl2/rcs/dist/src/ident.c
vendored
@ -1,5 +1,5 @@
|
|||||||
/* $NetBSD: ident.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: ident.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
/* $NetBSD: ident.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
/* Identify RCS keyword strings in files. */
|
/* Identify RCS keyword strings in files. */
|
||||||
|
|
||||||
/* Copyright 1982, 1988, 1989 Walter Tichy
|
/* Copyright 1982, 1988, 1989 Walter Tichy
|
||||||
@ -136,7 +136,7 @@ mainProg(identId, "ident", "Id: ident.c,v 5.9 1995/06/16 06:19:24 eggert Exp ")
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (0 <= quiet)
|
if (0 <= quiet) {
|
||||||
if (!a)
|
if (!a)
|
||||||
VOID scanfile(stdin, (char*)0, quiet);
|
VOID scanfile(stdin, (char*)0, quiet);
|
||||||
else
|
else
|
||||||
@ -150,7 +150,7 @@ mainProg(identId, "ident", "Id: ident.c,v 5.9 1995/06/16 06:19:24 eggert Exp ")
|
|||||||
)
|
)
|
||||||
break;
|
break;
|
||||||
} while ((a = *++argv));
|
} while ((a = *++argv));
|
||||||
|
}
|
||||||
if (ferror(stdout) || fclose(stdout)!=0) {
|
if (ferror(stdout) || fclose(stdout)!=0) {
|
||||||
reportError("standard output");
|
reportError("standard output");
|
||||||
status = EXIT_FAILURE;
|
status = EXIT_FAILURE;
|
||||||
@ -252,8 +252,8 @@ match(fp) /* group substring between two KDELIM's; then do pattern match */
|
|||||||
return c ? c : '\n';
|
return c ? c : '\n';
|
||||||
*tp++ = c;
|
*tp++ = c;
|
||||||
while( (c = getc(fp)) != KDELIM ) {
|
while( (c = getc(fp)) != KDELIM ) {
|
||||||
if (c == EOF && feof(fp) | ferror(fp))
|
if (c == EOF)
|
||||||
return c;
|
return c;
|
||||||
switch (ctab[c]) {
|
switch (ctab[c]) {
|
||||||
default:
|
default:
|
||||||
*tp++ = c;
|
*tp++ = c;
|
||||||
|
2
external/gpl2/rcs/dist/src/maketime.h
vendored
2
external/gpl2/rcs/dist/src/maketime.h
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: maketime.h,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: maketime.h,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Yield time_t from struct partime yielded by partime. */
|
/* Yield time_t from struct partime yielded by partime. */
|
||||||
|
|
||||||
|
2
external/gpl2/rcs/dist/src/merge.c
vendored
2
external/gpl2/rcs/dist/src/merge.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: merge.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: merge.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* merge - three-way file merge */
|
/* merge - three-way file merge */
|
||||||
|
|
||||||
|
2
external/gpl2/rcs/dist/src/merger.c
vendored
2
external/gpl2/rcs/dist/src/merger.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: merger.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: merger.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* three-way file merge internals */
|
/* three-way file merge internals */
|
||||||
|
|
||||||
|
2
external/gpl2/rcs/dist/src/partime.c
vendored
2
external/gpl2/rcs/dist/src/partime.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: partime.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: partime.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Parse a string, yielding a struct partime that describes it. */
|
/* Parse a string, yielding a struct partime that describes it. */
|
||||||
|
|
||||||
|
2
external/gpl2/rcs/dist/src/partime.h
vendored
2
external/gpl2/rcs/dist/src/partime.h
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: partime.h,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: partime.h,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Parse a string, yielding a struct partime that describes it. */
|
/* Parse a string, yielding a struct partime that describes it. */
|
||||||
|
|
||||||
|
22
external/gpl2/rcs/dist/src/rcs.c
vendored
22
external/gpl2/rcs/dist/src/rcs.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcs.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcs.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Change RCS file attributes. */
|
/* Change RCS file attributes. */
|
||||||
|
|
||||||
@ -730,8 +730,8 @@ getaccessor(opt, command)
|
|||||||
|
|
||||||
|
|
||||||
{
|
{
|
||||||
register c;
|
int c;
|
||||||
register char *sp;
|
char *sp;
|
||||||
|
|
||||||
sp = opt;
|
sp = opt;
|
||||||
while ((c = *++sp) == ' ' || c == '\n' || c == '\t' || c == ',')
|
while ((c = *++sp) == ' ' || c == '\n' || c == '\t' || c == ',')
|
||||||
@ -790,7 +790,7 @@ char *sp;
|
|||||||
{
|
{
|
||||||
char const *temp;
|
char const *temp;
|
||||||
struct Status *pt;
|
struct Status *pt;
|
||||||
register c;
|
int c;
|
||||||
|
|
||||||
while ((c = *++sp) ==' ' || c == '\t' || c == '\n')
|
while ((c = *++sp) ==' ' || c == '\t' || c == '\n')
|
||||||
continue;
|
continue;
|
||||||
@ -1394,7 +1394,7 @@ dolocks()
|
|||||||
for (lockpt = rmvlocklst; lockpt; lockpt = lockpt->nextrev)
|
for (lockpt = rmvlocklst; lockpt; lockpt = lockpt->nextrev)
|
||||||
if (expandsym(lockpt->revno, &numrev)) {
|
if (expandsym(lockpt->revno, &numrev)) {
|
||||||
target = genrevs(numrev.string, (char *)0, (char *)0, (char *)0, &gendeltas);
|
target = genrevs(numrev.string, (char *)0, (char *)0, (char *)0, &gendeltas);
|
||||||
if ( target )
|
if ( target ) {
|
||||||
if (!(countnumflds(numrev.string)&1) && cmpnum(target->num,numrev.string))
|
if (!(countnumflds(numrev.string)&1) && cmpnum(target->num,numrev.string))
|
||||||
rcserror("can't unlock nonexisting revision %s",
|
rcserror("can't unlock nonexisting revision %s",
|
||||||
lockpt->revno
|
lockpt->revno
|
||||||
@ -1402,19 +1402,21 @@ dolocks()
|
|||||||
else
|
else
|
||||||
changed |= breaklock(target);
|
changed |= breaklock(target);
|
||||||
/* breaklock does its own diagnose */
|
/* breaklock does its own diagnose */
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* add new locks which stored in newlocklst */
|
/* add new locks which stored in newlocklst */
|
||||||
for (lockpt = newlocklst; lockpt; lockpt = lockpt->nextrev)
|
for (lockpt = newlocklst; lockpt; lockpt = lockpt->nextrev)
|
||||||
changed |= setlock(lockpt->revno);
|
changed |= setlock(lockpt->revno);
|
||||||
|
|
||||||
if (lockhead) /* lock default branch or head */
|
if (lockhead) { /* lock default branch or head */
|
||||||
if (Dbranch)
|
if (Dbranch)
|
||||||
changed |= setlock(Dbranch);
|
changed |= setlock(Dbranch);
|
||||||
else if (Head)
|
else if (Head)
|
||||||
changed |= setlock(Head->num);
|
changed |= setlock(Head->num);
|
||||||
else
|
else
|
||||||
rcswarn("can't lock an empty tree");
|
rcswarn("can't lock an empty tree");
|
||||||
|
}
|
||||||
return changed;
|
return changed;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1433,7 +1435,7 @@ setlock(rev)
|
|||||||
if (expandsym(rev, &numrev)) {
|
if (expandsym(rev, &numrev)) {
|
||||||
target = genrevs(numrev.string, (char*)0, (char*)0,
|
target = genrevs(numrev.string, (char*)0, (char*)0,
|
||||||
(char*)0, &gendeltas);
|
(char*)0, &gendeltas);
|
||||||
if ( target )
|
if ( target ) {
|
||||||
if (!(countnumflds(numrev.string)&1) && cmpnum(target->num,numrev.string))
|
if (!(countnumflds(numrev.string)&1) && cmpnum(target->num,numrev.string))
|
||||||
rcserror("can't lock nonexisting revision %s",
|
rcserror("can't lock nonexisting revision %s",
|
||||||
numrev.string
|
numrev.string
|
||||||
@ -1447,6 +1449,7 @@ setlock(rev)
|
|||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -1489,7 +1492,7 @@ rcs_setstate(rev,status)
|
|||||||
if (expandsym(rev, &numrev)) {
|
if (expandsym(rev, &numrev)) {
|
||||||
target = genrevs(numrev.string, (char*)0, (char*)0,
|
target = genrevs(numrev.string, (char*)0, (char*)0,
|
||||||
(char*)0, &gendeltas);
|
(char*)0, &gendeltas);
|
||||||
if ( target )
|
if ( target ) {
|
||||||
if (!(countnumflds(numrev.string)&1) && cmpnum(target->num,numrev.string))
|
if (!(countnumflds(numrev.string)&1) && cmpnum(target->num,numrev.string))
|
||||||
rcserror("can't set state of nonexisting revision %s",
|
rcserror("can't set state of nonexisting revision %s",
|
||||||
numrev.string
|
numrev.string
|
||||||
@ -1498,6 +1501,7 @@ rcs_setstate(rev,status)
|
|||||||
target->state = status;
|
target->state = status;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -1582,7 +1586,7 @@ buildtree()
|
|||||||
pre = pt;
|
pre = pt;
|
||||||
pt = pt->nextbranch;
|
pt = pt->nextbranch;
|
||||||
}
|
}
|
||||||
if ( cuttail )
|
if ( cuttail && pt )
|
||||||
pt->hsh = cuttail;
|
pt->hsh = cuttail;
|
||||||
else if ( pt == pre )
|
else if ( pt == pre )
|
||||||
cuthead->branches = pt->nextbranch;
|
cuthead->branches = pt->nextbranch;
|
||||||
|
16
external/gpl2/rcs/dist/src/rcsbase.h
vendored
16
external/gpl2/rcs/dist/src/rcsbase.h
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcsbase.h,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcsbase.h,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* RCS common definitions and data structures */
|
/* RCS common definitions and data structures */
|
||||||
|
|
||||||
@ -272,14 +272,14 @@ Report problems and direct all questions to:
|
|||||||
# if maps_memory
|
# if maps_memory
|
||||||
# define declarecache register Iptr_type ptr, lim
|
# define declarecache register Iptr_type ptr, lim
|
||||||
# define setupcache(f) (lim = (f)->lim)
|
# define setupcache(f) (lim = (f)->lim)
|
||||||
# define Igeteof_(f,c,s) if ((f)->ptr==(f)->lim) s else (c)= *(f)->ptr++;
|
# define Igeteof_(f,c,s) { if ((f)->ptr==(f)->lim) s else (c)= *(f)->ptr++; }
|
||||||
# define cachegeteof_(c,s) if (ptr==lim) s else (c)= *ptr++;
|
# define cachegeteof_(c,s) { if (ptr==lim) s else (c)= *ptr++; }
|
||||||
# else
|
# else
|
||||||
int Igetmore P((RILE*));
|
int Igetmore P((RILE*));
|
||||||
# define declarecache register Iptr_type ptr; register RILE *rRILE
|
# define declarecache register Iptr_type ptr; register RILE *rRILE
|
||||||
# define setupcache(f) (rRILE = (f))
|
# define setupcache(f) (rRILE = (f))
|
||||||
# define Igeteof_(f,c,s) if ((f)->ptr==(f)->readlim && !Igetmore(f)) s else (c)= *(f)->ptr++;
|
# define Igeteof_(f,c,s) { if ((f)->ptr==(f)->readlim && !Igetmore(f)) s else (c)= *(f)->ptr++; }
|
||||||
# define cachegeteof_(c,s) if (ptr==rRILE->readlim && !Igetmore(rRILE)) s else (c)= *ptr++;
|
# define cachegeteof_(c,s) { if (ptr==rRILE->readlim && !Igetmore(rRILE)) s else (c)= *ptr++; }
|
||||||
# endif
|
# endif
|
||||||
# define uncache(f) ((f)->ptr = ptr)
|
# define uncache(f) ((f)->ptr = ptr)
|
||||||
# define cache(f) (ptr = (f)->ptr)
|
# define cache(f) (ptr = (f)->ptr)
|
||||||
@ -360,6 +360,7 @@ struct hshentry {
|
|||||||
char const * lockedby; /* who locks the revision */
|
char const * lockedby; /* who locks the revision */
|
||||||
char const * state; /* state of revision (Exp by default) */
|
char const * state; /* state of revision (Exp by default) */
|
||||||
char const * name; /* name (if any) by which retrieved */
|
char const * name; /* name (if any) by which retrieved */
|
||||||
|
char const * commitid; /* unique commit identifier */
|
||||||
struct cbuf log; /* log message requested at checkin */
|
struct cbuf log; /* log message requested at checkin */
|
||||||
struct branchhead * branches; /* list of first revisions on branches*/
|
struct branchhead * branches; /* list of first revisions on branches*/
|
||||||
struct cbuf ig; /* ignored phrases in admin part */
|
struct cbuf ig; /* ignored phrases in admin part */
|
||||||
@ -429,9 +430,12 @@ struct assoc {
|
|||||||
#define REVISION "Revision"
|
#define REVISION "Revision"
|
||||||
#define SOURCE "Source"
|
#define SOURCE "Source"
|
||||||
#define STATE "State"
|
#define STATE "State"
|
||||||
#define keylength 8 /* max length of any of the above keywords */
|
#define keylength 32 /* max length of any of the above keywords */
|
||||||
|
|
||||||
enum markers { Nomatch, Author, Date, Header, Id,
|
enum markers { Nomatch, Author, Date, Header, Id,
|
||||||
|
#ifdef LOCALID
|
||||||
|
LocalId,
|
||||||
|
#endif
|
||||||
Locker, Log, Name, RCSfile, Revision, Source, State };
|
Locker, Log, Name, RCSfile, Revision, Source, State };
|
||||||
/* This must be in the same order as rcskeys.c's Keyword[] array. */
|
/* This must be in the same order as rcskeys.c's Keyword[] array. */
|
||||||
|
|
||||||
|
11
external/gpl2/rcs/dist/src/rcsclean.c
vendored
11
external/gpl2/rcs/dist/src/rcsclean.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcsclean.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcsclean.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Clean up working files. */
|
/* Clean up working files. */
|
||||||
|
|
||||||
@ -323,11 +323,14 @@ get_directory(dirname, aargv)
|
|||||||
efaterror(dirname);
|
efaterror(dirname);
|
||||||
if (chars)
|
if (chars)
|
||||||
a = trealloc(char, a, chars);
|
a = trealloc(char, a, chars);
|
||||||
else
|
else {
|
||||||
tfree(a);
|
tfree(a);
|
||||||
|
a = NULL;
|
||||||
|
}
|
||||||
*aargv = p = tnalloc(char*, entries+1);
|
*aargv = p = tnalloc(char*, entries+1);
|
||||||
for (i=0; i<entries; i++)
|
if (a)
|
||||||
*p++ = a + offset[i];
|
for (i=0; i<entries; i++)
|
||||||
|
*p++ = a + offset[i];
|
||||||
*p = 0;
|
*p = 0;
|
||||||
tfree(offset);
|
tfree(offset);
|
||||||
return entries;
|
return entries;
|
||||||
|
11
external/gpl2/rcs/dist/src/rcsdiff.c
vendored
11
external/gpl2/rcs/dist/src/rcsdiff.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcsdiff.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcsdiff.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Compare RCS revisions. */
|
/* Compare RCS revisions. */
|
||||||
|
|
||||||
@ -178,7 +178,7 @@ mainProg(rcsdiffId, "rcsdiff", "Id: rcsdiff.c,v 5.19 1995/06/16 06:19:24 eggert
|
|||||||
struct hshentry * target;
|
struct hshentry * target;
|
||||||
char *a, *dcp, **newargv;
|
char *a, *dcp, **newargv;
|
||||||
int no_diff_means_no_output;
|
int no_diff_means_no_output;
|
||||||
register c;
|
int c;
|
||||||
|
|
||||||
exitstatus = DIFF_SUCCESS;
|
exitstatus = DIFF_SUCCESS;
|
||||||
|
|
||||||
@ -216,9 +216,9 @@ mainProg(rcsdiffId, "rcsdiff", "Id: rcsdiff.c,v 5.19 1995/06/16 06:19:24 eggert
|
|||||||
case '-': case 'D':
|
case '-': case 'D':
|
||||||
no_diff_means_no_output = false;
|
no_diff_means_no_output = false;
|
||||||
/* fall into */
|
/* fall into */
|
||||||
case 'C': case 'F': case 'I': case 'L': case 'W':
|
case 'C': case 'F': case 'I': case 'L': case 'W': case 'U':
|
||||||
#if DIFF_L
|
#if DIFF_L
|
||||||
if (c == 'L' && ++file_labels == 2)
|
if (c == 'L' && file_labels++ == 2)
|
||||||
faterror("too many -L options");
|
faterror("too many -L options");
|
||||||
#endif
|
#endif
|
||||||
*dcp++ = c;
|
*dcp++ = c;
|
||||||
@ -366,13 +366,14 @@ mainProg(rcsdiffId, "rcsdiff", "Id: rcsdiff.c,v 5.19 1995/06/16 06:19:24 eggert
|
|||||||
lexpandarg = "-kkvl";
|
lexpandarg = "-kkvl";
|
||||||
Izclose(&workptr);
|
Izclose(&workptr);
|
||||||
#if DIFF_L
|
#if DIFF_L
|
||||||
if (diff_label2)
|
if (diff_label2) {
|
||||||
if (revnums == 2)
|
if (revnums == 2)
|
||||||
*diff_label2 = setup_label(&labelbuf[1], target->num, target->date);
|
*diff_label2 = setup_label(&labelbuf[1], target->num, target->date);
|
||||||
else {
|
else {
|
||||||
time2date(workstat.st_mtime, date2);
|
time2date(workstat.st_mtime, date2);
|
||||||
*diff_label2 = setup_label(&labelbuf[1], (char*)0, date2);
|
*diff_label2 = setup_label(&labelbuf[1], (char*)0, date2);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
diagnose("retrieving revision %s\n", xrev1);
|
diagnose("retrieving revision %s\n", xrev1);
|
||||||
|
33
external/gpl2/rcs/dist/src/rcsedit.c
vendored
33
external/gpl2/rcs/dist/src/rcsedit.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcsedit.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcsedit.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* RCS stream editor */
|
/* RCS stream editor */
|
||||||
|
|
||||||
@ -619,7 +619,7 @@ copystring()
|
|||||||
* editline is incremented by the number of lines copied.
|
* editline is incremented by the number of lines copied.
|
||||||
* Assumption: next character read is first string character.
|
* Assumption: next character read is first string character.
|
||||||
*/
|
*/
|
||||||
{ register c;
|
{ int c;
|
||||||
declarecache;
|
declarecache;
|
||||||
register FILE *frew, *fcop;
|
register FILE *frew, *fcop;
|
||||||
register int amidline;
|
register int amidline;
|
||||||
@ -864,7 +864,7 @@ expandline(infile, outfile, delta, delimstuffed, frewfile, dolog)
|
|||||||
* 2 if a complete line is copied; adds 1 to yield if expansion occurred.
|
* 2 if a complete line is copied; adds 1 to yield if expansion occurred.
|
||||||
*/
|
*/
|
||||||
{
|
{
|
||||||
register c;
|
int c;
|
||||||
declarecache;
|
declarecache;
|
||||||
register FILE *out, *frew;
|
register FILE *out, *frew;
|
||||||
register char * tp;
|
register char * tp;
|
||||||
@ -1053,8 +1053,11 @@ keyreplace(marker, delta, delimstuffed, infile, out, dolog)
|
|||||||
break;
|
break;
|
||||||
case Id:
|
case Id:
|
||||||
case Header:
|
case Header:
|
||||||
|
#ifdef LOCALID
|
||||||
|
case LocalId:
|
||||||
|
#endif
|
||||||
escape_string(out,
|
escape_string(out,
|
||||||
marker==Id || RCSv<VERSION(4)
|
marker!=Header || RCSv<VERSION(4)
|
||||||
? basefilename(RCSname)
|
? basefilename(RCSname)
|
||||||
: getfullRCSname()
|
: getfullRCSname()
|
||||||
);
|
);
|
||||||
@ -1065,12 +1068,13 @@ keyreplace(marker, delta, delimstuffed, infile, out, dolog)
|
|||||||
RCSv==VERSION(3) && delta->lockedby ? "Locked"
|
RCSv==VERSION(3) && delta->lockedby ? "Locked"
|
||||||
: delta->state
|
: delta->state
|
||||||
);
|
);
|
||||||
if (delta->lockedby)
|
if (delta->lockedby) {
|
||||||
if (VERSION(5) <= RCSv) {
|
if (VERSION(5) <= RCSv) {
|
||||||
if (locker_expansion || exp==KEYVALLOCK_EXPAND)
|
if (locker_expansion || exp==KEYVALLOCK_EXPAND)
|
||||||
aprintf(out, " %s", delta->lockedby);
|
aprintf(out, " %s", delta->lockedby);
|
||||||
} else if (RCSv == VERSION(4))
|
} else if (RCSv == VERSION(4))
|
||||||
aprintf(out, " Locker: %s", delta->lockedby);
|
aprintf(out, " Locker: %s", delta->lockedby);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case Locker:
|
case Locker:
|
||||||
if (delta->lockedby)
|
if (delta->lockedby)
|
||||||
@ -1505,6 +1509,9 @@ makedirtemp(isworkfile)
|
|||||||
register size_t dl;
|
register size_t dl;
|
||||||
register struct buf *bn;
|
register struct buf *bn;
|
||||||
register char const *name = isworkfile ? workname : RCSname;
|
register char const *name = isworkfile ? workname : RCSname;
|
||||||
|
# if has_mkstemp
|
||||||
|
int fd;
|
||||||
|
# endif
|
||||||
|
|
||||||
dl = basefilename(name) - name;
|
dl = basefilename(name) - name;
|
||||||
bn = &dirtpname[newRCSdirtp_index + isworkfile];
|
bn = &dirtpname[newRCSdirtp_index + isworkfile];
|
||||||
@ -1523,10 +1530,17 @@ makedirtemp(isworkfile)
|
|||||||
catchints();
|
catchints();
|
||||||
# if has_mktemp
|
# if has_mktemp
|
||||||
VOID strcpy(tp, "XXXXXX");
|
VOID strcpy(tp, "XXXXXX");
|
||||||
|
# if has_mkstemp
|
||||||
|
if ((fd = mkstemp(np)) == -1)
|
||||||
|
# else
|
||||||
if (!mktemp(np) || !*np)
|
if (!mktemp(np) || !*np)
|
||||||
|
# endif
|
||||||
faterror("can't make temporary pathname `%.*s_%cXXXXXX'",
|
faterror("can't make temporary pathname `%.*s_%cXXXXXX'",
|
||||||
(int)dl, name, '0'+isworkfile
|
(int)dl, name, '0'+isworkfile
|
||||||
);
|
);
|
||||||
|
# if has_mkstemp
|
||||||
|
close(fd);
|
||||||
|
# endif
|
||||||
# else
|
# else
|
||||||
/*
|
/*
|
||||||
* Posix 1003.1-1990 has no reliable way
|
* Posix 1003.1-1990 has no reliable way
|
||||||
@ -1723,7 +1737,7 @@ addlock(delta, verbose)
|
|||||||
register struct rcslock *next;
|
register struct rcslock *next;
|
||||||
|
|
||||||
for (next = Locks; next; next = next->nextlock)
|
for (next = Locks; next; next = next->nextlock)
|
||||||
if (cmpnum(delta->num, next->delta->num) == 0)
|
if (cmpnum(delta->num, next->delta->num) == 0) {
|
||||||
if (strcmp(getcaller(), next->login) == 0)
|
if (strcmp(getcaller(), next->login) == 0)
|
||||||
return 0;
|
return 0;
|
||||||
else {
|
else {
|
||||||
@ -1733,6 +1747,7 @@ addlock(delta, verbose)
|
|||||||
);
|
);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
next = ftalloc(struct rcslock);
|
next = ftalloc(struct rcslock);
|
||||||
delta->lockedby = next->login = getcaller();
|
delta->lockedby = next->login = getcaller();
|
||||||
next->delta = delta;
|
next->delta = delta;
|
||||||
@ -1756,7 +1771,7 @@ addsymbol(num, name, rebind)
|
|||||||
register struct assoc *next;
|
register struct assoc *next;
|
||||||
|
|
||||||
for (next = Symbols; next; next = next->nextassoc)
|
for (next = Symbols; next; next = next->nextassoc)
|
||||||
if (strcmp(name, next->symbol) == 0)
|
if (strcmp(name, next->symbol) == 0) {
|
||||||
if (strcmp(next->num,num) == 0)
|
if (strcmp(next->num,num) == 0)
|
||||||
return 0;
|
return 0;
|
||||||
else if (rebind) {
|
else if (rebind) {
|
||||||
@ -1768,6 +1783,7 @@ addsymbol(num, name, rebind)
|
|||||||
);
|
);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
next = ftalloc(struct assoc);
|
next = ftalloc(struct assoc);
|
||||||
next->symbol = name;
|
next->symbol = name;
|
||||||
next->num = num;
|
next->num = num;
|
||||||
@ -1827,7 +1843,7 @@ dorewrite(lockflag, changed)
|
|||||||
{
|
{
|
||||||
int r = 0, e;
|
int r = 0, e;
|
||||||
|
|
||||||
if (lockflag)
|
if (lockflag) {
|
||||||
if (changed) {
|
if (changed) {
|
||||||
if (changed < 0)
|
if (changed < 0)
|
||||||
return -1;
|
return -1;
|
||||||
@ -1863,6 +1879,7 @@ dorewrite(lockflag, changed)
|
|||||||
}
|
}
|
||||||
# endif
|
# endif
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
2
external/gpl2/rcs/dist/src/rcsfcmp.c
vendored
2
external/gpl2/rcs/dist/src/rcsfcmp.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcsfcmp.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcsfcmp.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Compare working files, ignoring RCS keyword strings. */
|
/* Compare working files, ignoring RCS keyword strings. */
|
||||||
|
|
||||||
|
12
external/gpl2/rcs/dist/src/rcsfnms.c
vendored
12
external/gpl2/rcs/dist/src/rcsfnms.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcsfnms.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcsfnms.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* RCS filename and pathname handling */
|
/* RCS filename and pathname handling */
|
||||||
|
|
||||||
@ -294,14 +294,24 @@ maketemp(n)
|
|||||||
catchints();
|
catchints();
|
||||||
{
|
{
|
||||||
# if has_mktemp
|
# if has_mktemp
|
||||||
|
# if has_mkstemp
|
||||||
|
int fd;
|
||||||
|
# endif
|
||||||
char const *tp = tmp();
|
char const *tp = tmp();
|
||||||
size_t tplen = dir_useful_len(tp);
|
size_t tplen = dir_useful_len(tp);
|
||||||
p = testalloc(tplen + 10);
|
p = testalloc(tplen + 10);
|
||||||
VOID sprintf(p, "%.*s%cT%cXXXXXX", (int)tplen, tp, SLASH, '0'+n);
|
VOID sprintf(p, "%.*s%cT%cXXXXXX", (int)tplen, tp, SLASH, '0'+n);
|
||||||
|
# if has_mkstemp
|
||||||
|
if ((fd = mkstemp(p)) == -1)
|
||||||
|
# else
|
||||||
if (!mktemp(p) || !*p)
|
if (!mktemp(p) || !*p)
|
||||||
|
# endif
|
||||||
faterror("can't make temporary pathname `%.*s%cT%cXXXXXX'",
|
faterror("can't make temporary pathname `%.*s%cT%cXXXXXX'",
|
||||||
(int)tplen, tp, SLASH, '0'+n
|
(int)tplen, tp, SLASH, '0'+n
|
||||||
);
|
);
|
||||||
|
# if has_mkstemp
|
||||||
|
close(fd);
|
||||||
|
# endif
|
||||||
# else
|
# else
|
||||||
static char tpnamebuf[TEMPNAMES][L_tmpnam];
|
static char tpnamebuf[TEMPNAMES][L_tmpnam];
|
||||||
p = tpnamebuf[n];
|
p = tpnamebuf[n];
|
||||||
|
2
external/gpl2/rcs/dist/src/rcsfreeze.sh
vendored
2
external/gpl2/rcs/dist/src/rcsfreeze.sh
vendored
@ -25,7 +25,7 @@
|
|||||||
# {RCS/}.rcsfreeze.ver version number
|
# {RCS/}.rcsfreeze.ver version number
|
||||||
# {RCS/}.rscfreeze.log log messages, most recent first
|
# {RCS/}.rscfreeze.log log messages, most recent first
|
||||||
|
|
||||||
PATH=/usr/local/bin:/bin:/usr/bin:/usr/ucb:$PATH
|
PATH=/bin:/usr/bin:$PATH
|
||||||
export PATH
|
export PATH
|
||||||
|
|
||||||
DATE=`date` || exit
|
DATE=`date` || exit
|
||||||
|
5
external/gpl2/rcs/dist/src/rcsgen.c
vendored
5
external/gpl2/rcs/dist/src/rcsgen.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcsgen.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcsgen.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Generate RCS revisions. */
|
/* Generate RCS revisions. */
|
||||||
|
|
||||||
@ -446,7 +446,7 @@ getsstdin(option, name, note, buf)
|
|||||||
c = getcstdin(), !feof(stdin);
|
c = getcstdin(), !feof(stdin);
|
||||||
bufrealloc(buf, i+1), p = buf->string, p[i++] = c
|
bufrealloc(buf, i+1), p = buf->string, p[i++] = c
|
||||||
)
|
)
|
||||||
if (c == '\n')
|
if (c == '\n') {
|
||||||
if (i && p[i-1]=='.' && (i==1 || p[i-2]=='\n')) {
|
if (i && p[i-1]=='.' && (i==1 || p[i-2]=='\n')) {
|
||||||
/* Remove trailing '.'. */
|
/* Remove trailing '.'. */
|
||||||
--i;
|
--i;
|
||||||
@ -455,6 +455,7 @@ getsstdin(option, name, note, buf)
|
|||||||
aputs(">> ", stderr);
|
aputs(">> ", stderr);
|
||||||
eflush();
|
eflush();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return cleanlogmsg(p, i);
|
return cleanlogmsg(p, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
5
external/gpl2/rcs/dist/src/rcskeep.c
vendored
5
external/gpl2/rcs/dist/src/rcskeep.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcskeep.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcskeep.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Extract RCS keyword string values from working files. */
|
/* Extract RCS keyword string values from working files. */
|
||||||
|
|
||||||
@ -194,6 +194,9 @@ getoldkeys(fp)
|
|||||||
break;
|
break;
|
||||||
case Header:
|
case Header:
|
||||||
case Id:
|
case Id:
|
||||||
|
#ifdef LOCALID
|
||||||
|
case LocalId:
|
||||||
|
#endif
|
||||||
if (!(
|
if (!(
|
||||||
getval(fp, (struct buf*)0, false) &&
|
getval(fp, (struct buf*)0, false) &&
|
||||||
keeprev(fp) &&
|
keeprev(fp) &&
|
||||||
|
5
external/gpl2/rcs/dist/src/rcskeys.c
vendored
5
external/gpl2/rcs/dist/src/rcskeys.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcskeys.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcskeys.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* RCS keyword table and match operation */
|
/* RCS keyword table and match operation */
|
||||||
|
|
||||||
@ -73,6 +73,9 @@ char const *const Keyword[] = {
|
|||||||
/* This must be in the same order as rcsbase.h's enum markers type. */
|
/* This must be in the same order as rcsbase.h's enum markers type. */
|
||||||
0,
|
0,
|
||||||
AUTHOR, DATE, HEADER, IDH,
|
AUTHOR, DATE, HEADER, IDH,
|
||||||
|
#ifdef LOCALID
|
||||||
|
LOCALID,
|
||||||
|
#endif
|
||||||
LOCKER, LOG, NAME, RCSFILE, REVISION, SOURCE, STATE
|
LOCKER, LOG, NAME, RCSFILE, REVISION, SOURCE, STATE
|
||||||
};
|
};
|
||||||
|
|
||||||
|
12
external/gpl2/rcs/dist/src/rcslex.c
vendored
12
external/gpl2/rcs/dist/src/rcslex.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcslex.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcslex.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* lexical analysis of RCS files */
|
/* lexical analysis of RCS files */
|
||||||
|
|
||||||
@ -308,7 +308,7 @@ nextlex()
|
|||||||
* For ID's and NUM's, NextString is set to the character string.
|
* For ID's and NUM's, NextString is set to the character string.
|
||||||
* Assumption: nextc contains the next character.
|
* Assumption: nextc contains the next character.
|
||||||
*/
|
*/
|
||||||
{ register c;
|
{ int c;
|
||||||
declarecache;
|
declarecache;
|
||||||
register FILE *frew;
|
register FILE *frew;
|
||||||
register char * sp;
|
register char * sp;
|
||||||
@ -673,7 +673,7 @@ readstring()
|
|||||||
/* skip over characters until terminating single SDELIM */
|
/* skip over characters until terminating single SDELIM */
|
||||||
/* If foutptr is set, copy every character read to foutptr. */
|
/* If foutptr is set, copy every character read to foutptr. */
|
||||||
/* Does not advance nextlex at the end. */
|
/* Does not advance nextlex at the end. */
|
||||||
{ register c;
|
{ int c;
|
||||||
declarecache;
|
declarecache;
|
||||||
register FILE *frew;
|
register FILE *frew;
|
||||||
register RILE *fin;
|
register RILE *fin;
|
||||||
@ -706,7 +706,7 @@ printstring()
|
|||||||
* Does not advance nextlex at the end.
|
* Does not advance nextlex at the end.
|
||||||
*/
|
*/
|
||||||
{
|
{
|
||||||
register c;
|
int c;
|
||||||
declarecache;
|
declarecache;
|
||||||
register FILE *fout;
|
register FILE *fout;
|
||||||
register RILE *fin;
|
register RILE *fin;
|
||||||
@ -744,7 +744,7 @@ savestring(target)
|
|||||||
* Yield a copy of *TARGET, except with exact length.
|
* Yield a copy of *TARGET, except with exact length.
|
||||||
*/
|
*/
|
||||||
{
|
{
|
||||||
register c;
|
int c;
|
||||||
declarecache;
|
declarecache;
|
||||||
register FILE *frew;
|
register FILE *frew;
|
||||||
register char *tp;
|
register char *tp;
|
||||||
@ -999,7 +999,7 @@ fd2RILE(fd, name, type, status)
|
|||||||
if (!f->base) {
|
if (!f->base) {
|
||||||
catchmmapints();
|
catchmmapints();
|
||||||
f->base = (unsigned char *) mmap(
|
f->base = (unsigned char *) mmap(
|
||||||
(char *)0, s, PROT_READ, MAP_SHARED,
|
(char *)0, s, PROT_READ, MAP_FILE|MAP_SHARED,
|
||||||
fd, (off_t)0
|
fd, (off_t)0
|
||||||
);
|
);
|
||||||
# ifndef MAP_FAILED
|
# ifndef MAP_FAILED
|
||||||
|
2
external/gpl2/rcs/dist/src/rcsmap.c
vendored
2
external/gpl2/rcs/dist/src/rcsmap.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcsmap.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcsmap.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* RCS map of character types */
|
/* RCS map of character types */
|
||||||
|
|
||||||
|
2
external/gpl2/rcs/dist/src/rcsmerge.c
vendored
2
external/gpl2/rcs/dist/src/rcsmerge.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcsmerge.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcsmerge.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Merge RCS revisions. */
|
/* Merge RCS revisions. */
|
||||||
|
|
||||||
|
23
external/gpl2/rcs/dist/src/rcsrev.c
vendored
23
external/gpl2/rcs/dist/src/rcsrev.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcsrev.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcsrev.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Handle RCS revision numbers. */
|
/* Handle RCS revision numbers. */
|
||||||
|
|
||||||
@ -632,11 +632,19 @@ genbranch(bpoint, revno, length, date, author, state, store)
|
|||||||
);
|
);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (state && strcmp(state,trail->state)!=0) {
|
if (state) {
|
||||||
rcserror("Revision %s has state %s.",
|
const char *st;
|
||||||
trail->num,
|
|
||||||
trail->state ? trail->state : "<empty>"
|
if (trail->state == NULL)
|
||||||
);
|
st = "<empty>";
|
||||||
|
else if (strcmp(trail->state, state) != 0)
|
||||||
|
st = trail->state;
|
||||||
|
else
|
||||||
|
st = NULL;
|
||||||
|
|
||||||
|
if (st)
|
||||||
|
rcserror("Revision %s has state %s.",
|
||||||
|
trail->num, st);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -747,7 +755,7 @@ fexpandsym(source, target, fp)
|
|||||||
for (bp = tp; *bp=='0' && isdigit(bp[1]); bp++)
|
for (bp = tp; *bp=='0' && isdigit(bp[1]); bp++)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (!*bp)
|
if (!*bp) {
|
||||||
if (s || *sp!='.')
|
if (s || *sp!='.')
|
||||||
break;
|
break;
|
||||||
else {
|
else {
|
||||||
@ -763,6 +771,7 @@ fexpandsym(source, target, fp)
|
|||||||
bp = tp = target->string;
|
bp = tp = target->string;
|
||||||
tlim = tp + target->size;
|
tlim = tp + target->size;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
while ((*tp++ = *bp++))
|
while ((*tp++ = *bp++))
|
||||||
|
14
external/gpl2/rcs/dist/src/rcssyn.c
vendored
14
external/gpl2/rcs/dist/src/rcssyn.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcssyn.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcssyn.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* RCS file syntactic analysis */
|
/* RCS file syntactic analysis */
|
||||||
|
|
||||||
@ -173,6 +173,7 @@ char const
|
|||||||
Kauthor[] = "author",
|
Kauthor[] = "author",
|
||||||
Kbranch[] = "branch",
|
Kbranch[] = "branch",
|
||||||
Kcomment[] = "comment",
|
Kcomment[] = "comment",
|
||||||
|
Kcommitid[] = "commitid",
|
||||||
Kdate[] = "date",
|
Kdate[] = "date",
|
||||||
Kdesc[] = "desc",
|
Kdesc[] = "desc",
|
||||||
Kexpand[] = "expand",
|
Kexpand[] = "expand",
|
||||||
@ -432,6 +433,17 @@ getdelta()
|
|||||||
getkey(Knext);
|
getkey(Knext);
|
||||||
Delta->next = num = getdnum();
|
Delta->next = num = getdnum();
|
||||||
getsemi(Knext);
|
getsemi(Knext);
|
||||||
|
if (getkeyopt(Kcommitid)) {
|
||||||
|
if (nexttok == ID) {
|
||||||
|
Delta->commitid = NextString;
|
||||||
|
nextlex();
|
||||||
|
} else {
|
||||||
|
fatserror("missing %s", Kcommitid);
|
||||||
|
Delta->commitid = NULL;
|
||||||
|
}
|
||||||
|
getsemi(Kcommitid);
|
||||||
|
} else
|
||||||
|
Delta->commitid = NULL;
|
||||||
Delta->lockedby = 0;
|
Delta->lockedby = 0;
|
||||||
Delta->log.string = 0;
|
Delta->log.string = 0;
|
||||||
Delta->selector = true;
|
Delta->selector = true;
|
||||||
|
2
external/gpl2/rcs/dist/src/rcstime.c
vendored
2
external/gpl2/rcs/dist/src/rcstime.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcstime.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcstime.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Convert between RCS time format and Posix and/or C formats. */
|
/* Convert between RCS time format and Posix and/or C formats. */
|
||||||
|
|
||||||
|
7
external/gpl2/rcs/dist/src/rcsutil.c
vendored
7
external/gpl2/rcs/dist/src/rcsutil.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rcsutil.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rcsutil.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* RCS utility functions */
|
/* RCS utility functions */
|
||||||
|
|
||||||
@ -371,7 +371,7 @@ getusername(suspicious)
|
|||||||
faterror("no password entry for userid %lu",
|
faterror("no password entry for userid %lu",
|
||||||
(unsigned long)ruid()
|
(unsigned long)ruid()
|
||||||
);
|
);
|
||||||
name = pw->pw_name;
|
name = strdup(pw->pw_name);
|
||||||
#else
|
#else
|
||||||
#if has_setuid
|
#if has_setuid
|
||||||
faterror("setuid not supported");
|
faterror("setuid not supported");
|
||||||
@ -812,6 +812,9 @@ awrite(buf, chars, f)
|
|||||||
size_t chars;
|
size_t chars;
|
||||||
FILE *f;
|
FILE *f;
|
||||||
{
|
{
|
||||||
|
if (buf == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
/* Posix 1003.1-1990 ssize_t hack */
|
/* Posix 1003.1-1990 ssize_t hack */
|
||||||
while (SSIZE_MAX < chars) {
|
while (SSIZE_MAX < chars) {
|
||||||
if (Fwrite(buf, sizeof(*buf), SSIZE_MAX, f) != SSIZE_MAX)
|
if (Fwrite(buf, sizeof(*buf), SSIZE_MAX, f) != SSIZE_MAX)
|
||||||
|
18
external/gpl2/rcs/dist/src/rlog.c
vendored
18
external/gpl2/rcs/dist/src/rlog.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: rlog.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: rlog.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
/* Print log messages and other information about RCS files. */
|
/* Print log messages and other information about RCS files. */
|
||||||
|
|
||||||
@ -214,6 +214,7 @@ static char const *insDelFormat;
|
|||||||
static int branchflag; /*set on -b */
|
static int branchflag; /*set on -b */
|
||||||
static int exitstatus;
|
static int exitstatus;
|
||||||
static int lockflag;
|
static int lockflag;
|
||||||
|
static int commitid;
|
||||||
static struct Datepairs *datelist, *duelst;
|
static struct Datepairs *datelist, *duelst;
|
||||||
static struct Revpairs *revlist, *Revlst;
|
static struct Revpairs *revlist, *Revlst;
|
||||||
static struct authors *authorlist;
|
static struct authors *authorlist;
|
||||||
@ -224,7 +225,7 @@ static struct stateattri *statelist;
|
|||||||
mainProg(rlogId, "rlog", "Id: rlog.c,v 5.18 1995/06/16 06:19:24 eggert Exp ")
|
mainProg(rlogId, "rlog", "Id: rlog.c,v 5.18 1995/06/16 06:19:24 eggert Exp ")
|
||||||
{
|
{
|
||||||
static char const cmdusage[] =
|
static char const cmdusage[] =
|
||||||
"\nrlog usage: rlog -{bhLNRt} -ddates -l[lockers] -r[revs] -sstates -Vn -w[logins] -xsuff -zzone file ...";
|
"\nrlog usage: rlog -{cbhLNRt} -ddates -l[lockers] -r[revs] -sstates -Vn -w[logins] -xsuff -zzone file ...";
|
||||||
|
|
||||||
register FILE *out;
|
register FILE *out;
|
||||||
char *a, **newargv;
|
char *a, **newargv;
|
||||||
@ -251,6 +252,9 @@ mainProg(rlogId, "rlog", "Id: rlog.c,v 5.18 1995/06/16 06:19:24 eggert Exp ")
|
|||||||
argv = newargv;
|
argv = newargv;
|
||||||
while (a = *++argv, 0<--argc && *a++=='-') {
|
while (a = *++argv, 0<--argc && *a++=='-') {
|
||||||
switch (*a++) {
|
switch (*a++) {
|
||||||
|
case 'c':
|
||||||
|
commitid = true;
|
||||||
|
break;
|
||||||
|
|
||||||
case 'L':
|
case 'L':
|
||||||
onlylockflag = true;
|
onlylockflag = true;
|
||||||
@ -584,14 +588,17 @@ putadelta(node,editscript,trunk)
|
|||||||
date2str(node->date, datebuf),
|
date2str(node->date, datebuf),
|
||||||
node->author, node->state
|
node->author, node->state
|
||||||
);
|
);
|
||||||
|
if (commitid && node->commitid)
|
||||||
|
aprintf(out, " commitid: %s;", node->commitid);
|
||||||
|
|
||||||
if ( editscript )
|
if ( editscript ) {
|
||||||
if(trunk)
|
if(trunk)
|
||||||
aprintf(out, insDelFormat,
|
aprintf(out, insDelFormat,
|
||||||
editscript->deletelns, editscript->insertlns);
|
editscript->deletelns, editscript->insertlns);
|
||||||
else
|
else
|
||||||
aprintf(out, insDelFormat,
|
aprintf(out, insDelFormat,
|
||||||
editscript->insertlns, editscript->deletelns);
|
editscript->insertlns, editscript->deletelns);
|
||||||
|
}
|
||||||
|
|
||||||
newbranch = node->branches;
|
newbranch = node->branches;
|
||||||
if ( newbranch ) {
|
if ( newbranch ) {
|
||||||
@ -773,7 +780,7 @@ char *argv;
|
|||||||
/* and store in authorlist */
|
/* and store in authorlist */
|
||||||
|
|
||||||
{
|
{
|
||||||
register c;
|
int c;
|
||||||
struct authors * newauthor;
|
struct authors * newauthor;
|
||||||
|
|
||||||
argv--;
|
argv--;
|
||||||
@ -967,12 +974,13 @@ extractdelta(pdelta)
|
|||||||
while (strcmp(pstate->status, pdelta->state) != 0)
|
while (strcmp(pstate->status, pdelta->state) != 0)
|
||||||
if (!(pstate = pstate->nextstate))
|
if (!(pstate = pstate->nextstate))
|
||||||
return false;
|
return false;
|
||||||
if (lockflag) /* only locked revisions wanted */
|
if (lockflag) { /* only locked revisions wanted */
|
||||||
for (plock = Locks; ; plock = plock->nextlock)
|
for (plock = Locks; ; plock = plock->nextlock)
|
||||||
if (!plock)
|
if (!plock)
|
||||||
return false;
|
return false;
|
||||||
else if (plock->delta == pdelta)
|
else if (plock->delta == pdelta)
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
if ((prevision = Revlst)) /* only certain revs or branches wanted */
|
if ((prevision = Revlst)) /* only certain revs or branches wanted */
|
||||||
for (;;) {
|
for (;;) {
|
||||||
length = prevision->numfld;
|
length = prevision->numfld;
|
||||||
|
2
external/gpl2/rcs/dist/src/version.c
vendored
2
external/gpl2/rcs/dist/src/version.c
vendored
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: version.c,v 1.1.1.1 2016/01/14 03:05:06 christos Exp $ */
|
/* $NetBSD: version.c,v 1.2 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
#include "rcsbase.h"
|
#include "rcsbase.h"
|
||||||
char const RCS_version_string[] = "5.7";
|
char const RCS_version_string[] = "5.7";
|
||||||
|
406
external/gpl2/rcs/include/conf.h
vendored
Normal file
406
external/gpl2/rcs/include/conf.h
vendored
Normal file
@ -0,0 +1,406 @@
|
|||||||
|
/* RCS compile-time configuration */
|
||||||
|
|
||||||
|
/* $Id: conf.h,v 1.1 2016/01/14 04:22:39 christos Exp $ */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This file is generated automatically.
|
||||||
|
* If you edit it by hand your changes may be lost.
|
||||||
|
* Instead, please try to fix conf.sh,
|
||||||
|
* and send your fixes to rcs-bugs@cs.purdue.edu.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define exitmain(n) return n /* how to exit from main() */
|
||||||
|
/* #define _POSIX_C_SOURCE 2147483647L */ /* if strict C + Posix 1003.1b-1993 or later */
|
||||||
|
/* #define _POSIX_SOURCE */ /* if strict C + Posix 1003.1-1990 */
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <time.h>
|
||||||
|
|
||||||
|
/* Comment out #include lines below that do not work. */
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <dirent.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <limits.h>
|
||||||
|
/* #include <mach/mach.h> */
|
||||||
|
/* #include <net/errno.h> */
|
||||||
|
#include <pwd.h>
|
||||||
|
/* #include <siginfo.h> */
|
||||||
|
#include <signal.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/mman.h>
|
||||||
|
#include <sys/wait.h>
|
||||||
|
#include <ucontext.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <utime.h>
|
||||||
|
/* #include <vfork.h> */
|
||||||
|
|
||||||
|
/* Define boolean symbols to be 0 (false, the default), or 1 (true). */
|
||||||
|
#define has_sys_param_h 1 /* Does #include <sys/param.h> work? */
|
||||||
|
/* extern int errno; */ /* Uncomment if <errno.h> doesn't declare errno. */
|
||||||
|
#define has_readlink 1 /* Does readlink() work? */
|
||||||
|
#define readlink_isreg_errno EINVAL /* errno after readlink on regular file */
|
||||||
|
|
||||||
|
#if has_readlink && !defined(MAXSYMLINKS)
|
||||||
|
# if has_sys_param_h
|
||||||
|
# include <sys/param.h>
|
||||||
|
# endif
|
||||||
|
# ifndef MAXSYMLINKS
|
||||||
|
# define MAXSYMLINKS 20 /* BSD; not standard yet */
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Comment out the typedefs below if the types are already declared. */
|
||||||
|
/* Fix any uncommented typedefs that are wrong. */
|
||||||
|
/* typedef int mode_t; */
|
||||||
|
/* typedef long off_t; */
|
||||||
|
/* typedef int pid_t; */
|
||||||
|
/* typedef int sig_atomic_t; */
|
||||||
|
/* typedef unsigned size_t; */
|
||||||
|
/* typedef int ssize_t; */
|
||||||
|
/* typedef long time_t; */
|
||||||
|
/* typedef int uid_t; */
|
||||||
|
|
||||||
|
/* Comment out the keyword definitions below if the keywords work. */
|
||||||
|
/* #define const */
|
||||||
|
/* #define volatile */
|
||||||
|
|
||||||
|
/* Define boolean symbols to be 0 (false, the default), or 1 (true). */
|
||||||
|
#define has_prototypes 1 /* Do function prototypes work? */
|
||||||
|
#define has_stdarg 1 /* Does <stdarg.h> work? */
|
||||||
|
/* #define has_varargs ? */ /* Does <varargs.h> work? */
|
||||||
|
#define va_start_args 2 /* How many args does va_start() take? */
|
||||||
|
|
||||||
|
#if O_BINARY
|
||||||
|
/* Text and binary i/o behave differently. */
|
||||||
|
/* This is incompatible with Posix and Unix. */
|
||||||
|
# define FOPEN_RB "rb"
|
||||||
|
# define FOPEN_R_WORK (Expand==BINARY_EXPAND ? "r" : "rb")
|
||||||
|
# define FOPEN_WB "wb"
|
||||||
|
# define FOPEN_W_WORK (Expand==BINARY_EXPAND ? "w" : "wb")
|
||||||
|
# define FOPEN_WPLUS_WORK (Expand==BINARY_EXPAND ? "w+" : "w+b")
|
||||||
|
# define OPEN_O_BINARY O_BINARY
|
||||||
|
#else
|
||||||
|
/*
|
||||||
|
* Text and binary i/o behave the same.
|
||||||
|
* Omit "b", since some nonstandard hosts reject it.
|
||||||
|
*/
|
||||||
|
# define FOPEN_RB "r"
|
||||||
|
# define FOPEN_R_WORK "r"
|
||||||
|
# define FOPEN_WB "w"
|
||||||
|
# define FOPEN_W_WORK "w"
|
||||||
|
# define FOPEN_WPLUS_WORK "w+"
|
||||||
|
# define OPEN_O_BINARY 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* This may need changing on non-Unix systems (notably DOS). */
|
||||||
|
#define OPEN_CREAT_READONLY (S_IRUSR|S_IRGRP|S_IROTH) /* lock file mode */
|
||||||
|
#define OPEN_O_LOCK 0 /* extra open flags for creating lock file */
|
||||||
|
#define OPEN_O_WRONLY O_WRONLY /* main open flag for creating a lock file */
|
||||||
|
|
||||||
|
/* Define or comment out the following symbols as needed. */
|
||||||
|
#if has_prototypes
|
||||||
|
# define P(params) params
|
||||||
|
#else
|
||||||
|
# define P(params) ()
|
||||||
|
#endif
|
||||||
|
#if has_stdarg
|
||||||
|
# include <stdarg.h>
|
||||||
|
#else
|
||||||
|
# if has_varargs
|
||||||
|
# include <varargs.h>
|
||||||
|
# else
|
||||||
|
typedef char *va_list;
|
||||||
|
# define va_dcl int va_alist;
|
||||||
|
# define va_start(ap) ((ap) = (va_list)&va_alist)
|
||||||
|
# define va_arg(ap,t) (((t*) ((ap)+=sizeof(t))) [-1])
|
||||||
|
# define va_end(ap)
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#if va_start_args == 2
|
||||||
|
# define vararg_start va_start
|
||||||
|
#else
|
||||||
|
# define vararg_start(ap,p) va_start(ap)
|
||||||
|
#endif
|
||||||
|
#define bad_chmod_close 0 /* Can chmod() close file descriptors? */
|
||||||
|
#define bad_creat0 0 /* Do writes fail after creat(f,0)? */
|
||||||
|
#define bad_fopen_wplus 0 /* Does fopen(f,"w+") fail to truncate f? */
|
||||||
|
#define getlogin_is_secure 0 /* Is getlogin() secure? Usually it's not. */
|
||||||
|
#define has_attribute_noreturn 1 /* Does __attribute__((noreturn)) work? */
|
||||||
|
#if has_attribute_noreturn
|
||||||
|
# define exiting __attribute__((noreturn))
|
||||||
|
#else
|
||||||
|
# define exiting
|
||||||
|
#endif
|
||||||
|
#define has_dirent 1 /* Do opendir(), readdir(), closedir() work? */
|
||||||
|
#define void_closedir 0 /* Does closedir() yield void? */
|
||||||
|
#define has_fchmod 1 /* Does fchmod() work? */
|
||||||
|
#define has_fflush_input 0 /* Does fflush() work on input files? */
|
||||||
|
#define has_fputs 1 /* Does fputs() work? */
|
||||||
|
#define has_ftruncate 1 /* Does ftruncate() work? */
|
||||||
|
#define has_getuid 1 /* Does getuid() work? */
|
||||||
|
#define has_getpwuid 1 /* Does getpwuid() work? */
|
||||||
|
#define has_memcmp 1 /* Does memcmp() work? */
|
||||||
|
#define has_memcpy 1 /* Does memcpy() work? */
|
||||||
|
#define has_memmove 1 /* Does memmove() work? */
|
||||||
|
#define has_map_fd 0 /* Does map_fd() work? */
|
||||||
|
#define has_mmap 1 /* Does mmap() work on regular files? */
|
||||||
|
#define has_madvise 1 /* Does madvise() work? */
|
||||||
|
#define mmap_signal SIGBUS /* signal received if you reference nonexistent part of mmapped file */
|
||||||
|
#define has_rename 1 /* Does rename() work? */
|
||||||
|
#define bad_a_rename 0 /* Does rename(A,B) fail if A is unwritable? */
|
||||||
|
#define bad_b_rename 0 /* Does rename(A,B) fail if B is unwritable? */
|
||||||
|
#define bad_NFS_rename 0 /* Can rename(A,B) falsely report success? */
|
||||||
|
/* typedef int void; */ /* Some ancient compilers need this. */
|
||||||
|
#define VOID (void) /* 'VOID e;' discards the value of an expression 'e'. */
|
||||||
|
#define has_seteuid 1 /* Does seteuid() work? See ../INSTALL.RCS. */
|
||||||
|
#define has_setreuid 0 /* Does setreuid() work? See ../INSTALL.RCS. */
|
||||||
|
#define has_setuid 1 /* Does setuid() exist? */
|
||||||
|
#define has_sigaction 1 /* Does struct sigaction work? */
|
||||||
|
#define has_sa_sigaction 1 /* Does struct sigaction have sa_sigaction? */
|
||||||
|
#define has_signal 1 /* Does signal() work? */
|
||||||
|
#define signal_type void /* type returned by signal handlers */
|
||||||
|
#define sig_zaps_handler 0 /* Must a signal handler reinvoke signal()? */
|
||||||
|
/* #define has_sigblock ? */ /* Does sigblock() work? */
|
||||||
|
/* #define sigmask(s) (1 << ((s)-1)) */ /* Yield mask for signal number. */
|
||||||
|
typedef size_t fread_type; /* type returned by fread() and fwrite() */
|
||||||
|
typedef size_t freadarg_type; /* type of their size arguments */
|
||||||
|
typedef void *malloc_type; /* type returned by malloc() */
|
||||||
|
#define has_getcwd 1 /* Does getcwd() work? */
|
||||||
|
/* #define has_getwd ? */ /* Does getwd() work? */
|
||||||
|
#define needs_getabsname 0 /* Must we define getabsname? */
|
||||||
|
#define has_mktemp 1 /* Does mktemp() work? */
|
||||||
|
#define has_mkstemp 1 /* Does mkstemp() work? */
|
||||||
|
#define has_NFS 1 /* Might NFS be used? */
|
||||||
|
#define has_psiginfo 1 /* Does psiginfo() work? */
|
||||||
|
#define has_psignal 1 /* Does psignal() work? */
|
||||||
|
#define has_si_errno 1 /* Does siginfo_t have si_errno? */
|
||||||
|
/* #define has_sys_siglist ? */ /* Does sys_siglist[] work? */
|
||||||
|
/* #define strchr index */ /* Use old-fashioned name for strchr()? */
|
||||||
|
/* #define strrchr rindex */ /* Use old-fashioned name for strrchr()? */
|
||||||
|
#define bad_unlink 0 /* Does unlink() fail on unwritable files? */
|
||||||
|
#define has_vfork 1 /* Does vfork() work? */
|
||||||
|
#define has_fork 1 /* Does fork() work? */
|
||||||
|
#define has_spawn 0 /* Does spawn*() work? */
|
||||||
|
#define has_waitpid 1 /* Does waitpid() work? */
|
||||||
|
#define bad_wait_if_SIGCHLD_ignored 0 /* Does ignoring SIGCHLD break wait()? */
|
||||||
|
#define RCS_SHELL "/bin/sh" /* shell to run RCS subprograms */
|
||||||
|
#define has_printf_dot 1 /* Does "%.2d" print leading 0? */
|
||||||
|
#define has_vfprintf 1 /* Does vfprintf() work? */
|
||||||
|
#define has_attribute_format_printf 1 /* Does __attribute__((format(printf,N,N+1))) work? */
|
||||||
|
#if has_attribute_format_printf
|
||||||
|
# define printf_string(m, n) __attribute__((format(printf, m, n)))
|
||||||
|
#else
|
||||||
|
# define printf_string(m, n)
|
||||||
|
#endif
|
||||||
|
#if has_attribute_format_printf && has_attribute_noreturn
|
||||||
|
/* Work around a bug in GCC 2.5.x. */
|
||||||
|
# define printf_string_exiting(m, n) __attribute__((format(printf, m, n), noreturn))
|
||||||
|
#else
|
||||||
|
# define printf_string_exiting(m, n) printf_string(m, n) exiting
|
||||||
|
#endif
|
||||||
|
/* #define has__doprintf ? */ /* Does _doprintf() work? */
|
||||||
|
/* #define has__doprnt ? */ /* Does _doprnt() work? */
|
||||||
|
/* #undef EXIT_FAILURE */ /* Uncomment this if EXIT_FAILURE is broken. */
|
||||||
|
#define large_memory 1 /* Can main memory hold entire RCS files? */
|
||||||
|
#ifndef LONG_MAX
|
||||||
|
#ifdef _LP64
|
||||||
|
#define LONG_MAX 9223372036854775807L /* long maximum */
|
||||||
|
#else
|
||||||
|
#define LONG_MAX 2147483647L /* long maximum */
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
/* Do struct stat s and t describe the same file? Answer d if unknown. */
|
||||||
|
#define same_file(s,t,d) ((s).st_ino==(t).st_ino && (s).st_dev==(t).st_dev)
|
||||||
|
#define has_utimbuf 1 /* Does struct utimbuf work? */
|
||||||
|
#define CO "/usr/bin/co" /* name of 'co' program */
|
||||||
|
#define COMPAT2 0 /* Are version 2 files supported? */
|
||||||
|
#define DIFF "/usr/bin/diff" /* name of 'diff' program */
|
||||||
|
#define DIFF3 "/usr/bin/diff3" /* name of 'diff3' program */
|
||||||
|
#define DIFF3_BIN 1 /* Is diff3 user-visible (not the /usr/lib auxiliary)? */
|
||||||
|
#define DIFFFLAGS "-an" /* Make diff output suitable for RCS. */
|
||||||
|
#define DIFF_L 1 /* Does diff -L work? */
|
||||||
|
#define DIFF_SUCCESS 0 /* DIFF status if no differences are found */
|
||||||
|
#define DIFF_FAILURE 1 /* DIFF status if differences are found */
|
||||||
|
#define DIFF_TROUBLE 2 /* DIFF status if trouble */
|
||||||
|
#define ED "/bin/ed" /* name of 'ed' program (used only if !DIFF3_BIN) */
|
||||||
|
#define MERGE "/usr/bin/merge" /* name of 'merge' program */
|
||||||
|
#define TMPDIR "/tmp" /* default directory for temporary files */
|
||||||
|
#define SLASH '/' /* principal filename separator */
|
||||||
|
#define SLASHes '/' /* `case SLASHes:' labels all filename separators */
|
||||||
|
#define isSLASH(c) ((c) == SLASH) /* Is arg a filename separator? */
|
||||||
|
#define ROOTPATH(p) isSLASH((p)[0]) /* Is p an absolute pathname? */
|
||||||
|
#define X_DEFAULT ",v/" /* default value for -x option */
|
||||||
|
#define SLASHSLASH_is_SLASH 1 /* Are // and / the same directory? */
|
||||||
|
#define ALL_ABSOLUTE 1 /* Do all subprograms satisfy ROOTPATH? */
|
||||||
|
#define DIFF_ABSOLUTE 1 /* Is ROOTPATH(DIFF) true? */
|
||||||
|
#define SENDMAIL "/usr/sbin/sendmail" /* how to send mail */
|
||||||
|
#define TZ_must_be_set 0 /* Must TZ be set for gmtime() to work? */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Adjust the following declarations as needed. */
|
||||||
|
|
||||||
|
|
||||||
|
/* The rest is for the benefit of non-standard, traditional hosts. */
|
||||||
|
/* Don't bother to declare functions that in traditional hosts do not appear, */
|
||||||
|
/* or are declared in .h files, or return int or void. */
|
||||||
|
|
||||||
|
|
||||||
|
/* traditional BSD */
|
||||||
|
|
||||||
|
#if has_sys_siglist && !defined(sys_siglist)
|
||||||
|
extern char const * const sys_siglist[];
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* Posix (ISO/IEC 9945-1: 1990 / IEEE Std 1003.1-1990) */
|
||||||
|
|
||||||
|
/* <fcntl.h> */
|
||||||
|
#ifdef O_CREAT
|
||||||
|
# define open_can_creat 1
|
||||||
|
#else
|
||||||
|
# define open_can_creat 0
|
||||||
|
# define O_RDONLY 0
|
||||||
|
# define O_WRONLY 1
|
||||||
|
# define O_RDWR 2
|
||||||
|
# define O_CREAT 01000
|
||||||
|
# define O_TRUNC 02000
|
||||||
|
#endif
|
||||||
|
#ifndef O_EXCL
|
||||||
|
#define O_EXCL 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* <sys/stat.h> */
|
||||||
|
#ifndef S_IRUSR
|
||||||
|
# ifdef S_IREAD
|
||||||
|
# define S_IRUSR S_IREAD
|
||||||
|
# else
|
||||||
|
# define S_IRUSR 0400
|
||||||
|
# endif
|
||||||
|
# ifdef S_IWRITE
|
||||||
|
# define S_IWUSR S_IWRITE
|
||||||
|
# else
|
||||||
|
# define S_IWUSR (S_IRUSR/2)
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#ifndef S_IRGRP
|
||||||
|
# if has_getuid
|
||||||
|
# define S_IRGRP (S_IRUSR / 0010)
|
||||||
|
# define S_IWGRP (S_IWUSR / 0010)
|
||||||
|
# define S_IROTH (S_IRUSR / 0100)
|
||||||
|
# define S_IWOTH (S_IWUSR / 0100)
|
||||||
|
# else
|
||||||
|
/* single user OS -- not Posix or Unix */
|
||||||
|
# define S_IRGRP 0
|
||||||
|
# define S_IWGRP 0
|
||||||
|
# define S_IROTH 0
|
||||||
|
# define S_IWOTH 0
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#ifndef S_ISREG
|
||||||
|
#define S_ISREG(n) (((n) & S_IFMT) == S_IFREG)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* <sys/wait.h> */
|
||||||
|
#ifndef WEXITSTATUS
|
||||||
|
#define WEXITSTATUS(stat_val) ((unsigned)(stat_val) >> 8)
|
||||||
|
#undef WIFEXITED /* Avoid 4.3BSD incompatibility with Posix. */
|
||||||
|
#endif
|
||||||
|
#ifndef WIFEXITED
|
||||||
|
#define WIFEXITED(stat_val) (((stat_val) & 0377) == 0)
|
||||||
|
#endif
|
||||||
|
#ifndef WTERMSIG
|
||||||
|
#define WTERMSIG(stat_val) ((stat_val) & 0177)
|
||||||
|
#undef WIFSIGNALED /* Avoid 4.3BSD incompatibility with Posix. */
|
||||||
|
#endif
|
||||||
|
#ifndef WIFSIGNALED
|
||||||
|
#define WIFSIGNALED(stat_val) ((unsigned)(stat_val) - 1 < 0377)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* <unistd.h> */
|
||||||
|
char *getlogin P((void));
|
||||||
|
#ifndef STDIN_FILENO
|
||||||
|
# define STDIN_FILENO 0
|
||||||
|
# define STDOUT_FILENO 1
|
||||||
|
# define STDERR_FILENO 2
|
||||||
|
#endif
|
||||||
|
#if has_fork && !has_vfork
|
||||||
|
# undef vfork
|
||||||
|
# define vfork fork
|
||||||
|
#endif
|
||||||
|
#if has_getcwd || !has_getwd
|
||||||
|
char *getcwd P((char*,size_t));
|
||||||
|
#else
|
||||||
|
char *getwd P((char*));
|
||||||
|
#endif
|
||||||
|
#if has_setuid && !has_seteuid
|
||||||
|
# undef seteuid
|
||||||
|
# define seteuid setuid
|
||||||
|
#endif
|
||||||
|
#if has_spawn
|
||||||
|
# if ALL_ABSOLUTE
|
||||||
|
# define spawn_RCS spawnv
|
||||||
|
# else
|
||||||
|
# define spawn_RCS spawnvp
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
# if ALL_ABSOLUTE
|
||||||
|
# define exec_RCS execv
|
||||||
|
# else
|
||||||
|
# define exec_RCS execvp
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* utime.h */
|
||||||
|
#if !has_utimbuf
|
||||||
|
struct utimbuf { time_t actime, modtime; };
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* Standard C library */
|
||||||
|
|
||||||
|
/* <stdio.h> */
|
||||||
|
#ifndef L_tmpnam
|
||||||
|
#define L_tmpnam 32 /* power of 2 > sizeof("/usr/tmp/xxxxxxxxxxxxxxx") */
|
||||||
|
#endif
|
||||||
|
#ifndef SEEK_SET
|
||||||
|
#define SEEK_SET 0
|
||||||
|
#endif
|
||||||
|
#ifndef SEEK_CUR
|
||||||
|
#define SEEK_CUR 1
|
||||||
|
#endif
|
||||||
|
#if has_mktemp
|
||||||
|
char *mktemp P((char*)); /* traditional */
|
||||||
|
#else
|
||||||
|
char *tmpnam P((char*));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* <stdlib.h> */
|
||||||
|
char *getenv P((char const*));
|
||||||
|
#ifndef __NetBSD__
|
||||||
|
void _exit P((int)) exiting;
|
||||||
|
void exit P((int)) exiting;
|
||||||
|
#endif
|
||||||
|
malloc_type malloc P((size_t));
|
||||||
|
malloc_type realloc P((malloc_type,size_t));
|
||||||
|
#ifndef EXIT_FAILURE
|
||||||
|
#define EXIT_FAILURE 1
|
||||||
|
#endif
|
||||||
|
#ifndef EXIT_SUCCESS
|
||||||
|
#define EXIT_SUCCESS 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* <string.h> */
|
||||||
|
char *strcpy P((char*,char const*));
|
||||||
|
char *strchr P((char const*,int));
|
||||||
|
char *strrchr P((char const*,int));
|
||||||
|
void *memcpy P((void*,void const*,size_t));
|
||||||
|
#if has_memmove
|
||||||
|
void *memmove P((void*,void const*,size_t));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* <time.h> */
|
||||||
|
time_t time P((time_t*));
|
23
external/gpl2/rcs/lib/Makefile
vendored
Normal file
23
external/gpl2/rcs/lib/Makefile
vendored
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
# $NetBSD: Makefile,v 1.1 2016/01/14 04:22:39 christos Exp $
|
||||||
|
|
||||||
|
LIBISPRIVATE= yes
|
||||||
|
.include <bsd.init.mk>
|
||||||
|
|
||||||
|
# Define FSYNC_ALL to get slower but safer writes in case of crashes in
|
||||||
|
# the middle of CVS/RCS changes
|
||||||
|
CPPFLAGS+=-DFSYNC_ALL
|
||||||
|
|
||||||
|
# If you wish to use a different Id token in addition to Id,
|
||||||
|
# set the variable RCS_LOCALID in mk.conf or environment.
|
||||||
|
.if defined(RCS_LOCALID)
|
||||||
|
CPPFLAGS+=-DLOCALID=\"${RCS_LOCALID}\"
|
||||||
|
.endif
|
||||||
|
|
||||||
|
LIB= rcs
|
||||||
|
SRCS= maketime.c merger.c partime.c rcsedit.c rcsfcmp.c rcsfnms.c rcsgen.c \
|
||||||
|
rcskeep.c rcskeys.c rcslex.c rcsmap.c rcsrev.c rcssyn.c rcstime.c \
|
||||||
|
rcsutil.c version.c
|
||||||
|
|
||||||
|
CWARNFLAGS.clang+= -Wno-format-security -Wno-string-plus-int
|
||||||
|
|
||||||
|
.include <bsd.lib.mk>
|
134
external/gpl2/rcs/rcs2netbsd
vendored
Executable file
134
external/gpl2/rcs/rcs2netbsd
vendored
Executable file
@ -0,0 +1,134 @@
|
|||||||
|
#! /bin/sh
|
||||||
|
#
|
||||||
|
# $NetBSD: rcs2netbsd,v 1.1 2016/01/14 04:22:38 christos Exp $
|
||||||
|
#
|
||||||
|
# Copyright (c) 2016 The NetBSD Foundation, Inc.
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions
|
||||||
|
# are met:
|
||||||
|
# 1. Redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer.
|
||||||
|
# 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer in the
|
||||||
|
# documentation and/or other materials provided with the distribution.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
|
||||||
|
# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
||||||
|
# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||||
|
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
|
||||||
|
# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
# POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
#
|
||||||
|
# rcs2netbsd: convert an glibc source tree into a
|
||||||
|
# netbsd rcs source tree,
|
||||||
|
#
|
||||||
|
# Rough instructions for importing new rcs release:
|
||||||
|
#
|
||||||
|
# $ cd /some/where/temporary
|
||||||
|
# $ tar xpfz /malloc/release/tar/file
|
||||||
|
# $ sh /usr/src/external/gpl2/rcs/rcs2netbsd malloc `pwd`
|
||||||
|
# $ cd `pwd`/src/external/gpl2/rcs/dist
|
||||||
|
# $ cvs import -m "Import rcs rcs x.y" src/external/gpl2/rcs/dist FSF rcs-x-y
|
||||||
|
# merge sources according to instructions given
|
||||||
|
# e.g. cvs -d cvs.netbsd.org:/cvsroot checkout -jrcs-1-19 -jrcs-1-19-1 src/gnu/dist/rcs
|
||||||
|
|
||||||
|
if [ $# -ne 2 ]; then echo "rcs2netbsd src dest"; exit 1; fi
|
||||||
|
|
||||||
|
r=$1
|
||||||
|
d=$2/src/external/gpl2/rcs/dist
|
||||||
|
|
||||||
|
case "$d" in
|
||||||
|
/*)
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
d=`/bin/pwd`/$d
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
case "$r" in
|
||||||
|
/*)
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
r=`/bin/pwd`/$r
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
echo preparing directory $d
|
||||||
|
rm -rf $d
|
||||||
|
mkdir -p $d
|
||||||
|
|
||||||
|
### Copy the files and directories
|
||||||
|
echo copying $r to $d
|
||||||
|
cd $r
|
||||||
|
pax -rw * $d
|
||||||
|
chmod -x $d/*
|
||||||
|
|
||||||
|
# cd to import directory
|
||||||
|
cd $d
|
||||||
|
|
||||||
|
#
|
||||||
|
|
||||||
|
### Remove the $'s around RCS tags
|
||||||
|
cleantags $d
|
||||||
|
|
||||||
|
### Add our NetBSD RCS Id
|
||||||
|
find $d -type f -name '*.[chly]' -print | while read c; do
|
||||||
|
sed 1q < $c | grep -q '\$NetBSD' || (
|
||||||
|
echo "/* \$NetBSD\$ */" >/tmp/rcs3n$$
|
||||||
|
echo "" >>/tmp/rcs3n$$
|
||||||
|
cat $c >> /tmp/rcs3n$$
|
||||||
|
mv /tmp/rcs3n$$ $c && echo added NetBSD RCS tag to $c
|
||||||
|
)
|
||||||
|
done
|
||||||
|
|
||||||
|
find $d -type f -name '*.cpp' -print | while read c; do
|
||||||
|
sed 1q < $c | grep -q '\$NetBSD' || (
|
||||||
|
echo "/* \$NetBSD\$ */" >/tmp/rcs3n$$
|
||||||
|
echo "" >>/tmp/rcs3n$$
|
||||||
|
cat $c >> /tmp/rcs3n$$
|
||||||
|
mv /tmp/rcs3n$$ $c && echo added NetBSD RCS tag to $c
|
||||||
|
)
|
||||||
|
done
|
||||||
|
|
||||||
|
find $d -type f -name '*.[0-9]' -print | while read m; do
|
||||||
|
sed 1q < $m | grep -q '\$NetBSD' || (
|
||||||
|
echo ".\\\" \$NetBSD\$" >/tmp/rcs2m$$
|
||||||
|
echo ".\\\"" >>/tmp/rcs2m$$
|
||||||
|
cat $m >> /tmp/rcs2m$$
|
||||||
|
mv /tmp/rcs2m$$ $m && echo added NetBSD RCS tag to $m
|
||||||
|
)
|
||||||
|
done
|
||||||
|
|
||||||
|
find $d -type f -name '*.texi' -print | while read t; do
|
||||||
|
sed "2 s/^/@c \$NetBSD\$\\
|
||||||
|
/" < $t > /tmp/rcs4t$$
|
||||||
|
mv /tmp/rcs4t$$ $t && echo added NetBSD RCS tag to $t
|
||||||
|
done
|
||||||
|
|
||||||
|
echo done
|
||||||
|
|
||||||
|
### Clean up any CVS directories that might be around.
|
||||||
|
echo "cleaning up CVS residue."
|
||||||
|
(
|
||||||
|
cd $d
|
||||||
|
find . -type d -name "CVS" -print | xargs rm -r
|
||||||
|
)
|
||||||
|
echo done
|
||||||
|
|
||||||
|
### Fixing file and directory permissions.
|
||||||
|
echo "Fixing file/directory permissions."
|
||||||
|
(
|
||||||
|
cd $d
|
||||||
|
find . -type f -print | xargs chmod u+rw,go+r
|
||||||
|
find . -type d -print | xargs chmod u+rwx,go+rx
|
||||||
|
)
|
||||||
|
echo done
|
||||||
|
|
||||||
|
exit 0
|
Loading…
Reference in New Issue
Block a user