[前][次][番号順一覧][スレッド一覧]

ruby-changes:45784

From: naruse <ko1@a...>
Date: Sun, 12 Mar 2017 02:06:22 +0900 (JST)
Subject: [ruby-changes:45784] naruse:r57857 (ruby_2_4): merge revision(s) 57315:

naruse	2017-03-12 02:06:18 +0900 (Sun, 12 Mar 2017)

  New Revision: 57857

  https://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=57857

  Log:
    merge revision(s) 57315:
    
    vm_dump.c: postscript_dump
    
    * vm_dump.c (postscript_dump): mention crash report log twice
      because important.

  Modified directories:
    branches/ruby_2_4/
  Modified files:
    branches/ruby_2_4/version.h
    branches/ruby_2_4/vm_dump.c
Index: ruby_2_4/version.h
===================================================================
--- ruby_2_4/version.h	(revision 57856)
+++ ruby_2_4/version.h	(revision 57857)
@@ -1,6 +1,6 @@ https://github.com/ruby/ruby/blob/trunk/ruby_2_4/version.h#L1
 #define RUBY_VERSION "2.4.0"
 #define RUBY_RELEASE_DATE "2017-03-12"
-#define RUBY_PATCHLEVEL 22
+#define RUBY_PATCHLEVEL 23
 
 #define RUBY_RELEASE_YEAR 2017
 #define RUBY_RELEASE_MONTH 3
Index: ruby_2_4/vm_dump.c
===================================================================
--- ruby_2_4/vm_dump.c	(revision 57856)
+++ ruby_2_4/vm_dump.c	(revision 57857)
@@ -922,6 +922,33 @@ rb_dump_machine_register(const ucontext_ https://github.com/ruby/ruby/blob/trunk/ruby_2_4/vm_dump.c#L922
 # define rb_dump_machine_register(ctx) ((void)0)
 #endif /* HAVE_PRINT_MACHINE_REGISTERS */
 
+FUNC_MINIMIZED(static void bug_important_message(FILE *out, const char *const msg, size_t len));
+
+static void
+bug_important_message(FILE *out, const char *const msg, size_t len)
+{
+    const char *const endmsg = msg + len;
+    const char *p = msg;
+
+    if (!len) return;
+    if (isatty(fileno(out))) {
+	static const char red[] = "\033[;31;1;7m";
+	static const char green[] = "\033[;32;7m";
+	static const char reset[] = "\033[m";
+	const char *e = strchr(p, '\n');
+	const int w = (int)(e - p);
+	do {
+	    int i = (int)(e - p);
+	    fputs(*p == ' ' ? green : red, out);
+	    fwrite(p, 1, e - p, out);
+	    for (; i < w; ++i) fputc(' ', out);
+	    fputs(reset, out);
+	    fputc('\n', out);
+	} while ((p = e + 1) < endmsg && (e = strchr(p, '\n')) != 0 && e > p + 1);
+    }
+    fwrite(p, 1, endmsg - p, out);
+}
+
 static void
 preface_dump(void)
 {
@@ -937,26 +964,28 @@ preface_dump(void) https://github.com/ruby/ruby/blob/trunk/ruby_2_4/vm_dump.c#L964
 	"   for more details.\n"
 	"Don't forget to include the above Crash Report log file in bug reports.\n"
 	"\n";
-    const char *const endmsg = msg + sizeof(msg) - 1;
-    const char *p = msg;
-#define RED "\033[;31;1;7m"
-#define GREEN "\033[;32;7m"
-#define RESET "\033[m"
+    const size_t msglen = sizeof(msg) - 1;
+#else
+    const char *msg = NULL;
+    const size_t msglen = 0;
+#endif
+    bug_important_message(stderr, msg, msglen);
+}
 
-    if (isatty(fileno(stderr))) {
-	const char *e = strchr(p, '\n');
-	const int w = (int)(e - p);
-	do {
-	    int i = (int)(e - p);
-	    fputs(*p == ' ' ? GREEN : RED, stderr);
-	    fwrite(p, 1, e - p, stderr);
-	    for (; i < w; ++i) fputc(' ', stderr);
-	    fputs(RESET, stderr);
-	    fputc('\n', stderr);
-	} while ((p = e + 1) < endmsg && (e = strchr(p, '\n')) != 0 && e > p + 1);
-    }
-    fwrite(p, 1, endmsg - p, stderr);
+static void
+postscript_dump(void)
+{
+#if defined __APPLE__
+    static const char msg[] = ""
+	"[IMPORTANT]\n"
+	"Don't forget to include the Crash Report log file in bug reports.\n"
+	"\n";
+    const size_t msglen = sizeof(msg) - 1;
+#else
+    const char *msg = NULL;
+    const size_t msglen = 0;
 #endif
+    bug_important_message(stderr, msg, msglen);
 }
 
 void
@@ -1080,4 +1109,6 @@ rb_vm_bugreport(const void *ctx) https://github.com/ruby/ruby/blob/trunk/ruby_2_4/vm_dump.c#L1109
 	}
 #endif /* __FreeBSD__ */
     }
+
+    postscript_dump();
 }

Property changes on: ruby_2_4
___________________________________________________________________
Modified: svn:mergeinfo
   Merged /trunk:r57315


--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]