Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/external/gpl3/gcc/dist/gcc merge debug/file prefix/merge stu...



details:   https://anonhg.NetBSD.org/src/rev/ab6a185e54a0
branches:  trunk
changeset: 965784:ab6a185e54a0
user:      mrg <mrg%NetBSD.org@localhost>
date:      Tue Oct 01 21:17:27 2019 +0000

description:
merge debug/file prefix/merge stuff with upstream, which has gained
a lot of the same features.  builds, but may not actually run right.
adjust for add_path()'s SYSTEM -> INC_SYSTEM.

diffstat:

 external/gpl3/gcc/dist/gcc/Makefile.in       |    1 +
 external/gpl3/gcc/dist/gcc/c-family/c-opts.c |    2 +-
 external/gpl3/gcc/dist/gcc/file-prefix-map.c |  109 +++++++++++++++++
 external/gpl3/gcc/dist/gcc/final.c           |  171 ---------------------------
 4 files changed, 111 insertions(+), 172 deletions(-)

diffs (truncated from 327 to 300 lines):

diff -r cc3d801cd660 -r ab6a185e54a0 external/gpl3/gcc/dist/gcc/Makefile.in
--- a/external/gpl3/gcc/dist/gcc/Makefile.in    Tue Oct 01 21:13:43 2019 +0000
+++ b/external/gpl3/gcc/dist/gcc/Makefile.in    Tue Oct 01 21:17:27 2019 +0000
@@ -1955,6 +1955,7 @@
 selftest: s-selftest-c
 
 # C selftests
+C_SELFTEST_DEPS = 
 s-selftest-c: $(C_SELFTEST_DEPS)
        @echo "NOT REBUILDING $@"
 NetBSD_DISABLED_s-selftest:
diff -r cc3d801cd660 -r ab6a185e54a0 external/gpl3/gcc/dist/gcc/c-family/c-opts.c
--- a/external/gpl3/gcc/dist/gcc/c-family/c-opts.c      Tue Oct 01 21:13:43 2019 +0000
+++ b/external/gpl3/gcc/dist/gcc/c-family/c-opts.c      Tue Oct 01 21:17:27 2019 +0000
@@ -305,7 +305,7 @@
       break;
 
     case OPT_cxx_isystem:
-      add_path (xstrdup (arg), SYSTEM, 1, true);
+      add_path (xstrdup (arg), INC_SYSTEM, 1, true);
       break;
 
     case OPT_D:
diff -r cc3d801cd660 -r ab6a185e54a0 external/gpl3/gcc/dist/gcc/file-prefix-map.c
--- a/external/gpl3/gcc/dist/gcc/file-prefix-map.c      Tue Oct 01 21:13:43 2019 +0000
+++ b/external/gpl3/gcc/dist/gcc/file-prefix-map.c      Tue Oct 01 21:17:27 2019 +0000
@@ -123,6 +123,7 @@
   return remap_filename (macro_prefix_maps, filename);
 }
 
+#ifndef __NetBSD__
 /* Remap using -fdebug-prefix-map.  Return the GC-allocated new name
    corresponding to FILENAME or FILENAME if no remapping was performed.  */
 const char *
@@ -130,3 +131,111 @@
 {
   return remap_filename (debug_prefix_maps, filename);
 }
+#else
+
+/* Perform user-specified mapping of debug filename prefixes.  Return
+   the new name corresponding to FILENAME.  */
+
+static const char *
+remap_debug_prefix_filename (const char *filename)
+{
+  file_prefix_map *map;
+  char *s;
+  const char *name;
+  size_t name_len;
+
+  for (map = debug_prefix_maps; map; map = map->next)
+    if (filename_ncmp (filename, map->old_prefix, map->old_len) == 0)
+      break;
+  if (!map)
+    return filename;
+  name = filename + map->old_len;
+  name_len = strlen (name) + 1;
+  s = (char *) alloca (name_len + map->new_len);
+  memcpy (s, map->new_prefix, map->new_len);
+  memcpy (s + map->new_len, name, name_len);
+  return ggc_strdup (s);
+}
+
+#include <regex.h>
+
+typedef struct debug_regex_map
+{
+  regex_t re;
+  const char *sub;
+  struct debug_regex_map *next;
+} debug_regex_map;
+
+/* Linked list of such structures.  */
+debug_regex_map *debug_regex_maps;
+
+
+/* Record a debug file regex mapping.  ARG is the argument to
+   -fdebug-regex-map and must be of the form OLD=NEW.  */
+
+void
+add_debug_regex_map (const char *arg)
+{
+  debug_regex_map *map;
+  const char *p;
+  char *old;
+  char buf[1024];
+  regex_t re;
+  int e;
+
+  p = strchr (arg, '=');
+  if (!p)
+    {
+      error ("invalid argument %qs to -fdebug-regex-map", arg);
+      return;
+    }
+  
+  old = xstrndup (arg, p - arg);
+  if ((e = regcomp(&re, old, REG_EXTENDED)) != 0)
+    {
+      regerror(e, &re, buf, sizeof(buf));
+      warning (0, "regular expression compilation for %qs in argument to "
+              "-fdebug-regex-map failed: %qs", old, buf);
+      free(old);
+      return;
+    }
+  free(old);
+
+  map = XNEW (debug_regex_map);
+  map->re = re;
+  p++;
+  map->sub = xstrdup (p);
+  map->next = debug_regex_maps;
+  debug_regex_maps = map;
+}
+
+extern "C" ssize_t regasub(char **, const char *,
+  const regmatch_t *rm, const char *);
+
+/* Perform user-specified mapping of debug filename regular expressions.  Return
+   the new name corresponding to FILENAME.  */
+
+static const char *
+remap_debug_regex_filename (const char *filename)
+{
+  debug_regex_map *map;
+  char *s;
+  regmatch_t rm[10];
+
+  for (map = debug_regex_maps; map; map = map->next)
+    if (regexec (&map->re, filename, 10, rm, 0) == 0
+       && regasub (&s, map->sub, rm, filename) >= 0)
+      {
+        const char *name = ggc_strdup(s);
+        free(s);
+        return name;
+      }
+  return filename;
+}
+
+const char *
+remap_debug_filename (const char *filename)
+{
+   return remap_debug_regex_filename (remap_debug_prefix_filename (filename));
+}
+#endif
diff -r cc3d801cd660 -r ab6a185e54a0 external/gpl3/gcc/dist/gcc/final.c
--- a/external/gpl3/gcc/dist/gcc/final.c        Tue Oct 01 21:13:43 2019 +0000
+++ b/external/gpl3/gcc/dist/gcc/final.c        Tue Oct 01 21:17:27 2019 +0000
@@ -1508,177 +1508,6 @@
   return count;
 }
 
