summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@cvs.openbsd.org>2010-05-08 18:58:28 +0000
committerNicholas Marriott <nicm@cvs.openbsd.org>2010-05-08 18:58:28 +0000
commitdf39f8d38fd4cab767e86d7a18b3a6804ab90656 (patch)
treee1903904bf06e9bee8c5ae17aeba8a4fb1f1520a
parentd978e8ed95d31fa987f1211c6c0f1df78b60f5c4 (diff)
Fixes to build with gcc4, mostly function prototypes and missing
headers. ok robert kettenis jsg
-rw-r--r--gnu/usr.bin/groff/libbib/map.c1
-rw-r--r--gnu/usr.bin/groff/pfbtops/pfbtops.c1
-rw-r--r--gnu/usr.bin/groff/psbb/psbb.c1
-rw-r--r--gnu/usr.bin/groff/refer/refer.cc3
-rw-r--r--gnu/usr.bin/groff/troff/input.cc25
-rw-r--r--gnu/usr.bin/groff/troff/node.cc3
6 files changed, 28 insertions, 6 deletions
diff --git a/gnu/usr.bin/groff/libbib/map.c b/gnu/usr.bin/groff/libbib/map.c
index 3632a11ef48..e8d9c47dbb2 100644
--- a/gnu/usr.bin/groff/libbib/map.c
+++ b/gnu/usr.bin/groff/libbib/map.c
@@ -21,6 +21,7 @@ Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
#include <sys/types.h>
#include <sys/mman.h>
+#include <stdlib.h>
/* The Net-2 man pages says that a MAP_FILE flag is required. */
#ifndef MAP_FILE
diff --git a/gnu/usr.bin/groff/pfbtops/pfbtops.c b/gnu/usr.bin/groff/pfbtops/pfbtops.c
index fb370ab79df..54923abee43 100644
--- a/gnu/usr.bin/groff/pfbtops/pfbtops.c
+++ b/gnu/usr.bin/groff/pfbtops/pfbtops.c
@@ -1,6 +1,7 @@
/* This translates ps fonts in .pfb format to ASCII ps files. */
#include <stdio.h>
+#include <stdlib.h>
/* Binary bytes per output line. */
#define BYTES_PER_LINE (64/2)
diff --git a/gnu/usr.bin/groff/psbb/psbb.c b/gnu/usr.bin/groff/psbb/psbb.c
index 43de191d34f..973e7b00d65 100644
--- a/gnu/usr.bin/groff/psbb/psbb.c
+++ b/gnu/usr.bin/groff/psbb/psbb.c
@@ -18,6 +18,7 @@ with groff; see the file COPYING. If not, write to the Free Software
Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
#include <stdio.h>
+#include <stdlib.h>
#include <string.h>
#include <errno.h>
#ifndef errno
diff --git a/gnu/usr.bin/groff/refer/refer.cc b/gnu/usr.bin/groff/refer/refer.cc
index 08de6703a62..ea1dd5bdb8c 100644
--- a/gnu/usr.bin/groff/refer/refer.cc
+++ b/gnu/usr.bin/groff/refer/refer.cc
@@ -513,7 +513,8 @@ static void do_file(const char *filename)
if ((flags & FORCE_LEFT_BRACKET) || !have_text)
pending_line += PRE_LABEL_MARKER;
pending_line += pre;
- pending_line += LABEL_MARKER + lt;
+ char lm = LABEL_MARKER + (int)lt;
+ pending_line += lm;
pending_line += post;
if ((flags & FORCE_RIGHT_BRACKET) || !have_text)
pending_line += POST_LABEL_MARKER;
diff --git a/gnu/usr.bin/groff/troff/input.cc b/gnu/usr.bin/groff/troff/input.cc
index 2f942c9ca29..7b2db2a96e5 100644
--- a/gnu/usr.bin/groff/troff/input.cc
+++ b/gnu/usr.bin/groff/troff/input.cc
@@ -75,6 +75,9 @@ void vjustify();
#endif /* COLUMN */
void transparent();
void transparent_file();
+void process_input_stack();
+void end_diversions();
+void title();
const char *program_name = 0;
token tok;
@@ -5331,6 +5334,13 @@ struct string_list {
string_list(const char *ss) : s(ss), next(0) {}
};
+static void prepend_string(const char *s, string_list **p)
+{
+ string_list *l = new string_list(s);
+ l->next = *p;
+ *p = l;
+}
+
static void add_string(const char *s, string_list **p)
{
while (*p)
@@ -5341,8 +5351,8 @@ static void add_string(const char *s, string_list **p)
void usage(const char *prog)
{
errprint(
-"usage: %1 -abivzCER -wname -Wname -dcstring -mname -nN -olist -rcN\n"
-" -Tname -Fdir -Mdir [ files ]\n",
+"usage: %1 -abivzCERU -wname -Wname -dcs -ffam -mname -nnum -olist\n"
+" -rcn -Tname -Fdir -Mdir [files...]\n",
prog);
exit(USAGE_EXIT_CODE);
}
@@ -5360,11 +5370,12 @@ int main(int argc, char **argv)
int tflag = 0;
int fflag = 0;
int nflag = 0;
+ int safer_flag = 1; // safer by default
int no_rc = 0; // don't process troffrc
int next_page_number;
opterr = 0;
hresolution = vresolution = 1;
- while ((c = getopt(argc, argv, "abivw:W:zCEf:m:n:o:r:d:F:M:T:tqs:R"))
+ while ((c = getopt(argc, argv, "abivw:W:zCEf:m:n:o:r:d:F:M:T:tqs:RU"))
!= EOF)
switch(c) {
case 'v':
@@ -5444,6 +5455,9 @@ int main(int argc, char **argv)
case 't':
// silently ignore these
break;
+ case 'U':
+ safer_flag = 0; // unsafe behaviour
+ break;
case '?':
usage(argv[0]);
default:
@@ -5501,6 +5515,8 @@ int main(int argc, char **argv)
}
if (!no_rc)
process_startup_file();
+ if (safer_flag)
+ prepend_string("safer", &macros);
while (macros) {
process_macro_file(macros->s);
string_list *tem = macros;
@@ -5727,7 +5743,8 @@ static node *read_draw_node()
maxpoints *= 2;
a_delete oldpoint;
}
- if (!get_hunits(&point[i].h, 'm')) {
+ if (!get_hunits(&point[i].h,
+ type == 'f' || type == 't' ? 'u' : 'm')) {
err = 1;
break;
}
diff --git a/gnu/usr.bin/groff/troff/node.cc b/gnu/usr.bin/groff/troff/node.cc
index b3dceecbc32..8c28f05bf7f 100644
--- a/gnu/usr.bin/groff/troff/node.cc
+++ b/gnu/usr.bin/groff/troff/node.cc
@@ -168,6 +168,7 @@ public:
hunits get_subscript_correction(charinfo *);
friend tfont *make_tfont(tfont_spec &);
};
+tfont *make_tfont(tfont_spec &);
inline int env_definite_font(environment *env)
{
@@ -1491,7 +1492,7 @@ void glyph_node::operator delete(void *p)
void ligature_node::operator delete(void *p)
{
- delete p;
+ delete[] (char *)p;
}
glyph_node::glyph_node(charinfo *c, tfont *t, node *x)