diff options
author | Fernando ApesteguĂa <fernape@FreeBSD.org> | 2018-09-28 17:47:39 +0000 |
---|---|---|
committer | Fernando ApesteguĂa <fernape@FreeBSD.org> | 2018-09-28 17:47:39 +0000 |
commit | f12dc10f3e5f7d9537307a0c9f56683fd308beb6 (patch) | |
tree | cfea0ed52766d8fdcd2c9e2b033fac72f60601e8 | |
parent | fb5a9f8874400dd77fd77749ac65e39b89ab1b72 (diff) |
editors/teco: Improve documentation and set maintainership
* Add detailed man page
* Add DOCS option
* Add LICENSE
* Give maintainership to submitter
PR: 231184
Submitted by: bob@eager.cx
Approved by: tcberner (mentor)
Differential Revision: https://reviews.freebsd.org/D17228
Notes
Notes:
svn path=/head/; revision=480869
-rw-r--r-- | editors/teco/Makefile | 14 | ||||
-rw-r--r-- | editors/teco/files/patch-src_makefile (renamed from editors/teco/files/patch-makefile) | 6 | ||||
-rw-r--r-- | editors/teco/files/patch-src_skpcmd.c | 92 | ||||
-rw-r--r-- | editors/teco/files/patch-src_zlinux.c (renamed from editors/teco/files/patch-zlinux) | 8 | ||||
-rw-r--r-- | editors/teco/files/teco.1.in | 506 | ||||
-rw-r--r-- | editors/teco/pkg-descr | 8 | ||||
-rw-r--r-- | editors/teco/pkg-message | 44 | ||||
-rw-r--r-- | editors/teco/pkg-plist | 1 |
8 files changed, 655 insertions, 24 deletions
diff --git a/editors/teco/Makefile b/editors/teco/Makefile index c82c8a0f541a..69eb8de869d5 100644 --- a/editors/teco/Makefile +++ b/editors/teco/Makefile @@ -3,25 +3,33 @@ PORTNAME= teco PORTVERSION= 0398 +PORTREVISION= 1 CATEGORIES= editors MASTER_SITES= http://almy.us/files/ DISTNAME= tecoclinux${PORTVERSION} -MAINTAINER= ports@FreeBSD.org +MAINTAINER= bob@eager.cx COMMENT= Powerful and compact editor with nongraphical user interface +LICENSE= BSD3CLAUSE + +CFLAGS+= -Wno-pointer-sign -Wno-expansion-to-defined -Wno-int-to-pointer-cast MAKEFILE= makefile + WRKSRC= ${WRKDIR}/tecoc${PORTVERSION} BUILD_WRKSRC= ${WRKSRC}/src ALL_TARGET= # empty -DOCSFILES= src/readme.1st src/readme.lnx src/changes.txt src/aaout.txt \ - src/problems.txt src/video.txt doc/teco.doc doc/wchart.txt +SUB_FILES= teco.1 OPTIONS_DEFINE= DOCS +DOCSFILES= src/readme.1st src/readme.lnx src/changes.txt src/aaout.txt \ + src/problems.txt src/video.txt doc/teco.doc doc/wchart.txt + do-install: ${INSTALL_PROGRAM} ${WRKSRC}/src/tecoc ${STAGEDIR}${PREFIX}/bin + ${INSTALL_MAN} ${WRKDIR}/teco.1 ${STAGEDIR}${PREFIX}/man/man1 @${MKDIR} ${STAGEDIR}${DATADIR} ${INSTALL_DATA} ${WRKSRC}/lib/* ${STAGEDIR}${DATADIR} diff --git a/editors/teco/files/patch-makefile b/editors/teco/files/patch-src_makefile index 82e791bad6e5..153a027cd835 100644 --- a/editors/teco/files/patch-makefile +++ b/editors/teco/files/patch-src_makefile @@ -1,5 +1,5 @@ ---- src/makefile.orig Fri May 21 18:26:06 2004 -+++ src/makefile Tue Feb 15 03:20:32 2005 +--- src/makefile.orig 2004-05-21 14:26:06 UTC ++++ src/makefile @@ -23,11 +23,11 @@ # COMPILE.c macro so it doesn't stick in the -target option, which gcc # doesn't understand. @@ -15,7 +15,7 @@ ############################################################################# -@@ -56,7 +56,7 @@ +@@ -56,7 +56,7 @@ tecoc: tecoc.o ${OBJECTS} tecoc.o: tecoc.c zport.h tecoc.h deferr.h dchars.h chmacs.h clpars.h: genclp clpars.tec diff --git a/editors/teco/files/patch-src_skpcmd.c b/editors/teco/files/patch-src_skpcmd.c new file mode 100644 index 000000000000..add5070b7bd2 --- /dev/null +++ b/editors/teco/files/patch-src_skpcmd.c @@ -0,0 +1,92 @@ +--- src/skpcmd.c.orig 1991-07-12 04:21:24 UTC ++++ src/skpcmd.c +@@ -84,13 +84,17 @@ static DEFAULT SkpCtU() /* skip control + BOOLEAN TTrace; /* temp: holds trace flag */ + + if (CBfPtr == CStEnd) ++ { + if (MStTop < 0) /* if not in a macro */ + { + ErrUTC(); /* unterminated command */ + return FAILURE; + } + else ++ { + return SUCCESS; ++ } ++ } + ++CBfPtr; + TTrace = TraceM; /* save trace mode flag */ + TraceM = FALSE; /* keep FindES from tracing */ +@@ -145,13 +149,17 @@ static DEFAULT SkpDqu() /* skip a " (do + { + DBGFEN(3,"SkpDqu",NULL); + if (CBfPtr == CStEnd) /* if end of command string */ ++ { + if (MStTop < 0) /* if not in a macro */ + { + ErrUTC(); /* unterminated command */ + return FAILURE; + } + else ++ { + return SUCCESS; ++ } ++ } + ++CBfPtr; + switch (To_Upper(*CBfPtr)) { + case 'A': +@@ -232,13 +240,17 @@ static DEFAULT SkpSkp() /* */ + static DEFAULT SkpF() /* skip one of the F commands */ + { + if (CBfPtr == CStEnd) ++ { + if (MStTop < 0) /* if not in a macro */ + { + ErrUTC(); /* unterminated command */ + return FAILURE; + } + else ++ { + return SUCCESS; ++ } ++ } + ++CBfPtr; + + switch (To_Upper(*CBfPtr)) { +@@ -320,13 +332,17 @@ static DEFAULT SkpCrt() /* skip a ^ (ca + WORD CDummy; + + if (CBfPtr == CStEnd) /* if end of command string */ ++ { + if (MStTop < 0) /* if macro stack empty */ + { + ErrUTC(); /* unterminated command */ + return FAILURE; + } + else ++ { + return SUCCESS; ++ } ++ } + ++CBfPtr; + if ((*CBfPtr >= 'A') && (*CBfPtr <= '_')) + CDummy = *CBfPtr - 'A'; +@@ -360,13 +376,17 @@ static DEFAULT SkpE() /* skip one of t + /* Y */ SkpSkp, /* Z */ SkpSkp + }; + if (CBfPtr == CStEnd) ++ { + if (MStTop < 0) /* if not in a macro */ + { + ErrUTC(); /* unterminated command */ + return FAILURE; + } + else ++ { + return SUCCESS; ++ } ++ } + + ++CBfPtr; + TmpChr = To_Upper(*CBfPtr); diff --git a/editors/teco/files/patch-zlinux b/editors/teco/files/patch-src_zlinux.c index 14d8f2b01dcc..98f362d2ae96 100644 --- a/editors/teco/files/patch-zlinux +++ b/editors/teco/files/patch-src_zlinux.c @@ -1,5 +1,5 @@ ---- src/zlinux.c.orig Tue Feb 15 20:15:29 2005 -+++ src/zlinux.c Tue Feb 15 20:22:42 2005 +--- src/zlinux.c.orig 2004-05-21 20:59:29 UTC ++++ src/zlinux.c @@ -10,7 +10,6 @@ #include <sys/types.h> /* needed before sys/param.h is included */ @@ -8,7 +8,7 @@ #include <signal.h> /* to catch ^C and ^Z signals */ #include <stdio.h> /* define stdin */ #include <string.h> /* strncpy(), strlen(), etc. */ -@@ -50,8 +49,6 @@ +@@ -50,8 +49,6 @@ char *tgetstr(); /* get str value of a static int vernum(); /* see bottom of this file */ @@ -17,7 +17,7 @@ static int SupGotCtC = 0; static glob_t pglob; -@@ -1057,9 +1054,9 @@ +@@ -1057,9 +1054,9 @@ char *argv[]; * execute imbedded command line-parsing macro directly from clpars[] */ diff --git a/editors/teco/files/teco.1.in b/editors/teco/files/teco.1.in new file mode 100644 index 000000000000..1df2c4a0a8e5 --- /dev/null +++ b/editors/teco/files/teco.1.in @@ -0,0 +1,506 @@ +.Dd September 05, 2018 +.Os +.Dt TECO 1 CON +.Sh NAME +.Nm teco +.Nd The grand old text editor +.Sh SYNOPSIS +.Cm tecoc +.Cm make +.Op Fl noini +.Op Fl nomemory +.Ar file +.br +.Cm tecoc +.Cm teco +.Op Fl inspect +.Op Fl nocreate +.Op Fl noini +.Op Fl nomemory +.Op Fl nopage +.Op Fl norename +.Op Sy +nnn +.Ar file +.br +.Cm tecoc +.Cm mung +.Op Fl noini +.Ar file +.Sh DESCRIPTION +This description section is sufficiently long that it has been split into a number of subsections. +.Ss Command names +.Nm +is actually invoked by the command +.Sy tecoc . +It takes a first argument of +.Cm make , +.Cm teco , +or +.Cm mung +to control its operating mode. In the +.Fx +version, the base name of the invoking command is tested to provide this +first argument. For ease of use, it is recommended that aliases are set +up. The recommended (and usual) mappings are: +.Bl -tag -width inspect +.It Sy Make +to +.Sy tecoc make +(note the uppercase first letter to avoid confusion with +.Xr make 1 ) +.It Sy teco +to +.Sy tecoc teco +.It Sy mung +to +.Sy tecoc mung +.It Sy inspect +to +.Sy tecoc teco -inspect +.El +.Pp +These mappings are assumed in the +.Sx Options +and +.Sx Command invocations +sections below. +.Ss Options +Options may be abbreviated; for each option, the part shown in brackets can be omitted. +The following options are available for the +.Nm +command: +.Bl -tag -width nocreate +.It Fl in[spect] +read the file only, don't create an output file. +.It Fl noc[reate] +if the file doesn't exist, don't create it. +.It Fl noi[ni] +don't execute the initialisation file. This is valid for +.Sy Make +or +.Sy mung +as well. +.It Fl nom[emory] +don't remember the filename (see +.Sx Filename memory +below). This is valid for +.Sy Make +also. +.It Fl nop[age] +don't separate input into pages. Instead, treat form feeds as normal characters. +.It Fl nor[ename] +don't rename files, but copy them to keep references correct +.It Sy +nnn +where +.Ar nnn +is any number of digits. Go to line number +.Ar nnn +and set +.Fl nopage . +.El +.Ss Command invocations +.Pp +There are a number of different ways of starting +.Nm . +.Bl -tag +.It Sy Make Ar file +starts +.Nm +to create +.Ar file . +.br +This is equivalent to +.Li EWfile$$ +.It Sy teco Ar file +starts +.Nm +to edit +.Ar file . +.br +This is equivalent to +.Li EBfile$Y$$ +.It Sy teco Ar file2=file1 +starts +.Nm +to edit +.Ar file1 , +writing to +.Ar file2. +.br +This is equivalent to +.Li ERfile1$EWfile2$Y$$ +.It Sy teco +starts +.Nm +to edit the last edited file. +By default, the name of that file is saved in a file named +.Pa tecoN.tmp +in the current directory, where +.Em N +is the process ID of the parent process to +.Nm . +This can be overridden, as described in +.Sx Filename memory +below. +.It Sy mung Ar file args +starts +.Nm +to execute +.Ar file. +.br +This is equivalent to +.Li I<args>$JEIfile$$ +.br +Instead of +.Sy mung , +the command +.Sy teco Ar @file args +can be used. +.El +.Pp +.Ss Key Bindings +The keys mentioned in the +.Pa teco.doc +file are somewhat confusing. This should help: +.Bl -tag -width <DELETE> +.It Li <DELIM> +The +.Li Esc +echoes as +.Li $ , +however the +.Pa teco.doc +file shows it as +.Li ` . +.It Li <BS> +Type as +.Li Control-H ; +this isn't the +.Li Backspace +key. +.It Li <DELETE> +The +.Li Backspace +key; this isn't the +.Li Delete +key. +.It Li <CR> +The +.Li Enter +key. +.It Li <LF> +Type as +.Li Control-J . +.El +.Pp +Note that the assignments for +.Li <BS> +and +.Li <DELETE> +shown here are +swapped. +.Li <BS> +can be +.Li Backspace +and +.Li <DELETE> +can be +.Li Control-H +by +clearing +.Li ET&2048 , +e.g. +.Li 2048,0ET +.Ss Initialisation file +.Nm +.Em mungs +(executes as +.Nm +commands) the file +.Pa TECO.INI +(yes, in uppercase) in the +current directory before processing the command line. Initialisation +can be done instead by defining an environment variable named +.Ev TEC_INIT . +The value is either the list of +.Nm +commands to execute, or a +.Li $ +followed by the pathname of the initialisation file. This allows a +single, centrally located initialisation file. Remember that the +.Li $ +must be escaped with a backslash character. +.Pp +The initialisation file can be used to make initial settings. It can +return a value, but the value setting is somewhat obscure. +.Pp +For example, the following will both cause successful searches to +auto-display in all +.Nm +sessions. +.Pp +.Bl -tag -compact -offset indent -width Examplex(bash)x +.It Example (csh): +.Li setenv +.Ev TEC_INIT +1es +.It Example (bash): +.Li TEC_INIT=1es +.br +.Li export TEC_INIT +.El +.Pp +The following will each cause the file +.Pa ~/.tecrc +to be used as the initialisation file. +.Bl -tag -compact -offset indent -width Examplex(bash)x +.It Example (csh): +.Li setenv TEC_INIT \e$~/.tecrc +.It Example (bash): +.Li TEC_INIT=\e$~/.tecrc +.br +.Li export TEC_INIT +.El +.Ss Filename memory +.Nm +tries to remember the last file that it edited, +so that after a file has been edited once, it can be re-edited without +the file name having to be repeated on the command line. +.Nm +implements this by writing and reading a file that contains +the name of the last file edited. By default, the file name is +.Pa tecoN.tmp +in the current directory, where +.Em N +is the process ID of the parent process to +.Nm . +.Pp +To change the location of the memory file, +define the environment variable +.Ev TEC_MEMORY +to be +.Li $ +followed by the +pathname of the file to be designated as the memory file. +Remember that the +.Li $ +must be escaped with a backslash character. +.Pp +The following examples will cause the name of the last +file edited to be stored in the file +.Pa teco.mem +in the home directory. +.Pp +.Bl -tag -compact -offset indent -width Examplex(bash)x +.It Example (csh): +.Li setenv TEC_MEMORY \e$~/teco.mem +.It Example (bash): +.Li TEC_MEMORY=\e$~/teco.mem +.br +.Li export TEC_MEMORY +.El +.Pp +.Ss Library directory +The environment variable +.Ev TEC_LIBRARY +can be set to be a directory path (including the final +.Pa / Ns ); +the path must be preceded by a +.Li $ +character. This allows the +.Li EI +command to fetch +.Nm +commands from this directory if the file is not found in the +current directory. Remember that the +.Li $ +must be escaped with a backslash character. +.Pp +.Bl -tag -compact -offset indent -width Examplex(bash)x +.It Example (csh): +.Li setenv TEC_LIBRARY \e$%%PREFIX%%/lib/ +.It Example (bash): +.Li TEC_LIBRARY=\e$/usr/%%PREFIX%%/lib/ +.br +.Li export TEC_LIBRARY +.El +.Pp +This will cause the directory +.Pa %%PREFIX%%/lib +to be searched for +.Nm teco +command files. +.Ss Implemented flags +There are a number of flags that can be set inside +.Nm , +using the +.Li ED +and +.Li ET +mode control commands. To add functionality, +.Nm +is also sensitive to bits in an extra mode control +flag, +.Li EZ . +Bits in the +.Li EZ +mode control command are +used in different ways by different operating systems; only those +relevant to +.Fx +are described here. +.Pp +.Bl -tag -compact -offset indent -width ETx32768 +.It Li ED&1 +Allow the caret +.Li ^ +character in string searches. +.It Li ED&2 +Allow yank and _ unconditionally. +.It Li ED&16 +Failed searches preserve dot. +.It Li ED&64 +Move dot by one after each match in multiple occurrence searches. +.El +.Pp +.Bl -tag -compact -offset indent -width ETx32768 +.It Li ET&1 +Type out in image mode. +.It Li ET&2 +Use scope for delete and +.Li Control-U +(default=1) +.It Li ET&4 +Accept lowercase input (default=1). +.It Li ET&8 +.Li Control-T +reads without echo. +.It Li ET&32 +.Li Control-T +reads with no wait. +.It Li ET&128 +.Em mung +mode (abort on error); cleared by +.Li * +prompt. +.It Li ET&2048 +Swap backspace and delete. +.It Li ET&4096 +We are using 8 bit characters (default=1). +.It Li ET&32768 +Trap +.Li Control-C . +.El +.Pp +.Bl -tag -compact -offset indent -width ET&32768 +.It Li EZ&128 +If set, don't stop on form feeds when reading. If clear, a form +feed in the input stream stops the read (the standard +.Nm +style). +This bit is off by default. +.It Li EZ&256 +If set, use UNIX-style newline terminators. This means when files +are read in, carriage-returns are not added to the end of lines, +and when the user types the RETURN key, only a newline is entered +into the command line (usually a carriage-return/line-feed pair is +entered). Old macros (and old +.Nm +users) may get confused if this +bit is set. +.It Li EZ&16384 +Normally, the backup file name is created by replacing the file extension +with +.Pa .bak +- +.Pa foo.c +becomes +.Pa foo.bak ; +however, if this bit is set then the backup file name is created by simply +adding +.Pa .bak +to the name - +.Pa foo.c +becomes +.Pa foo.c.bak . +This choice is overridden by +.Li EZ&1 = 0 . +.El +.Sh ENVIRONMENT +The following environment variables are used by +.Nm : +.Bl -tag -width TECO_LIBRARY +.It Ev TECO_INIT +The value of this variable can be either a +.Nm +command string, or the name of a file containing +.Nm +commands. The filename must be preceded by a +.Li $ +character. Remember that the +.Li $ +must be escaped with a backslash character. +See also +.Sx Initialisation file Ns No . +.It Ev TECO_LIBRARY +The value of this variable should be a path to the directory +that contains files of +.Nm +commands, to be accessed using +.Li XX . +The pathname should include the trailing +.Li / Ns No . +Remember that the +.Li $ +must be escaped with a backslash character. +See also +.Sx Library directory Ns No . +.It Ev TECO_MEMORY +The value of this variable should be the name of a file +To be used for remembereing the name of the last file +edited by +.Nm . +The filename must be preceded by a +.Li $ +character. Remember that the +.Li $ +must be escaped with a backslash character. +See also +.Sx Filename memory Ns No . +.El +.Sh FILES +.Bl -tag +.It Pa %%DATADIR%%/* +Miscellaneous +.Nm +macros and commands. +.It Pa %%DOCSDIR%%/teco.doc +The +.Nm +manual (if installed). +.It Pa %%DOCSDIR%%/wchart.txt +Summary of +.Nm +keystrokes (if installed). +.El +.Sh EXIT STATUS +.Ex -std +.Sh SEE ALSO +A variety of documentation files may be installed in +.Pa %%DOCSDIR%% . +Apart from the ones mentioned in the +.Sx FILES +section, they are of limited use, because they refer to +slightly different versions of +.Nm . +.Pp +There are also many online resources. +.Sh AUTHORS +.An "Pete Siemsen" Aq siemsen@usc.edu . +.br +.An "Tom Almy" Aq tomalmy@aracnet.com . +.br +FreeBSD port and manual page maintained by +.An "Bob Eager" Aq bob@eager.cx . +.Sh BUGS +There is no video mode. diff --git a/editors/teco/pkg-descr b/editors/teco/pkg-descr index 74b7cc224873..687c2c9b54ee 100644 --- a/editors/teco/pkg-descr +++ b/editors/teco/pkg-descr @@ -1,8 +1,8 @@ -TECO is the grand old text editor. It is powerful and compact precursor -to EMACS and has a completely nongraphical user interface. It is very fast -(probably the fastes editor in the world) and have a macro language. TECO +TECO is the grand old text editor. It is a powerful and compact precursor +to EMACS, and has a completely nongraphical user interface. It is very fast +(probably the fastest editor in the world) and has a macro language. TECO was written by Dan Murphy (http://www.opost.com/dlm) at Digital Equipment Corporation in 1962. This is based on Pete Siemsen's TECOC implementation, -and comes with a copy of the originals DECUS TECO documentation. +and comes with a copy of the original's DECUS TECO documentation. WWW: http://almy.us/teco.html diff --git a/editors/teco/pkg-message b/editors/teco/pkg-message index 05fc6fc295a2..40f740319f83 100644 --- a/editors/teco/pkg-message +++ b/editors/teco/pkg-message @@ -1,13 +1,37 @@ -============================================================================= +Powerful and compact editor with nongraphical user interface - Teco takes a first argument of mung, teco or make to control its -operating mode. Also the name of the executable is tested to provide this -first argument. The mapping is: - teco - tecoc teco - Make - tecoc make - mung - tecoc mung - inspect - tecoc teco -inspect +The FreeBSD port implements pretty well all that the Linux version does. -You can create symlinks for this to work. +There is now a manual page; note carefully that the name of the +executable file is 'tecoc', and that it takes a first argument +specifying how it is to run. The manual page has many more details. -============================================================================= +Most users will want to set up aliases for using the program; this is +not done by the port to avoid unnecessary namespace pollution. There is +also the issue that the conventional command for creating a new file +with teco is 'make' - it is suggested that a capitalised version, +'Make', is used instead. However, users can choose any name they like. + +An example set of aliases for csh might be: + + alias Make 'tecoc make' + alias teco 'tecoc teco' + alias mung 'tecoc mung' + alias inspect 'tecoc teco -inspect' + +For bash, they might be: + + alias Make='tecoc make' + alias teco='tecoc teco' + alias mung='tecoc mung' + alias inspect='tecoc teco -inspect' + + +If the port is built with the DOCS option set to ON, then documentation +will be installed into %%DOCSDIR%%. This will include +a large teco manual named 'teco.doc', and a quick reference 'wall chart' +named 'wchart.txt'. Other documents located there are outdated and/or +inconsistent, and thus of limited use. + +Before starting to use tecoc, see the sections "DESCRIPTION/Command +names" and "SEE ALSO" in the manual page. diff --git a/editors/teco/pkg-plist b/editors/teco/pkg-plist index 977c27878c25..7deaa706d765 100644 --- a/editors/teco/pkg-plist +++ b/editors/teco/pkg-plist @@ -1,4 +1,5 @@ bin/tecoc +man/man1/teco.1.gz %%DATADIR%%/upcase.tec %%DATADIR%%/change.tes %%DATADIR%%/date.tes |