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/