diff options
author | dholland <dholland@pkgsrc.org> | 2012-12-28 03:03:08 +0000 |
---|---|---|
committer | dholland <dholland@pkgsrc.org> | 2012-12-28 03:03:08 +0000 |
commit | 60082b65c5a23f83f8bb26c82ce4bf6f168ff856 (patch) | |
tree | 8c0484149657a50a301fa0bcb9d58f2f596c8985 /editors/ex | |
parent | 940a2e4139667eff9afbc0ac65b4bd46085a5d49 (diff) | |
download | pkgsrc-60082b65c5a23f83f8bb26c82ce4bf6f168ff856.tar.gz |
Fix legacy C. Pass -Wall -W -Wmissing-declarations -Wwrite-strings on
gcc45.
- avoid implicit int, declare void functions void
- return values from non-void functions
- put most external declarations properly in header files
- use some static and const
- fix up a big mess with function pointer casting
- use standard includes, don't provide own decls of standard functions
- use types matching libc when providing own malloc, printf, and putchar
- use <ctype.h> functions correctly
- silence assorted compiler warnings
- fix some bugs exposed by compiler warnings
- don't intentionally exercise signed overflow
- remove some unused items
- add patch comments to other patch (patch-aa)
As this includes several fixes and removes some undefined behavior on
a commonly reachable code path, bump PKGREVISION.
Diffstat (limited to 'editors/ex')
43 files changed, 7800 insertions, 37 deletions
diff --git a/editors/ex/Makefile b/editors/ex/Makefile index be13dd77c5b..51daa8b67f8 100644 --- a/editors/ex/Makefile +++ b/editors/ex/Makefile @@ -1,9 +1,9 @@ -# $NetBSD: Makefile,v 1.10 2012/10/03 11:43:33 asau Exp $ +# $NetBSD: Makefile,v 1.11 2012/12/28 03:03:08 dholland Exp $ # DISTNAME= ex-040103 PKGNAME= ex-20040103 -PKGREVISION= 2 +PKGREVISION= 3 CATEGORIES= editors MASTER_SITES= ${MASTER_SITE_SOURCEFORGE:=ex-vi/files/ex-vi/040103/} @@ -12,6 +12,12 @@ HOMEPAGE= http://ex-vi.sourceforge.net/ COMMENT= Berkeley vi 3.7 LICENSE= original-bsd +SUBST_CLASSES+= getline +SUBST_STAGE.getline= post-extract +SUBST_MESSAGE.getline= Changing 'getline' to 'get_line' +SUBST_FILES.getline= ex*.c ex_proto.h +SUBST_SED.getline= -e "s,getline,get_line,g" + MAKE_DIRS_PERMS+= ${VARBASE}/tmp/vi.recover ${REAL_ROOT_USER} ${REAL_ROOT_GROUP} 1777 .include "../../mk/curses.buildlink3.mk" diff --git a/editors/ex/distinfo b/editors/ex/distinfo index 666602b364f..de3a716062b 100644 --- a/editors/ex/distinfo +++ b/editors/ex/distinfo @@ -1,10 +1,46 @@ -$NetBSD: distinfo,v 1.14 2011/08/01 05:47:40 dholland Exp $ +$NetBSD: distinfo,v 1.15 2012/12/28 03:03:08 dholland Exp $ SHA1 (ex-040103.tar.gz) = 51fa1d613b37a4f3aed1ef2968be691465cdff09 RMD160 (ex-040103.tar.gz) = 5fc3f222dde5a8d00e1b233281ccf210affdbdf1 Size (ex-040103.tar.gz) = 284130 bytes -SHA1 (patch-aa) = 8902846a518fbf214725a801293610ebe12c143b -SHA1 (patch-ab) = 5bac9911e71b7fe787023568a7a46d1e87fb4d0e -SHA1 (patch-ac) = 0401448724a4aba59b4aeb07a4cb00982bb52d98 -SHA1 (patch-ad) = 31bafb04f553ca286baf90505da450964fea9954 -SHA1 (patch-exrecover_c) = f5fd1bff1f1e8229170415081815531d86e482da +SHA1 (patch-aa) = a8b9fd02ec7e576ea1bbf239cbd34bf7bae7c4a8 +SHA1 (patch-ab) = 1b75764cb5ef0873a307874bb94dd9d4e7e74290 +SHA1 (patch-ac) = a849730017d13a60686cdca81c9c74a55cd29b53 +SHA1 (patch-ad) = 497407efc9b2afc397a735abc6234bed8ece97ae +SHA1 (patch-ex__addr_c) = 61d9851b746fe90b2f413dd42b09659fda13ffdb +SHA1 (patch-ex__argv_h) = e121a95b2dd50ed5778af43df716913758d643d5 +SHA1 (patch-ex__cmds2_c) = 9856d947c0be80a3f597c7b16ec28ac729880668 +SHA1 (patch-ex__cmds_c) = 730252b283392a944f3b95c43182ed178a459ddd +SHA1 (patch-ex__cmdsub_c) = d76d0e0d2748c30f1541a95fe194b3cf70a670fa +SHA1 (patch-ex__get_c) = 19f439eaa2ab68755fb2f1b9e38bd6b2bfff6466 +SHA1 (patch-ex__io_c) = cc490141c0eaf6c172d36eccb403e21f762052f7 +SHA1 (patch-ex__proto_h) = ecd701f056e9ab78fd47d07b997e80e32e1e47fe +SHA1 (patch-ex__put_c) = c3f8dddff3919b745f460aead3bc2dfda8b30083 +SHA1 (patch-ex__re_c) = fde8ef4a089ffc64980fde00a320ff906f7f4ee2 +SHA1 (patch-ex__set_c) = fa59569a6fa00649a01c2f399ec17f1e3d9e2de9 +SHA1 (patch-ex__subr_c) = 2c7291aa9988644c8eb7fa62778497743dd96d14 +SHA1 (patch-ex__tagio_c) = 83227d9ff2e88e55e06d3c8db94e106a25d2e00a +SHA1 (patch-ex__temp_c) = 1b45c4f02d6ad0ff90f814e8e9c18e2ec739ec15 +SHA1 (patch-ex__tty_c) = 65d2ea5b01f6049419a00ece6664a86d9044fafc +SHA1 (patch-ex__tty_h) = 64d7a196f499d3eedb7330a904e192e67d83cf3a +SHA1 (patch-ex__unix_c) = f52c637a52987191404befd262e3717472995d91 +SHA1 (patch-ex__v_c) = 1af23e5f70f92e0269a740fcef665b45e1a0b461 +SHA1 (patch-ex__vadj_c) = 4de4dae1865d61a56da756493e8c098eff05039c +SHA1 (patch-ex__version_c) = ddc81149794020a151435c1571817ad2315c305f +SHA1 (patch-ex__vget_c) = 6b28e0fd02b6c6304a7996da9825e397a4f7635a +SHA1 (patch-ex__vis_h) = be29bf377a0badf691ad3b65f8fedef73d67de4d +SHA1 (patch-ex__vmain_c) = 52822b649d88acf16899ba1beb4559a3534b489d +SHA1 (patch-ex__voper_c) = 2f0a55d21466f581ce4089986632339a67795633 +SHA1 (patch-ex__vops2_c) = cea13dde0335b81507f87838137e3360fe545d60 +SHA1 (patch-ex__vops3_c) = d2bab4f54f3bf8d7fa9b5cc44a8a5210dfdba87a +SHA1 (patch-ex__vops_c) = f7c15746a93544ed058ab4af6a389049b74a99a8 +SHA1 (patch-ex__vput_c) = fa0216eb004ae58a297c3f00a610d689c978f273 +SHA1 (patch-ex__vwind_c) = 9ed05094167870f5eb9af28deb39318aa69cf832 +SHA1 (patch-ex_c) = c0c5d5d5fd45da46e2594101a7a3d4350c49ae05 +SHA1 (patch-expreserve_c) = 2c94b4eefa3e72c6abc4aaa2f54750557705c794 +SHA1 (patch-exrecover_c) = 8742a5ba155996632971891cdd4a24b4d97d4376 +SHA1 (patch-libterm_libterm_h) = 2f552d89726baf1d8b2c3be15ef386db7dffe04d +SHA1 (patch-libterm_termcap_c) = cbc3ece52b9bbfd286be7953d9cb3bcf6e460b0e +SHA1 (patch-libterm_tgoto_c) = d4299bdd468f0fff4d0fbbb67f37b8080a334787 +SHA1 (patch-libterm_tputs_c) = a305e0ccc35aafe30b3b061bb47964b0ae845e9a +SHA1 (patch-printf_c) = 4a64b79fd7d3f1c6271d238cc3b71f02f43537d0 diff --git a/editors/ex/patches/patch-aa b/editors/ex/patches/patch-aa index e8423752b27..bc3158a28b8 100644 --- a/editors/ex/patches/patch-aa +++ b/editors/ex/patches/patch-aa @@ -1,4 +1,9 @@ -$NetBSD: patch-aa,v 1.7 2010/01/31 21:24:04 joerg Exp $ +$NetBSD: patch-aa,v 1.8 2012/12/28 03:03:08 dholland Exp $ + +- configure paths and programs for pkgsrc +- don't install the executable sticky as that's often no longer allowed +- don't create the PRESERVEDIR at install time + (the pkgsrc makefile takes care of it) --- Makefile.orig 2004-01-03 14:22:47.000000000 +0000 +++ Makefile diff --git a/editors/ex/patches/patch-ab b/editors/ex/patches/patch-ab index 4cb692d3ef6..e110c484bfe 100644 --- a/editors/ex/patches/patch-ab +++ b/editors/ex/patches/patch-ab @@ -1,6 +1,11 @@ -$NetBSD: patch-ab,v 1.1 2005/10/31 20:04:46 tv Exp $ +$NetBSD: patch-ab,v 1.2 2012/12/28 03:03:08 dholland Exp $ ---- malloc.c.orig 2002-03-02 07:15:03.000000000 -0500 +- use standard headers + (these functions are supposed to substitute for the libc ones, so they + need to match stdlib.h exactly) +- declare void functions void + +--- malloc.c.orig 2002-03-02 12:15:03.000000000 +0000 +++ malloc.c @@ -45,6 +45,7 @@ #include <sys/types.h> @@ -10,3 +15,19 @@ $NetBSD: patch-ab,v 1.1 2005/10/31 20:04:46 tv Exp $ #else /* !POSIX_1 */ #include <sys/types.h> extern int errno; +@@ -235,6 +236,7 @@ found: + + /* freeing strategy tuned for LIFO allocation + */ ++void + free(ap) + register char *ap; + { +@@ -331,6 +333,7 @@ size_t num, size; + } + + /*ARGSUSED*/ ++void + cfree(p, num, size) + char *p; + size_t num, size; diff --git a/editors/ex/patches/patch-ac b/editors/ex/patches/patch-ac index 1434c62a7d0..64139b817a8 100644 --- a/editors/ex/patches/patch-ac +++ b/editors/ex/patches/patch-ac @@ -1,26 +1,166 @@ -$NetBSD: patch-ac,v 1.4 2006/07/22 04:23:29 minskim Exp $ +$NetBSD: patch-ac,v 1.5 2012/12/28 03:03:08 dholland Exp $ ---- mapmalloc.c.orig 2003-01-28 12:04:25.000000000 -0800 +- use standard headers + (these functions are supposed to substitute for the libc ones, so they + need to match stdlib.h exactly) +- use own headers +- declare void functions void +- fix return and argument types + +--- mapmalloc.c.orig 2003-01-28 20:04:25.000000000 +0000 +++ mapmalloc.c -@@ -54,6 +54,9 @@ +@@ -54,18 +54,12 @@ #include <fcntl.h> #include <errno.h> #include <limits.h> -+#if defined(__INTERIX) +-#ifdef __GLIBC__ +-/* +- * Broken GNU libc will include stdlib.h with conflicting +- * malloc() types otherwise. +- */ +-#ifndef __NO_STRING_INLINES +-#define __NO_STRING_INLINES +-#endif /* !__NO_STRING_INLINES */ +-#endif /* __GLIBC__ */ +#include <stdlib.h> -+#endif - #ifdef __GLIBC__ + #include <string.h> + + #include "config.h" ++#include "ex.h" ++#include "ex_proto.h" + + #ifdef LANGMSG + #include <nl_types.h> +@@ -176,8 +170,6 @@ static MM *mm_global = NULL; + static int zerofd = -1; + #endif + +-extern int error __P((char *, ...)); +- /* - * Broken GNU libc will include stdlib.h with conflicting -@@ -551,7 +554,11 @@ size_t alignment, size; + * Determine memory page size of OS + */ +@@ -308,7 +300,7 @@ mm_create(MM *mmPrev, size_t usize) + * and/or next chunk when possible to form larger chunks out of + * smaller ones. + */ +-static ++static void + mm_insert_chunk(MM *mm, mem_chunk *mcInsert) + { + mem_chunk *mc; +@@ -429,7 +421,7 @@ mm_retrieve_chunk(MM *mm, size_t size) + /* + * Allocate a chunk of memory + */ +-char * ++void * + malloc(size_t usize) + { + MM *mm; +@@ -469,10 +461,12 @@ nextpool: + /* + * Free a chunk of memory + */ +-free(char *ptr) ++void ++free(void *ptrV) + { + MM *mm; + mem_chunk *mc; ++ char *ptr = ptrV; + + if (mm_global == NULL || ptr == NULL) + return; +@@ -494,12 +488,13 @@ free(char *ptr) + /* + * Reallocate a chunk of memory + */ +-char * +-realloc(char *ptr, size_t usize) ++void * ++realloc(void *ptrV, size_t usize) + { + size_t size; + mem_chunk *mc; + char *vp; ++ char *ptr = ptrV; + + if (ptr == NULL) + return malloc(usize); /* POSIX.1 semantics */ +@@ -523,7 +518,7 @@ realloc(char *ptr, size_t usize) + /* + * Allocate and initialize a chunk of memory + */ +-char * ++void * + calloc(size_t number, size_t usize) + { + char *vp; +@@ -534,38 +529,55 @@ calloc(size_t number, size_t usize) + return vp; } ++#ifndef __NetBSD__ /* signature does not agree with netbsd's libcompat */ /*ARGSUSED*/ -+#if defined(__DragonFly__) || defined(__APPLE__) -+void * -+#else - char * +-cfree(p, num, size) ++void cfree(p, num, size) + char *p; + size_t num, size; + { + free(p); + } +#endif ++ ++ ++/* ++ * Not all systems have the following in libc, so avoid compiler warnings ++ * by inserting extra global declarations. ++ */ ++char *memalign(size_t alignment, size_t size); ++void *valloc(size_t size); ++char *mallinfo(void); ++int mallopt(void); ++char *poolsbrk(intptr_t val); ++ + + /*ARGSUSED*/ + char * + memalign(alignment, size) + size_t alignment, size; + { ++ (void)alignment; ++ (void)size; + return NULL; + } + + /*ARGSUSED*/ +-char * ++void * valloc(size) size_t size; { ++ (void)size; + return NULL; + } + + char * +-mallinfo() ++mallinfo(void) + { + return NULL; + } + + int +-mallopt() ++mallopt(void) + { + return -1; + } +@@ -574,5 +586,6 @@ mallopt() + char * + poolsbrk(intptr_t val) + { ++ (void)val; + return NULL; + } diff --git a/editors/ex/patches/patch-ad b/editors/ex/patches/patch-ad index fbecc97e450..b476d4b8b91 100644 --- a/editors/ex/patches/patch-ad +++ b/editors/ex/patches/patch-ad @@ -1,8 +1,76 @@ -$NetBSD: patch-ad,v 1.1 2006/06/08 16:15:47 minskim Exp $ +$NetBSD: patch-ad,v 1.2 2012/12/28 03:03:08 dholland Exp $ ---- ex.h.orig 2003-03-18 20:29:07.000000000 +0000 +- teach it about dead functions +- use const for string constants +- use speed_t for tty speed +- don't declare versionstring, which is static in ex_version.c +- fix up function pointer casting mess + +--- ex.h.orig 2012-12-27 21:58:42.000000000 +0000 +++ ex.h -@@ -549,7 +549,6 @@ extern int tfile; /* Temporary file uni +@@ -238,6 +238,15 @@ typedef int woid; + #endif /* !__STDC__ */ + + /* ++ * nonreturning functions ++ */ ++#if defined(__GNUC__) || defined(__CLANG__) ++#define dead __attribute__((__noreturn__)) ++#else ++#define dead ++#endif ++ ++/* + * Use reliable POSIX.1 signals if available. + */ + #ifdef POSIX_1 +@@ -401,8 +410,8 @@ typedef jmp_buf JMP_BUF; + * ex_data.c... see the shell script "makeoptions". + */ + struct option { +- char *oname; +- char *oabbrev; ++ const char *oname; ++ const char *oabbrev; + short otype; /* Types -- see below */ + short odefault; /* Default value */ + short ovalue; /* Current value */ +@@ -483,7 +492,7 @@ var bool aiflag; /* Append/change/inser + var bool anymarks; /* We have used '[a-z] */ + var int bsize; /* Block size for disk i/o */ + var int chng; /* Warn "No write" */ +-var char *Command; ++var const char *Command; + var short defwind; /* -w# change default window size */ + var int dirtcnt; /* When >= MAXDIRT, should sync temporary */ + #ifdef TIOCLGET +@@ -504,11 +513,11 @@ var char file[FNSIZE]; /* Working file n + var bool fixedzero; /* zero file size was fixed (for visual) */ + var char genbuf[MAXBSIZE]; /* Working buffer when manipulating linebuf */ + var bool hush; /* Command line option - was given, hush up! */ +-var char *globp; /* (Untyped) input string to command mode */ ++var const char *globp; /* (Untyped) input string to command mode */ + var bool holdcm; /* Don't cursor address */ + var bool inappend; /* in ex command append mode */ + var bool inglobal; /* Inside g//... or v//... */ +-var char *initev; /* Initial : escape for visual */ ++var const char *initev; /* Initial : escape for visual */ + var bool inopen; /* Inside open or visual */ + var char *input; /* Current position in cmd line input buffer */ + var bool intty; /* Input is a tty */ +@@ -530,7 +539,11 @@ var shand oldquit; /* Previous SIGQUIT h + var shand oldxfsz; /* Previous SIGXFSZ handler */ + #endif + var short oprompt; /* Saved during source */ ++#ifdef POSIX_1 ++extern speed_t ospeed; /* Output speed (from gtty) */ ++#else + extern short ospeed; /* Output speed (from gtty) */ ++#endif + var int otchng; /* Backup tchng to find changes in macros */ + var short peekc; /* Peek ahead character (cmd mode input) */ + var char *pkill[2]; /* Trim for put with ragged (LISP) delete */ +@@ -549,7 +562,6 @@ extern int tfile; /* Temporary file uni var bool tflag; /* -t option given on command line */ var bool vcatch; /* Want to catch an error (open/visual) */ var bool verbose; /* -V option; print command input to stderr */ @@ -10,3 +78,24 @@ $NetBSD: patch-ad,v 1.1 2006/06/08 16:15:47 minskim Exp $ var JMP_BUF vreslab; /* For error throws to a visual catch */ var bool writing; /* 1 if in middle of a file write */ var int xchng; /* Suppresses multiple "No writes" in !cmd */ +@@ -639,9 +651,9 @@ var line *undadot; /* If we saved all li + #define UNDNONE 3 + #define UNDPUT 4 + +-extern int (*Outchar)(); +-extern int (*Pline)(); +-extern int (*Putchar)(); ++extern int (*Outchar)(int); ++extern int (*Pline)(int); ++extern int (*Putchar)(int); + + #define NOSTR (char *) 0 + #define NOLINE (line *) 0 +@@ -663,6 +675,6 @@ var nl_catd catd; + #else /* !LANGMSG */ + #define catgets(a, b, c, d) (d) + #endif /* !LANGMSG */ +-var char *cntrlhm; ++var const char *cntrlhm; + + #include "ex_proto.h" diff --git a/editors/ex/patches/patch-ex__addr_c b/editors/ex/patches/patch-ex__addr_c new file mode 100644 index 00000000000..c482d705b3e --- /dev/null +++ b/editors/ex/patches/patch-ex__addr_c @@ -0,0 +1,71 @@ +$NetBSD: patch-ex__addr_c,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- declare void functions void +- avoid implicit int + +--- ex_addr.c~ 2002-02-02 02:08:35.000000000 +0000 ++++ ex_addr.c +@@ -102,6 +102,7 @@ static bool bigmove; + /* + * Set up addr1 and addr2 for commands whose default address is dot. + */ ++void + setdot() + { + +@@ -114,6 +115,7 @@ setdot() + * Call setdot1 to set up default addresses without ever + * setting the previous context mark. + */ ++void + setdot1() + { + +@@ -132,6 +134,7 @@ setdot1() + * to delete 5 lines, etc. + * Such nonsense is implemented by setcount. + */ ++void + setcount() + { + register int cnt; +@@ -155,6 +158,7 @@ setcount() + /* + * Parse a number out of the command input stream. + */ ++int + getnum() + { + register int cnt; +@@ -168,6 +172,7 @@ getnum() + * Set the default addresses for commands which use the whole + * buffer as default, notably write. + */ ++void + setall() + { + +@@ -188,6 +193,7 @@ setall() + /* + * No address allowed on, e.g. the file command. + */ ++void + setnoaddr() + { + +@@ -377,6 +383,7 @@ error(catgets(catd, 1, 11, "No match to + * Left over from squashing ex version 1.1 into + * 11/34's and 11/40's. + */ ++void + setCNL() + { + +@@ -384,6 +391,7 @@ setCNL() + newline(); + } + ++void + setNAEOL() + { + diff --git a/editors/ex/patches/patch-ex__argv_h b/editors/ex/patches/patch-ex__argv_h new file mode 100644 index 00000000000..5594d9013be --- /dev/null +++ b/editors/ex/patches/patch-ex__argv_h @@ -0,0 +1,12 @@ +$NetBSD: patch-ex__argv_h,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- declare void functions void + +--- ex_argv.h~ 2002-02-02 00:05:46.000000000 +0000 ++++ ex_argv.h +@@ -102,4 +102,4 @@ struct glob { + }; + var struct glob frob; + +-int gglob __P((struct glob *)); ++void gglob __P((struct glob *)); diff --git a/editors/ex/patches/patch-ex__cmds2_c b/editors/ex/patches/patch-ex__cmds2_c new file mode 100644 index 00000000000..d7e1ea433b3 --- /dev/null +++ b/editors/ex/patches/patch-ex__cmds2_c @@ -0,0 +1,239 @@ +$NetBSD: patch-ex__cmds2_c,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- avoid implicit int +- declare void functions void +- use const for string constants + +--- ex_cmds2.c~ 2002-02-02 02:08:35.000000000 +0000 ++++ ex_cmds2.c +@@ -95,6 +95,7 @@ extern int poffset; /* mjm: extern; als + /* + * Is there a single letter indicating a named buffer next? + */ ++int + cmdreg() + { + register int c = 0; +@@ -108,6 +109,7 @@ cmdreg() + /* + * Tell whether the character ends a command + */ ++int + endcmd(ch) + int ch; + { +@@ -129,6 +131,7 @@ endcmd(ch) + /* + * Insist on the end of the command. + */ ++void + eol() + { + +@@ -144,7 +147,8 @@ eol() + * just fixing up the echo area for the print. + * Otherwise we reset a number of externals, and discard unused input. + */ +-error0() ++static void ++error0(void) + { + + if (vcatch) { +@@ -191,8 +195,8 @@ error0() + * Otherwise, in the normal command mode error case, + * finish state reset, and throw to top. + */ +-error1(str) +- char *str; ++static void ++error1(const char *str) + { + bool die; + +@@ -230,17 +234,18 @@ error1(str) + * with i an integer argument to printf. + */ + /*VARARGS2*/ ++void + #ifndef __STDC__ + error(str, i) + #ifdef lint +- register char *str; ++ register const char *str; + #else + register int str; + #endif + int i; + { + #else +-error(char *str, ...) ++error(const char *str, ...) + { + va_list ap; + #endif +@@ -265,6 +270,7 @@ error(char *str, ...) + /* + * Rewind the argument list. + */ ++void + erewind() + { + +@@ -280,6 +286,7 @@ erewind() + } + } + ++void + fixol() + { + if (Outchar != vputchar) { +@@ -298,6 +305,7 @@ fixol() + /* + * Does an ! character follow in the command stream? + */ ++int + exclam() + { + +@@ -311,6 +319,7 @@ exclam() + /* + * Make an argument list for e.g. next. + */ ++void + makargs() + { + +@@ -324,6 +333,7 @@ makargs() + /* + * Advance to next file in argument list. + */ ++void + next() + { + extern short isalt; /* defined in ex_io.c */ +@@ -343,6 +353,7 @@ next() + * Eat trailing flags and offsets after a command, + * saving for possible later post-command prints. + */ ++void + newline() + { + register int c; +@@ -399,6 +410,7 @@ serror(catgets(catd, 1, 32, + * Before quit or respec of arg list, check that there are + * no more files in the arg list. + */ ++void + nomore() + { + +@@ -413,6 +425,7 @@ nomore() + * Before edit of new file check that either an ! follows + * or the file has not been changed. + */ ++int + quickly() + { + +@@ -432,6 +445,7 @@ quickly() + /* + * Reset the flavor of the output to print mode with no numbering. + */ ++void + resetflav() + { + +@@ -448,10 +462,11 @@ resetflav() + * Print an error message with a %s type argument to printf. + * Message text comes from error message file. + */ ++void + #ifndef __STDC__ + serror(str, cp) + #ifdef lint +- register char *str; ++ register const char *str; + #else + register int str; + #endif +@@ -463,7 +478,7 @@ serror(str, cp) + error1(str); + } + #else /* __STDC__ */ +-serror(char *str, ...) ++serror(const char *str, ...) + { + va_list ap; + +@@ -482,6 +497,7 @@ serror(char *str, ...) + * and either use normally decoded (ARPAnet standard) characters or list mode, + * where end of lines are marked and tabs print as ^I. + */ ++void + setflav() + { + +@@ -495,6 +511,7 @@ setflav() + /* + * Skip white space and tell whether command ends then. + */ ++int + skipend() + { + +@@ -505,6 +522,7 @@ skipend() + /* + * Set the command name for non-word commands. + */ ++void + tailspec(c) + int c; + { +@@ -518,15 +536,17 @@ tailspec(c) + * Try to read off the rest of the command word. + * If alphabetics follow, then this is not the command we seek. + */ ++void + tail(comm) +- char *comm; ++ const char *comm; + { + + tailprim(comm, 1, 0); + } + ++void + tail2of(comm) +- char *comm; ++ const char *comm; + { + + tailprim(comm, 2, 0); +@@ -534,8 +554,9 @@ tail2of(comm) + + char tcommand[20]; + ++void + tailprim(comm, i, notinvis) +- register char *comm; ++ register const char *comm; + int i; + bool notinvis; + { +@@ -574,6 +595,7 @@ ret: + /* + * Continue after a : command from open/visual. + */ ++void + vcontin(ask) + bool ask; + { +@@ -643,6 +665,7 @@ vcontin(ask) + * Put out a newline (before a shell escape) + * if in open/visual. + */ ++void + vnfl() + { + diff --git a/editors/ex/patches/patch-ex__cmds_c b/editors/ex/patches/patch-ex__cmds_c new file mode 100644 index 00000000000..3bae7cb4713 --- /dev/null +++ b/editors/ex/patches/patch-ex__cmds_c @@ -0,0 +1,42 @@ +$NetBSD: patch-ex__cmds_c,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- declare void functions void +- silence warnings about && and || precedence +- silence warnings about braces + +--- ex_cmds.c~ 2012-12-27 20:24:51.000000000 +0000 ++++ ex_cmds.c +@@ -96,6 +96,7 @@ int poffset; + * is to strip command addresses, do a little address oriented + * processing and call command routines to do the real work. + */ ++void + commands(noprompt, exitoneof) + bool noprompt, exitoneof; + { +@@ -127,7 +128,7 @@ commands(noprompt, exitoneof) + * before the next command. + */ + if (pflag || +- lchng != chng && value(AUTOPRINT) && !inglobal && !inopen && endline) { ++ (lchng != chng && value(AUTOPRINT) && !inglobal && !inopen && endline)) { + pflag = 0; + nochng(); + if (dol != zero) { +@@ -165,7 +166,7 @@ error(catgets(catd, 1, 17, + addr1 = addr2; + addr = address(0); + c = getcd(); +- if (addr == 0) ++ if (addr == 0) { + if (c == ',') + addr = dot; + else if (addr1 != 0) { +@@ -173,6 +174,7 @@ error(catgets(catd, 1, 17, + break; + } else + break; ++ } + addr2 = addr; + given++; + if (c == ';') { diff --git a/editors/ex/patches/patch-ex__cmdsub_c b/editors/ex/patches/patch-ex__cmdsub_c new file mode 100644 index 00000000000..d3f95ad22e2 --- /dev/null +++ b/editors/ex/patches/patch-ex__cmdsub_c @@ -0,0 +1,296 @@ +$NetBSD: patch-ex__cmdsub_c,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- declare local functions static +- avoid implicit int +- declare void functions void +- silence warnings about assignments in conditionals +- use const for string constants + +--- ex_cmdsub.c.orig 2012-12-27 21:58:41.000000000 +0000 ++++ ex_cmdsub.c +@@ -93,15 +93,18 @@ static char sccsid[] = "@(#)ex_cmdsub.c + + bool endline = 1; + line *tad1; +-static jnoop(); ++ ++static int jnoop(void); ++static int getcopy(void); + + /* + * Append after line a lines returned by function f. + * Be careful about intermediate states to avoid scramble + * if an interrupt comes in. + */ ++int + append(f, a) +- int (*f)(); ++ int (*f)(void); + line *a; + { + register line *a1, *a2, *rdot; +@@ -144,6 +147,7 @@ append(f, a) + return (nline); + } + ++void + appendnone() + { + +@@ -156,6 +160,7 @@ appendnone() + /* + * Print out the argument list, with []'s around the current name. + */ ++void + pargs() + { + register char **av = argv0, *as = args0; +@@ -182,6 +187,7 @@ pargs() + * Delete lines; two cases are if we are really deleting, + * more commonly we are just moving lines to the undo save area. + */ ++void + delete(hush) + bool hush; + { +@@ -242,6 +248,7 @@ delete(hush) + killed(); + } + ++void + deletenone() + { + +@@ -256,6 +263,7 @@ deletenone() + * Crush out the undo save area, moving the open/visual + * save area down in its place. + */ ++void + squish() + { + register line *a1 = dol + 1, *a2 = unddol + 1, *a3 = truedol + 1; +@@ -276,8 +284,9 @@ squish() + * Join lines. Special hacks put in spaces, two spaces if + * preceding line ends with '.', or no spaces if next line starts with ). + */ +-static int jcount, jnoop(); ++static int jcount; + ++void + join(c) + int c; + { +@@ -300,7 +309,7 @@ join(c) + } + } + } +- while (*cp++ = *cp1++) ++ while ((*cp++ = *cp1++) != 0) + if (cp > &genbuf[LBSIZE-2]) + error(catgets(catd, 1, 40, + "Line overflow|Result line of join would be too long")); +@@ -316,8 +325,8 @@ join(c) + vundkind = VMANY; + } + +-static +-jnoop() ++static int ++jnoop(void) + { + + return(--jcount); +@@ -327,11 +336,9 @@ jnoop() + * Move and copy lines. Hard work is done by move1 which + * is also called by undo. + */ +-int getcopy(); + +-move1(cflag, addrt) +- int cflag; +- line *addrt; ++static void ++move1(int cflag, line *addrt) + { + register line *adt, *ad1, *ad2; + int lines; +@@ -384,6 +391,7 @@ move1(cflag, addrt) + } + } + ++void + move() + { + register line *adt; +@@ -406,7 +414,8 @@ move() + killed(); + } + +-getcopy() ++static int ++getcopy(void) + { + + if (tad1 > addr2) +@@ -418,7 +427,8 @@ getcopy() + /* + * Put lines in the buffer from the undo save area. + */ +-getput() ++static int ++getput(void) + { + + if (tad1 > unddol) +@@ -428,6 +438,7 @@ getput() + return (0); + } + ++void + put() + { + register int cnt; +@@ -452,6 +463,7 @@ put() + * Argument says pkills have meaning, e.g. called from + * put; it is 0 on calls from putreg. + */ ++void + pragged(kill) + bool kill; + { +@@ -489,6 +501,7 @@ pragged(kill) + * Shift lines, based on c. + * If c is neither < nor >, then this is a lisp aligning =. + */ ++void + shift(c, cnt) + int c; + int cnt; +@@ -546,6 +559,7 @@ shift(c, cnt) + * Find a tag in the tags file. + * Most work here is in parsing the tags file itself. + */ ++void + tagfind(quick) + bool quick; + { +@@ -634,7 +648,7 @@ badtag: + /* loop for each tags file entry */ + register char *cp = linebuf; + register char *lp = lasttag; +- char *oglobp; ++ const char *oglobp; + + #ifdef FASTTAG + mid = (top + bot) / 2; +@@ -777,6 +791,7 @@ badtags: + * Save lines from addr1 thru addr2 as though + * they had been deleted. + */ ++void + yank() + { + +@@ -801,6 +816,7 @@ bool zhadpr; + bool znoclear; + short zweight; + ++void + zop(hadpr) + int hadpr; + { +@@ -862,8 +878,8 @@ zop(hadpr) + zop2(lines, op); + } + +-static +-splitit() ++static void ++splitit(void) + { + register int l; + +@@ -872,6 +888,7 @@ splitit() + putnl(); + } + ++void + zop2(lines, op) + register int lines; + register int op; +@@ -956,6 +973,7 @@ zop2(lines, op) + plines(addr1, addr2, 0); + } + ++void + plines(adr1, adr2, movedot) + line *adr1; + register line *adr2; +@@ -981,6 +999,7 @@ plines(adr1, adr2, movedot) + } + } + ++void + pofix() + { + +@@ -994,6 +1013,7 @@ pofix() + * Be (almost completely) sure there really + * was a change, before claiming to undo. + */ ++static void + somechange() + { + register line *ip, *jp; +@@ -1045,6 +1065,7 @@ somechange() + * + * Undo is its own inverse. + */ ++void + undo(c) + bool c; + { +@@ -1191,6 +1212,7 @@ undo(c) + * Map command: + * map src dest + */ ++void + mapcmd(un, ab) + int un; /* true if this is unmap command */ + int ab; /* true if this is abbr command */ +@@ -1287,8 +1309,10 @@ mapcmd(un, ab) + * using NOSTR for dest. Dname is what to show in listings. mp is + * the structure to affect (arrows, etc). + */ ++void + addmac(src,dest,dname,mp) +- register char *src, *dest, *dname; ++ register char *src; ++ register const char *dest, *dname; + register struct maps *mp; + { + register int slot, zer; +@@ -1314,7 +1338,7 @@ addmac(src,dest,dname,mp) + * linefeed, and escape, he can screw himself. This is + * so weird I don't bother to check for it. + */ +- if (isalpha(cuc(src[0])) && src[1] || any(src[0],":")) ++ if ((isalpha(cuc(src[0])) && src[1]) || any(src[0],":")) + error(catgets(catd, 1, 64, + "Too dangerous to map that")); + } +@@ -1385,12 +1409,13 @@ addmac(src,dest,dname,mp) + * Implements macros from command mode. c is the buffer to + * get the macro from. + */ ++void + cmdmac(c) + char c; + { + char macbuf[BUFSIZ]; + line *ad, *a1, *a2; +- char *oglobp; ++ const char *oglobp; + short pk; + bool oinglobal; + diff --git a/editors/ex/patches/patch-ex__get_c b/editors/ex/patches/patch-ex__get_c new file mode 100644 index 00000000000..26b2472fc57 --- /dev/null +++ b/editors/ex/patches/patch-ex__get_c @@ -0,0 +1,121 @@ +$NetBSD: patch-ex__get_c,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- declare void functions void +- avoid implicit int +- silence warnings about assignments in conditionals +- silence warnings about braces +- don't put external declarations inside functions + +--- ex_get.c.orig 2012-12-27 21:58:42.000000000 +0000 ++++ ex_get.c +@@ -90,12 +90,14 @@ static char sccsid[] = "@(#)ex_get.c 1.1 + static bool junkbs; + short lastc = '\n'; + ++void + ignchar() + { + ignore(getchar()); + } + +-getach() ++static int ++getach(void) + { + register int c; + static char in_line[BUFSIZ]; +@@ -114,7 +116,7 @@ getach() + } + top: + if (input) { +- if (c = *input++&0377) { ++ if ((c = *input++&0377) != 0) { + if (verbose && !intty) + write(2, &input[-1], 1); + #ifndef BIT8 +@@ -156,6 +158,7 @@ top: + goto top; + } + ++int + getchar() + { + register int c; +@@ -166,7 +169,8 @@ getchar() + return (c); + } + +-checkjunk(c) ++static void ++checkjunk(int c) + { + + if (junkbs == 0 && c == '\b') { +@@ -175,6 +179,7 @@ checkjunk(c) + } + } + ++int + getcd() + { + register int c; +@@ -188,16 +193,18 @@ again: + #else + c &= TRIM; + #endif +- if (!inopen) ++ if (!inopen) { + if (!globp && c == CTRL('d')) + setlastchar('\n'); + else if (junk(c)) { + checkjunk(c); + goto again; + } ++ } + return (c); + } + ++int + peekchar() + { + +@@ -206,6 +213,7 @@ peekchar() + return (peekc); + } + ++int + peekcd() + { + if (peekc == 0) +@@ -220,6 +228,7 @@ peekcd() + * This should really be done differently so as to use the whitecnt routine + * and also to hack indenting for LISP. + */ ++static int + smunch(col, ocp) + register int col; + char *ocp; +@@ -251,13 +260,12 @@ smunch(col, ocp) + */ + static short lastin; + ++int + gettty() + { + register int c = 0; + register char *cp = genbuf; + char hadup = 0; +- int numbline(); +- extern int (*Pline)(); + int offset = Pline == numbline ? 8 : 0; + int ch; + +@@ -354,7 +362,7 @@ gettty() + return (0); + } + +-line * ++void + setin(addr) + line *addr; + { diff --git a/editors/ex/patches/patch-ex__io_c b/editors/ex/patches/patch-ex__io_c new file mode 100644 index 00000000000..f8eef346ce3 --- /dev/null +++ b/editors/ex/patches/patch-ex__io_c @@ -0,0 +1,238 @@ +$NetBSD: patch-ex__io_c,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- declare local functions static +- declare void functions void +- avoid implicit int +- silence miscellaneous gcc45 warning +- silence warnings about braces +- silence warnings about unused arguments +- use const for string constants + +--- ex_io.c~ 2012-12-27 20:24:51.000000000 +0000 ++++ ex_io.c +@@ -109,13 +109,14 @@ long cntnull; /* Count of nulls " */ + long cntodd; /* Count of non-ascii characters " */ + #endif + +-int checkmodeline __P((char *)); ++static void checkmodeline __P((char *)); + + /* + * Parse file name for command encoded by comm. + * If comm is E then command is doomed and we are + * parsing just so user won't have to retype the name. + */ ++void + filename(comm) + int comm; + { +@@ -168,7 +169,7 @@ filename(comm) + break; + } + } +- if (hush && comm != 'f' || comm == 'E') ++ if ((hush && comm != 'f') || comm == 'E') + return; + if (file[0] != 0) { + lprintf("\"%s\"", file); +@@ -196,6 +197,7 @@ filename(comm) + * Get the argument words for a command into genbuf + * expanding # and %. + */ ++int + getargs() + { + register int c; +@@ -271,7 +273,8 @@ filexp: + * Scan genbuf for shell metacharacters. + * Set is union of v7 shell and csh metas. + */ +-gscan() ++static int ++gscan(void) + { + register char *cp; + +@@ -285,6 +288,7 @@ gscan() + * Glob the argument words in genbuf, or if no globbing + * is implied, just split them up directly. + */ ++void + gglob(gp) + struct glob *gp; + { +@@ -372,6 +376,8 @@ gglob(gp) + * Parse one filename into file. + */ + struct glob G; ++ ++void + getone() + { + register char *str; +@@ -393,6 +399,7 @@ missing: + /* + * Are these two really the same inode? + */ ++static int + samei(sp, cp) + struct stat *sp; + char *cp; +@@ -408,6 +415,7 @@ samei(sp, cp) + * Read a file from the world. + * C is command, 'e' if this really an edit (or a recover). + */ ++void + rop(c) + int c; + { +@@ -603,6 +611,7 @@ end_ft: + rop3(c); + } + ++void + rop2() + { + line *first, *last, *a; +@@ -638,7 +647,8 @@ rop2() + /* + * Io is finished, close the unit and print statistics. + */ +-iostats() ++static int ++iostats(void) + { + + fsync(io); +@@ -683,6 +693,7 @@ iostats() + ); + } + ++void + rop3(c) + int c; + { +@@ -732,10 +743,13 @@ other: + * if this is a partial buffer, and distinguish + * all cases. + */ +-edfile() ++static int ++edfile(void) + { ++ /* work around gcc45 warning in eq() because file is a char[] */ ++ char *fyle = file; + +- if (!edited || !eq(file, savedfile)) ++ if (!edited || !eq(fyle, savedfile)) + return (NOTEDF); + return (addr1 == one && addr2 == dol ? EDF : PARTBUF); + } +@@ -743,6 +757,7 @@ edfile() + /* + * Write a file. + */ ++void + wop(dofname) + bool dofname; /* if 1 call filename, else use savedfile */ + { +@@ -831,12 +846,13 @@ cre: + if (io < 0) + syserror(); + writing = 1; +- if (hush == 0) ++ if (hush == 0) { + if (nonexist) + printf(catgets(catd, 1, 115, " [New file]")); + else if (value(WRITEANY) && edfile() != EDF) + printf(catgets(catd, 1, 116, + " [Existing file]")); ++ } + break; + + case 2: +@@ -852,7 +868,10 @@ cre: + putfile(0); + ignore(iostats()); + if (c != 2 && addr1 == one && addr2 == dol) { +- if (eq(file, savedfile)) ++ /* work around gcc45 warning in eq() because file is a char[] */ ++ char *fyle = file; ++ ++ if (eq(fyle, savedfile)) + edited = 1; + synced(); + } +@@ -868,6 +887,7 @@ cre: + */ + char *nextip; + ++int + getfile() + { + register short c; +@@ -922,6 +942,7 @@ getfile() + /* + * Write a range onto the io stream. + */ ++void + putfile(isfilter) + int isfilter; + { +@@ -930,6 +951,8 @@ int isfilter; + register int nib; + struct stat statb; + ++ (void)isfilter; ++ + a1 = addr1; + clrstats(); + cntln = fixedzero ? 0 : addr2 - a1 + 1; +@@ -975,10 +998,13 @@ int isfilter; + * the edited file then we consider it to have changed since it is + * now likely scrambled. + */ ++void + wrerror() + { ++ /* work around gcc45 warning in eq() because file is a char[] */ ++ char *fyle = file; + +- if (eq(file, savedfile) && edited) ++ if (eq(fyle, savedfile) && edited) + change(); + syserror(); + } +@@ -990,13 +1016,14 @@ wrerror() + short slevel; + short ttyindes; + ++void + source(fil, okfail) +- char *fil; ++ const char *fil; + bool okfail; + { + JMP_BUF osetexit; + register int saveinp, ointty, oerrno; +- char *saveglobp; ++ const char *saveglobp; + short savepeekc; + + signal(SIGINT, SIG_IGN); +@@ -1050,6 +1077,7 @@ source(fil, okfail) + /* + * Clear io statistics before a read or write. + */ ++void + clrstats() + { + +@@ -1082,6 +1110,7 @@ char *strrchr(); + #endif /* !USG3TTY */ + #endif /* !__STDC__ */ + ++static void + checkmodeline(lin) + char *lin; + { diff --git a/editors/ex/patches/patch-ex__proto_h b/editors/ex/patches/patch-ex__proto_h new file mode 100644 index 00000000000..2598cac47fc --- /dev/null +++ b/editors/ex/patches/patch-ex__proto_h @@ -0,0 +1,595 @@ +$NetBSD: patch-ex__proto_h,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- declare void functions void +- fix up function pointer casting mess +- don't declare static functions in header files +- avoid sloppy code that subtracts 1 from the base address of a char[] + (which isn't valid) + +--- ex_proto.h.orig 2012-12-27 21:58:42.000000000 +0000 ++++ ex_proto.h +@@ -81,352 +81,356 @@ + #ifdef POSIX_1 + shand setsig __P((int, shand)); + #endif +-int init __P((void)); ++void init __P((void)); + /* ex_addr.c */ +-int setdot __P((void)); +-int setdot1 __P((void)); +-int setcount __P((void)); ++void setdot __P((void)); ++void setdot1 __P((void)); ++void setcount __P((void)); + int getnum __P((void)); +-int setall __P((void)); +-int setnoaddr __P((void)); ++void setall __P((void)); ++void setnoaddr __P((void)); + line *address __P((char *)); +-int setCNL __P((void)); +-int setNAEOL __P((void)); ++void setCNL __P((void)); ++void setNAEOL __P((void)); + /* ex_cmds.c */ +-int commands __P((int, int)); ++void commands __P((int, int)); + /* ex_cmds2.c */ + int cmdreg __P((void)); + int endcmd __P((int)); +-int eol __P((void)); +-int error __P((char *, ...)); +-int erewind __P((void)); +-int fixol __P((void)); ++void eol __P((void)); ++void error __P((const char *, ...)); ++void erewind __P((void)); ++void fixol __P((void)); + int exclam __P((void)); +-int makargs __P((void)); +-int next __P((void)); +-int newline __P((void)); +-int nomore __P((void)); ++void makargs __P((void)); ++void next __P((void)); ++void newline __P((void)); ++void nomore __P((void)); + int quickly __P((void)); +-int resetflav __P((void)); +-int serror __P((char *, ...)); +-int setflav __P((void)); ++void resetflav __P((void)); ++void serror __P((const char *, ...)); ++void setflav __P((void)); + int skipend __P((void)); +-int tailspec __P((int)); +-int tail __P((char *)); +-int tail2of __P((char *)); +-int tailprim __P((char *, int, int)); +-int vcontin __P((int)); +-int vnfl __P((void)); ++void tailspec __P((int)); ++void tail __P((const char *)); ++void tail2of __P((const char *)); ++void tailprim __P((const char *, int, int)); ++void vcontin __P((int)); ++void vnfl __P((void)); + /* ex_cmdsub.c */ +-int append __P((int (*)(), line *)); +-int appendnone __P((void)); +-int pargs __P((void)); +-int delete __P((int)); +-int deletenone __P((void)); +-int squish __P((void)); +-int join __P((int)); +-int move __P((void)); +-int put __P((void)); +-int pragged __P((int)); +-int shift __P((int, int)); +-int tagfind __P((int)); +-int yank __P((void)); +-int zop __P((int)); +-int zop2 __P((int, int)); +-int plines __P((line *, line *, int)); +-int pofix __P((void)); +-int undo __P((int)); +-int mapcmd __P((int, int)); +-int cmdmac __P((int)); ++int append __P((int (*)(void), line *)); ++void appendnone __P((void)); ++void pargs __P((void)); ++void delete __P((int)); ++void deletenone __P((void)); ++void squish __P((void)); ++void join __P((int)); ++void move __P((void)); ++void put __P((void)); ++void pragged __P((int)); ++void shift __P((int, int)); ++void tagfind __P((int)); ++void yank __P((void)); ++void zop __P((int)); ++void zop2 __P((int, int)); ++void plines __P((line *, line *, int)); ++void pofix __P((void)); ++void undo __P((int)); ++void mapcmd __P((int, int)); ++void cmdmac __P((int)); + /* ex_data.c */ + /* ex_extern.c */ + /* ex_get.c */ +-int ignchar __P((void)); ++void ignchar __P((void)); + int getchar __P((void)); + int getcd __P((void)); + int peekchar __P((void)); + int peekcd __P((void)); + int gettty __P((void)); +-line *setin __P((line *)); ++void setin __P((line *)); + /* ex_io.c */ +-int filename __P((int)); ++void filename __P((int)); + int getargs __P((void)); +-int getone __P((void)); +-int rop __P((int)); +-int rop2 __P((void)); +-int rop3 __P((int)); +-int wop __P((int)); ++void getone __P((void)); ++void rop __P((int)); ++void rop2 __P((void)); ++void rop3 __P((int)); ++void wop __P((int)); + int getfile __P((void)); +-int putfile __P((int)); +-int wrerror __P((void)); +-int source __P((char *, int)); +-int clrstats __P((void)); ++void putfile __P((int)); ++void wrerror __P((void)); ++void source __P((const char *, int)); ++void clrstats __P((void)); + /* ex_put.c */ +-int (*setlist __P((int))) __P((void)); +-int (*setnumb __P((int))) __P((void)); ++int (*setlist __P((bool))) __P((int)); ++int (*setnumb __P((bool))) __P((int)); + int listchar __P((int)); + int normchar __P((int)); + int numbline __P((int)); +-int normline __P((void)); ++int normline __P((int)); + int putchar __P((int)); + int termchar __P((int)); +-int flush __P((void)); +-int flush1 __P((void)); +-int fgoto __P((void)); +-int tab __P((int)); +-int noteinp __P((void)); +-int termreset __P((void)); +-int draino __P((void)); +-int flusho __P((void)); +-int putnl __P((void)); ++void flush __P((void)); ++void flush1 __P((void)); ++void fgoto __P((void)); ++void tab __P((int)); ++void noteinp __P((void)); ++void termreset __P((void)); ++void draino __P((void)); ++void flusho __P((void)); ++void putnl __P((void)); + int putch __P((int)); +-int putpad __P((char *)); +-int setoutt __P((void)); +-int vlprintf __P((char *, va_list)); +-int lprintf __P((char *, ...)); +-int putNFL __P((void)); +-int pstart __P((void)); +-int pstop __P((void)); +-int tostart __P((void)); +-int tostop __P((void)); +-int gTTY __P((int)); +-int noonl __P((void)); ++void putpad __P((const char *)); ++void setoutt __P((void)); ++void vlprintf __P((const char *, va_list)); ++void lprintf __P((const char *, ...)); ++void putNFL __P((void)); ++void pstart __P((void)); ++void pstop __P((void)); ++void tostart __P((void)); ++void tostop __P((void)); ++void vcook __P((void)); ++void vraw __P((void)); ++void gTTY __P((int)); ++void noonl __P((void)); + /* ex_re.c */ +-int global __P((int)); ++void global __P((int)); + int substitute __P((int)); + int getsub __P((void)); +-char *place __P((char *, char *, char *)); + int compile __P((int, int)); + int same __P((int, int)); + int execute __P((int, line *)); + int advance __P((char *, char *)); + /* ex_set.c */ +-int set __P((void)); ++void set __P((void)); + /* ex_subr.c */ +-int any __P((int, char *)); ++int any __P((int, const char *)); + int backtab __P((int)); +-int change __P((void)); ++void change __P((void)); + int column __P((char *)); +-int comment __P((void)); +-int Copy __P((char *, char *, int)); +-int copyw __P((line *, line *, int)); +-int copywR __P((line *, line *, int)); ++void comment __P((void)); ++void Copy __P((char *, char *, int)); ++void copyw __P((line *, line *, int)); ++void copywR __P((line *, line *, int)); + int ctlof __P((int)); +-int dingdong __P((void)); ++void dingdong __P((void)); + int fixindent __P((int)); +-int filioerr __P((char *)); ++void filioerr __P((const char *)); + char *genindent __P((int)); +-int getDOT __P((void)); ++void getDOT __P((void)); + line *getmark __P((int)); + int getn __P((char *)); +-int ignnEOF __P((void)); ++void ignnEOF __P((void)); + int is_white __P((int)); + int junk __P((int)); +-int killed __P((void)); +-int killcnt __P((int)); ++void killed __P((void)); ++void killcnt __P((int)); + int lineno __P((line *)); + int lineDOL __P((void)); + int lineDOT __P((void)); +-int markDOT __P((void)); +-int markpr __P((line *)); ++void markDOT __P((void)); ++void markpr __P((line *)); + int markreg __P((int)); +-char *mesg __P((char *)); +-int vmerror __P((char *, va_list)); +-int merror __P((char *, ...)); ++char *mesg __P((const char *)); ++void vmerror __P((const char *, va_list)); ++void merror __P((const char *, ...)); + int morelines __P((void)); +-int nonzero __P((void)); ++void nonzero __P((void)); + int notable __P((int)); +-int notempty __P((void)); +-int netchHAD __P((int)); +-int netchange __P((int)); ++void notempty __P((void)); ++void netchHAD __P((int)); ++void netchange __P((int)); + int printof __P((int)); +-int putmark __P((line *)); +-int putmk1 __P((line *, int)); +-char *plural __P((long)); +-int qcolumn __P((char *, char *)); +-int reverse __P((line *, line *)); +-int save __P((line *, line *)); +-int save12 __P((void)); +-int saveall __P((void)); ++void putmark __P((line *)); ++void putmk1 __P((line *, int)); ++const char *plural __P((long)); ++int qcolumn2 __P((char *, char *)); ++void reverse __P((line *, line *)); ++void save __P((line *, line *)); ++void save12 __P((void)); ++void saveall __P((void)); + int span __P((void)); +-int synced __P((void)); ++void synced __P((void)); + int skipwh __P((void)); +-int vsmerror __P((char *, va_list)); +-int smerror __P((char *, ...)); ++void vsmerror __P((const char *, va_list)); ++void smerror __P((const char *, ...)); + char *strend __P((char *)); +-int strcLIN __P((char *)); +-int syserror __P((void)); ++const char *strendk __P((const char *)); ++void strcLIN __P((const char *)); ++void syserror __P((void)); + int tabcol __P((int, int)); + char *vfindcol __P((int)); + char *vskipwh __P((char *)); + char *vpastwh __P((char *)); + int whitecnt __P((char *)); +-int markit __P((line *)); +-int setrupt __P((void)); ++void markit __P((line *)); ++void setrupt __P((void)); + int preserve __P((void)); +-int exitex __P((int)); ++dead void exitex __P((int)); + /* ex_tagio.c */ + int topen __P((char *, char *)); + int tseek __P((int, off_t)); + int tgets __P((char *, int, int)); +-int tclose __P((int)); ++void tclose __P((int)); + /* ex_temp.c */ +-int fileinit __P((void)); +-int cleanup __P((int)); +-int get_line __P((line)); ++void fileinit __P((void)); ++void cleanup __P((int)); ++void get_line __P((line)); + int putline __P((void)); +-int tlaste __P((void)); +-int tflush __P((void)); +-int synctmp __P((void)); +-int TSYNC __P((void)); +-int putreg __P((int)); ++void tlaste __P((void)); ++void tflush __P((void)); ++void synctmp __P((void)); ++void TSYNC __P((void)); ++void putreg __P((int)); + int partreg __P((int)); +-int notpart __P((int)); +-int YANKreg __P((int)); +-int kshift __P((void)); +-int regbuf __P((int, char *, int)); ++void notpart __P((int)); ++void YANKreg __P((int)); ++void kshift __P((void)); ++void regbuf __P((int, char *, int)); + /* ex_tty.c */ +-int gettmode __P((void)); +-int setterm __P((char *)); +-int setsize __P((void)); ++void gettmode __P((void)); ++void setterm __P((const char *)); ++void setsize __P((void)); + char *fkey __P((int)); +-int cost __P((char *)); ++int cost __P((const char *)); + /* ex_unix.c */ +-int unix0 __P((int)); +-int filter __P((int)); +-int recover __P((void)); +-int waitfor __P((void)); +-int revocer __P((void)); ++void unix0 __P((int)); ++void filter __P((int)); ++void recover __P((void)); ++void waitfor __P((void)); ++void revocer __P((void)); + /* ex_v.c */ +-int oop __P((void)); +-int vop __P((void)); +-int fixzero __P((void)); +-int savevis __P((void)); +-int undvis __P((void)); +-int vsetsiz __P((int)); ++void oop __P((void)); ++void vop __P((void)); ++void fixzero __P((void)); ++void savevis __P((void)); ++void undvis __P((void)); ++void vsetsiz __P((int)); + /* ex_vadj.c */ +-int vopen __P((line *, int)); ++void vopen __P((line *, int)); + int vreopen __P((int, int, int)); + int vglitchup __P((int, int)); +-int vinslin __P((int, int, int)); +-int vrollup __P((int)); +-int vup1 __P((void)); +-int vmoveitup __P((int, int)); +-int vscrap __P((void)); +-int vrepaint __P((char *)); +-int vredraw __P((int)); +-int vsyncCL __P((void)); +-int vsync __P((int)); +-int vsync1 __P((int)); +-int vreplace __P((int, int, int)); +-int sethard __P((void)); +-int vdirty __P((int, int)); ++void vinslin __P((int, int, int)); ++void vrollup __P((int)); ++void vup1 __P((void)); ++void vmoveitup __P((int, int)); ++void vscrap __P((void)); ++void vrepaint __P((char *)); ++void vredraw __P((int)); ++void vsyncCL __P((void)); ++void vsync __P((int)); ++void vsync1 __P((int)); ++void vreplace __P((int, int, int)); ++void sethard __P((void)); ++void vdirty __P((int, int)); + /* ex_version.c */ +-int printver __P((void)); ++void printver __P((void)); + /* ex_vget.c */ +-int ungetkey __P((int)); ++void ungetkey __P((int)); + int getkey __P((void)); + int peekbr __P((void)); + int getbr __P((void)); + int getesc __P((void)); + int peekkey __P((void)); + int readecho __P((int)); +-int setLAST __P((void)); +-int addtext __P((char *)); +-int setDEL __P((void)); +-int setBUF __P((cell *)); ++void setLAST __P((void)); ++void addtext __P((char *)); ++void setDEL __P((void)); ++void setBUF __P((cell *)); + int noteit __P((int)); +-int macpush __P((char *, int)); ++void macpush __P((const char *, int)); ++void vudump __P((const char *s)); + int vgetcnt __P((void)); + /* ex_vmain.c */ +-int vmain __P((void)); +-int prepapp __P((void)); +-int vremote __P((int, int (*)(), int)); +-int vsave __P((void)); ++void vmain __P((void)); ++void prepapp __P((void)); ++void vremote __P((int, void (*)(int), int)); ++void vsave __P((void)); + cell *str2cell __P((cell *, char *)); + char *cell2str __P((char *, cell *)); + cell *cellcpy __P((cell *, cell *)); + size_t cellen __P((cell *)); + cell *cellcat __P((cell *, cell *)); + /* ex_voper.c */ +-int operate __P((int, int)); ++void operate __P((int, int)); + int find __P((int)); +-int word __P((int (*)(), int)); +-int eend __P((int (*)())); ++int word __P((void (*)(int), int)); ++void eend __P((void (*)(int))); + int wordof __P((int, char *)); + int wordch __P((char *)); + int margin __P((void)); + /* ex_vops.c */ +-int vUndo __P((void)); +-int vundo __P((int)); +-int vmacchng __P((int)); +-int vnoapp __P((void)); +-int vmove __P((void)); +-int vdelete __P((int)); +-int vchange __P((int)); +-int voOpen __P((int, int)); +-int vshftop __P((void)); +-int vfilter __P((void)); +-int vrep __P((int)); +-int vyankit __P((void)); ++void vUndo __P((void)); ++void vundo __P((int)); ++void vmacchng __P((int)); ++void vnoapp __P((void)); ++void vmove __P((void)); ++void vmove_i __P((int)); ++void vdelete __P((int)); ++void vchange __P((int)); ++void voOpen __P((int, int)); ++void vshftop __P((void)); ++void vfilter __P((void)); ++void vrep __P((int)); ++void vyankit __P((void)); + /* ex_vops2.c */ +-int bleep __P((int, char *)); ++void bleep __P((int, char *)); + int vdcMID __P((void)); +-int takeout __P((cell *)); ++void takeout __P((cell *)); + int ateopr __P((void)); +-int showmode __P((int)); +-int vappend __P((int, int, int)); +-int back1 __P((void)); ++void showmode __P((int)); ++void vappend __P((int, int, int)); ++void back1 __P((void)); + char *vget_line __P((int, char *, bool *, int)); +-int vdoappend __P((char *)); ++void vdoappend __P((const char *)); + /* ex_vops3.c */ +-int llfind __P((int, int, int (*)(), line *)); ++int llfind __P((int, int, void (*)(int), line *)); + int lindent __P((line *)); + int lmatchp __P((line *)); +-int lsmatch __P((char *)); ++void lsmatch __P((char *)); + int lnext __P((void)); +-int lbrack __P((int, int (*)())); ++int lbrack __P((int, void (*)(int))); + /* ex_vput.c */ +-int vclear __P((void)); +-int vclrcell __P((cell *, int)); +-int vclrlin __P((int, line *)); +-int vclreol __P((void)); +-int vclrech __P((int)); +-int fixech __P((void)); +-int vcursbef __P((char *)); +-int vcursat __P((char *)); +-int vcursaft __P((char *)); +-int vfixcurs __P((void)); +-int vsetcurs __P((char *)); +-int vigoto __P((int, int)); +-int vcsync __P((void)); +-int vgotoCL __P((int)); +-int vgoto __P((int, int)); +-int vprepins __P((void)); ++void vclear __P((void)); ++void vclrcell __P((cell *, int)); ++void vclrlin __P((int, line *)); ++void vclreol __P((void)); ++void vclrech __P((int)); ++void fixech __P((void)); ++void vcursbef __P((char *)); ++void vcursat __P((char *)); ++void vcursaft __P((char *)); ++void vfixcurs __P((void)); ++void vsetcurs __P((char *)); ++void vigoto __P((int, int)); ++void vcsync __P((void)); ++void vgotoCL __P((int)); ++void vgoto __P((int, int)); ++void vprepins __P((void)); + int vputch __P((int)); + int vinschar __P((int)); +-int goim __P((void)); +-int endim __P((void)); ++void goim __P((void)); ++void endim __P((void)); + int vputchar __P((int)); +-int physdc __P((int, int)); ++void physdc __P((int, int)); + /* ex_vwind.c */ +-int vmoveto __P((line *, char *, int)); +-int vjumpto __P((line *, char *, int)); +-int vupdown __P((int, char *)); +-int vup __P((int, int, int)); +-int vdown __P((int, int, int)); +-int vcontext __P((line *, int)); +-int vclean __P((void)); +-int vshow __P((line *, line *)); +-int vroll __P((int)); ++void vmoveto __P((line *, char *, int)); ++void vjumpto __P((line *, char *, int)); ++void vupdown __P((int, char *)); ++void vup __P((int, int, int)); ++void vdown __P((int, int, int)); ++void vcontext __P((line *, int)); ++void vclean __P((void)); ++void vshow __P((line *, line *)); ++void vroll __P((int)); + int vdepth __P((void)); +-int vnline __P((char *)); ++void vnline __P((char *)); + /* malloc.c */ + char *poolsbrk __P((intptr_t)); + /* printf.c */ + int printf __P((const char *, ...)); + int vprintf __P((const char *, va_list)); +-char *p_dconv __P((long, char *)); ++char *p_dconv __P((unsigned long, char *)); + + woid onemt __P((int)); + woid onhup __P((int)); diff --git a/editors/ex/patches/patch-ex__put_c b/editors/ex/patches/patch-ex__put_c new file mode 100644 index 00000000000..bdcd03e6669 --- /dev/null +++ b/editors/ex/patches/patch-ex__put_c @@ -0,0 +1,530 @@ +$NetBSD: patch-ex__put_c,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- fix up function pointer casting mess +- avoid implicit int +- silence warnings about && and || precedence +- use const for string constants +- return values from non-void functions +- silence warnings about braces +- declare void functions void +- remove unused function + +--- ex_put.c.orig 2012-12-27 21:58:42.000000000 +0000 ++++ ex_put.c +@@ -99,15 +99,13 @@ static char sccsid[] = "@(#)ex_put.c 1.1 + * During open/visual, outchar and putchar will be set to + * routines in the file ex_vput.c (vputchar, vinschar, etc.). + */ +-int (*Outchar)() = termchar; +-int (*Putchar)() = normchar; +-int (*Pline)() = normline; +- +-int (* +-setlist(t))() +- bool t; ++int (*Outchar)(int) = termchar; ++int (*Putchar)(int) = normchar; ++int (*Pline)(int) = normline; ++ ++int (*setlist(bool t))(int) + { +- register int (*P)(); ++ register int (*P)(int); + + listf = t; + P = Putchar; +@@ -115,15 +113,13 @@ setlist(t))() + return (P); + } + +-int (* +-setnumb(t))() +- bool t; ++int (*setnumb(bool t))(int) + { +- register int (*P)(); ++ register int (*P)(int); + + numberf = t; + P = Pline; +- Pline = t ? (int(*)()) numbline : (int(*)()) normline; ++ Pline = t ? numbline : normline; + return (P); + } + +@@ -131,6 +127,7 @@ setnumb(t))() + * Format c for list mode; leave things in common + * with normal print mode to be done by normchar. + */ ++int + listchar(c) + register short c; + { +@@ -167,23 +164,24 @@ listchar(c) + if (c < ' ' && c != '\n') + outchar('^'), c = ctlof(c); + #else /* !BIT8 */ +- if (!is_print(c) && c != '\n' || c == DELETE) ++ if ((!is_print(c) && c != '\n') || c == DELETE) + c = printof(c); + #endif + break; + } +- normchar(c); ++ return normchar(c); + } + + /* + * Format c for printing. Handle funnies of upper case terminals + * and crocky hazeltines which don't have ~. + */ ++int + normchar(c) + register short c; + { + #ifdef UCVISUAL +- register char *colp; ++ register const char *colp; + + if (c == '~' && xHZ) { + normchar('\\'); +@@ -196,7 +194,7 @@ normchar(c) + if (c & QUOTE) { + #else + if (c == overbuf) +- return; ++ return c; + if (quot(c)) { + #endif + switch (c) { +@@ -231,7 +229,7 @@ normchar(c) + putchar('^'), c = ctlof(c); + #endif /* !BIT8 */ + #ifdef UCVISUAL +- else if (UPPERCASE) ++ else if (UPPERCASE) { + if (isupper(c)) { + outchar('\\'); + c = tolower(c); +@@ -244,11 +242,13 @@ normchar(c) + break; + } + } ++ } + #endif /* UCVISUAL */ + #ifdef BIT8 + } + #endif + outchar(c); ++ return c; + } + + /* +@@ -256,8 +256,8 @@ normchar(c) + * the printing of the line will erase or otherwise obliterate + * the prompt which was printed before. If it won't, do it now. + */ +-slobber(c) +- int c; ++static void ++slobber(int c) + { + + shudclob = 0; +@@ -288,6 +288,7 @@ slobber(c) + /* + * Print a line with a number. + */ ++int + numbline(i) + int i; + { +@@ -295,13 +296,14 @@ numbline(i) + if (shudclob) + slobber(' '); + printf("%6d ", i); +- normline(); ++ return normline(i); + } + + /* + * Normal line output, no numbering. + */ +-normline() ++int ++normline(int arg) + { + register char *cp; + +@@ -320,6 +322,7 @@ normline() + putchar('\n'); + #endif + } ++ return arg; + } + + /* +@@ -340,11 +343,12 @@ static bool phadnl; + /* + * Indirect to current definition of putchar. + */ ++int + putchar(c) + int c; + { + +- (*Putchar)(c); ++ return (*Putchar)(c); + } + + /* +@@ -353,6 +357,7 @@ putchar(c) + * Otherwise flush into next level of buffering when + * small buffer fills or at a newline. + */ ++int + termchar(c) + int c; + { +@@ -368,9 +373,11 @@ termchar(c) + fgoto(); + flush1(); + } ++ return c; + } + +-flush2() ++static void ++flush2(void) + { + + fgoto(); +@@ -378,6 +385,7 @@ flush2() + pstop(); + } + ++void + flush() + { + +@@ -390,6 +398,7 @@ flush() + * Work here is destroying motion into positions, and then + * letting fgoto do the optimized motion. + */ ++void + flush1() + { + register char *lp; +@@ -472,16 +481,19 @@ static int plodcnt, plodflg; + * and backspace. + */ + +-plodput(c) ++static int ++plodput(int c) + { + + if (plodflg) + plodcnt--; + else + putch(c); ++ return c; + } + +-plod(cnt) ++static int ++plod(int cnt) + { + register int i, j, k = 0; + register int soutcol, soutline; +@@ -585,7 +597,7 @@ plod(cnt) + * If it will be cheaper, or if we can't back up, then send + * a return preliminarily. + */ +- if (j > i + 1 || outcol > destcol && !BS && !BC) { ++ if (j > i + 1 || (outcol > destcol && !BS && !BC)) { + /* + * BUG: this doesn't take the (possibly long) length + * of xCR into account. +@@ -764,6 +776,7 @@ out: + * column position implied by wraparound or the lack thereof and + * rolling up the screen to get destline on the screen. + */ ++void + fgoto() + { + register int l, c; +@@ -778,11 +791,12 @@ fgoto() + outcol %= TCOLUMNS; + if (AM == 0) { + while (l > 0) { +- if (pfast) ++ if (pfast) { + if (xCR) + tputs(xCR, 0, putch); + else + putch('\r'); ++ } + if (xNL) + tputs(xNL, 0, putch); + else +@@ -834,7 +848,7 @@ fgoto() + outcol = 0; + } + } +- if (destline < outline && !(CA && !holdcm || UP != NOSTR)) ++ if (destline < outline && !((CA && !holdcm) || UP != NOSTR)) + destline = outline; + if (CA && !holdcm) + if (plod(costCM) > 0) +@@ -851,6 +865,7 @@ fgoto() + * Tab to column col by flushing and then setting destcol. + * Used by "set all". + */ ++void + tab(col) + int col; + { +@@ -865,6 +880,7 @@ tab(col) + * Approximate because kill character echoes newline with + * no feedback and also because of long input lines. + */ ++void + noteinp() + { + +@@ -883,6 +899,7 @@ noteinp() + * On cursor addressible terminals setting to unknown + * will force a cursor address soon. + */ ++void + termreset() + { + +@@ -906,12 +923,14 @@ termreset() + */ + char *obp = obuf; + ++void + draino() + { + + obp = obuf; + } + ++void + flusho() + { + +@@ -921,12 +940,15 @@ flusho() + } + } + ++void + putnl() + { + + putchar('\n'); + } + ++#if 0 /* unused */ ++void + putS(cp) + char *cp; + { +@@ -936,8 +958,10 @@ putS(cp) + while (*cp) + putch(*cp++); + } ++#endif + + ++int + putch(c) + int c; + { +@@ -953,6 +977,7 @@ putch(c) + #endif + if (obp >= &obuf[sizeof obuf]) + flusho(); ++ return c; + } + + /* +@@ -962,8 +987,9 @@ putch(c) + /* + * Put with padding + */ ++void + putpad(cp) +- char *cp; ++ const char *cp; + { + + flush(); +@@ -973,6 +999,7 @@ putpad(cp) + /* + * Set output through normal command mode routine. + */ ++void + setoutt() + { + +@@ -983,27 +1010,29 @@ setoutt() + * Printf (temporarily) in list mode. + */ + /*VARARGS2*/ ++void + #ifndef __STDC__ + lprintf(cp, dp) +- char *cp, *dp; ++ const char *cp, *dp; + { +- register int (*P)(); ++ register int (*P)(int); + + P = setlist(1); + printf(cp, dp); + Putchar = P; + } + #else +-vlprintf(char *cp, va_list ap) ++vlprintf(const char *cp, va_list ap) + { +- register int (*P)(); ++ register int (*P)(int); + + P = setlist(1); + vprintf(cp, ap); + Putchar = P; + } + +-lprintf(char *cp, ...) ++void ++lprintf(const char *cp, ...) + { + va_list ap; + +@@ -1016,6 +1045,7 @@ lprintf(char *cp, ...) + /* + * Newline + flush. + */ ++void + putNFL() + { + +@@ -1027,8 +1057,8 @@ putNFL() + * sTTY: set the tty modes on file descriptor i to be what's + * currently in global "tty". (Also use nttyc if needed.) + */ +-sTTY(i) +- int i; ++static void ++sTTY(int i) + { + + #ifdef POSIX_1 +@@ -1067,6 +1097,7 @@ sTTY(i) + /* + * Try to start -nl mode. + */ ++void + pstart() + { + +@@ -1101,6 +1132,7 @@ pstart() + /* + * Stop -nl mode. + */ ++void + pstop() + { + +@@ -1121,7 +1153,8 @@ pstop() + */ + #ifndef TERMIO_S + #ifdef TIOCGETC +-ttcharoff() ++static void ++ttcharoff(void) + { + nttyc.t_quitc = '\377'; + if (nttyc.t_startc != CTRL('q')) +@@ -1138,7 +1171,8 @@ ttcharoff() + #endif + + #else /* TERMIO_S */ +-ttcharoff() ++static void ++ttcharoff(void) + { + #ifdef _PC_VDISABLE + long vdis; +@@ -1239,6 +1273,7 @@ ostart() + } + + /* actions associated with putting the terminal in open mode */ ++void + tostart() + { + putpad(VS); +@@ -1275,6 +1310,7 @@ tostart() + /* + * Stop open, restoring tty modes. + */ ++void + ostop(f) + ttymode f; + { +@@ -1290,6 +1326,7 @@ ostop(f) + } + + /* Actions associated with putting the terminal in the right mode. */ ++void + tostop() + { + putpad(VE); +@@ -1302,7 +1339,8 @@ tostop() + /* + * Into cooked mode for interruptibility. + */ +-vcook() ++void ++vcook(void) + { + + tty.sg_flags &= ~RAW; +@@ -1312,7 +1350,8 @@ vcook() + /* + * Back into raw mode. + */ +-vraw() ++void ++vraw(void) + { + + tty.sg_flags |= RAW; +@@ -1323,6 +1362,7 @@ vraw() + /* + * Restore flags to normal state f. + */ ++void + normal(f) + ttymode f; + { +@@ -1365,6 +1405,7 @@ setty(f) + return (ot); + } + ++void + gTTY(i) + int i; + { +@@ -1391,6 +1432,7 @@ gTTY(i) + /* + * Print newline, or blank if in open/visual + */ ++void + noonl() + { + diff --git a/editors/ex/patches/patch-ex__re_c b/editors/ex/patches/patch-ex__re_c new file mode 100644 index 00000000000..836f8ccc023 --- /dev/null +++ b/editors/ex/patches/patch-ex__re_c @@ -0,0 +1,348 @@ +$NetBSD: patch-ex__re_c,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- declare local functions static +- declare void functions void +- use const for string constants +- wrap unused function in the proper matching ifdef +- avoid implicit int +- fix signed/unsigned mismatch +- silence warnings about assignments in conditionals +- silence warnings about && and || precedence + +--- ex_re.c~ 2012-12-27 21:58:42.000000000 +0000 ++++ ex_re.c +@@ -82,32 +82,35 @@ static char sccsid[] = "@(#)ex_re.c 1.37 + #include "ex.h" + #include "ex_re.h" + +-int compsub __P((int)); +-int dosubcon __P((int, line *)); +-int snote __P((register int, register int)); +-int comprhs __P((int)); +-int confirmed __P((line *)); +-int dosub __P((void)); +-int ugo __P((int, int)); +-int fixcase __P((register int)); +-int cerror __P((char *)); +-int cclass __P((register char *, register int, int)); ++static int compsub __P((int)); ++static int dosubcon __P((int, line *)); ++static void snote __P((register int, register int)); ++static void comprhs __P((int)); ++static int confirmed __P((line *)); ++static void dosub __P((void)); ++static void ugo __P((int, int)); ++static int fixcase __P((register int)); ++static char *place __P((char *, char *, char *)); ++static void cerror __P((const char *)); ++static int cclass __P((register const char *, register int, int)); + + /* + * Global, substitute and regular expressions. + * Very similar to ed, with some re extensions and + * confirmed substitute. + */ ++void + global(k) + bool k; + { + register char *gp; + register int c; + register line *a1; +- char globuf[GBSIZE], *Cwas; ++ char globuf[GBSIZE]; ++ const char *Cwas; + int lines = lineDOL(); + int oinglobal = inglobal; +- char *oglobp = globp; ++ const char *oglobp = globp; + + Cwas = Command; + /* +@@ -220,6 +223,7 @@ brkwh: + } + } + ++#ifdef notdef /* used above in a notdef block */ + /* + * gdelete: delete inside a global command. Handles the + * special case g/r.e./d. All lines to be deleted have +@@ -228,7 +232,8 @@ brkwh: + * and g/r.e./.,/r.e.2/d are not treated specially. There is no + * good reason for this except the question: where to you draw the line? + */ +-gdelete() ++static void ++gdelete(void) + { + register line *a1, *a2, *a3; + +@@ -250,16 +255,19 @@ gdelete() + dot = dol; + change(); + } ++#endif + + bool cflag; + int scount, slines, stotal; + ++int + substitute(c) + int c; + { + register line *addr; + register int n; +- int gsubf, hopcount; ++ int gsubf; ++ unsigned hopcount; + + gsubf = compsub(c); + if(FIXUNDO) +@@ -267,7 +275,8 @@ substitute(c) + stotal = 0; + slines = 0; + for (addr = addr1; addr <= addr2; addr++) { +- scount = hopcount = 0; ++ scount = 0; ++ hopcount = 0; + if (dosubcon(0, addr) == 0) + continue; + if (gsubf) { +@@ -299,7 +308,8 @@ substitute(c) + return (stotal); + } + +-compsub(ch) ++static int ++compsub(int ch) + { + register int seof, c, uselastre; + static int gsubf; +@@ -368,6 +378,7 @@ compsub(ch) + } + } + ++static void + comprhs(seof) + int seof; + { +@@ -469,6 +480,7 @@ endrhs: + *rp++ = 0; + } + ++int + getsub() + { + register char *p; +@@ -480,6 +492,7 @@ getsub() + return (0); + } + ++static int + dosubcon(f, a) + bool f; + line *a; +@@ -494,11 +507,12 @@ dosubcon(f, a) + return (1); + } + ++static int + confirmed(a) + line *a; + { + register int c; +- char *yesstr = catgets(catd, 1, 249, "y"); ++ const char *yesstr = catgets(catd, 1, 249, "y"); + int okay = -1; + + if (cflag == 0) +@@ -539,6 +553,7 @@ again: + } + + #ifdef notdef ++int + ex_getch() + { + char c; +@@ -553,6 +568,7 @@ ex_getch() + } + #endif /* notdef */ + ++static void + ugo(cnt, with) + int with; + int cnt; +@@ -567,7 +583,8 @@ ugo(cnt, with) + int casecnt; + bool destuc; + +-dosub() ++static void ++dosub(void) + { + register char *lp, *sp, *rp; + int c; +@@ -585,7 +602,7 @@ dosub() + while (lp < loc1) + *sp++ = *lp++; + casecnt = 0; +- while (c = *rp++) { ++ while ((c = *rp++) != 0) { + #ifdef BIT8 + c = cuc(c); + q = *qp++; +@@ -661,12 +678,13 @@ ovflo: + } + lp = loc2; + loc2 = sp + (linebuf - genbuf); +- while (*sp++ = *lp++) ++ while ((*sp++ = *lp++) != 0) + if (sp >= &genbuf[LBSIZE]) + goto ovflo; + strcLIN(genbuf); + } + ++static int + fixcase(c) + register int c; + { +@@ -683,7 +701,7 @@ fixcase(c) + return (c); + } + +-char * ++static char * + place(sp, l1, l2) + register char *sp, *l1, *l2; + { +@@ -696,6 +714,7 @@ place(sp, l1, l2) + return (sp); + } + ++static void + snote(total, lines) + register int total, lines; + { +@@ -709,16 +728,17 @@ snote(total, lines) + flush(); + } + ++static void + cerror(s) +- char *s; ++ const char *s; + { + expbuf[0] = '\0'; + error(s); + } + + #ifdef UXRE +-refree(rp) +-struct regexp *rp; ++static void ++refree(struct regexp *rp) + { + struct regexp *r1 = NULL, *r2 = NULL; + +@@ -986,8 +1006,7 @@ complex: cerror(catgets(catd, 1, 139, + } + + int +-execute(gf, addr) +-line *addr; ++execute(int gf, line *addr) + { + char *p; + int c; +@@ -1041,6 +1060,7 @@ line *addr; + goto complex; \ + } + ++int + compile(eof, oknl) + int eof; + int oknl; +@@ -1123,7 +1143,7 @@ complex: + return (eof); + } + if (value(MAGIC)) { +- if (c != '*' && (c != '\\' || peekchar() != '{') || ++ if ((c != '*' && (c != '\\' || peekchar() != '{')) || + ep == expbuf) { + lastep = ep; + } +@@ -1349,7 +1369,7 @@ magic: + "Badly formed re|Missing closing delimiter for regular expression")); + + case '$': +- if (peekchar() == eof || peekchar() == EOF || oknl && peekchar() == '\n') { ++ if (peekchar() == eof || peekchar() == EOF || (oknl && peekchar() == '\n')) { + *ep++ = CDOL; + continue; + } +@@ -1370,17 +1390,19 @@ defchar: + } + } + ++int + same(a, b) + register int a, b; + { + +- return (a == b || value(IGNORECASE) && +- ((islower(a) && toupper(a) == b) || (islower(b) && toupper(b) == a))); ++ return (a == b || ++ (value(IGNORECASE) && ++ ((islower(a) && toupper(a) == b) || ++ (islower(b) && toupper(b) == a)))); + } + +-ecmp(a, b, count) +- register char *a, *b; +- register int count; ++static int ++ecmp(register char *a, register char *b, register int count) + { + while (count--) + if (!same(*a++, *b++)) +@@ -1390,8 +1412,8 @@ ecmp(a, b, count) + + char *locs; + +-execute(gf, addr) +- line *addr; ++int ++execute(int gf, line *addr) + { + register char *p1, *p2; + register int c; +@@ -1437,8 +1459,8 @@ execute(gf, addr) + return (0); + } + +-getrnge(str) +- register char *str; ++static void ++getrnge(register char *str) + { + low = *str++ & 0377; + siz = (*str & 0377) == 255 ? 20000 : (*str & 0377) - low; +@@ -1446,6 +1468,7 @@ getrnge(str) + + #define uletter(c) (isalpha(c) || c == '_') + ++int + advance(lp, ep) + register char *lp, *ep; + { +@@ -1628,8 +1651,9 @@ star: + } + } + ++static int + cclass(set, c, af) +- register char *set; ++ register const char *set; + register int c; + int af; + { diff --git a/editors/ex/patches/patch-ex__set_c b/editors/ex/patches/patch-ex__set_c new file mode 100644 index 00000000000..a0a1537530f --- /dev/null +++ b/editors/ex/patches/patch-ex__set_c @@ -0,0 +1,128 @@ +$NetBSD: patch-ex__set_c,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- declare local functions static +- declare void functions void +- avoid implicit int +- use const for string constants +- silence warnings about && and || precedence + +--- ex_set.c~ 2012-12-27 21:58:42.000000000 +0000 ++++ ex_set.c +@@ -88,18 +88,19 @@ static char sccsid[] = "@(#)ex_set.c 1.8 + */ + char optname[ONMSZ]; + +-int setend __P((void)); +-int prall __P((void)); +-int propts __P((void)); +-int propt __P((register struct option *)); ++static int setend __P((void)); ++static void prall __P((void)); ++static void propts __P((void)); ++static void propt __P((register struct option *)); + ++void + set() + { +- register char *cp; ++ register const char *cp; ++ register char *cp2; + register struct option *op; + register int c; + bool no; +- extern short ospeed; + + setnoaddr(); + if (skipend()) { +@@ -109,12 +110,12 @@ set() + return; + } + do { +- cp = optname; ++ cp2 = optname; + do { +- if (cp < &optname[ONMSZ - 2]) +- *cp++ = getchar(); ++ if (cp2 < &optname[ONMSZ - 2]) ++ *cp2++ = getchar(); + } while (isalnum(peekchar())); +- *cp = 0; ++ *cp2 = 0; + cp = optname; + if (eq("all", cp)) { + if (inopen) +@@ -146,7 +147,7 @@ dontset: + cp = "window"; + } + for (op = options; op < &options[NOPTS]; op++) +- if (eq(op->oname, cp) || op->oabbrev && eq(op->oabbrev, cp)) ++ if (eq(op->oname, cp) || (op->oabbrev && eq(op->oabbrev, cp))) + break; + if (op->oname == 0) + serror(catgets(catd, 1, 159, +@@ -193,18 +194,18 @@ printone: + + case STRING: + case OTERM: +- cp = optname; ++ cp2 = optname; + while (!setend()) { +- if (cp >= &optname[ONMSZ]) ++ if (cp2 >= &optname[ONMSZ]) + error(catgets(catd, 1, 163, + "String too long@in option assignment")); + /* adb change: allow whitepace in strings */ +- if( (*cp = getchar()) == '\\') ++ if( (*cp2 = getchar()) == '\\') + if( peekchar() != EOF) +- *cp = getchar(); +- cp++; ++ *cp2 = getchar(); ++ cp2++; + } +- *cp = 0; ++ *cp2 = 0; + if (op->otype == OTERM) { + /* + * At first glance it seems like we shouldn't care if the terminal type +@@ -237,13 +238,15 @@ setnext: + eol(); + } + ++static int + setend() + { + + return (is_white(peekchar()) || endcmd(peekchar())); + } + +-prall() ++static void ++prall(void) + { + register int incr = (NOPTS + 2) / 3; + register int rows = incr; +@@ -261,7 +264,8 @@ prall() + } + } + +-propts() ++static void ++propts(void) + { + register struct option *op; + +@@ -292,10 +296,10 @@ propts() + flush(); + } + +-propt(op) +- register struct option *op; ++static void ++propt(register struct option *op) + { +- register char *name; ++ register const char *name; + + name = op->oname; + diff --git a/editors/ex/patches/patch-ex__subr_c b/editors/ex/patches/patch-ex__subr_c new file mode 100644 index 00000000000..599b88f6ee2 --- /dev/null +++ b/editors/ex/patches/patch-ex__subr_c @@ -0,0 +1,686 @@ +$NetBSD: patch-ex__subr_c,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- use standard headers +- avoid sloppy code that subtracts 1 from the base address of a char[] + (which isn't valid) (although this could be tidied further) +- avoid implicit int +- silence warnings about && and || precedence +- declare void functions void +- use const for string constants +- use <ctype.h> functions properly +- fix up function pointer casting mess +- silence warnings about unused arguments +- teach it about dead functions + +--- ex_subr.c~ 2012-12-27 21:58:42.000000000 +0000 ++++ ex_subr.c +@@ -79,27 +79,33 @@ static char sccsid[] = "@(#)ex_subr.c 1. + + /* from ex_subr.c 7.10.1 (2.11BSD) 1996/3/22 */ + ++#include <sys/ioctl.h> ++ + #include "ex.h" + #include "ex_re.h" + #include "ex_tty.h" + #include "ex_vis.h" + ++static int qcolumn __P((char *, char *)); ++ + /* + * Random routines, in alphabetical order. + */ + ++int + any(c, s) + int c; +- register char *s; ++ register const char *s; + { + register int x; + +- while (x = *s++) ++ while ((x = *s++) != 0) + if (x == c) + return (1); + return (0); + } + ++int + backtab(i) + register int i; + { +@@ -114,6 +120,7 @@ backtab(i) + return (i); + } + ++void + change() + { + +@@ -128,6 +135,7 @@ change() + * characters through position cp of the + * current line. + */ ++int + column(cp) + register char *cp; + { +@@ -141,6 +149,7 @@ column(cp) + * Ignore a comment to the end of the line. + * This routine eats the trailing newline so don't call newline(). + */ ++void + comment() + { + register int c; +@@ -152,6 +161,7 @@ comment() + ungetchar(c); + } + ++void + Copy(to, from, size) + register char *from, *to; + register int size; +@@ -163,6 +173,7 @@ Copy(to, from, size) + while (--size > 0); + } + ++void + copyw(to, from, size) + register line *from, *to; + register int size; +@@ -174,6 +185,7 @@ copyw(to, from, size) + while (--size > 0); + } + ++void + copywR(to, from, size) + register line *from, *to; + register int size; +@@ -183,6 +195,7 @@ copywR(to, from, size) + to[size] = from[size]; + } + ++int + ctlof(c) + int c; + { +@@ -190,6 +203,7 @@ ctlof(c) + return (c == DELETE ? '?' : c | ('A' - 1)); + } + ++void + dingdong() + { + +@@ -199,6 +213,7 @@ dingdong() + putch('\207'); + } + ++int + fixindent(indent) + int indent; + { +@@ -215,8 +230,9 @@ fixindent(indent) + return (i); + } + ++void + filioerr(cp) +- char *cp; ++ const char *cp; + { + register int oerrno = errno; + +@@ -238,6 +254,7 @@ genindent(indent) + return (cp); + } + ++void + getDOT() + { + +@@ -257,6 +274,7 @@ getmark(c) + return (0); + } + ++int + getn(cp) + register char *cp; + { +@@ -269,6 +287,7 @@ getn(cp) + return (i); + } + ++void + ignnEOF() + { + register int c = getchar(); +@@ -279,6 +298,7 @@ ignnEOF() + comment(); + } + ++int + is_white(c) + int c; + { +@@ -286,11 +306,12 @@ is_white(c) + #ifndef BIT8 + return (c == ' ' || c == '\t'); + #else +- return (isspace(c) && c != '\n' && c != '\r' ++ return (isspace((unsigned char)c) && c != '\n' && c != '\r' + && c != '\f' && c != '\v'); + #endif + } + ++int + junk(c) + register int c; + { +@@ -315,12 +336,14 @@ junk(c) + } + } + ++void + killed() + { + + killcnt(addr2 - addr1 + 1); + } + ++void + killcnt(cnt) + register int cnt; + { +@@ -343,6 +366,7 @@ killcnt(cnt) + putNFL(); + } + ++int + lineno(a) + line *a; + { +@@ -350,24 +374,28 @@ lineno(a) + return (a - zero); + } + ++int + lineDOL() + { + + return (lineno(dol)); + } + ++int + lineDOT() + { + + return (lineno(dot)); + } + ++void + markDOT() + { + + markpr(dot); + } + ++void + markpr(which) + line *which; + { +@@ -379,6 +407,7 @@ markpr(which) + } + } + ++int + markreg(c) + register int c; + { +@@ -397,12 +426,13 @@ markreg(c) + * All others map to themselves. + */ + char * +-mesg(str) +- register char *str; ++mesg(arg) ++ const char *arg; + { ++ register char *str; + register char *cp; + +- str = strcpy(genbuf, str); ++ str = strcpy(genbuf, arg); + for (cp = str; *cp; cp++) + switch (*cp) { + +@@ -422,12 +452,13 @@ mesg(str) + return (str); + } + ++static void + merror1(seekpt) + #ifdef VMUNIX +- char *seekpt; ++ const char *seekpt; + #else + # ifdef lint +- char *seekpt; ++ const char *seekpt; + # else + int seekpt; + # endif +@@ -444,20 +475,21 @@ merror1(seekpt) + } + + /*VARARGS2*/ ++void + #ifndef __STDC__ + merror(seekpt, i) + #ifdef VMUNIX +- char *seekpt; ++ const char *seekpt; + #else + # ifdef lint +- char *seekpt; ++ const char *seekpt; + # else + int seekpt; + # endif + #endif + int i; + #else +-vmerror(char *seekpt, va_list ap) ++vmerror(const char *seekpt, va_list ap) + #endif + { + +@@ -482,7 +514,8 @@ vmerror(char *seekpt, va_list ap) + } + + #ifdef __STDC__ +-merror(char *cp, ...) ++void ++merror(const char *cp, ...) + { + va_list ap; + +@@ -494,6 +527,7 @@ merror(char *cp, ...) + } + #endif + ++int + morelines() + { + #ifdef _SC_PAGESIZE +@@ -517,6 +551,7 @@ morelines() + #endif /* !_SC_PAGESIZE */ + } + ++void + nonzero() + { + +@@ -527,6 +562,7 @@ nonzero() + } + } + ++int + notable(i) + int i; + { +@@ -534,7 +570,7 @@ notable(i) + return (hush == 0 && !inglobal && i > value(REPORT)); + } + +- ++void + notempty() + { + +@@ -542,7 +578,7 @@ notempty() + error(catgets(catd, 1, 173, "No lines@in the buffer")); + } + +- ++void + netchHAD(cnt) + int cnt; + { +@@ -550,10 +586,11 @@ netchHAD(cnt) + netchange(lineDOL() - cnt); + } + ++void + netchange(i) + register int i; + { +- register char *cp; ++ register const char *cp; + + if (i > 0) + notesgn = cp = catgets(catd, 1, 174, "more "); +@@ -575,10 +612,11 @@ netchange(i) + * Print an escape sequence corresponding to c. + */ + #ifdef BIT8 ++int + printof(c) + int c; + { +- char *nums = "01234567"; ++ const char *nums = "01234567"; + int d; + + if (c < 040 || c == DELETE) { +@@ -597,6 +635,7 @@ printof(c) + } + #endif + ++void + putmark(addr) + line *addr; + { +@@ -604,6 +643,7 @@ putmark(addr) + putmk1(addr, putline()); + } + ++void + putmk1(addr, n) + register line *addr; + int n; +@@ -620,7 +660,7 @@ putmk1(addr, n) + *addr = n | oldglobmk; + } + +-char * ++const char * + plural(i) + long i; + { +@@ -629,14 +669,15 @@ plural(i) + : catgets(catd, 1, 179, "s")); + } + +-int qcount(); ++static int qcount(int c); + short vcntcol; + ++static int + qcolumn(lim, gp) + register char *lim, *gp; + { + register int x = 0; +- int (*OO)(); ++ int (*OO)(int); + + OO = Outchar; + Outchar = qcount; +@@ -653,18 +694,33 @@ qcolumn(lim, gp) + return (vcntcol); + } + ++/* ++ * Like qcolumn() but doesn't require subtracting 1 from the first ++ * argument before calling it. ++ */ + int ++qcolumn2(char *lim, char *gp) ++{ ++ if (lim != NULL) { ++ lim--; ++ } ++ return qcolumn(lim, gp); ++} ++ ++static int + qcount(c) + int c; + { + + if (c == '\t') { + vcntcol += value(TABSTOP) - vcntcol % value(TABSTOP); +- return; ++ return c; + } + vcntcol++; ++ return c; + } + ++void + reverse(a1, a2) + register line *a1, *a2; + { +@@ -679,6 +735,7 @@ reverse(a1, a2) + } + } + ++void + save(a1, a2) + line *a1; + register line *a2; +@@ -714,24 +771,28 @@ save(a1, a2) + #endif + } + ++void + save12() + { + + save(addr1, addr2); + } + ++void + saveall() + { + + save(one, dol); + } + ++int + span() + { + + return (addr2 - addr1 + 1); + } + ++void + synced() + { + +@@ -740,7 +801,7 @@ synced() + xchng = 0; + } + +- ++int + skipwh() + { + register int wh; +@@ -754,17 +815,18 @@ skipwh() + } + + /*VARARGS2*/ ++void + #ifndef __STDC__ + smerror(seekpt, cp) + #ifdef lint +- char *seekpt; ++ const char *seekpt; + #else + int seekpt; + #endif +- char *cp; ++ const char *cp; + { + #else +-vsmerror(char *seekpt, va_list ap) ++vsmerror(const char *seekpt, va_list ap) + { + + #endif +@@ -786,7 +848,8 @@ vsmerror(char *seekpt, va_list ap) + } + + #ifdef __STDC__ +-smerror(char *seekpt, ...) ++void ++smerror(const char *seekpt, ...) + { + va_list ap; + +@@ -808,13 +871,25 @@ strend(cp) + return (cp); + } + ++const char * ++strendk(cp) ++ register const char *cp; ++{ ++ ++ while (*cp) ++ cp++; ++ return (cp); ++} ++ ++void + strcLIN(dp) +- char *dp; ++ const char *dp; + { + + CP(linebuf, dp); + } + ++void + syserror() + { + +@@ -828,6 +903,7 @@ syserror() + * hitting a tab, where tabs are set every ts columns. Work right for + * the case where col > TCOLUMNS, even if ts does not divide TCOLUMNS. + */ ++int + tabcol(col, ts) + int col, ts; + { +@@ -847,10 +923,10 @@ vfindcol(i) + int i; + { + register char *cp; +- register int (*OO)() = Outchar; ++ register int (*OO)(int) = Outchar; + + Outchar = qcount; +- ignore(qcolumn(linebuf - 1, NOSTR)); ++ ignore(qcolumn2(linebuf, NOSTR)); + for (cp = linebuf; *cp && vcntcol < i; cp++) + putchar(*cp); + if (cp != linebuf) +@@ -880,6 +956,7 @@ vpastwh(cp) + return (cp); + } + ++int + whitecnt(cp) + register char *cp; + { +@@ -911,13 +988,14 @@ Ignore(a) + } + + Ignorf(a) +- int (*a)(); ++ int (*a)(int); + { + + a = a; + } + #endif + ++void + markit(addr) + line *addr; + { +@@ -937,10 +1015,12 @@ markit(addr) + */ + int _ovno; + woid +-onemt(signum) ++onemt(int signum) + { + int oovno; + ++ (void)signum; ++ + #ifndef POSIX_1 + signal(SIGEMT, onemt); + #endif +@@ -963,8 +1043,9 @@ onemt(signum) + * are not removed. + */ + woid +-onhup(signum) ++onhup(int signum) + { ++ (void)signum; + + /* + * USG tty driver can send multiple HUP's!! +@@ -993,9 +1074,11 @@ onhup(signum) + * suppressed in visual mode). + */ + woid +-onintr(signum) ++onintr(int signum) + { + ++ (void)signum; ++ + #ifndef POSIX_1 + #ifndef CBREAK + signal(SIGINT, onintr); +@@ -1022,6 +1105,7 @@ onintr(signum) + * In some critical sections we turn interrupts off, + * but not very often. + */ ++void + setrupt() + { + +@@ -1040,6 +1124,7 @@ setrupt() + } + } + ++int + preserve() + { + +@@ -1063,6 +1148,8 @@ preserve() + } + + #ifndef V6 ++dead ++void + exitex(i) + int i; + { +@@ -1081,7 +1168,7 @@ exitex(i) + * We have just gotten a susp. Suspend and prepare to resume. + */ + woid +-onsusp(signum) ++onsusp(int signum) + { + ttymode f; + /* int omask; */ +@@ -1092,6 +1179,8 @@ onsusp(signum) + sigset_t set; + #endif + ++ (void)signum; ++ + f = setty(normf); + vnfl(); + putpad(TE); diff --git a/editors/ex/patches/patch-ex__tagio_c b/editors/ex/patches/patch-ex__tagio_c new file mode 100644 index 00000000000..fc4314e0b67 --- /dev/null +++ b/editors/ex/patches/patch-ex__tagio_c @@ -0,0 +1,63 @@ +$NetBSD: patch-ex__tagio_c,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- avoid implicit int +- don't misuse NULL +- declare void functions void + +--- ex_tagio.c~ 2003-09-03 19:53:02.000000000 +0000 ++++ ex_tagio.c +@@ -96,6 +96,7 @@ static int bcnt = 0; + static int b_size = MAXBSIZE; + static char *ibuf; + ++int + topen(file, buf) + char *file, *buf; + { +@@ -116,6 +117,7 @@ char *file, *buf; + return(fd); + } + ++int + tseek(fd, off) + int fd; + off_t off; +@@ -134,6 +136,7 @@ off_t off; + return(0); + } + ++int + tgets(buf, cnt, fd) + register char *buf; + int cnt; +@@ -145,19 +148,19 @@ int fd; + cc = offset; + if (cc == -1) { + if ((bcnt = read(fd, ibuf, b_size)) <= 0) +- return (NULL); ++ return 0; + cc = 0; + block = 0; + } + if (bcnt == 0) /* EOF */ +- return(NULL); ++ return 0; + cp = ibuf + cc; + while (--cnt > 0) { + if (++cc > bcnt) { + block += b_size; + if ((bcnt = read(fd, ibuf, b_size)) <= 0) { + offset = cc; +- return (NULL); ++ return 0; + } + cp = ibuf; + cc = 1; +@@ -170,6 +173,7 @@ int fd; + return(1); + } + ++void + tclose(fd) + int fd; + { diff --git a/editors/ex/patches/patch-ex__temp_c b/editors/ex/patches/patch-ex__temp_c new file mode 100644 index 00000000000..f3350266a31 --- /dev/null +++ b/editors/ex/patches/patch-ex__temp_c @@ -0,0 +1,255 @@ +$NetBSD: patch-ex__temp_c,v 1.1 2012/12/28 03:03:08 dholland Exp $ + +- declare local functions static +- declare void functions void +- avoid implicit int +- silence warnings about assignments in conditionals +- silence signed/unsigned compiler warning +- return values from non-void functions + +--- ex_temp.c~ 2012-12-27 21:58:41.000000000 +0000 ++++ ex_temp.c +@@ -106,11 +106,14 @@ int havetmp; + int tfile = -1; + int rfile = -1; + +-int YANKline __P((void)); +-int rbflush __P((void)); +-int blkio __P((bloc, char *, ssize_t (*) __P((int, void *, size_t)))); +-char *getblock __P((line, int)); ++static void YANKline __P((void)); ++static void rbflush __P((void)); ++static void blkio __P((bloc, char *, ssize_t (*) __P((int, void *, size_t)))); ++static char *getblock __P((line, int)); ++static ssize_t shread __P((void)); ++static int getREG __P((void)); + ++void + fileinit() + { + register char *p; +@@ -196,6 +199,7 @@ dumbness: + /* brk((char *)fendcore); */ + } + ++void + cleanup(all) + bool all; + { +@@ -213,6 +217,7 @@ cleanup(all) + } + } + ++void + get_line(tl) + line tl; + { +@@ -223,13 +228,14 @@ get_line(tl) + bp = getblock(tl, READ); + nl = nleft; + tl &= ~OFFMSK; +- while (*lp++ = *bp++) ++ while ((*lp++ = *bp++) != 0) + if (--nl == 0) { + bp = getblock(tl += INCRMT, READ); + nl = nleft; + } + } + ++int + putline() + { + register char *bp, *lp; +@@ -243,7 +249,7 @@ putline() + bp = getblock(tl, WRITE); + nl = nleft; + tl &= ~OFFMSK; +- while (*bp = *lp++) { ++ while ((*bp = *lp++) != 0) { + if (*bp++ == '\n') { + *--bp = 0; + linebp = lp; +@@ -264,7 +270,7 @@ ssize_t read __P((int, void *, size_t)); + ssize_t write __P((int, void *, size_t)); + #endif + +-char * ++static char * + getblock(atl, iof) + line atl; + int iof; +@@ -321,8 +327,8 @@ char incorb[INCORB+1][BUFSIZ]; + bloc stilinc; /* up to here not written yet */ + #endif + ++static void + #ifdef __STDC__ +-int + blkio(bloc b, char *buf, ssize_t (*iofcn)(int, void *, size_t)) + #else /* !__STDC__ */ + blkio(b, buf, iofcn) +@@ -353,6 +359,7 @@ blkio(b, buf, iofcn) + } + + #ifdef INCORB ++void + tlaste() + { + +@@ -360,6 +367,7 @@ tlaste() + dirtcnt = 0; + } + ++void + tflush() + { + bbloc i = stilinc; +@@ -375,6 +383,7 @@ tflush() + * Synchronize the state of the temporary file in case + * a crash occurs. + */ ++void + synctmp() + { + register bbloc cnt; +@@ -438,6 +447,7 @@ oops: + #endif + } + ++void + TSYNC() + { + +@@ -493,6 +503,7 @@ short rblock; + short rnext; + char *rbufcp; + ++static void + regio(b, iofcn) + short b; + ssize_t (*iofcn) __P((int, void *, size_t)); +@@ -542,11 +553,12 @@ oops: + rblock = b; + } + ++static int + REGblk() + { + register int i, j, m; + +- for (i = 0; i < sizeof rused / sizeof rused[0]; i++) { ++ for (i = 0; i < (int)(sizeof rused / sizeof rused[0]); i++) { + m = (rused[i] ^ 0177777) & 0177777; + if (i == 0) + m &= ~1; +@@ -562,10 +574,11 @@ REGblk() + } + } + error(catgets(catd, 1, 186, "Out of register space (ugh)")); +- /*NOTREACHED*/ ++ /* XXX what do we do here? */ ++ return 0; + } + +-struct strreg * ++static struct strreg * + mapreg(c) + register int c; + { +@@ -575,8 +588,7 @@ mapreg(c) + return (isdigit(c) ? &strregs[('z'-'a'+1)+(c-'0')] : &strregs[c-'a']); + } + +-ssize_t shread(); +- ++static void + KILLreg(c) + register int c; + { +@@ -598,8 +610,8 @@ KILLreg(c) + } + + /*VARARGS*/ +-ssize_t +-shread() ++static ssize_t ++shread(void) + { + struct front { short a; short b; }; + +@@ -608,9 +620,8 @@ shread() + return (0); + } + +-int getREG(); +- +-putreg(c) ++void ++putreg(int c) + { + register line *odot = dot; + register line *odol = dol; +@@ -651,12 +662,14 @@ putreg(c) + notecnt = cnt; + } + +-partreg(c) ++int ++partreg(int c) + { + + return (mapreg(c)->rg_flags); + } + ++void + notpart(c) + register int c; + { +@@ -665,6 +678,7 @@ notpart(c) + mapreg(c)->rg_flags = 0; + } + ++static int + getREG() + { + register char *lp = linebuf; +@@ -691,6 +705,7 @@ getREG() + } + } + ++void + YANKreg(c) + register int c; + { +@@ -729,6 +744,7 @@ YANKreg(c) + CP(linebuf,savelb); + } + ++void + kshift() + { + register int i; +@@ -738,6 +754,7 @@ kshift() + copy(mapreg(i+1), mapreg(i), sizeof (struct strreg)); + } + ++static void + YANKline() + { + register char *lp = linebuf; +@@ -764,6 +781,7 @@ YANKline() + *rbufcp = 0; + } + ++static void + rbflush() + { + register struct strreg *sp = strp; +@@ -778,6 +796,7 @@ rbflush() + } + + /* Register c to char buffer buf of size buflen */ ++void + regbuf(c, buf, buflen) + char c; + char *buf; diff --git a/editors/ex/patches/patch-ex__tty_c b/editors/ex/patches/patch-ex__tty_c new file mode 100644 index 00000000000..497f08fb345 --- /dev/null +++ b/editors/ex/patches/patch-ex__tty_c @@ -0,0 +1,147 @@ +$NetBSD: patch-ex__tty_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- use standard headers +- declare local functions (and data) static +- declare void functions void +- don't put function declarations inside other functions +- return values from non-void functions + +--- ex_tty.c~ 2003-03-18 20:29:07.000000000 +0000 ++++ ex_tty.c +@@ -79,14 +79,16 @@ static char sccsid[] = "@(#)ex_tty.c 1.1 + + /* from ex_tty.c 7.10.1 (2.11BSD GTE) 12/9/94 */ + ++#include <sys/ioctl.h> ++ + #include "ex.h" + #include "ex_tty.h" + + int ATTN = DELETE; + +-int gettmode __P((void)); +-char *gettlongname __P((char *, char *)); +-int zap __P((void)); ++static const char *gettlongname __P((char *, const char *)); ++static void zap __P((void)); ++static int countnum(int ch); + + /* + * Terminal type initialization routines, +@@ -95,6 +97,7 @@ int zap __P((void)); + */ + /* short ospeed = -1; mjm: def also in tputs.c of termcap.a */ + ++void + gettmode() + { + #ifdef POSIX_1 +@@ -171,7 +174,7 @@ gettmode() + } + + char *xPC; +-char **sstrs[] = { ++static char **sstrs[] = { + &AL, &BC, &BT, &CD, &CE, &CL, &CM, &xCR, &xCS, &DC, &DL, &DM, &DO, + &ED, &EI, &F0, &F1, &F2, &F3, &F4, &F5, &F6, &F7, &F8, &F9, + &HO, &IC, &IM, &IP, &KD, &KE, &KH, &KL, &KR, &KS, &KU, &LL, &ND, &xNL, +@@ -189,13 +192,17 @@ bool *sflags[] = { + char **fkeys[10] = { + &F0, &F1, &F2, &F3, &F4, &F5, &F6, &F7, &F8, &F9 + }; ++ ++void + setterm(type) +- char *type; ++ const char *type; + { +- char *tgoto(); + register int unknown; + char ltcbuf[TCBUFSIZE]; + ++ /* to avoid needing to make all the terminal strings const */ ++ static char empty[] = ""; ++ + if (type[0] == 0) + type = "xx"; + unknown = 0; +@@ -221,13 +228,13 @@ setterm(type) + * Handle funny termcap capabilities + */ + if (xCS && SC && RC) { +- if (AL==NULL) AL=""; +- if (DL==NULL) DL=""; ++ if (AL==NULL) AL=empty; ++ if (DL==NULL) DL=empty; + } +- if (AL_PARM && AL==NULL) AL=""; +- if (DL_PARM && DL==NULL) DL=""; +- if (IC && IM==NULL) IM=""; +- if (IC && EI==NULL) EI=""; ++ if (AL_PARM && AL==NULL) AL=empty; ++ if (DL_PARM && DL==NULL) DL=empty; ++ if (IC && IM==NULL) IM=empty; ++ if (IC && EI==NULL) EI=empty; + if (!GT) BT=NULL; /* If we can't tab, we can't backtab either */ + + #ifndef USG3TTY +@@ -313,6 +320,7 @@ setterm(type) + "%s: Unknown terminal type"), type); + } + ++void + setsize() + { + register int l, i; +@@ -369,9 +377,10 @@ setsize() + TLINES = 2; + } + +-zap() ++static void ++zap(void) + { +- register char *namp; ++ register const char *namp; + register bool **fp; + register char ***sp; + int flag; +@@ -397,10 +406,10 @@ zap() + } while (*namp); + } + +-char * ++static const char * + gettlongname(bp, def) + register char *bp; +- char *def; ++ const char *def; + { + register char *cp; + +@@ -438,11 +447,11 @@ fkey(i) + * than AL vs SR, won't be really affected.) + */ + static int costnum; ++ ++int + cost(str) +-char *str; ++const char *str; + { +- int countnum(); +- + if (str == NULL || *str=='O') /* OOPS */ + return 10000; /* infinity */ + costnum = 0; +@@ -451,8 +460,10 @@ char *str; + } + + /* ARGSUSED */ ++static int + countnum(ch) + char ch; + { + costnum++; ++ return ch; + } diff --git a/editors/ex/patches/patch-ex__tty_h b/editors/ex/patches/patch-ex__tty_h new file mode 100644 index 00000000000..6a2f94961c2 --- /dev/null +++ b/editors/ex/patches/patch-ex__tty_h @@ -0,0 +1,39 @@ +$NetBSD: patch-ex__tty_h,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- use const for string constants +- declare void functions void +- don't declare local functions in header files + +--- ex_tty.h.orig 2002-02-06 00:43:55.000000000 +0000 ++++ ex_tty.h +@@ -259,9 +259,9 @@ var short costRP; /* likewise for RIGHT_ + # define MAXCHARMACS 1536 /* max # of chars total in macros */ + #endif + struct maps { +- char *cap; /* pressing button that sends this.. */ +- char *mapto; /* .. maps to this string */ +- char *descr; /* legible description of key */ ++ const char *cap; /* pressing button that sends this.. */ ++ const char *mapto; /* .. maps to this string */ ++ const char *descr; /* legible description of key */ + bool hadthis; /* did this mapping already (avoid recursion) */ + }; + var struct maps arrows[MAXNOMACS]; /* macro defs - 1st 5 built in */ +@@ -275,12 +275,11 @@ var bool anyabbrs; /* true if abbr or un + var char ttynbuf[20]; /* result of ttyname() */ + var int ttymesg; /* original mode of users tty */ + +-int addmac __P((register char *, register char *, register char *, register struct maps *)); ++void addmac __P((register char *, register const char *, register const char *, register struct maps *)); + ttymode ostart __P((void)); +-int normal __P((ttymode)); +-int ostop __P((ttymode)); ++void normal __P((ttymode)); ++void ostop __P((ttymode)); + ttymode setty __P((ttymode)); +-ttymode unixex __P((char *, char *, int, int)); +-int unixwt __P((int, ttymode)); +-int ovend __P((ttymode)); ++ttymode unixex __P((const char *, char *, int, int)); ++void unixwt __P((int, ttymode)); + int map __P((register int, register struct maps *)); diff --git a/editors/ex/patches/patch-ex__unix_c b/editors/ex/patches/patch-ex__unix_c new file mode 100644 index 00000000000..49b7ca304ff --- /dev/null +++ b/editors/ex/patches/patch-ex__unix_c @@ -0,0 +1,65 @@ +$NetBSD: patch-ex__unix_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare void functions void +- use const for string constants + +--- ex_unix.c~ 2003-09-03 19:53:02.000000000 +0000 ++++ ex_unix.c +@@ -95,6 +95,7 @@ static char sccsid[] = "@(#)ex_unix.c 1. + * First part of a shell escape, + * parse the line, expanding # and % and ! and printing if implied. + */ ++void + unix0(warn) + bool warn; + { +@@ -217,7 +218,8 @@ uexp: + */ + ttymode + unixex(opt, up, newstdin, mode) +- char *opt, *up; ++ const char *opt; ++ char *up; + int newstdin, mode; + { + int pvec[2]; +@@ -299,6 +301,7 @@ unixex(opt, up, newstdin, mode) + * F is for restoration of tty mode if from open/visual. + * C flags suppression of printing. + */ ++void + unixwt(c, f) + bool c; + ttymode f; +@@ -328,6 +331,7 @@ unixwt(c, f) + * the filter, then a child editor is created to write it. + * If output is catch it from io which is created by unixex. + */ ++void + filter(mode) + register int mode; + { +@@ -391,6 +395,7 @@ filter(mode) + * Set up to do a recover, getting io to be a pipe from + * the recover process. + */ ++void + recover() + { + static int pvec[2]; +@@ -420,6 +425,7 @@ recover() + /* + * Wait for the process (pid an external) to complete. + */ ++void + waitfor() + { + int stat = 0; +@@ -449,6 +455,7 @@ waitfor() + * exits non-zero, force not edited; otherwise force + * a write. + */ ++void + revocer() + { + diff --git a/editors/ex/patches/patch-ex__v_c b/editors/ex/patches/patch-ex__v_c new file mode 100644 index 00000000000..f25572baa51 --- /dev/null +++ b/editors/ex/patches/patch-ex__v_c @@ -0,0 +1,155 @@ +$NetBSD: patch-ex__v_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare local functions static +- declare void functions void +- don't declare local functions in headers +- silence warnings about assignments in conditionals +- avoid implicit int +- silence warnings about unused arguments + +--- ex_v.c~ 2012-12-27 21:58:42.000000000 +0000 ++++ ex_v.c +@@ -127,9 +127,10 @@ static char sccsid[] = "@(#)ex_v.c 1.14 + + JMP_BUF venv; + +-int ovbeg __P((void)); +-int setwind __P((void)); +-int vok __P((cell *)); ++static void ovbeg __P((void)); ++static void ovend __P((ttymode f)); ++static void setwind __P((void)); ++static void vok __P((cell *)); + + /* + * Enter open mode +@@ -137,6 +138,7 @@ int vok __P((cell *)); + #ifdef u370 + cell atube[TUBESIZE+LBSIZE]; + #endif ++void + oop() + { + register char *ic; +@@ -146,7 +148,7 @@ oop() + ttymode f; /* mjm: was register */ + int resize; + +- if (resize = SETJMP(venv)) { ++ if ((resize = SETJMP(venv)) != 0) { + setsize(); + initev = (char *)0; + inopen = 0; +@@ -217,7 +219,8 @@ oop() + #endif + } + +-ovbeg() ++static void ++ovbeg(void) + { + + if (!value(OPEN)) +@@ -233,8 +236,8 @@ ovbeg() + dot = addr2; + } + +-ovend(f) +- ttymode f; ++static void ++ovend(ttymode f) + { + + splitw++; +@@ -255,6 +258,7 @@ ovend(f) + /* + * Enter visual mode + */ ++void + vop() + { + register int c; +@@ -292,7 +296,7 @@ toopen: + goto toopen; + error(catgets(catd, 1, 214, "Visual requires scrolling")); + } +- if (resize = SETJMP(venv)) { ++ if ((resize = SETJMP(venv)) != 0) { + setsize(); + initev = (char *)0; + inopen = 0; +@@ -333,6 +337,7 @@ toopen: + * empty buffer since routines internally + * demand at least one line. + */ ++void + fixzero() + { + +@@ -361,6 +366,7 @@ fixzero() + * at some point, and then quit from the visual and undo + * you get the old file back. Somewhat weird. + */ ++void + savevis() + { + +@@ -376,6 +382,7 @@ savevis() + * Restore a sensible state after a visual/open, moving the saved + * stuff back to [unddol,dol], and killing the partial line kill indicators. + */ ++void + undvis() + { + +@@ -396,6 +403,7 @@ undvis() + * Set the window parameters based on the base state bastate + * and the available buffer space. + */ ++static void + setwind() + { + +@@ -436,6 +444,7 @@ setwind() + * If so, then divide the screen buffer up into lines, + * and initialize a bunch of state variables before we start. + */ ++static void + vok(atube) + register cell *atube; + { +@@ -478,11 +487,13 @@ vok(atube) + + #ifdef CBREAK + woid +-vintr(signum) ++vintr(int signum) + { + extern JMP_BUF readbuf; + extern int doingread; + ++ (void)signum; ++ + signal(SIGINT, vintr); + if (vcatch) + onintr(SIGINT); +@@ -499,6 +510,7 @@ vintr(signum) + * Set the size of the screen to size lines, to take effect the + * next time the screen is redrawn. + */ ++void + vsetsiz(size) + int size; + { +@@ -517,8 +529,10 @@ vsetsiz(size) + + #ifdef SIGWINCH + woid +-onwinch(signum) ++onwinch(int signum) + { ++ (void)signum; ++ + vsave(); + setty(normf); + LONGJMP(venv, 1); diff --git a/editors/ex/patches/patch-ex__vadj_c b/editors/ex/patches/patch-ex__vadj_c new file mode 100644 index 00000000000..577eb6dc166 --- /dev/null +++ b/editors/ex/patches/patch-ex__vadj_c @@ -0,0 +1,259 @@ +$NetBSD: patch-ex__vadj_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare local functions static +- declare void functions void +- avoid implicit int +- silence warnings about braces +- silence warnings about && and || precedence + +--- ex_vadj.c~ 2012-12-27 21:58:42.000000000 +0000 ++++ ex_vadj.c +@@ -90,12 +90,12 @@ static char sccsid[] = "@(#)ex_vadj.c 1. + * screen cleanup after a change. + */ + +-int vdellin __P((int, int, int)); +-int vscroll __P((register int)); +-int vadjAL __P((int, int)); +-int vcloseup __P((int, register int)); +-int vopenup __P((int, int, int)); +-int vadjDL __P((int, int)); ++static void vdellin __P((int, int, int)); ++static void vscroll __P((register int)); ++static void vadjAL __P((int, int)); ++static void vcloseup __P((int, register int)); ++static void vopenup __P((int, int, int)); ++static void vadjDL __P((int, int)); + + /* + * Display a new line at physical line p, returning +@@ -106,6 +106,7 @@ int vadjDL __P((int, int)); + * on the screen in which case the line may actually end up + * somewhere other than line p. + */ ++void + vopen(tp, p) + line *tp; + int p; +@@ -118,11 +119,12 @@ vopen(tp, p) + tfixnl(), fprintf(trace, "vopen(%d, %d)\n", lineno(tp), p); + #endif + if (state != VISUAL) { +- if (vcnt) ++ if (vcnt) { + if (hold & HOLDROL) + vup1(); + else + vclean(); ++ } + + /* + * Forget all that we once knew. +@@ -169,6 +171,7 @@ vopen(tp, p) + /* + * Redisplay logical line l at physical line p with line number lineno. + */ ++int + vreopen(p, lineno, l) + int p, lineno, l; + { +@@ -256,6 +259,7 @@ vreopen(p, lineno, l) + * delete some (blank) lines from the top of the screen so that + * later inserts will not push stuff off the bottom. + */ ++int + vglitchup(l, o) + int l, o; + { +@@ -297,6 +301,7 @@ vglitchup(l, o) + * Insert cnt blank lines before line p, + * logically and (if supported) physically. + */ ++void + vinslin(p, cnt, l) + register int p, cnt; + int l; +@@ -378,9 +383,11 @@ vinslin(p, cnt, l) + * it ourselves (brute force) we will squish out @ lines in the process + * if this will save us work. + */ ++static void + vopenup(cnt, could, l) + int cnt; + bool could; ++ int l; + { + register struct vlinfo *vc = &vlinfo[l + 1]; + register struct vlinfo *ve = &vlinfo[vcnt]; +@@ -423,6 +430,7 @@ vopenup(cnt, could, l) + * Adjust data structure internally to account for insertion of + * blank lines on the screen. + */ ++static void + vadjAL(p, cnt) + int p, cnt; + { +@@ -451,6 +459,7 @@ vadjAL(p, cnt) + * Roll the screen up logically and physically + * so that line dl is the bottom line on the screen. + */ ++void + vrollup(dl) + int dl; + { +@@ -469,6 +478,7 @@ vrollup(dl) + destline = dl - cnt, destcol = dc; + } + ++void + vup1() + { + +@@ -480,6 +490,7 @@ vup1() + * If doclr is true, do a clear eol if the terminal + * has standout (to prevent it from scrolling up) + */ ++void + vmoveitup(cnt, doclr) + register int cnt; + bool doclr; +@@ -513,6 +524,7 @@ vmoveitup(cnt, doclr) + /* + * Scroll the screen up cnt lines logically. + */ ++static void + vscroll(cnt) + register int cnt; + { +@@ -541,6 +553,7 @@ vscroll(cnt) + /* + * Discard logical lines due to physical wandering off the screen. + */ ++void + vscrap() + { + register int i, j; +@@ -591,6 +604,7 @@ vscrap() + * Repaint the screen, with cursor at curs, aftern an arbitrary change. + * Handle notification on large changes. + */ ++void + vrepaint(curs) + char *curs; + { +@@ -605,15 +619,16 @@ vrepaint(curs) + /* + * Deal with a totally useless display. + */ +- if (vcnt == 0 || vcline < 0 || vcline > vcnt || holdupd && state != VISUAL) { ++ if (vcnt == 0 || vcline < 0 || vcline > vcnt || (holdupd && state != VISUAL)) { + register line *odol = dol; + + vcnt = 0; +- if (holdupd) ++ if (holdupd) { + if (state == VISUAL) + ignore(peekkey()); + else + vup1(); ++ } + holdupd = 0; + if (odol == zero) + fixzero(); +@@ -682,6 +697,7 @@ vrepaint(curs) + * line after last won't completely fit. The routine vsync is + * more conservative and much less work on dumb terminals. + */ ++void + vredraw(p) + register int p; + { +@@ -803,6 +819,7 @@ vredraw(p) + * Do the real work in deleting cnt lines starting at line p from + * the display. First affected line is line l. + */ ++static void + vdellin(p, cnt, l) + int p, cnt, l; + { +@@ -849,6 +866,7 @@ vdellin(p, cnt, l) + /* + * Adjust internal physical screen image to account for deleted lines. + */ ++static void + vadjDL(p, cnt) + int p, cnt; + { +@@ -878,12 +896,14 @@ vadjDL(p, cnt) + * In any case, if the redraw option is set then all syncs map to redraws + * as if vsync didn't exist. + */ ++void + vsyncCL() + { + + vsync(LINE(vcline)); + } + ++void + vsync(p) + register int p; + { +@@ -898,6 +918,7 @@ vsync(p) + * The guts of a sync. Similar to redraw but + * just less ambitous. + */ ++void + vsync1(p) + register int p; + { +@@ -933,7 +954,7 @@ vsync1(p) + * the current line, or if this line is piled under the + * next line (vreplace does this and we undo it). + */ +- if (l == 0 && state != VISUAL || ++ if ((l == 0 && state != VISUAL) || + (l < vcnt && (vp->vliny <= p || vp[0].vliny == vp[1].vliny))) { + if (l == 0 || vp->vliny < p || (vp->vflags & VDIRT)) { + if (l == vcline) +@@ -972,6 +993,7 @@ vsync1(p) + * Subtract (logically) cnt physical lines from the + * displayed position of lines starting with line l. + */ ++static void + vcloseup(l, cnt) + int l; + register int cnt; +@@ -996,6 +1018,7 @@ vcloseup(l, cnt) + * + * Many boundary conditions here. + */ ++void + vreplace(l, cnt, newcnt) + int l, cnt, newcnt; + { +@@ -1054,7 +1077,7 @@ vreplace(l, cnt, newcnt) + * over them, since otherwise we will push them + * slowly off the screen, a clear lose. + */ +- if (cnt == newcnt || vcnt - l == newcnt && AL && DL) { ++ if (cnt == newcnt || (vcnt - l == newcnt && AL && DL)) { + if (cnt > 1 && l + cnt > vcnt) + savenote++; + vdirty(l, newcnt); +@@ -1135,6 +1158,7 @@ skip: + * If we are in a scroll ^D within hardcopy open then all this + * is suppressed. + */ ++void + sethard() + { + +@@ -1155,6 +1179,7 @@ sethard() + * as dirty so that they will be checked for correct + * display at next sync/redraw. + */ ++void + vdirty(base, i) + register int base, i; + { diff --git a/editors/ex/patches/patch-ex__version_c b/editors/ex/patches/patch-ex__version_c new file mode 100644 index 00000000000..8f6c4956db1 --- /dev/null +++ b/editors/ex/patches/patch-ex__version_c @@ -0,0 +1,21 @@ +$NetBSD: patch-ex__version_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare void functions void +- use const for string constants + +--- ex_version.c~ 2004-01-03 14:11:39.000000000 +0000 ++++ ex_version.c +@@ -74,10 +74,11 @@ + */ + + #include "ex.h" ++#include "ex_proto.h" + +-static char *versionstring = "@(#)Version 3.7, 6/7/85 (gritter) 1/3/04"; ++static const char *versionstring = "@(#)Version 3.7, 6/7/85 (gritter) 1/3/04"; + +-int ++void + printver() + { + printf("%s%s%s", versionstring + 4, diff --git a/editors/ex/patches/patch-ex__vget_c b/editors/ex/patches/patch-ex__vget_c new file mode 100644 index 00000000000..5e55b18ec04 --- /dev/null +++ b/editors/ex/patches/patch-ex__vget_c @@ -0,0 +1,258 @@ +$NetBSD: patch-ex__vget_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare local functions static +- declare void functions void +- avoid implicit int +- use const for string constants +- silence warnings about assignments in conditionals +- silence warnings about && and || precedence +- silence warnings about unused arguments + +--- ex_vget.c~ 2012-12-27 21:58:42.000000000 +0000 ++++ ex_vget.c +@@ -89,12 +89,13 @@ static char sccsid[] = "@(#)ex_vget.c 1. + * large changes which appears in the echo area. + */ + +-int addto __P((cell *, char *)); +-int fastpeekkey __P((void)); ++static void addto __P((cell *, char *)); ++static int fastpeekkey __P((void)); + + /* + * Return the key. + */ ++void + ungetkey(c) + int c; /* mjm: char --> int */ + { +@@ -106,6 +107,7 @@ ungetkey(c) + /* + * Return a keystroke, but never a ^@. + */ ++int + getkey() + { + register int c; /* mjm: char --> int */ +@@ -121,6 +123,7 @@ getkey() + /* + * Tell whether next keystroke would be a ^@. + */ ++int + peekbr() + { + +@@ -139,13 +142,14 @@ int doingread = 0; + * from repeating commands with .), and finally new + * keystrokes. + */ ++int + getbr() + { + char ch; + register int c; + #ifdef UCVISUAL + register int d; +- register char *colp; ++ register const char *colp; + #endif + #ifdef BEEHIVE + int cnt; +@@ -248,7 +252,7 @@ again: + d = toupper(c); + else { + colp = "({)}!|^~'~"; +- while (d = *colp++) ++ while ((d = *colp++) != 0) + if (d == c) { + d = *colp++; + break; +@@ -292,6 +296,7 @@ again: + * Get a key, but if a delete, quit or attention + * is typed return 0 so we will abort a partial command. + */ ++int + getesc() + { + register int c; +@@ -320,6 +325,7 @@ case_ATTN: + /* + * Peek at the next keystroke. + */ ++int + peekkey() + { + +@@ -331,7 +337,8 @@ peekkey() + * Read a line from the echo area, with single character prompt c. + * A return value of 1 means the user blewit or blewit away. + */ +-readecho(c) ++int ++readecho(int c) + { + register char *sc = cursor; + register int (*OP)(); +@@ -383,6 +390,7 @@ blewit: + * the purposes of repeat, so copy it from + * the working to the previous command buffer. + */ ++void + setLAST() + { + +@@ -400,6 +408,7 @@ setLAST() + * If the insertion buffer oveflows, then destroy + * the repeatability of the insert. + */ ++void + addtext(cp) + char *cp; + { +@@ -415,6 +424,7 @@ addtext(cp) + lastcmd[0] = 0; + } + ++void + setDEL() + { + +@@ -424,6 +434,7 @@ setDEL() + /* + * Put text from cursor upto wcursor in BUF. + */ ++void + setBUF(BUF) + register cell *BUF; + { +@@ -437,6 +448,7 @@ setBUF(BUF) + *wp = c; + } + ++static void + addto(buf, str) + register cell *buf; + register char *str; +@@ -467,12 +479,13 @@ addto(buf, str) + * to do this for open modes now; return and save for later + * notification in visual. + */ ++int + noteit(must) + bool must; + { + register int sdl = destline, sdc = destcol; + +- if (notecnt < 2 || !must && state == VISUAL) ++ if (notecnt < 2 || (!must && state == VISUAL)) + return (0); + splitw++; + if (WBOT == WECHO) +@@ -483,7 +496,7 @@ noteit(must) + putchar('s'); + if (*notenam) { + printf(" %s", notenam); +- if (*(strend(notenam) - 1) != 'e') ++ if (*(strendk(notenam) - 1) != 'e') + putchar('e'); + putchar('d'); + } +@@ -502,7 +515,8 @@ noteit(must) + * Rrrrringgggggg. + * If possible, use flash (VB). + */ +-beep() ++void ++beep(void) + { + + if (VB && value(FLASH)) +@@ -517,13 +531,14 @@ beep() + * motions. I.e. on an adm3a we might map ^K to ^P. + * DM1520 for example has a lot of mappable characters. + */ +- ++int + map(c,maps) + register int c; + register struct maps *maps; + { + register int d; +- register char *p, *q; ++ register const char *p; ++ register char *q; + char b[10]; /* Assumption: no keypad sends string longer than 10 */ + + /* +@@ -559,7 +574,7 @@ map(c,maps) + if (trace) + fprintf(trace,"\ntry '%s', ",maps[d].cap); + #endif +- if (p = maps[d].cap) { ++ if ((p = maps[d].cap) != NULL) { + for (q=b; *p; p++, q++) { + #ifdef MDEBUG + if (trace) +@@ -633,8 +648,9 @@ map(c,maps) + * is false for, for example, pushing back lookahead from fastpeekkey(), + * since otherwise two fast escapes can clobber our undo. + */ ++void + macpush(st, canundo) +-char *st; ++const char *st; + int canundo; + { + char tmpbuf[BUFSIZ]; +@@ -671,8 +687,8 @@ int canundo; + } + + #ifdef TRACE +-visdump(s) +-char *s; ++static void ++visdump(const char *s) + { + register int i; + +@@ -688,8 +704,8 @@ char *s; + tvliny(); + } + +-vudump(s) +-char *s; ++void ++vudump(const char *s) + { + register line *p; + char savelb[1024]; +@@ -717,6 +733,7 @@ char *s; + * Get a count from the keyed input stream. + * A zero count is indistinguishable from no count. + */ ++int + vgetcnt() + { + register int c, cnt; +@@ -734,8 +751,11 @@ vgetcnt() + return(cnt); + } + +-woid +-trapalarm(signum) { ++static woid ++trapalarm(int signum) ++{ ++ (void)signum; ++ + alarm(0); + if (vcatch) + LONGJMP(vreslab,1); +@@ -747,6 +767,7 @@ trapalarm(signum) { + * a machine generated sequence (such as a function pad from an escape + * flavor terminal) but fail for a human hitting escape then waiting. + */ ++static int + fastpeekkey() + { + shand Oint; diff --git a/editors/ex/patches/patch-ex__vis_h b/editors/ex/patches/patch-ex__vis_h new file mode 100644 index 00000000000..6f6abca2521 --- /dev/null +++ b/editors/ex/patches/patch-ex__vis_h @@ -0,0 +1,36 @@ +$NetBSD: patch-ex__vis_h,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- use const for string constants +- declare void functions void +- remove stray extra copies of function declarations from elsewhere + +--- ex_vis.h~ 2012-12-27 21:58:42.000000000 +0000 ++++ ex_vis.h +@@ -300,8 +300,8 @@ var bool lasthad; /* Last command had a + var short lastvgk; /* Previous input key, if not from keyboard */ + var short lastreg; /* Register with last command */ + var char *ncols['z'-'a'+2]; /* Cursor positions of marks */ +-var char *notenam; /* Name to be noted with change count */ +-var char *notesgn; /* Change count from last command */ ++var const char *notenam; /* Name to be noted with change count */ ++var const char *notesgn; /* Change count from last command */ + var char op; /* Operation of current command */ + var short Peekkey; /* Peek ahead key */ + var bool rubble; /* Line is filthy (in hardcopy open), redraw! */ +@@ -333,13 +333,7 @@ var cell workcmd[5]; /* Temporary for la + /* + * Function types + */ +-int beep(); +-int qcount(); +-int vchange(); +-int vdelete(); ++void beep(void); + int vgrabit(); +-int vinschar(); +-int vmove(); +-int vputchar(); +-int vshift(); +-int vyankit(); ++ ++ diff --git a/editors/ex/patches/patch-ex__vmain_c b/editors/ex/patches/patch-ex__vmain_c new file mode 100644 index 00000000000..52012ba41ac --- /dev/null +++ b/editors/ex/patches/patch-ex__vmain_c @@ -0,0 +1,209 @@ +$NetBSD: patch-ex__vmain_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare local functions static +- declare void functions void +- use volatile for compiler warnings about setjmp/vfork clobbering +- fix up function pointer casting mess +- silence warnings about assignments in conditionals +- use <ctype.h> functions correctly +- silence warnings about && and || precedence + +--- ex_vmain.c~ 2012-12-27 21:58:42.000000000 +0000 ++++ ex_vmain.c +@@ -83,8 +83,8 @@ static char sccsid[] = "@(#)ex_vmain.c 1 + #include "ex_tty.h" + #include "ex_vis.h" + +-int vzop __P((int, int, register int)); +-int grabtag __P((void)); ++static void vzop __P((int, int, register int)); ++static void grabtag __P((void)); + + /* + * This is the main routine for visual. +@@ -96,17 +96,26 @@ int grabtag __P((void)); + + #define forbid(a) { if (a) goto fonfon; } + ++static void ++doput(int ignore) ++{ ++ (void)ignore; ++ put(); ++} ++ ++void + vmain() + { + int c, cnt, i; + cell esave[TUBECOLS]; +- char *oglobp; +- short d; +- line *addr; ++ const char *volatile oglobp; ++ volatile short d; ++ line *volatile addr; + int ind, nlput; +- int shouldpo = 0; +- int onumber = 0, olist = 0, +- (*OPline)() = NULL, (*OPutchar)() = NULL; ++ volatile int shouldpo = 0; ++ volatile int onumber = 0, olist = 0; ++ int (*volatile OPline)(int) = NULL; ++ int (*volatile OPutchar)(int) = NULL; + + CLOBBGRD(c); + CLOBBGRD(cnt); +@@ -160,7 +169,7 @@ vmain() + Xhadcnt = hadcnt = 0; + Xcnt = cnt = 1; + splitw = 0; +- if (i = holdupd) { ++ if ((i = holdupd) != 0) { + if (state == VISUAL) + ignore(peekkey()); + holdupd = 0; +@@ -205,7 +214,7 @@ looptop: + * an 'empty' named buffer spec in the routine + * kshift (see ex_temp.c). + */ +- forbid (c == '0' || !isalpha(c) && !isdigit(c)); ++ forbid (c == '0' || (!isalpha((unsigned char)c) && !isdigit((unsigned char)c))); + vreg = c; + } + reread: +@@ -635,8 +644,8 @@ reread: + if (isalpha(cuc(mbuf[1]))) + { + char x = cuc(mbuf[1]); +- mbuf[1] = isupper(x) ? +- tolower(x) : toupper(x); ++ mbuf[1] = isupper((unsigned char)x) ? ++ tolower((unsigned char)x) : toupper((unsigned char)x); + } + macpush(mbuf, 1); + } +@@ -865,7 +874,7 @@ case_ATTN: + vmacchng(1); + setLAST(); + i = 0; +- if (vreg && partreg(vreg) || !vreg && pkill[0]) { ++ if ((vreg && partreg(vreg)) || (!vreg && pkill[0])) { + /* + * Restoring multiple lines which were partial + * lines; will leave cursor in middle +@@ -898,8 +907,7 @@ case_ATTN: + */ + addr = dol; /* old dol */ + CATCH +- vremote(1, vreg ? (int(*)())putreg +- : (int(*)())put, vreg); ++ vremote(1, vreg ? putreg : doput, vreg); + ONERR + if (vreg == -1) { + splitw = 0; +@@ -1160,7 +1168,7 @@ fixup: + * in open mode and . moved, then redraw. + */ + i = vcline + (dot - addr); +- if (i < 0 || i >= vcnt && i >= -vcnt || state != VISUAL && dot != addr) { ++ if (i < 0 || (i >= vcnt && i >= -vcnt) || (state != VISUAL && dot != addr)) { + if (state == CRTOPEN) + vup1(); + if (vcnt > 0) +@@ -1247,6 +1255,7 @@ fonfon: + /* + * Grab the word after the cursor so we can look for it as a tag. + */ ++static void + grabtag() + { + register char *cp, *dp; +@@ -1271,6 +1280,7 @@ grabtag() + * Before appending lines, set up addr1 and + * the command mode undo information. + */ ++void + prepapp() + { + +@@ -1284,8 +1294,8 @@ prepapp() + * Execute function f with the address bounds addr1 + * and addr2 surrounding cnt lines starting at dot. + */ +-vremote(cnt, f, arg) +- int cnt, (*f)(), arg; ++void ++vremote(int cnt, void (*f)(int), int arg) + { + register int oing = inglobal; + +@@ -1301,15 +1311,23 @@ vremote(cnt, f, arg) + vmcurs = 0; + } + ++static void ++doyank(int ignore) ++{ ++ (void)ignore; ++ yank(); ++} ++ + /* + * Save the current contents of linebuf, if it has changed. + */ ++void + vsave() + { + char temp[LBSIZE]; + + CP(temp, linebuf); +- if (FIXUNDO && vundkind == VCHNG || vundkind == VCAPU) { ++ if ((FIXUNDO && vundkind == VCHNG) || vundkind == VCAPU) { + /* + * If the undo state is saved in the temporary buffer + * vutmp, then we sync this into the temp file so that +@@ -1321,7 +1339,7 @@ vsave() + prepapp(); + CP(linebuf, vutmp); + putmark(dot); +- vremote(1, yank, 0); ++ vremote(1, doyank, 0); + vundkind = VMCHNG; + notecnt = 0; + undkind = UNDCHANGE; +@@ -1345,6 +1363,7 @@ vsave() + * Do a z operation. + * Code here is rather long, and very uninteresting. + */ ++static void + vzop(hadcnt, cnt, c) + bool hadcnt; + int cnt; +@@ -1434,7 +1453,7 @@ register char *src; + { + register cell *cp = dst; + +- while (*cp++ = *src++ & 0377); ++ while ((*cp++ = *src++ & 0377) != 0); + return dst; + } + +@@ -1445,7 +1464,7 @@ register cell *src; + { + register char *cp = dst; + +- while (*cp++ = *src++); ++ while ((*cp++ = *src++) != 0); + return dst; + } + +@@ -1456,7 +1475,7 @@ register cell *src; + { + register cell *cp = dst; + +- while (*cp++ = *src++); ++ while ((*cp++ = *src++) != 0); + return dst; + } + diff --git a/editors/ex/patches/patch-ex__voper_c b/editors/ex/patches/patch-ex__voper_c new file mode 100644 index 00000000000..0a6be127f5b --- /dev/null +++ b/editors/ex/patches/patch-ex__voper_c @@ -0,0 +1,351 @@ +$NetBSD: patch-ex__voper_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare local functions static +- fix up function pointer casting mess +- declare void functions void +- use const for string constants +- silence warnings about && and || precedence +- use <ctype.h> functions correctly +- avoid implicit int + +--- ex_voper.c~ 2012-12-27 21:58:41.000000000 +0000 ++++ ex_voper.c +@@ -89,7 +89,35 @@ static char sccsid[] = "@(#)ex_voper.c 1 + + cell vscandir[2] = { '/', 0 }; + +-int edge __P((void)); ++static int edge __P((void)); ++ ++static void ++dovfilter(int ignore) ++{ ++ (void)ignore; ++ vfilter(); ++} ++ ++static void ++dovshftop(int ignore) ++{ ++ (void)ignore; ++ vshftop(); ++} ++ ++static void ++dovyankit(int ignore) ++{ ++ (void)ignore; ++ vyankit(); ++} ++ ++static void ++dobeep(int ignore) ++{ ++ (void)ignore; ++ beep(); ++} + + /* + * Decode an operator/operand type command. +@@ -101,14 +129,17 @@ int edge __P((void)); + * and if wcursor is zero, then the first non-blank location of the + * other line is implied. + */ ++void + operate(c, cnt) + register int c, cnt; + { + register int i = 0; +- int (*moveop)(), (*deleteop)(); +- int (*opf)(); ++ void (*volatile moveop)(int); ++ void (*deleteop)(int); ++ void (*opf)(int); + bool subop = 0; +- char *oglobp, *ocurs; ++ const char *oglobp; ++ char *ocurs; + register line *addr; + line *odot; + static char lastFKND, lastFCHR; +@@ -120,7 +151,8 @@ operate(c, cnt) + qmarkcell[0] = '?'; + slashcell[0] = '/'; + nullcell[0] = qmarkcell[1] = slashcell[1] = 0; +- moveop = vmove, deleteop = vdelete; ++ moveop = vmove_i; ++ deleteop = vdelete; + wcursor = cursor; + wdot = NOLINE; + notecnt = 0; +@@ -132,7 +164,7 @@ operate(c, cnt) + */ + case 'd': + moveop = vdelete; +- deleteop = beep; ++ deleteop = dobeep; + break; + + /* +@@ -147,18 +179,18 @@ operate(c, cnt) + * c Change operator. + */ + case 'c': +- if (c == 'c' && workcmd[0] == 'C' || workcmd[0] == 'S') ++ if ((c == 'c' && workcmd[0] == 'C') || workcmd[0] == 'S') + subop++; + moveop = vchange; +- deleteop = beep; ++ deleteop = dobeep; + break; + + /* + * ! Filter through a UNIX command. + */ + case '!': +- moveop = vfilter; +- deleteop = beep; ++ moveop = dovfilter; ++ deleteop = dobeep; + break; + + /* +@@ -166,8 +198,8 @@ operate(c, cnt) + * can be put back with p/P. Also yanks to named buffers. + */ + case 'y': +- moveop = vyankit; +- deleteop = beep; ++ moveop = dovyankit; ++ deleteop = dobeep; + break; + + /* +@@ -185,8 +217,8 @@ operate(c, cnt) + */ + case '<': + case '>': +- moveop = vshftop; +- deleteop = beep; ++ moveop = dovshftop; ++ deleteop = dobeep; + break; + + /* +@@ -309,7 +341,7 @@ ein: + #endif + getDOT(); + forbid(!i); +- if (opf != vmove) ++ if (opf != vmove_i) + if (dir > 0) + wcursor++; + else +@@ -353,8 +385,8 @@ ein: + */ + case ',': + forbid (lastFKND == 0); +- c = isupper(cuc(lastFKND)) +- ? tolower(lastFKND) : toupper(lastFKND); ++ c = isupper(cuc((unsigned char)lastFKND)) ++ ? tolower((unsigned char)lastFKND) : toupper((unsigned char)lastFKND); + i = lastFCHR; + if (vglobp == 0) + vglobp = nullcell; +@@ -415,7 +447,7 @@ ein: + wcursor--; + case 'f': + fixup: +- if (moveop != vmove) ++ if (moveop != vmove_i) + wcursor++; + break; + } +@@ -444,13 +476,13 @@ fixup: + * $ To end of line. + */ + case '$': +- if (opf == vmove) { ++ if (opf == vmove_i) { + vmoving = 1; + vmovcol = 20000; + } else + vmoving = 0; + if (cnt > 1) { +- if (opf == vmove) { ++ if (opf == vmove_i) { + wcursor = 0; + cnt--; + } else +@@ -480,10 +512,10 @@ fixup: + */ + case 'l': + case ' ': +- forbid (margin() || opf == vmove && edge()); ++ forbid (margin() || (opf == vmove_i && edge())); + while (cnt > 0 && !margin()) + wcursor += dir, cnt--; +- if (margin() && opf == vmove || wcursor < linebuf) ++ if ((margin() && opf == vmove_i) || wcursor < linebuf) + wcursor -= dir; + vmoving = 0; + break; +@@ -520,7 +552,7 @@ deleteit: + * Stuttered operators are equivalent to the operator on + * a line, thus turn dd into d_. + */ +- if (opf == vmove || c != workcmd[0]) { ++ if (opf == vmove_i || c != workcmd[0]) { + errlab: + beep(); + vmacp = 0; +@@ -545,7 +577,7 @@ errlab: + */ + case 'H': + wdot = (dot - vcline) + cnt - 1; +- if (opf == vmove) ++ if (opf == vmove_i) + markit(wdot); + vmoving = 0; + wcursor = 0; +@@ -578,7 +610,7 @@ errlab: + */ + case 'L': + wdot = dot + vcnt - vcline - cnt; +- if (opf == vmove) ++ if (opf == vmove_i) + markit(wdot); + vmoving = 0; + wcursor = 0; +@@ -589,7 +621,7 @@ errlab: + */ + case 'M': + wdot = dot + ((vcnt + 1) / 2) - vcline - 1; +- if (opf == vmove) ++ if (opf == vmove_i) + markit(wdot); + vmoving = 0; + wcursor = 0; +@@ -656,7 +688,7 @@ errlab: + forbid (Xhadcnt); + vmoving = 0; + wcursor = d == '`' ? ncols[c - 'a'] : 0; +- if (opf == vmove && (wdot != dot || (d == '`' && wcursor != cursor))) ++ if (opf == vmove_i && (wdot != dot || (d == '`' && wcursor != cursor))) + markDOT(); + if (wcursor) { + vsave(); +@@ -678,7 +710,7 @@ errlab: + cnt = lineDOL(); + wdot = zero + cnt; + forbid (wdot < one || wdot > dol); +- if (opf == vmove) ++ if (opf == vmove_i) + markit(wdot); + vmoving = 0; + wcursor = 0; +@@ -765,7 +797,7 @@ slerr: + wcursor = loc1; + if (i != 0) + vsetsiz(i); +- if (opf == vmove) { ++ if (opf == vmove_i) { + if (state == ONEOPEN || state == HARDOPEN) + outline = destline = WBOT; + if (addr != dot || loc1 != cursor) +@@ -804,7 +836,8 @@ slerr: + /* + * Find single character c, in direction dir from cursor. + */ +-find(c) ++int ++find(int c) + { + + for(;;) { +@@ -820,8 +853,9 @@ find(c) + * Do a word motion with operator op, and cnt more words + * to go after this. + */ ++int + word(op, cnt) +- register int (*op)(); ++ register void (*op)(int); + int cnt; + { + register int which = 0; +@@ -832,7 +866,7 @@ word(op, cnt) + iwc = wcursor; + which = wordch(wcursor); + while (wordof(which, wcursor)) { +- if (cnt == 1 && op != vmove && wcursor[1] == 0) { ++ if (cnt == 1 && op != vmove_i && wcursor[1] == 0) { + wcursor++; + break; + } +@@ -848,7 +882,7 @@ word(op, cnt) + else + if (wcursor == iwc && iwdot == wdot && *iwc) + wcursor++; +- if (op == vmove && margin()) ++ if (op == vmove_i && margin()) + wcursor--; + } else { + if (!lnext()) +@@ -871,8 +905,9 @@ word(op, cnt) + * To end of word, with operator op and cnt more motions + * remaining after this. + */ ++void + eend(op) +- register int (*op)(); ++ register void (*op)(int); + { + register int which; + +@@ -898,8 +933,8 @@ eend(op) + * Wordof tells whether the character at *wc is in a word of + * kind which (blank/nonblank words are 0, conservative words 1). + */ +-wordof(which, wc) +- register char *wc; ++int ++wordof(int which, register char *wc) + { + + if (isspace(cuc(*wc))) +@@ -911,12 +946,13 @@ wordof(which, wc) + * Wordch tells whether character at *wc is a word character + * i.e. an alfa, digit, or underscore. + */ ++int + wordch(wc) + char *wc; + { + register int c; + +- c = wc[0]; ++ c = (unsigned char)wc[0]; + return (isalpha(c) || isdigit(c) || c == '_' + #ifdef BIT8 + #ifdef ISO8859_1 +@@ -935,7 +971,8 @@ wordch(wc) + /* + * Edge tells when we hit the last character in the current line. + */ +-edge() ++static int ++edge(void) + { + + if (linebuf[0] == 0) +@@ -949,7 +986,8 @@ edge() + /* + * Margin tells us when we have fallen off the end of the line. + */ +-margin() ++int ++margin(void) + { + + return (wcursor < linebuf || wcursor[0] == 0); diff --git a/editors/ex/patches/patch-ex__vops2_c b/editors/ex/patches/patch-ex__vops2_c new file mode 100644 index 00000000000..c075dfe97d5 --- /dev/null +++ b/editors/ex/patches/patch-ex__vops2_c @@ -0,0 +1,211 @@ +$NetBSD: patch-ex__vops2_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare local functions static +- declare void functions void +- avoid implicit int +- use const for string constants +- fix up function pointer casting mess +- avoid sloppy code that subtracts 1 from the base address of a char[] + (which isn't valid) +- silence warnings about && and || precedence +- silence warnings about braces + + +--- ex_vops2.c~ 2012-12-27 21:58:42.000000000 +0000 ++++ ex_vops2.c +@@ -91,12 +91,14 @@ static char sccsid[] = "@(#)ex_vops2.c 1 + extern char *vUA1, *vUA2; /* mjm: extern; also in ex_vops.c */ + extern char *vUD1, *vUD2; /* mjm: extern; also in ex_vops.c */ + +-int vmaxrep __P((int, register int)); ++static int vmaxrep __P((int, register int)); ++static int vgetsplit(void); + + /* + * Obleeperate characters in hardcopy + * open with \'s. + */ ++void + bleep(i, cp) + register int i; + char *cp; +@@ -117,6 +119,7 @@ bleep(i, cp) + * Common code for middle part of delete + * and change operating on parts of lines. + */ ++int + vdcMID() + { + register char *cp; +@@ -136,6 +139,7 @@ vdcMID() + * in the VBSIZE buffer BUF. Used to save + * deleted text of part of line. + */ ++void + takeout(BUF) + cell *BUF; + { +@@ -165,6 +169,7 @@ takeout(BUF) + * Are we at the end of the printed representation of the + * line? Used internally in hardcopy open. + */ ++int + ateopr() + { + register int i, c; +@@ -185,10 +190,12 @@ ateopr() + return (1); + } + +-showmode(mode) ++void ++showmode(int mode) + { + int sdc = destcol, sdl = destline; +- char *ocurs, *str; ++ char *ocurs; ++ const char *str; + + if (value(SHOWMODE) == 0 || TCOLUMNS <= 20 || state == ONEOPEN + || state == HARDOPEN || vmacp != NULL) +@@ -246,8 +253,8 @@ char *ogcursor; + * The addtext() and addto() routines combined, accepting a single + * cell character. + */ +-addc(c) +-cell c; ++static void ++addc(cell c) + { + register cell *cp = INS; + +@@ -274,6 +281,14 @@ cell c; + } + } + ++static void ++doyank(int ignore) ++{ ++ (void)ignore; ++ yank(); ++} ++ ++void + vappend(ch, cnt, indent) + int ch; /* mjm: char --> int */ + int cnt, indent; +@@ -330,7 +345,7 @@ vappend(ch, cnt, indent) + if (value(AUTOINDENT) && indent != 0) { + gcursor = genindent(indent); + *gcursor = 0; +- vgotoCL(qcolumn(cursor - 1, genbuf)); ++ vgotoCL(qcolumn2(cursor, genbuf)); + } else { + gcursor = genbuf; + *gcursor = 0; +@@ -536,7 +551,7 @@ vappend(ch, cnt, indent) + * correctly later. + */ + if (FIXUNDO && vundkind == VCHNG) { +- vremote(1, yank, 0); ++ vremote(1, doyank, 0); + undap1--; + } + +@@ -561,7 +576,7 @@ vappend(ch, cnt, indent) + strcLIN(gcursor); + *gcursor = 0; + cursor = linebuf; +- vgotoCL(qcolumn(cursor - 1, genbuf)); ++ vgotoCL(qcolumn2(cursor, genbuf)); + showmode(ch); + } + +@@ -594,6 +609,7 @@ vappend(ch, cnt, indent) + * backwards around end of lines (vgoto can't hack columns which are + * less than 0 in general). + */ ++void + back1() + { + +@@ -620,6 +636,7 @@ vget_line(cnt, gcursor, aescaped, commch + int cnt; + register char *gcursor; + bool *aescaped; ++ int commch; + { + register int c, ch; + register char *cp; +@@ -771,7 +788,7 @@ vbackup: + endim(); + *cp = 0; + c = cindent(); +- vgotoCL(qcolumn(cursor - 1, genbuf)); ++ vgotoCL(qcolumn2(cursor, genbuf)); + if (doomed >= 0) + doomed += c - cindent(); + gcursor = cp; +@@ -836,7 +853,7 @@ vbackup: + } + if (value(WRAPMARGIN) && + (outcol >= OCOLUMNS - value(WRAPMARGIN) || +- backsl && outcol==0) && ++ (backsl && outcol==0)) && + commch != 'r') { + /* + * At end of word and hit wrapmargin. +@@ -991,7 +1008,7 @@ btrp: + * generated autoindent. We count the ^D for repeat + * purposes. + */ +- if (c == iwhite && c != 0) ++ if (c == iwhite && c != 0) { + if (cp == gcursor) { + iwhite = backtab(c); + CDCNT++; +@@ -1015,6 +1032,7 @@ btrp: + vputchar(' '); + goto vbackup; + } ++ } + if (vglobp && vglobp - iglobp >= 2 && + (vglobp[-2] == '^' || vglobp[-2] == '0') + && gcursor == ogcursor + 1) +@@ -1057,15 +1075,15 @@ vadone: + return (gcursor); + } + +-int vgetsplit(); +-char *vsplitpt; ++static const char *vsplitpt; + + /* + * Append the line in buffer at lp + * to the buffer after dot. + */ ++void + vdoappend(lp) +- char *lp; ++ const char *lp; + { + register int oing = inglobal; + +@@ -1078,6 +1096,7 @@ vdoappend(lp) + /* + * Subroutine for vdoappend to pass to append. + */ ++static int + vgetsplit() + { + +@@ -1093,7 +1112,9 @@ vgetsplit() + * allowed that will yield total line length less than + * LBSIZE characters and also does hacks for the R command. + */ ++static int + vmaxrep(ch, cnt) ++ int ch; + register int cnt; + { + register int len, replen; diff --git a/editors/ex/patches/patch-ex__vops3_c b/editors/ex/patches/patch-ex__vops3_c new file mode 100644 index 00000000000..f795885e9ef --- /dev/null +++ b/editors/ex/patches/patch-ex__vops3_c @@ -0,0 +1,323 @@ +$NetBSD: patch-ex__vops3_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare local functions (and data) static +- fix up function pointer casting mess +- avoid implicit int +- silence warnings about && and || precedence +- silence warnings about unused arguments +- use const for string constants +- declare void functions void + + +--- ex_vops3.c~ 2012-12-27 21:58:41.000000000 +0000 ++++ ex_vops3.c +@@ -99,23 +99,26 @@ static char sccsid[] = "@(#)ex_vops3.c 1 + * + * The code here is very hard to understand. + */ +-line *llimit; +-int (*lf)(); ++static line *llimit; ++static bool wasend; + +-int lskipa1 __P((register char *)); +-int endsent __P((int)); +-int endPS __P((void)); +-int lskipbal __P((register char *)); +-int ltosolid __P((void)); +-int lskipatom __P((void)); +-int isa __P((register char *)); +-int ltosol1 __P((register char *)); +- +-#ifdef LISPCODE +-int lindent(); +-#endif ++/* ++ * lf is never called, but is compared against other function pointers. ++ * lindent() is the wrong type, so instead of setting lf = lindent, set ++ * it to 0 and set lf_is_lindent to nonzero. Other assignments to lf ++ * whould be accompanied by lf_is_lindent = 0. ++ */ ++static void (*lf)(int); ++static int lf_is_lindent; + +-bool wasend; ++static int lskipa1 __P((register const char *)); ++static int endsent __P((int)); ++static int endPS __P((void)); ++static int lskipbal __P((register const char *)); ++static int ltosolid __P((void)); ++static int lskipatom __P((void)); ++static int isa __P((register const char *)); ++static int ltosol1 __P((register const char *)); + + /* + * Find over structure, repeated count times. +@@ -124,9 +127,11 @@ bool wasend; + * rather than (), implying past atoms in a list (or a paragraph + * rather than a sentence. + */ ++int + llfind(pastatom, cnt, f, limit) + bool pastatom; +- int cnt, (*f)(); ++ int cnt; ++ void (*f)(int); + line *limit; + { + #ifdef LISPCODE +@@ -142,6 +147,7 @@ llfind(pastatom, cnt, f, limit) + */ + wasend = 0; + lf = f; ++ lf_is_lindent = 0; + strcpy(save, linebuf); + if (limit == 0) + limit = dir < 0 ? one : dol; +@@ -210,7 +216,7 @@ begin: + while (!endsent(pastatom)) + if (!lnext()) + goto ret; +- if (!pastatom || wcursor == linebuf && endPS()) ++ if (!pastatom || (wcursor == linebuf && endPS())) + if (--cnt <= 0) + break; + if (linebuf[0] == 0) { +@@ -246,7 +252,7 @@ begin: + * If we are not at a section/paragraph division, + * advance to next. + */ +- if (wcursor == icurs && wdot == idot || wcursor != linebuf || !endPS()) ++ if ((wcursor == icurs && wdot == idot) || wcursor != linebuf || !endPS()) + ignore(lskipa1("")); + } + #ifdef LISPCODE +@@ -256,7 +262,7 @@ begin: + * Startup by skipping if at a ( going left or a ) going + * right to keep from getting stuck immediately. + */ +- if (dir < 0 && c == '(' || dir > 0 && c == ')') { ++ if ((dir < 0 && c == '(') || (dir > 0 && c == ')')) { + if (!lnext()) { + rc = -1; + goto ret; +@@ -272,7 +278,7 @@ begin: + */ + while (cnt > 0) { + c = *wcursor; +- if (dir < 0 && c == ')' || dir > 0 && c == '(') { ++ if ((dir < 0 && c == ')') || (dir > 0 && c == '(')) { + if (!lskipbal("()")) + goto ret; + /* +@@ -285,7 +291,7 @@ begin: + if (!lnext() || !ltosolid()) + goto ret; + --cnt; +- } else if (dir < 0 && c == '(' || dir > 0 && c == ')') ++ } else if ((dir < 0 && c == '(') || (dir > 0 && c == ')')) + /* Found a higher level paren */ + goto ret; + else { +@@ -305,12 +311,15 @@ ret: + /* + * Is this the end of a sentence? + */ ++static int + endsent(pastatom) + bool pastatom; + { + register char *cp = wcursor; + register int c, d; + ++ (void)pastatom; ++ + /* + * If this is the beginning of a line, then + * check for the end of a paragraph or section. +@@ -330,7 +339,7 @@ endsent(pastatom) + if ((d = *++cp) == 0) + return (1); + while (any(d, ")]'")); +- if (*cp == 0 || *cp++ == ' ' && *cp == ' ') ++ if (*cp == 0 || (*cp++ == ' ' && *cp == ' ')) + return (1); + tryps: + if (cp[1] == 0) +@@ -342,6 +351,7 @@ tryps: + * End of paragraphs/sections are respective + * macros as well as blank lines and form feeds. + */ ++static int + endPS() + { + +@@ -351,6 +361,7 @@ endPS() + } + + #ifdef LISPCODE ++int + lindent(addr) + line *addr; + { +@@ -382,7 +393,8 @@ again: + wdot = addr; + dir = -1; + llimit = one; +- lf = lindent; ++ lf = 0; ++ lf_is_lindent = 1; + if (!lskipbal("()")) + i = 0; + else if (wcursor == linebuf) +@@ -407,16 +419,19 @@ again: + } + #endif + ++int + lmatchp(addr) + line *addr; + { + register int i; +- register char *parens, *cp; ++ register const char *parens; ++ register char *cp; + + for (cp = cursor; !any(*cp, "({[)}]");) + if (*cp++ == 0) + return (0); + lf = 0; ++ lf_is_lindent = 0; + parens = any(*cp, "()") ? "()" : any(*cp, "[]") ? "[]" : "{}"; + if (*cp == parens[1]) { + dir = -1; +@@ -435,6 +450,7 @@ lmatchp(addr) + return (i); + } + ++void + lsmatch(cp) + char *cp; + { +@@ -473,14 +489,16 @@ lsmatch(cp) + cursor = scurs; + } + ++static int + ltosolid() + { + + return (ltosol1("()")); + } + ++static int + ltosol1(parens) +- register char *parens; ++ register const char *parens; + { + register char *cp; + +@@ -498,8 +516,9 @@ ltosol1(parens) + return (1); + } + ++static int + lskipbal(parens) +- register char *parens; ++ register const char *parens; + { + register int level = dir; + register int c; +@@ -518,14 +537,16 @@ lskipbal(parens) + return (1); + } + ++static int + lskipatom() + { + + return (lskipa1("()")); + } + ++static int + lskipa1(parens) +- register char *parens; ++ register const char *parens; + { + register int c; + +@@ -546,6 +567,7 @@ lskipa1(parens) + return (ltosol1(parens)); + } + ++int + lnext() + { + +@@ -555,7 +577,7 @@ lnext() + if (*wcursor) + return (1); + if (wdot >= llimit) { +- if (lf == vmove && wcursor > linebuf) ++ if (lf == vmove_i && wcursor > linebuf) + wcursor--; + return (0); + } +@@ -568,7 +590,7 @@ lnext() + if (wcursor >= linebuf) + return (1); + #ifdef LISPCODE +- if (lf == lindent && linebuf[0] == '(') ++ if (lf_is_lindent && linebuf[0] == '(') + llimit = wdot; + #endif + if (wdot <= llimit) { +@@ -582,9 +604,10 @@ lnext() + } + } + ++int + lbrack(c, f) + register int c; +- int (*f)(); ++ void (*f)(int); + { + register line *addr; + +@@ -598,21 +621,21 @@ lbrack(c, f) + get_line(*addr); + if (linebuf[0] == '{' || + #ifdef LISPCODE +- value(LISP) && linebuf[0] == '(' || ++ (value(LISP) && linebuf[0] == '(') || + #endif + isa(svalue(SECTIONS))) { +- if (c == ']' && f != vmove) { ++ if (c == ']' && f != vmove_i) { + addr--; + get_line(*addr); + } + break; + } +- if (c == ']' && f != vmove && linebuf[0] == '}') ++ if (c == ']' && f != vmove_i && linebuf[0] == '}') + break; + } + if (addr == dot) + return (0); +- if (f != vmove) ++ if (f != vmove_i) + wcursor = c == ']' ? strend(linebuf) : linebuf; + else + wcursor = 0; +@@ -621,8 +644,9 @@ lbrack(c, f) + return (1); + } + ++static int + isa(cp) +- register char *cp; ++ register const char *cp; + { + + if (linebuf[0] != '.') diff --git a/editors/ex/patches/patch-ex__vops_c b/editors/ex/patches/patch-ex__vops_c new file mode 100644 index 00000000000..adee374cd39 --- /dev/null +++ b/editors/ex/patches/patch-ex__vops_c @@ -0,0 +1,240 @@ +$NetBSD: patch-ex__vops_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare local functions static +- declare void functions void +- silence warnings about braces +- fix up function pointer casting mess +- avoid implicit int +- silence warnings about && and || precedence +- use const for string constants +- silence warnings about unused arguments +- silence signed/unsigned compiler warning + +--- ex_vops.c~ 2012-12-27 21:58:42.000000000 +0000 ++++ ex_vops.c +@@ -89,8 +89,9 @@ static char sccsid[] = "@(#)ex_vops.c 1. + * display representations. + */ + +-int xdw __P((void)); +-int setpk __P((void)); ++static int xdw __P((void)); ++static void vshift(int ignore); ++static void setpk __P((void)); + + /* + * Undo. +@@ -111,6 +112,7 @@ int setpk __P((void)); + char *vUA1, *vUA2; + char *vUD1, *vUD2; + ++void + vUndo() + { + +@@ -137,6 +139,7 @@ vUndo() + vfixcurs(); + } + ++void + vundo(show) + bool show; /* if true update the screen */ + { +@@ -173,12 +176,13 @@ bool show; /* if true update the screen + * with dol through unddol-1. Hack screen image to + * reflect this replacement. + */ +- if (show) ++ if (show) { + if (undkind == UNDMOVE) + vdirty(0, TLINES); + else + vreplace(undap1 - addr, undap2 - undap1, + undkind == UNDPUT ? 0 : unddol - dol); ++ } + savenote = notecnt; + undo(1); + if (show && (vundkind != VMCHNG || addr != dot)) +@@ -250,6 +254,7 @@ bool show; /* if true update the screen + * opposed to an ex command). This has nothing to do with being + * in open/visual mode as :s/foo/bar is not fromvis. + */ ++void + vmacchng(fromvis) + bool fromvis; + { +@@ -259,7 +264,6 @@ bool fromvis; + int nlines, more; + /* register line *a1, *a2; */ + /* char ch; */ /* DEBUG */ +- int copyw(), copywR(); + + if (!inopen) + return; +@@ -338,6 +342,7 @@ bool fromvis; + /* + * Initialize undo information before an append. + */ ++void + vnoapp() + { + +@@ -357,6 +362,7 @@ vnoapp() + /* + * Move is simple, except for moving onto new lines in hardcopy open mode. + */ ++void + vmove() + { + register int cnt; +@@ -423,6 +429,17 @@ vmove() + } + + /* ++ * This is the same as vmove, but throws away its argument, so ++ * it can be used in combination with other function pointers. ++ */ ++void ++vmove_i(int ignore) ++{ ++ (void)ignore; ++ vmove(); ++} ++ ++/* + * Delete operator. + * + * Hard case of deleting a range where both wcursor and wdot +@@ -430,7 +447,8 @@ vmove() + * by vchange (although vchange may pass it back if it degenerates + * to a full line range delete.) + */ +-vdelete(c) ++void ++vdelete(int c) + { + register char *cp; + register int i; +@@ -489,7 +507,8 @@ vdelete(c) + * Across lines with both wcursor and wdot given, we delete + * and sync then append (but one operation for undo). + */ +-vchange(c) ++void ++vchange(int c) + { + register char *cp; + register int i, ind, cnt; +@@ -705,6 +724,7 @@ smallchange: + * Actually counts are obsoleted, since if your terminal is slow + * you are better off with slowopen. + */ ++void + voOpen(c, cnt) + int c; /* mjm: char --> int */ + register int cnt; +@@ -719,7 +739,7 @@ voOpen(c, cnt) + #endif + #endif + +- if (value(SLOWOPEN) || value(REDRAW) && AL && DL) ++ if (value(SLOWOPEN) || (value(REDRAW) && AL && DL)) + cnt = 1; + #ifdef SIGWINCH + #ifndef POSIX_1 +@@ -794,6 +814,7 @@ voOpen(c, cnt) + */ + char vshnam[2] = { 'x', 0 }; + ++void + vshftop() + { + register line *addr; +@@ -817,11 +838,12 @@ vshftop() + * + * Filter portions of the buffer through unix commands. + */ ++void + vfilter() + { + register line *addr; + register int cnt; +- char *oglobp; ++ const char *oglobp; + short d; + #ifdef BIT8 + cell cuxb[UXBSIZE + 2]; +@@ -885,6 +907,7 @@ vfilter() + * that wdot is reasonable. Its name comes from + * xchange dotand wdot + */ ++static int + xdw() + { + register char *cp; +@@ -956,9 +979,10 @@ xdw() + /* + * Routine for vremote to call to implement shifts. + */ +-vshift() ++static void ++vshift(int ignore) + { +- ++ (void)ignore; + shift(op, 1); + } + +@@ -966,12 +990,13 @@ vshift() + * Replace a single character with the next input character. + * A funny kind of insert. + */ ++void + vrep(cnt) + register int cnt; + { + register int i, c; + +- if (cnt > strlen(cursor)) { ++ if (cnt > (int)strlen(cursor)) { + beep(); + return; + } +@@ -1000,12 +1025,20 @@ vrep(cnt) + setLAST(); + } + ++static void ++doyank(int ignore) ++{ ++ (void)ignore; ++ yank(); ++} ++ + /* + * Yank. + * + * Yanking to string registers occurs for free (essentially) + * in the routine xdw(). + */ ++void + vyankit() + { + register int cnt; +@@ -1013,7 +1046,7 @@ vyankit() + if (wdot) { + if ((cnt = xdw()) < 0) + return; +- vremote(cnt, yank, 0); ++ vremote(cnt, doyank, 0); + setpk(); + notenam = "yank"; + if (FIXUNDO) +@@ -1036,6 +1069,7 @@ vyankit() + * the first and last lines. The compromise + * is for put to be more clever. + */ ++static void + setpk() + { + diff --git a/editors/ex/patches/patch-ex__vput_c b/editors/ex/patches/patch-ex__vput_c new file mode 100644 index 00000000000..d1cb1010855 --- /dev/null +++ b/editors/ex/patches/patch-ex__vput_c @@ -0,0 +1,471 @@ +$NetBSD: patch-ex__vput_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare local functions static +- declare void functions void +- avoid implicit int +- return values from non-void functions +- silence warnings about && and || precedence +- silence warnings about braces +- fix up function pointer casting mess + +--- ex_vput.c~ 2012-12-27 21:58:42.000000000 +0000 ++++ ex_vput.c +@@ -88,14 +88,14 @@ static char sccsid[] = "@(#)ex_vput.c 1. + #define vquot(c) (c == quotsp) + #endif /* BIT8 */ + +-int vmaktop __P((int, cell *)); +-int vnpins __P((int)); +-int vrigid __P((void)); +-int vneedpos __P((int)); +-int vishft __P((void)); +-int viin __P((int)); +-int godm __P((void)); +-int enddm __P((void)); ++static void vmaktop __P((int, cell *)); ++static void vnpins __P((int)); ++static void vrigid __P((void)); ++static void vneedpos __P((int)); ++static void vishft __P((void)); ++static void viin __P((int)); ++static void godm __P((void)); ++static void enddm __P((void)); + + /* + * Deal with the screen, clearing, cursor positioning, putting characters +@@ -103,6 +103,7 @@ int enddm __P((void)); + * Really hard stuff here is utilizing insert character operations + * on intelligent terminals which differs widely from terminal to terminal. + */ ++void + vclear() + { + +@@ -122,6 +123,7 @@ vclear() + /* + * Clear memory. + */ ++void + vclrcell(cp, i) + register cell *cp; + register int i; +@@ -135,6 +137,7 @@ vclrcell(cp, i) + /* + * Clear a physical display line, high level. + */ ++void + vclrlin(l, tp) + int l; + line *tp; +@@ -155,6 +158,7 @@ vclrlin(l, tp) + /* + * Clear to the end of the current physical line + */ ++void + vclreol() + { + register int i, j; +@@ -169,7 +173,7 @@ vclreol() + i = WCOLS - destcol; + tp = vtube[destline] + destcol; + if (CE) { +- if (IN && *tp || !ateopr()) { ++ if ((IN && *tp) || !ateopr()) { + vcsync(); + vputp(CE, 1); + } +@@ -200,6 +204,7 @@ vclreol() + * If work here is being held off, just remember, in + * heldech, if work needs to be done, don't do anything. + */ ++void + vclrech(didphys) + bool didphys; + { +@@ -252,6 +257,7 @@ vclrech(didphys) + * the state variable splitw so we wont rollup + * when we move the cursor there. + */ ++void + fixech() + { + +@@ -266,6 +272,7 @@ fixech() + /* + * Put the cursor ``before'' cp. + */ ++void + vcursbef(cp) + register char *cp; + { +@@ -279,6 +286,7 @@ vcursbef(cp) + /* + * Put the cursor ``at'' cp. + */ ++void + vcursat(cp) + register char *cp; + { +@@ -292,6 +300,7 @@ vcursat(cp) + /* + * Put the cursor ``after'' cp. + */ ++void + vcursaft(cp) + register char *cp; + { +@@ -303,6 +312,7 @@ vcursaft(cp) + * Fix the cursor to be positioned in the correct place + * to accept a command. + */ ++void + vfixcurs() + { + +@@ -313,6 +323,7 @@ vfixcurs() + * Compute the column position implied by the cursor at ``nc'', + * and move the cursor there. + */ ++void + vsetcurs(nc) + register char *nc; + { +@@ -328,6 +339,7 @@ vsetcurs(nc) + /* + * Move the cursor invisibly, i.e. only remember to do it. + */ ++void + vigoto(y, x) + int y, x; + { +@@ -340,6 +352,7 @@ vigoto(y, x) + * Move the cursor to the position implied by any previous + * vigoto (or low level hacking with destcol/destline as in readecho). + */ ++void + vcsync() + { + +@@ -349,6 +362,7 @@ vcsync() + /* + * Goto column x of the current line. + */ ++void + vgotoCL(x) + register int x; + { +@@ -362,8 +376,8 @@ vgotoCL(x) + /* + * Invisible goto column x of current line. + */ +-vigotoCL(x) +- register int x; ++static void ++vigotoCL(register int x) + { + + if (splitw) +@@ -375,6 +389,7 @@ vigotoCL(x) + /* + * Move cursor to line y, column x, handling wraparound and scrolling. + */ ++void + vgoto(y, x) + register int y, x; + { +@@ -523,7 +538,8 @@ vgoto(y, x) + * with a QUOTE. We use QUOTE internally to represent a position + * which is part of the expansion of a tab. + */ +-vgotab() ++static void ++vgotab(void) + { + register int i = tabcol(destcol, value(TABSTOP)) - destcol; + +@@ -555,6 +571,7 @@ int slakused; /* This much of tabslack + * of the screen image buffer so it is easier for us to + * maniuplate them. + */ ++void + vprepins() + { + register int i; +@@ -566,6 +583,7 @@ vprepins() + } + } + ++static void + vmaktop(p, cp) + register int p; + cell *cp; +@@ -594,6 +612,7 @@ vmaktop(p, cp) + * for tabs) and code assumes this in several place + * to make life simpler. + */ ++int + vinschar(c) + int c; /* mjm: char --> int */ + { +@@ -609,12 +628,12 @@ vinschar(c) + */ + if (c == '\t') { + vgotab(); +- return; ++ return c; + } + vputchar(c); + if (DEPTH(vcline) * WCOLS + !value(REDRAW) > + (destline - LINE(vcline)) * WCOLS + destcol) +- return; ++ return c; + /* + * The next line is about to be clobbered + * make space for another segment of this line +@@ -627,14 +646,14 @@ vinschar(c) + } else { + c = LINE(vcline) + DEPTH(vcline); + if (c < LINE(vcline + 1) || c > WBOT) +- return; ++ return c; + i = destcol; + vinslin(c, 1, vcline); + DEPTH(vcline)++; + vigoto(c, i); + vprepins(); + } +- return; ++ return c; + } + /* + * Compute the number of positions in the line image of the +@@ -693,7 +712,7 @@ vinschar(c) + do + vputchar(c); + while (--inssiz); +- return; ++ return c; + } + + /* +@@ -787,12 +806,14 @@ vinschar(c) + destline = LINE(vcline); + destcol = inscol + inssiz; + vcsync(); ++ return c; + } + + /* + * Rigidify the rest of the line after the first + * group of following tabs, typing blanks over ``spaces''. + */ ++void + vrigid() + { + register int col; +@@ -827,6 +848,7 @@ vrigid() + * On a dumb terminal we may infact redisplay the rest of the + * screen here brute force to keep it pretty. + */ ++void + vneedpos(npcnt) + int npcnt; + { +@@ -866,6 +888,7 @@ vneedpos(npcnt) + vnpins(1); + } + ++void + vnpins(dosync) + int dosync; + { +@@ -900,6 +923,7 @@ vnpins(dosync) + * Do the shift of the next tabstop implied by + * insertion so it expands. + */ ++void + vishft() + { + int tshft = 0; +@@ -1004,6 +1028,7 @@ vishft() + /* + * Now do the insert of the characters (finally). + */ ++static void + viin(c) + int c; /* mjm: char --> int */ + { +@@ -1014,7 +1039,7 @@ viin(c) + short oldhold = hold; + + hold |= HOLDPUPD; +- if (tabsize && (IM && EI) && inssiz - doomed > tabslack) ++ if (tabsize && (IM && EI) && inssiz - doomed > tabslack) { + /* + * There is a tab out there which will be affected + * by the insertion since there aren't enough doomed +@@ -1053,6 +1078,7 @@ viin(c) + enddm(); + } + } ++ } + + /* + * Now put out the characters of the actual insertion. +@@ -1175,6 +1201,7 @@ viin(c) + * is the same as that which goes into insert + * mode, then we are in delete mode already. + */ ++void + godm() + { + +@@ -1194,6 +1221,7 @@ godm() + * if we just moved over to delete space from part of + * a tab (above). + */ ++static void + enddm() + { + +@@ -1211,6 +1239,7 @@ enddm() + * if the terminal does all insertions a single character + * at a time, since it branches based on whether IM is null. + */ ++void + goim() + { + +@@ -1219,6 +1248,7 @@ goim() + insmode = 1; + } + ++void + endim() + { + +@@ -1238,6 +1268,7 @@ endim() + * you can erase overstrikes with some work. CRT's which do underlining + * implicitly which has to be erased (like CONCEPTS) are also handled. + */ ++int + vputchar(c) + register int c; + { +@@ -1292,7 +1323,7 @@ vputchar(c) + *tp = overbuf; + #endif + destcol++; +- return; ++ return c; + } + /* + * A ``space'' ontop of a part of a tab. +@@ -1303,7 +1334,7 @@ vputchar(c) + if (vquot(*tp)) { + #endif + destcol++; +- return; ++ return c; + } + #ifndef BIT8 + c = ' ' | QUOTE; +@@ -1328,7 +1359,7 @@ vputchar(c) + + case '\t': + vgotab(); +- return; ++ return c; + + case ' ': + /* +@@ -1349,7 +1380,7 @@ vputchar(c) + ) { + *tp = ' '; + destcol++; +- return; ++ return c; + } + goto def; + +@@ -1374,7 +1405,7 @@ def: + if ((hold & HOLDPUPD) == 0) + *tp = c; + destcol++; +- return; ++ return c; + } + /* + * Backwards looking optimization. +@@ -1413,7 +1444,7 @@ def: + e = trim(c); + if (!insmode && d && d != ' ' && d != e) { + #endif +- if (EO && (OS || UL && (c == '_' || d == '_'))) { ++ if (EO && (OS || (UL && (c == '_' || d == '_')))) { + vputc(' '); + outcol++, destcol++; + back1(); +@@ -1478,12 +1509,14 @@ def: + vputc('\n'); + } + } ++ return c; + } + + /* + * Delete display positions stcol through endcol. + * Amount of use of special terminal features here is limited. + */ ++void + physdc(stcol, endcol) + int stcol, endcol; + { +@@ -1578,7 +1611,7 @@ physdc(stcol, endcol) + if (IN) { + up = vtube0 + stcol; + tp = vtube0 + endcol; +- while (i = *tp++) { ++ while ((i = *tp++) != 0) { + #ifndef BIT8 + if ((i & (QUOTE|TRIM)) == QUOTE) + #else +@@ -1602,6 +1635,7 @@ physdc(stcol, endcol) + } + + #ifdef TRACE ++void + tfixnl() + { + +@@ -1610,6 +1644,7 @@ tfixnl() + trubble = 0, techoin = 0; + } + ++void + tvliny() + { + register int i; +@@ -1630,6 +1665,7 @@ tvliny() + fprintf(trace, "\n"); + } + ++void + tracec(c) + int c; /* mjm: char --> int */ + { +@@ -1652,6 +1688,7 @@ tracec(c) + /* + * Put a character with possible tracing. + */ ++int + vputch(c) + int c; + { +@@ -1660,5 +1697,5 @@ vputch(c) + if (trace) + tracec(c); + #endif +- vputc(c); ++ return vputc(c); + } diff --git a/editors/ex/patches/patch-ex__vwind_c b/editors/ex/patches/patch-ex__vwind_c new file mode 100644 index 00000000000..f3e20e22d72 --- /dev/null +++ b/editors/ex/patches/patch-ex__vwind_c @@ -0,0 +1,173 @@ +$NetBSD: patch-ex__vwind_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare local functions static +- declare void functions void +- avoid implicit int +- hide unused function in the proper matching ifdef + +--- ex_vwind.c~ 2012-12-27 21:58:41.000000000 +0000 ++++ ex_vwind.c +@@ -89,10 +89,14 @@ static char sccsid[] = "@(#)ex_vwind.c 1 + * directions. Code here is very dependent on mode (open versus visual). + */ + +-int vfit __P((register line *, int)); +-int vrollR __P((register int)); +-line *vback __P((register line *, register int)); +-int vreset __P((int)); ++static int vfit __P((register line *, int)); ++static void vrollR __P((register int)); ++static line *vback __P((register line *, register int)); ++static void vreset __P((int)); ++ ++#ifndef CBREAK ++static int vcookit(register int cnt); ++#endif + + /* + * Move in a nonlocal way to line addr. +@@ -100,9 +104,11 @@ int vreset __P((int)); + * New position for cursor is curs. + * Like most routines here, we vsave(). + */ ++void + vmoveto(addr, curs, context) + register line *addr; + char *curs; ++ int context; + { + + markit(addr); +@@ -114,9 +120,11 @@ vmoveto(addr, curs, context) + * Vjumpto is like vmoveto, but doesn't mark previous + * context or save linebuf as current line. + */ ++void + vjumpto(addr, curs, context) + register line *addr; + char *curs; ++ int context; + { + + noteit(0); +@@ -131,6 +139,7 @@ vjumpto(addr, curs, context) + /* + * Go up or down cnt (negative is up) to new position curs. + */ ++void + vupdown(cnt, curs) + register int cnt; + char *curs; +@@ -152,6 +161,7 @@ vupdown(cnt, curs) + * If scroll, then we MUST use a scroll. + * Otherwise clear and redraw if motion is far. + */ ++void + vup(cnt, ind, scroll) + register int cnt, ind; + bool scroll; +@@ -201,6 +211,7 @@ okr: + /* + * Like vup, but scrolling down. + */ ++void + vdown(cnt, ind, scroll) + register int cnt, ind; + bool scroll; +@@ -250,8 +261,10 @@ dcontxt: + * Work here is in determining new top line implied by + * this placement of line addr, since we always draw from the top. + */ ++void + vcontext(addr, where) + register line *addr; ++ int where; + { + register line *top; + +@@ -293,6 +306,7 @@ vcontext(addr, where) + * we may be able to reuse the line we are on + * if it is blank. This is a real win. + */ ++void + vclean() + { + +@@ -310,6 +324,7 @@ vclean() + * (and call us recursively). Eventually, we clear the screen + * (or its open mode equivalent) and redraw. + */ ++void + vshow(addr, top) + line *addr, *top; + { +@@ -363,6 +378,7 @@ vshow(addr, top) + * area; we are called this way in the middle of a :e escape + * from visual, e.g. + */ ++static void + vreset(inecho) + bool inecho; + { +@@ -378,7 +394,7 @@ vreset(inecho) + * Starting from which line preceding tp uses almost (but not more + * than) cnt physical lines? + */ +-line * ++static line * + vback(tp, cnt) + register int cnt; + register line *tp; +@@ -399,6 +415,7 @@ vback(tp, cnt) + /* + * How much scrolling will it take to roll cnt lines starting at tp? + */ ++static int + vfit(tp, cnt) + register line *tp; + int cnt; +@@ -419,6 +436,7 @@ vfit(tp, cnt) + /* + * Roll cnt lines onto the screen. + */ ++void + vroll(cnt) + register int cnt; + { +@@ -460,6 +478,7 @@ vroll(cnt) + /* + * Roll backwards (scroll up). + */ ++static void + vrollR(cnt) + register int cnt; + { +@@ -504,16 +523,20 @@ vrollR(cnt) + * BUG: An interrupt during a scroll in this way + * dumps to command mode. + */ ++#ifndef CBREAK ++static int + vcookit(cnt) + register int cnt; + { + + return (cnt > 1 && (ospeed < B1200 && !initev || cnt > TLINES * 2)); + } ++#endif + + /* + * Determine displayed depth of current line. + */ ++int + vdepth() + { + register int d; +@@ -529,6 +552,7 @@ vdepth() + /* + * Move onto a new line, with cursor at position curs. + */ ++void + vnline(curs) + char *curs; + { diff --git a/editors/ex/patches/patch-ex_c b/editors/ex/patches/patch-ex_c new file mode 100644 index 00000000000..b8df97f15fa --- /dev/null +++ b/editors/ex/patches/patch-ex_c @@ -0,0 +1,122 @@ +$NetBSD: patch-ex_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare local functions static +- declare void functions void +- avoid implicit int +- use volatile for compiler warnings about setjmp/vfork clobbering +- silence warnings about assignments in conditionals + +--- ex.c~ 2003-03-18 20:47:50.000000000 +0000 ++++ ex.c +@@ -144,13 +144,15 @@ char tttrace[] = { '/','d','e','v','/',' + + static char *progname; + +-erropen() ++static void ++erropen(void) + { + close(1); + dup(2); + } + +-usage() ++static void ++usage(void) + { + printf(catgets(catd, 1, 1, "\ + Usage: %s [- | -s] [-l] [-L] [-R] [-r [file]] [-t tag]\n\ +@@ -160,7 +162,8 @@ Usage: %s [- | -s] [-l] [-L] [-R] [-r [f + exitex(1); + } + +-needarg(c) ++static void ++needarg(int c) + { + erropen(); + printf(catgets(catd, 1, 2, +@@ -168,7 +171,8 @@ needarg(c) + usage(); + } + +-invopt(c) ++static void ++invopt(int c) + { + erropen(); + printf(catgets(catd, 1, 3, "%s: illegal option -- %c\n"), progname, c); +@@ -178,9 +182,8 @@ invopt(c) + /* + * Return last component of unix path name p. + */ +-char * +-tailpath(p) +-register char *p; ++static char * ++tailpath(register char *p) + { + register char *r; + +@@ -194,8 +197,8 @@ register char *p; + * Check ownership of file. Return nonzero if it exists and is owned by the + * user or the option sourceany is used + */ +-iownit(file) +-char *file; ++static int ++iownit(const char *file) + { + struct stat sb; + +@@ -214,8 +217,7 @@ char *file; + + #ifdef POSIX_1 + shand +-setsig(signum, handler) +-shand handler; ++setsig(int signum, shand handler) + { + struct sigaction nact, oact; + +@@ -244,7 +246,8 @@ shand handler; + * Main thing here is to get a new buffer (in fileinit), + * rest is peripheral state resetting. + */ +-init() ++void ++init(void) + { + register int i; + +@@ -268,6 +271,7 @@ init() + * there is a 'd' in our name. For edit we just diddle options; + * for vi we actually force an early visual command. + */ ++int + main(ac, av) + register int ac; + register char *av[]; +@@ -280,7 +284,13 @@ main(ac, av) + #endif + char *cp = NULL; + register int c; ++#ifdef __STDC__ ++ volatile ++#endif + bool ivis; ++#ifdef __STDC__ ++ volatile ++#endif + bool fast = 0; + #ifdef TRACE + register char *tracef; +@@ -560,7 +570,7 @@ argend: + setrupt(); + intty = isatty(0); + value(PROMPT) = intty; +- if (cp = getenv("SHELL")) ++ if ((cp = getenv("SHELL")) != NULL) + strcpy(shell, cp); + if (fast || !intty) + setterm("dumb"); diff --git a/editors/ex/patches/patch-expreserve_c b/editors/ex/patches/patch-expreserve_c new file mode 100644 index 00000000000..9a2da49a846 --- /dev/null +++ b/editors/ex/patches/patch-expreserve_c @@ -0,0 +1,90 @@ +$NetBSD: patch-expreserve_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare void functions void +- use static for local functions +- use a bit of const +- silence gcc warnings about unused arguments +- avoid implicit int +- don't pass a string constant to putenv() + +--- expreserve.c.orig 2002-08-27 04:14:56.000000000 +0000 ++++ expreserve.c +@@ -203,10 +203,10 @@ char xstr[1]; /* make loader happy */ + #endif + #endif + +-int notify __P((uid_t uid, char *fname, int flag, time_t time)); +-int copyout __P((char *name)); +-int mkdigits __P((char *cp)); +-int mknext __P((char *cp)); ++static void notify __P((uid_t uid, const char *fname, int flag, time_t time)); ++static int copyout __P((char *name)); ++static void mkdigits __P((char *cp)); ++static void mknext __P((char *cp)); + + /* + * Expreserve - preserve a file in /usr/preserve +@@ -275,6 +275,7 @@ char **argv; + exit(1); + exit(0); + } ++ (void)argv; + + /* + * If not super user, then can only preserve standard input. +@@ -328,9 +329,11 @@ char pattern[] = "/var/preserve/Exa`XXXX + /* + * Notify user uid that his file fname has been saved. + */ ++static void + notify(uid, fname, flag, time) + uid_t uid; +- char *fname; ++ const char *fname; ++ int flag; + time_t time; + { + struct passwd *pp = getpwuid(uid); +@@ -345,6 +348,9 @@ notify(uid, fname, flag, time) + char croak[128]; + char *timestamp, *ctime(); + ++ /* cannot properly string constants to putenv */ ++ static char mailrc_var[] = "MAILRC=/dev/null"; ++ + if (pp == NULL) + return; + #ifndef POSIX_1 +@@ -355,7 +361,7 @@ notify(uid, fname, flag, time) + #endif + timestamp = ctime(&time); + timestamp[16] = 0; /* blast from seconds on */ +- putenv("MAILRC=/dev/null"); ++ putenv(mailrc_var); + sprintf(cmd, "/bin/mail %s", pp->pw_name); + setuid(getuid()); + mf = popen(cmd, "w"); +@@ -411,6 +417,7 @@ notify(uid, fname, flag, time) + * file (this is the slowest thing since we must stat + * to find a unique name), and finally copy the file. + */ ++static int + copyout(name) + char *name; + { +@@ -546,6 +553,7 @@ format: + /* + * Blast the last 5 characters of cp to be the process number. + */ ++static void + mkdigits(cp) + char *cp; + { +@@ -566,6 +574,7 @@ mkdigits(cp) + * three alphabetic characters into a sequence of the form 'aab', 'aac', etc. + * Mktemp gets weird names too quickly to be useful here. + */ ++static void + mknext(cp) + char *cp; + { diff --git a/editors/ex/patches/patch-exrecover_c b/editors/ex/patches/patch-exrecover_c index 2b114aae0c9..f943fcac58a 100644 --- a/editors/ex/patches/patch-exrecover_c +++ b/editors/ex/patches/patch-exrecover_c @@ -1,23 +1,333 @@ -$NetBSD: patch-exrecover_c,v 1.1 2011/08/01 05:47:40 dholland Exp $ +$NetBSD: patch-exrecover_c,v 1.2 2012/12/28 03:03:09 dholland Exp $ -Fix illegal C caught by clang. +- use standard headers +- don't declare own perror +- declare void functions void +- avoid implicit int +- silence signed/unsigned compiler warning +- use const for string constants +- silence warnings about assignments in conditionals +- return values from non-void functions +- silence warnings about unused arguments ---- exrecover.c~ 2002-04-07 12:02:27.000000000 +0000 +--- exrecover.c.orig 2012-12-27 21:58:41.000000000 +0000 +++ exrecover.c -@@ -198,7 +198,7 @@ char *getblock __P((line, int)); - int blkio __P((bloc, char *, ssize_t (*) __P((int, void *, size_t)))); +@@ -98,6 +98,8 @@ static char sccsid[] UNUSED = "@(#)exrec + typedef int xFILE; + #endif + ++#include <stdio.h> ++ + #define var + + #include "ex.h" +@@ -193,30 +195,30 @@ int vercnt; /* Count number of version + #endif + #endif + +-extern int perror __P((const char *)); + char *getblock __P((line, int)); +-int blkio __P((bloc, char *, ssize_t (*) __P((int, void *, size_t)))); ++void blkio __P((bloc, char *, ssize_t (*) __P((int, void *, size_t)))); char *poolsbrk __P((intptr_t)); - int error __P((char *str, ...)); +-int error __P((char *str, ...)); -int listfiles __P((char *)); -+void listfiles __P((char *)); - int enter __P((struct svfile *, char *, int)); +-int enter __P((struct svfile *, char *, int)); ++void error __P((const char *str, ...)); ++void listfiles __P((const char *)); ++void enter __P((struct svfile *, char *, int)); int qucmp __P((struct svfile *, struct svfile *)); - int findtmp __P((char *)); -@@ -384,6 +384,7 @@ error(char *str, ...) +-int findtmp __P((char *)); +-int searchdir __P((char *)); +-int yeah __P((char *)); ++void findtmp __P((const char *)); ++void searchdir __P((const char *)); ++int yeah __P((const char *)); + int preserve __P((void)); +-int scrapbad __P((void)); +-int putfile __P((int)); +-int wrerror __P((void)); +-int clrstats __P((void)); +-int get_line __P((line)); +-int syserror __P((void)); +-int xvfprintf __P((xFILE *, char *, va_list)); +-int xfprintf __P((xFILE *, char *, ...)); ++void scrapbad __P((void)); ++void putfile __P((int)); ++void wrerror __P((void)); ++void clrstats __P((void)); ++void get_line __P((line)); ++void syserror __P((void)); ++void xvfprintf __P((xFILE *, const char *, va_list)); ++void xfprintf __P((xFILE *, const char *, ...)); + #ifdef __STDC__ + int vsprintf(char *, const char *, va_list); + #endif + ++int + main(argc, argv) + int argc; + char *argv[]; +@@ -295,7 +297,7 @@ main(argc, argv) + while (H.Flines > 0) { + ignorl(lseek(tfile, (off_t) ((blocks[b] & BLKMSK) * BUFSIZ), + SEEK_SET)); +- i = H.Flines < BUFSIZ / sizeof (line) ? ++ i = H.Flines < (int)(BUFSIZ / sizeof (line)) ? + H.Flines * sizeof (line) : BUFSIZ; + if (read(tfile, (char *) dot, i) != i) { + perror(nb); +@@ -350,13 +352,14 @@ main(argc, argv) + * a newline which would screw up the screen. + */ + /*VARARGS2*/ ++void + #ifndef __STDC__ + error(str, inf) +- char *str; ++ const char *str; + int inf; + { + #else +-error(char *str, ...) ++error(const char *str, ...) + { + va_list ap; + #endif +@@ -384,8 +387,9 @@ error(char *str, ...) exit(1); } +void listfiles(dirname) - char *dirname; +- char *dirname; ++ const char *dirname; + { + register DIR *dir; + #ifndef POSIX_1 +@@ -486,9 +490,11 @@ listfiles(dirname) + /* + * Enter a new file into the saved file information. + */ ++void + enter(fp, fname, count) + struct svfile *fp; + char *fname; ++ int count; + { + register char *cp, *cp2; + register struct svfile *f, *fl; +@@ -521,7 +527,7 @@ enter(fp, fname, count) + fp->sf_time = H.Time; + fp->sf_lines = H.Flines; + cp2 = fp->sf_name, cp = savedfile; +- while (*cp2++ = *cp++); ++ while ((*cp2++ = *cp++) != 0); + for (cp2 = fp->sf_entry, cp = fname; *cp && cp-fname < 14;) + *cp2++ = *cp++; + *cp2++ = 0; +@@ -531,12 +537,13 @@ enter(fp, fname, count) + * Do the qsort compare to sort the entries first by file name, + * then by modify time. + */ ++int + qucmp(p1, p2) + struct svfile *p1, *p2; + { + register int t; + +- if (t = strcmp(p1->sf_name, p2->sf_name)) ++ if ((t = strcmp(p1->sf_name, p2->sf_name)) != 0) + return(t); + if (p1->sf_time > p2->sf_time) + return(-1); +@@ -555,8 +562,9 @@ int bestfd; /* Keep best file open so + * (i.e. usually /tmp) and in /usr/preserve. + * Want to find the newest so we search on and on. + */ ++void + findtmp(dir) +- char *dir; ++ const char *dir; + { + + /* +@@ -608,8 +616,9 @@ findtmp(dir) + * name of the file we want to unlink is relative, rather than absolute + * we won't be able to find it again. + */ ++void + searchdir(dirname) +- char *dirname; ++ const char *dirname; + { + #ifndef POSIX_1 + struct direct *dirent; +@@ -662,8 +671,9 @@ searchdir(dirname) + * if its really an editor temporary and of this + * user and the file specified. + */ ++int + yeah(name) +- char *name; ++ const char *name; + { + + tfile = open(name, O_RDWR); +@@ -688,9 +698,10 @@ nope: + return (1); + } + ++int + preserve() + { +- ++ return 0; + } + + /* +@@ -707,6 +718,7 @@ preserve() + * This only seems to happen on very heavily loaded systems, and + * not very often. + */ ++void + scrapbad() + { + register line *ip; +@@ -791,6 +803,7 @@ null: + * Aw shucks, if we only had a (void) cast. + */ + #ifdef lint ++void + Ignorl(a) + long a; { +@@ -798,6 +811,7 @@ Ignorl(a) + a = a; + } + ++void + Ignore(a) + char *a; + { +@@ -805,13 +819,15 @@ Ignore(a) + a = a; + } + ++void + Ignorf(a) +- int (*a)(); ++ void (*a)(int); + { + + a = a; + } + ++void + ignorl(a) + long a; + { +@@ -824,12 +840,15 @@ int cntch, cntln, cntodd, cntnull; + /* + * Following routines stolen mercilessly from ex. + */ +-putfile(unused) ++void ++putfile(int unused) + { + line *a1; + register char *fp, *lp; + register int nib; + ++ (void)unused; ++ + a1 = addr1; + clrstats(); + cntln = addr2 - a1 + 1; +@@ -861,12 +880,14 @@ putfile(unused) + cntch += nib; + } + ++void + wrerror() + { + + syserror(); + } + ++void + clrstats() + { + +@@ -880,6 +901,7 @@ clrstats() + #define READ 0 + #define WRITE 1 + ++void + get_line(tl) + line tl; + { +@@ -890,7 +912,7 @@ get_line(tl) + bp = getblock(tl, READ); + nl = nleft; + tl &= ~OFFMSK; +- while (*lp++ = *bp++) ++ while ((*lp++ = *bp++) != 0) + if (--nl == 0) { + bp = getblock(tl += INCRMT, READ); + nl = nleft; +@@ -934,8 +956,8 @@ getblock(atl, iof) + return (obuff + off); + } + ++void + #ifdef __STDC__ +-int + blkio(bloc b, char *buf, ssize_t (*iofcn)(int, void *, size_t)) + #else /* !__STDC__ */ + blkio(b, buf, iofcn) +@@ -950,6 +972,7 @@ blkio(b, buf, iofcn) + syserror(); + } + ++void + syserror() + { + +@@ -964,10 +987,11 @@ syserror() + * allocation and stdio uses malloc. + */ + #ifndef __STDC__ ++void + xfprintf(fp, fmt, a1, a2, a3, a4, a5) + xFILE *fp; +- char *fmt; +- char *a1, *a2, *a3, *a4, *a5; ++ const char *fmt; ++ const char *a1, *a2, *a3, *a4, *a5; + { + char buf[BUFSIZ]; + +@@ -981,17 +1005,19 @@ xfprintf(fp, fmt, a1, a2, a3, a4, a5) + * I do not know whether vsprintf() uses malloc() or not. + * So this may be fail, too. + */ +-xvfprintf(xFILE *fp, char *fmt, va_list ap) ++void ++xvfprintf(xFILE *fp, const char *fmt, va_list ap) + { + char buf[BUFSIZ]; + + if (fp != xstderr) + return; +- vsprintf(buf, fmt, ap); ++ vsnprintf(buf, sizeof(buf), fmt, ap); + write(2, buf, strlen(buf)); + } + +-xfprintf(xFILE *fp, char *fmt, ...) ++void ++xfprintf(xFILE *fp, const char *fmt, ...) + { + va_list ap; + diff --git a/editors/ex/patches/patch-libterm_libterm_h b/editors/ex/patches/patch-libterm_libterm_h new file mode 100644 index 00000000000..6eb244b2516 --- /dev/null +++ b/editors/ex/patches/patch-libterm_libterm_h @@ -0,0 +1,23 @@ +$NetBSD: patch-libterm_libterm_h,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- use const for string constants +- declare type of function pointer properly + +--- libterm/libterm.h.orig 2002-02-04 01:30:04.000000000 +0000 ++++ libterm/libterm.h +@@ -56,9 +56,9 @@ + #endif + #endif + +-int tgetent __P((char *, char *)); +-int tgetnum __P((char *)); +-int tgetflag __P((char *)); +-char *tgetstr __P((char *, char **)); +-char *tgoto __P((char *, int, int)); +-int tputs __P((register char *, int, int (*)())); ++int tgetent __P((char *, const char *)); ++int tgetnum __P((const char *)); ++int tgetflag __P((const char *)); ++char *tgetstr __P((const char *, char **)); ++const char *tgoto __P((char *, int, int)); ++void tputs __P((register const char *, int, int (*)(int))); diff --git a/editors/ex/patches/patch-libterm_termcap_c b/editors/ex/patches/patch-libterm_termcap_c new file mode 100644 index 00000000000..5cc467454d7 --- /dev/null +++ b/editors/ex/patches/patch-libterm_termcap_c @@ -0,0 +1,77 @@ +$NetBSD: patch-libterm_termcap_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare local functions static +- avoid implicit int +- use const for string constants + +--- libterm/termcap.c.orig 2004-01-03 14:17:30.000000000 +0000 ++++ libterm/termcap.c +@@ -93,6 +93,7 @@ int tgetent(); + * against each such name. The normal : terminator after the last + * name (before the first field) stops us. + */ ++static int + tnamatch(np) + char *np; + { +@@ -121,6 +122,7 @@ tnamatch(np) + * entries to say "like an HP2621 but doesn't turn on the labels". + * Note that this works because of the left to right scan. + */ ++static int + tnchktc() + { + register char *p, *q; +@@ -179,8 +181,10 @@ tnchktc() + * from the termcap file. Parse is very rudimentary; + * we just notice escaped newlines. + */ ++int + tgetent(bp, name) +- char *bp, *name; ++ char *bp; ++ const char *name; + { + register char *cp; + register int c; +@@ -281,8 +285,9 @@ tskip(bp) + * a # character. If the option is not found we return -1. + * Note that we handle octal numbers beginning with 0. + */ ++int + tgetnum(id) +- char *id; ++ const char *id; + { + register int i, base; + register char *bp = tbuf; +@@ -314,8 +319,9 @@ tgetnum(id) + * of the buffer. Return 1 if we find the option, or 0 if it is + * not given. + */ ++int + tgetflag(id) +- char *id; ++ const char *id; + { + register char *bp = tbuf; + +@@ -342,7 +348,8 @@ tgetflag(id) + */ + char * + tgetstr(id, area) +- char *id, **area; ++ const char *id; ++ char **area; + { + register char *bp = tbuf; + +@@ -372,7 +379,7 @@ tdecode(str, area) + { + register char *cp; + register int c; +- register char *dp; ++ register const char *dp; + int i; + + cp = *area; diff --git a/editors/ex/patches/patch-libterm_tgoto_c b/editors/ex/patches/patch-libterm_tgoto_c new file mode 100644 index 00000000000..bd8bffbc045 --- /dev/null +++ b/editors/ex/patches/patch-libterm_tgoto_c @@ -0,0 +1,25 @@ +$NetBSD: patch-libterm_tgoto_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- use const for string constants +- silence warnings about assignments in conditionals + +--- libterm/tgoto.c~ 2002-02-04 01:30:04.000000000 +0000 ++++ libterm/tgoto.c +@@ -83,7 +83,7 @@ char *BC; + * + * all other characters are ``self-inserting''. + */ +-char * ++const char * + tgoto(CM, destcol, destline) + char *CM; + int destcol, destline; +@@ -104,7 +104,7 @@ toohard: + return ("OOPS"); + } + added[0] = 0; +- while (c = *cp++) { ++ while ((c = *cp++) != 0) { + if (c != '%') { + *dp++ = c; + continue; diff --git a/editors/ex/patches/patch-libterm_tputs_c b/editors/ex/patches/patch-libterm_tputs_c new file mode 100644 index 00000000000..e271e59584a --- /dev/null +++ b/editors/ex/patches/patch-libterm_tputs_c @@ -0,0 +1,32 @@ +$NetBSD: patch-libterm_tputs_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- declare void functions void +- use const for string constants +- fix up function pointer casting mess +- silence signed/unsigned compiler warning + +--- libterm/tputs.c.orig 2002-02-04 03:15:46.000000000 +0000 ++++ libterm/tputs.c +@@ -71,10 +71,11 @@ char PC; + * The number of affected lines is affcnt, and the routine + * used to output one character is outc. + */ ++void + tputs(cp, affcnt, outc) +- register char *cp; ++ register const char *cp; + int affcnt; +- int (*outc)(); ++ int (*outc)(int); + { + register int i = 0; + register int mspc10; +@@ -121,7 +122,7 @@ tputs(cp, affcnt, outc) + */ + if (i == 0) + return; +- if (ospeed <= 0 || ospeed >= (sizeof tmspc10 / sizeof tmspc10[0])) ++ if (ospeed <= 0 || ospeed >= (int)(sizeof tmspc10 / sizeof tmspc10[0])) + return; + + /* diff --git a/editors/ex/patches/patch-printf_c b/editors/ex/patches/patch-printf_c new file mode 100644 index 00000000000..bbddb4b5035 --- /dev/null +++ b/editors/ex/patches/patch-printf_c @@ -0,0 +1,205 @@ +$NetBSD: patch-printf_c,v 1.1 2012/12/28 03:03:09 dholland Exp $ + +- use standard headers + (this is supposed to substitute for libc's printf, so it *must* + match stdio.h) +- use own headers +- declare local functions static +- avoid implicit int +- return values from non-void functions +- use const for string constants +- remove/replace code that intentionally uses signed overflow + +--- printf.c.orig 2012-12-27 21:57:52.000000000 +0000 ++++ printf.c +@@ -82,6 +82,8 @@ static char sccsid[] = "@(#)printf.c 1.1 + /* The pwb version this is based on */ + /* from printf.c:2.2 6/5/79 */ + ++#include <stdio.h> ++ + #ifndef __STDC__ + #include "varargs.h" + #else +@@ -95,6 +97,8 @@ extern nl_catd catd; + #define catgets(a, b, c, d) (d) + #endif + ++#include "ex.h" ++#include "ex_proto.h" + #include "config.h" + + /* +@@ -115,15 +119,13 @@ extern nl_catd catd; + + static int width, sign, fill; + +-extern int putchar __P((int)); +- +-char *p_dconv __P((long, char *)); +-int p_emit __P((char *, char *)); ++static void p_emit __P((const char *, const char *)); + + #ifdef __STDC__ + int vprintf(const char *fmt, va_list ap); + #endif + ++int + #ifndef __STDC__ + printf(va_alist) + va_dcl +@@ -155,14 +157,17 @@ printf(const char *fmt, ...) + return ret; + } + ++int + vprintf(const char *fmt, va_list ap) + { + char fcode; + int prec; + int length,mask1,nbits,n; + long int mask2, num; +- register char *bptr; +- char *ptr; ++ unsigned long unum; ++ register const char *bptr; ++ register char *vbptr; ++ const char *ptr; + char buf[134]; + #endif /* __STDC__ */ + +@@ -171,7 +176,7 @@ vprintf(const char *fmt, va_list ap) + while ((fcode = *fmt++)!='%') { + /* ordinary (non-%) character */ + if (fcode=='\0') +- return; ++ return 0; + putchar(fcode); + } + /* length modifier: -1 for h, 1 for l, 0 for none */ +@@ -288,18 +293,18 @@ vprintf(const char *fmt, va_list ap) + nbits = 4; + } + n = (num!=0); +- bptr = buf + MAXOCT + 3; ++ vbptr = buf + MAXOCT + 3; + /* shift and mask for speed */ + do + if (((int) num & mask1) < 10) +- *--bptr = ((int) num & mask1) + 060; ++ *--vbptr = ((int) num & mask1) + 060; + else +- *--bptr = ((int) num & mask1) + 0127; +- while (num = (num >> nbits) & mask2); ++ *--vbptr = ((int) num & mask1) + 0127; ++ while ((num = (num >> nbits) & mask2) != 0); + + if (fcode=='o') { + if (n) +- *--bptr = '0'; ++ *--vbptr = '0'; + } + else + if (!sign && fill <= 0) { +@@ -308,9 +313,10 @@ vprintf(const char *fmt, va_list ap) + width -= 2; + } + else { +- *--bptr = fcode; +- *--bptr = '0'; ++ *--vbptr = fcode; ++ *--vbptr = '0'; + } ++ bptr = vbptr; + ptr = buf + MAXOCT + 3; + break; + case 'D': +@@ -331,14 +337,20 @@ vprintf(const char *fmt, va_list ap) + else + num = (long) n; + } +- if (n = (fcode != 'u' && num < 0)) +- num = -num; ++ if ((n = (fcode != 'u' && num < 0)) != 0) { ++ /* avoid overflow on -LONG_MAX */ ++ unum = ((unsigned long)-(num + 1)) + 1; ++ } ++ else { ++ unum = (unsigned long) num; ++ } + /* now convert to digits */ +- bptr = p_dconv(num, buf); ++ vbptr = p_dconv(unum, buf); + if (n) +- *--bptr = '-'; ++ *--vbptr = '-'; + if (fill == 0) + fill = -1; ++ bptr = vbptr; + ptr = buf + MAXDIGS + 1; + break; + default: +@@ -369,13 +381,15 @@ vprintf(const char *fmt, va_list ap) + */ + char * + p_dconv(value, buffer) +- long value; ++ unsigned long value; + char *buffer; + { + register char *bp; +- register int svalue; ++ register unsigned int svalue; ++#if 0 + int n; + long lval; ++#endif + + bp = buffer; + +@@ -386,6 +400,7 @@ p_dconv(value, buffer) + return(bp); + } + ++#if 0 /* original code, undefined behavior */ + /* develop the leading digit of the value in "n" */ + n = 0; + while (value < 0) { +@@ -399,6 +414,7 @@ p_dconv(value, buffer) + + /* stash it in buffer[1] to allow for a sign */ + bp[1] = n + '0'; ++#endif + /* + * Now develop the rest of the digits. Since speed counts here, + * we do it in two loops. The first gets "value" down until it +@@ -417,13 +433,15 @@ p_dconv(value, buffer) + *--bp = (svalue % 10) + '0'; + svalue /= 10; + } +- ++ ++#if 0 + /* fill in intermediate zeroes if needed */ + if (buffer[1] != '0') { + while (bp > buffer + 2) + *--bp = '0'; + --bp; + } ++#endif + return(bp); + } + +@@ -439,9 +457,10 @@ p_dconv(value, buffer) + * any padding in right-justification (to avoid printing "-3" as + * "000-3" where "-0003" was intended). + */ ++static void + p_emit(s, send) +- register char *s; +- char *send; ++ register const char *s; ++ const char *send; + { + char cfill; + register int alen; |