-/* ??? This is probably the wrong place for these.  */
-/* Structure recording the mapping from source file and directory
-   names at compile time to those to be embedded in debug
-   information.  */
-struct debug_prefix_map
-{
-  const char *old_prefix;
-  const char *new_prefix;
-  size_t old_len;
-  size_t new_len;
-  struct debug_prefix_map *next;
-};
-
-/* Linked list of such structures.  */
-static debug_prefix_map *debug_prefix_maps;
-
-
-/* Record a debug file prefix mapping.  ARG is the argument to
-   -fdebug-prefix-map and must be of the form OLD=NEW.  */
-
-void
-add_debug_prefix_map (const char *arg)
-{
-  debug_prefix_map *map;
-  const char *p;
-  char *env;
-  const char *old;
-  size_t oldlen;
-
-  p = strchr (arg, '=');
-  if (!p)
-    {
-      error ("invalid argument %qs to -fdebug-prefix-map", arg);
-      return;
-    }
-  if (*arg == '$')
-    {
-      env = xstrndup (arg+1, p - (arg+1));
-      old = getenv(env);
-      if (!old)
-       {
-         warning (0, "environment variable %qs not set in argument to "
-                  "-fdebug-prefix-map", env);
-         free(env);
-         return;
-       }
-      oldlen = strlen(old);
-      free(env);
-    }
-  else
-    {
-      old = xstrndup (arg, p - arg);
-      oldlen = p - arg;
-    }
-
-  map = XNEW (debug_prefix_map);
-  map->old_prefix = old;
-  map->old_len = oldlen;
-  p++;
-  map->new_prefix = xstrdup (p);
-  map->new_len = strlen (p);
-  map->next = debug_prefix_maps;
-  debug_prefix_maps = map;
-}
-
-/* Perform user-specified mapping of debug filename prefixes.  Return
-   the new name corresponding to FILENAME.  */
-
-static const char *
-remap_debug_prefix_filename (const char *filename)
-{
-  debug_prefix_map *map;
-  char *s;
-  const char *name;
-  size_t name_len;
-
-  for (map = debug_prefix_maps; map; map = map->next)
-    if (filename_ncmp (filename, map->old_prefix, map->old_len) == 0)
-      break;
-  if (!map)
-    return filename;
-  name = filename + map->old_len;
-  name_len = strlen (name) + 1;
-  s = (char *) alloca (name_len + map->new_len);
-  memcpy (s, map->new_prefix, map->new_len);
-  memcpy (s + map->new_len, name, name_len);
-  return ggc_strdup (s);
-}
-
-#include <regex.h>
-
-typedef struct debug_regex_map
-{
-  regex_t re;
-  const char *sub;
-  struct debug_regex_map *next;
-} debug_regex_map;
-
-/* Linked list of such structures.  */
-debug_regex_map *debug_regex_maps;
-
-
-/* Record a debug file regex mapping.  ARG is the argument to
-   -fdebug-regex-map and must be of the form OLD=NEW.  */
-
-void
-add_debug_regex_map (const char *arg)
-{
-  debug_regex_map *map;
-  const char *p;
-  char *old;
-  char buf[1024];
-  regex_t re;
-  int e;
-
-  p = strchr (arg, '=');
-  if (!p)
-    {
-      error ("invalid argument %qs to -fdebug-regex-map", arg);
-      return;
-    }
-  
-  old = xstrndup (arg, p - arg);
-  if ((e = regcomp(&re, old, REG_EXTENDED)) != 0)
-    {
-      regerror(e, &re, buf, sizeof(buf));
-      warning (0, "regular expression compilation for %qs in argument to "
-              "-fdebug-regex-map failed: %qs", old, buf);
-      free(old);
-      return;
-    }
-  free(old);
-
-  map = XNEW (debug_regex_map);
-  map->re = re;
-  p++;
-  map->sub = xstrdup (p);
-  map->next = debug_regex_maps;
-  debug_regex_maps = map;
-}
-
-extern "C" ssize_t regasub(char **, const char *,
-  const regmatch_t *rm, const char *);
-
-/* Perform user-specified mapping of debug filename regular expressions.  Return
-   the new name corresponding to FILENAME.  */
-



Home | Main Index | Thread Index | Old Index