summaryrefslogtreecommitdiff
path: root/version.c
diff options
context:
space:
mode:
Diffstat (limited to 'version.c')
-rw-r--r--version.c377
1 files changed, 258 insertions, 119 deletions
diff --git a/version.c b/version.c
index 1f6553030c..5547832652 100644
--- a/version.c
+++ b/version.c
@@ -3,165 +3,304 @@
version.c -
$Author$
- $Date$
created at: Thu Sep 30 20:08:01 JST 1993
- Copyright (C) 1993-2003 Yukihiro Matsumoto
+ Copyright (C) 1993-2007 Yukihiro Matsumoto
**********************************************************************/
-#include "ruby.h"
-#define RUBY_VERSION_C 1
+#include "internal/cmdlineopt.h"
+#include "internal/parse.h"
+#include "internal/gc.h"
+#include "ruby/internal/globals.h"
+#include "ruby/ruby.h"
#include "version.h"
+#include "vm_core.h"
+#include "yjit.h"
#include <stdio.h>
-#define PRINT(type) puts(TOKEN_PASTE(ruby_,type))
-#ifndef rb_str_new_cstr
-#define rb_str_new_cstr(str) rb_str_new(str, strlen(str))
+#ifndef EXIT_SUCCESS
+#define EXIT_SUCCESS 0
#endif
-#define MKSTR(type) rb_obj_freeze(rb_str_new(TOKEN_PASTE(ruby_,type), sizeof(TOKEN_PASTE(ruby_,type))-1))
-#ifndef UNALIGNED
-#ifdef __GNUC__
-#define UNALIGNED __attribute__((aligned(1)))
+
+#ifdef RUBY_REVISION
+# if RUBY_PATCHLEVEL == -1
+# define RUBY_API_VERSION_NAME "master"
+# ifndef RUBY_BRANCH_NAME
+# define RUBY_BRANCH_NAME RUBY_API_VERSION_NAME
+# endif
+# define RUBY_REVISION_STR " "RUBY_BRANCH_NAME" "RUBY_REVISION
+# else
+# define RUBY_REVISION_STR " revision "RUBY_REVISION
+# endif
#else
-#define UNALIGNED
+# define RUBY_REVISION "HEAD"
+# define RUBY_REVISION_STR ""
+#endif
+#ifndef RUBY_API_VERSION_NAME
+# define RUBY_API_VERSION_NAME RUBY_API_VERSION_STR
#endif
+#if !defined RUBY_RELEASE_DATETIME || RUBY_PATCHLEVEL != -1
+# undef RUBY_RELEASE_DATETIME
+# define RUBY_RELEASE_DATETIME RUBY_RELEASE_DATE
#endif
-const int ruby_patchlevel = RUBY_PATCHLEVEL;
-const char ruby_version[] = RUBY_VERSION;
-const char ruby_release_date[] = RUBY_RELEASE_DATE;
-const char ruby_platform[] = RUBY_PLATFORM;
-#ifdef RUBY_DESCRIPTION
-const char ruby_description[] = RUBY_DESCRIPTION;
+#define PRINT(type) puts(ruby_##type)
+#define MKSTR(type) rb_obj_freeze(rb_usascii_str_new_static(ruby_##type, sizeof(ruby_##type)-1))
+#define MKINT(name) INT2FIX(ruby_##name)
+
+#define RUBY_API_VERSION_STR \
+ STRINGIZE(RUBY_API_VERSION_MAJOR) "." \
+ STRINGIZE(RUBY_API_VERSION_MINOR)
+const int ruby_api_version[] = {
+ RUBY_API_VERSION_MAJOR,
+ RUBY_API_VERSION_MINOR,
+ RUBY_API_VERSION_TEENY,
+};
+#define RUBY_VERSION \
+ STRINGIZE(RUBY_VERSION_MAJOR) "." \
+ STRINGIZE(RUBY_VERSION_MINOR) "." \
+ STRINGIZE(RUBY_VERSION_TEENY) ""
+#ifndef RUBY_FULL_REVISION
+# define RUBY_FULL_REVISION RUBY_REVISION
+#endif
+#ifdef YJIT_SUPPORT
+#define YJIT_DESCRIPTION " +YJIT " STRINGIZE(YJIT_SUPPORT)
#else
-const struct {
- char ruby[sizeof("ruby ")-1];
- char version[sizeof(RUBY_VERSION)-1];
- char patchlevel[sizeof(RUBY_PATCHLEVEL_STR)-1];
- char pad1[2];
- char release_date[sizeof(RUBY_RELEASE_DATE)-1];
-#if RUBY_REVISION
- char revision[sizeof(RUBY_REVISION_STR)-1];
+#define YJIT_DESCRIPTION " +YJIT"
#endif
- char pad2[3];
- char platform[sizeof(RUBY_PLATFORM)-1];
- char pad3[2];
-} ruby_description[1] UNALIGNED = {
- {
- "ruby ", RUBY_VERSION, RUBY_PATCHLEVEL_STR,
- " (", RUBY_RELEASE_DATE,
-#if RUBY_REVISION
- RUBY_REVISION_STR,
+#ifdef ZJIT_SUPPORT
+#define ZJIT_DESCRIPTION " +ZJIT " STRINGIZE(ZJIT_SUPPORT)
+#else
+#define ZJIT_DESCRIPTION " +ZJIT"
#endif
- ") [",
- RUBY_PLATFORM, "]"
- }
-};
-#define ruby_description (*(const char (*)[sizeof(ruby_description)])ruby_description)
+#if USE_MODULAR_GC
+#define GC_DESCRIPTION " +GC"
+#else
+#define GC_DESCRIPTION ""
#endif
+const char ruby_version[] = RUBY_VERSION;
+const char ruby_revision[] = RUBY_FULL_REVISION;
+const char ruby_release_date[] = RUBY_RELEASE_DATE;
+const char ruby_platform[] = RUBY_PLATFORM;
+const int ruby_patchlevel = RUBY_PATCHLEVEL;
+const char ruby_api_version_name[] = RUBY_API_VERSION_NAME;
+const char ruby_description[] =
+ "ruby " RUBY_VERSION RUBY_PATCHLEVEL_STR " "
+ "(" RUBY_RELEASE_DATETIME RUBY_REVISION_STR ") "
+ "[" RUBY_PLATFORM "]";
+static const int ruby_description_opt_point =
+ (int)(sizeof(ruby_description) - sizeof(" [" RUBY_PLATFORM "]"));
-#ifdef RUBY_COPYRIGHT
-const char ruby_copyright[] = RUBY_COPYRIGHT;
-#else
-const struct {
- char ruby[21];
- char birth[4];
- char pad1[1];
- char release[sizeof(STRINGIZE(RUBY_RELEASE_YEAR))-1];
- char pad2[1];
- char author[sizeof(RUBY_AUTHOR)];
-} ruby_copyright[1] UNALIGNED = {
- {
- "ruby - Copyright (C) ",
- STRINGIZE(RUBY_BIRTH_YEAR), "-", STRINGIZE(RUBY_RELEASE_YEAR),
- " ", RUBY_AUTHOR
+const char ruby_copyright[] = "ruby - Copyright (C) "
+ RUBY_BIRTH_YEAR_STR "-" RUBY_RELEASE_YEAR_STR " "
+ RUBY_AUTHOR;
+const char ruby_engine[] = "ruby";
+
+// Might change after initialization
+const char *rb_dynamic_description = ruby_description;
+
+static inline void
+define_ruby_const(VALUE mod, const char *name, VALUE value, bool toplevel)
+{
+ if (toplevel) {
+ rb_define_global_const(name, value);
+ name += rb_strlen_lit("RUBY_");
}
-};
-#define ruby_copyright (*(const char (*)[sizeof(ruby_copyright[0])])ruby_copyright)
-#endif
+ rb_define_const(mod, name, value);
+}
-const struct ruby_initial_loadpath {
-#ifdef RUBY_SEARCH_PATH
- char search_path[sizeof(RUBY_SEARCH_PATH)];
-#endif
- char site_lib2[sizeof(RUBY_SITE_LIB2)];
-#ifdef RUBY_SITE_THIN_ARCHLIB
- char site_thin_archlib[sizeof(RUBY_SITE_THIN_ARCHLIB)];
-#endif
- char site_archlib[sizeof(RUBY_SITE_ARCHLIB)];
- char site_lib[sizeof(RUBY_SITE_LIB)];
+/* RDoc needs rb_define_const */
+#define rb_define_const(mod, name, value) \
+ define_ruby_const(mod, (mod == mRuby ? "RUBY_" name : name), value, (mod == mRuby))
- char vendor_lib2[sizeof(RUBY_VENDOR_LIB2)];
-#ifdef RUBY_VENDOR_THIN_ARCHLIB
- char vendor_thin_archlib[sizeof(RUBY_VENDOR_THIN_ARCHLIB)];
-#endif
- char vendor_archlib[sizeof(RUBY_VENDOR_ARCHLIB)];
- char vendor_lib[sizeof(RUBY_VENDOR_LIB)];
+void
+Init_Ruby_module(void)
+{
+ rb_define_module("Ruby");
+}
+
+/*! Defines platform-depended Ruby-level constants */
+void
+Init_version(void)
+{
+ /*
+ * The Ruby[rdoc-ref:Ruby] module that contains portable information among
+ * implementations.
+ *
+ * The constants defined here are aliased in the toplevel with
+ * +RUBY_+ prefix.
+ */
+ VALUE mRuby = rb_define_module("Ruby");
+
+ enum {ruby_patchlevel = RUBY_PATCHLEVEL};
+ VALUE version = MKSTR(version);
+ VALUE ruby_engine_name = MKSTR(engine);
+ // MKSTR macro is a marker for fake.rb
+
+ /*
+ * The running version of ruby
+ */
+ rb_define_const(mRuby, "VERSION", /* MKSTR(version) */ version);
+ /*
+ * The date this ruby was released
+ */
+ rb_define_const(mRuby, "RELEASE_DATE", MKSTR(release_date));
+ /*
+ * The platform for this ruby
+ */
+ rb_define_const(mRuby, "PLATFORM", MKSTR(platform));
+ /*
+ * The patchlevel for this ruby. If this is a development build of ruby
+ * the patchlevel will be -1
+ */
+ rb_define_const(mRuby, "PATCHLEVEL", MKINT(patchlevel));
+ /*
+ * The GIT commit hash for this ruby.
+ */
+ rb_define_const(mRuby, "REVISION", MKSTR(revision));
+ /*
+ * The copyright string for ruby
+ */
+ rb_define_const(mRuby, "COPYRIGHT", MKSTR(copyright));
+ /*
+ * The engine or interpreter this ruby uses.
+ */
+ rb_define_const(mRuby, "ENGINE", /* MKSTR(engine) */ ruby_engine_name);
+ ruby_set_script_name(ruby_engine_name);
+ /*
+ * The version of the engine or interpreter this ruby uses.
+ */
+ rb_define_const(mRuby, "ENGINE_VERSION", /* MKSTR(version) */ version);
- char lib[sizeof(RUBY_LIB)];
-#ifdef RUBY_THIN_ARCHLIB
- char thin_archlib[sizeof(RUBY_THIN_ARCHLIB)];
+ rb_provide("ruby2_keywords.rb");
+}
+
+#if USE_YJIT
+#define YJIT_OPTS_ON opt->yjit
+#else
+#define YJIT_OPTS_ON 0
#endif
- char archlib[sizeof(RUBY_ARCHLIB)];
- char terminator[1];
-} ruby_initial_load_paths UNALIGNED = {
-#ifdef RUBY_SEARCH_PATH
- RUBY_SEARCH_PATH,
+
+#if USE_ZJIT
+#define ZJIT_OPTS_ON opt->zjit
+#else
+#define ZJIT_OPTS_ON 0
#endif
- RUBY_SITE_LIB2,
-#ifdef RUBY_SITE_THIN_ARCHLIB
- RUBY_SITE_THIN_ARCHLIB,
+
+int ruby_mn_threads_enabled;
+
+#ifndef RB_DEFAULT_PARSER
+#define RB_DEFAULT_PARSER RB_DEFAULT_PARSER_PRISM
#endif
- RUBY_SITE_ARCHLIB,
- RUBY_SITE_LIB,
+static ruby_default_parser_enum default_parser = RB_DEFAULT_PARSER;
- RUBY_VENDOR_LIB2,
-#ifdef RUBY_VENDOR_THIN_ARCHLIB
- RUBY_VENDOR_THIN_ARCHLIB,
+ruby_default_parser_enum
+rb_ruby_default_parser(void)
+{
+ return default_parser;
+}
+
+void
+rb_ruby_default_parser_set(ruby_default_parser_enum parser)
+{
+ default_parser = parser;
+}
+
+static void
+define_ruby_description(const char *const jit_opt)
+{
+#define JIT_DESCRIPTION YJIT_DESCRIPTION ZJIT_DESCRIPTION
+
+ static char desc[
+ sizeof(ruby_description)
+ + rb_strlen_lit(JIT_DESCRIPTION)
+ + rb_strlen_lit(" +MN")
+ + rb_strlen_lit(" +PRISM")
+#if USE_MODULAR_GC
+ + rb_strlen_lit(GC_DESCRIPTION)
+ // Assume the active GC name can not be longer than 20 chars
+ // so that we don't have to use strlen and remove the static
+ // qualifier from desc.
+ + RB_GC_MAX_NAME_LEN + 3
#endif
- RUBY_VENDOR_ARCHLIB,
- RUBY_VENDOR_LIB,
- RUBY_LIB,
-#ifdef RUBY_THIN_ARCHLIB
- RUBY_THIN_ARCHLIB,
+ ];
+
+ int n = ruby_description_opt_point;
+ memcpy(desc, ruby_description, n);
+# define append(s) (n += (int)strlcpy(desc + n, s, sizeof(desc) - n))
+ if (*jit_opt) append(jit_opt);
+ RUBY_ASSERT(n <= ruby_description_opt_point + (int)rb_strlen_lit(JIT_DESCRIPTION));
+ if (ruby_mn_threads_enabled) append(" +MN");
+ if (rb_ruby_prism_p()) append(" +PRISM");
+#if USE_MODULAR_GC
+ append(GC_DESCRIPTION);
+ if (rb_gc_modular_gc_loaded_p()) {
+ append("[");
+ append(rb_gc_active_gc_name());
+ append("]");
+ }
#endif
- RUBY_ARCHLIB,
- ""
-};
+ append(ruby_description + ruby_description_opt_point);
+# undef append
+
+ VALUE mRuby = rb_path2class("Ruby");
+ VALUE description = rb_obj_freeze(rb_usascii_str_new_static(desc, n));
+ rb_dynamic_description = desc;
+
+ /*
+ * The full ruby version string, like <tt>ruby -v</tt> prints
+ */
+ rb_define_const(mRuby, "DESCRIPTION", /* MKSTR(description) */ description);
+#undef JIT_DESCRIPTION
+}
+
+void
+Init_ruby_description(ruby_cmdline_options_t *opt)
+{
+ const char *const jit_opt =
+ YJIT_OPTS_ON ? YJIT_DESCRIPTION :
+ ZJIT_OPTS_ON ? ZJIT_DESCRIPTION :
+ "";
+ define_ruby_description(jit_opt);
+}
void
-Init_version()
+ruby_set_yjit_description(void)
{
- VALUE v = MKSTR(version);
- VALUE d = MKSTR(release_date);
- VALUE p = MKSTR(platform);
-
- rb_define_global_const("RUBY_VERSION", v);
- rb_define_global_const("RUBY_RELEASE_DATE", d);
- rb_define_global_const("RUBY_PLATFORM", p);
- rb_define_global_const("RUBY_PATCHLEVEL", INT2FIX(RUBY_PATCHLEVEL));
- rb_define_global_const("RUBY_REVISION", INT2FIX(RUBY_REVISION));
- rb_define_global_const("RUBY_DESCRIPTION", MKSTR(description));
- rb_define_global_const("RUBY_COPYRIGHT", MKSTR(copyright));
-
- /* obsolete constants */
- rb_define_global_const("VERSION", v);
- rb_define_global_const("RELEASE_DATE", d);
- rb_define_global_const("PLATFORM", p);
+ VALUE mRuby = rb_path2class("Ruby");
+ rb_const_remove(rb_cObject, rb_intern("RUBY_DESCRIPTION"));
+ rb_const_remove(mRuby, rb_intern("DESCRIPTION"));
+ define_ruby_description(YJIT_DESCRIPTION);
}
void
-ruby_show_version()
+ruby_set_zjit_description(void)
{
- PRINT(description);
+ VALUE mRuby = rb_path2class("Ruby");
+ rb_const_remove(rb_cObject, rb_intern("RUBY_DESCRIPTION"));
+ rb_const_remove(mRuby, rb_intern("DESCRIPTION"));
+ define_ruby_description(ZJIT_DESCRIPTION);
+}
+
+void
+ruby_show_version(void)
+{
+ puts(rb_dynamic_description);
+
+#ifdef RUBY_LAST_COMMIT_TITLE
+ fputs("last_commit=" RUBY_LAST_COMMIT_TITLE, stdout);
+#endif
+#ifdef HAVE_MALLOC_CONF
+ if (malloc_conf) printf("malloc_conf=%s\n", malloc_conf);
+#endif
fflush(stdout);
}
void
-ruby_show_copyright()
+ruby_show_copyright(void)
{
PRINT(copyright);
- exit(0);
+ fflush(stdout);
}