Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.bin/config Revert "Accept only relative paths ...". Thi...
details: https://anonhg.NetBSD.org/src/rev/f7eb4bf959fa
branches: trunk
changeset: 340305:f7eb4bf959fa
user: uebayasi <uebayasi%NetBSD.org@localhost>
date: Sun Aug 30 21:58:19 2015 +0000
description:
Revert "Accept only relative paths ...". This will be redone in much better,
stricter way.
diffstat:
usr.bin/config/defs.h | 4 +-
usr.bin/config/mkmakefile.c | 116 +++++++++++++++++++++++++++++++++----------
2 files changed, 91 insertions(+), 29 deletions(-)
diffs (212 lines):
diff -r fc0836f102de -r f7eb4bf959fa usr.bin/config/defs.h
--- a/usr.bin/config/defs.h Sun Aug 30 21:16:10 2015 +0000
+++ b/usr.bin/config/defs.h Sun Aug 30 21:58:19 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: defs.h,v 1.72 2015/08/30 05:12:00 uebayasi Exp $ */
+/* $NetBSD: defs.h,v 1.73 2015/08/30 21:58:19 uebayasi Exp $ */
/*
* Copyright (c) 1992, 1993
@@ -107,7 +107,7 @@
* The next two lines define the current version of the config(1) binary,
* and the minimum version of the configuration files it supports.
*/
-#define CONFIG_VERSION 20150832
+#define CONFIG_VERSION 20150833
#define CONFIG_MINVERSION 0
/*
diff -r fc0836f102de -r f7eb4bf959fa usr.bin/config/mkmakefile.c
--- a/usr.bin/config/mkmakefile.c Sun Aug 30 21:16:10 2015 +0000
+++ b/usr.bin/config/mkmakefile.c Sun Aug 30 21:58:19 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: mkmakefile.c,v 1.48 2015/08/30 05:12:00 uebayasi Exp $ */
+/* $NetBSD: mkmakefile.c,v 1.49 2015/08/30 21:58:19 uebayasi Exp $ */
/*
* Copyright (c) 1992, 1993
@@ -45,7 +45,7 @@
#endif
#include <sys/cdefs.h>
-__RCSID("$NetBSD: mkmakefile.c,v 1.48 2015/08/30 05:12:00 uebayasi Exp $");
+__RCSID("$NetBSD: mkmakefile.c,v 1.49 2015/08/30 21:58:19 uebayasi Exp $");
#include <sys/param.h>
#include <ctype.h>
@@ -62,6 +62,12 @@
* Make the Makefile.
*/
+static const char *srcpath(struct files *);
+
+static const char *prefix_prologue(const char *);
+static const char *filetype_prologue(struct filetype *);
+
+
static void emitdefs(FILE *);
static void emitfiles(FILE *, int, int);
@@ -257,6 +263,46 @@
}
}
+/*
+ * Return (possibly in a static buffer) the name of the `source' for a
+ * file. If we have `options source', or if the file is marked `always
+ * source', this is always the path from the `file' line; otherwise we
+ * get the .o from the obj-directory.
+ */
+static const char *
+srcpath(struct files *fi)
+{
+#if 1
+ /* Always have source, don't support object dirs for kernel builds. */
+ return (fi->fi_path);
+#else
+ static char buf[MAXPATHLEN];
+
+ if (have_source || (fi->fi_flags & FI_ALWAYSSRC) != 0)
+ return (fi->fi_path);
+ if (objpath == NULL) {
+ cfgerror("obj-directory not set");
+ return (NULL);
+ }
+ (void)snprintf(buf, sizeof buf, "%s/%s.o", objpath, fi->fi_base);
+ return (buf);
+#endif
+}
+
+static const char *
+filetype_prologue(struct filetype *fit)
+{
+
+ return (*fit->fit_path == '/') ? "" : "$S/";
+}
+
+static const char *
+prefix_prologue(const char *path)
+{
+
+ return (*path == '/') ? "" : "$S/";
+}
+
static void
emitdefs(FILE *fp)
{
@@ -304,17 +350,21 @@
fprintf(fp, "\t%s.o \\\n", fi->fi_base);
}
TAILQ_FOREACH(oi, &allobjects, oi_next) {
- const char *prefix, *sep;
+ const char *prologue, *prefix, *sep;
if ((oi->oi_flags & OI_SEL) == 0)
continue;
- if (oi->oi_prefix != NULL) {
- prefix = oi->oi_prefix;
- sep = "/";
- } else {
- prefix = sep = "";
+ prologue = prefix = sep = "";
+ if (*oi->oi_path != '/') {
+ if (oi->oi_prefix != NULL) {
+ prologue = prefix_prologue(oi->oi_path);
+ prefix = oi->oi_prefix;
+ sep = "/";
+ } else {
+ prologue = filetype_prologue(&oi->oi_fit);
+ }
}
- fprintf(fp, "\t%s%s%s%s \\\n", "$S/", prefix, sep,
+ fprintf(fp, "\t%s%s%s%s \\\n", prologue, prefix, sep,
oi->oi_path);
}
putc('\n', fp);
@@ -448,25 +498,31 @@
emitfiles(FILE *fp, int suffix, int upper_suffix)
{
struct files *fi;
+ const char *fpath;
struct config *cf;
char swapname[100];
fprintf(fp, "%cFILES= \\\n", toupper(suffix));
TAILQ_FOREACH(fi, &allfiles, fi_next) {
- const char *prefix, *sep;
+ const char *prologue, *prefix, *sep;
if ((fi->fi_flags & FI_SEL) == 0)
continue;
+ fpath = srcpath(fi);
if (fi->fi_suffix != suffix && fi->fi_suffix != upper_suffix)
continue;
- if (fi->fi_prefix != NULL) {
- prefix = fi->fi_prefix;
- sep = "/";
- } else {
- prefix = sep = "";
+ prologue = prefix = sep = "";
+ if (*fi->fi_path != '/') {
+ if (fi->fi_prefix != NULL) {
+ prologue = prefix_prologue(fi->fi_prefix);
+ prefix = fi->fi_prefix;
+ sep = "/";
+ } else {
+ prologue = filetype_prologue(&fi->fi_fit);
+ }
}
- fprintf(fp, "\t%s%s%s%s \\\n", "$S/", prefix, sep,
- fi->fi_path);
+ fprintf(fp, "\t%s%s%s%s \\\n",
+ prologue, prefix, sep, fpath);
}
/*
@@ -491,22 +547,28 @@
emitrules(FILE *fp)
{
struct files *fi;
+ const char *fpath;
TAILQ_FOREACH(fi, &allfiles, fi_next) {
- const char *prefix, *sep;
+ const char *prologue, *prefix, *sep;
if ((fi->fi_flags & FI_SEL) == 0)
continue;
if (fi->fi_mkrule == NULL)
continue;
- if (fi->fi_prefix != NULL) {
- prefix = fi->fi_prefix;
- sep = "/";
- } else {
- prefix = sep = "";
- }
- fprintf(fp, "%s.o: %s%s%s%s\n", fi->fi_base, "$S/", prefix,
- sep, fi->fi_path);
+ fpath = srcpath(fi);
+ prologue = prefix = sep = "";
+ if (*fpath != '/') {
+ if (fi->fi_prefix != NULL) {
+ prologue = prefix_prologue(fi->fi_prefix);
+ prefix = fi->fi_prefix;
+ sep = "/";
+ } else {
+ prologue = filetype_prologue(&fi->fi_fit);
+ }
+ }
+ fprintf(fp, "%s.o: %s%s%s%s\n", fi->fi_base,
+ prologue, prefix, sep, fpath);
fprintf(fp, "\t%s\n\n", fi->fi_mkrule);
}
}
@@ -566,7 +628,7 @@
SLIST_FOREACH(pf, &allprefixes, pf_next) {
fprintf(fp, "EXTRA_INCLUDES+=\t-I%s%s\n",
- "$S/", pf->pf_prefix);
+ prefix_prologue(pf->pf_prefix), pf->pf_prefix);
}
}
Home |
Main Index |
Thread Index |
Old Index