From fe25c6e6eee8dcd375958dd125acfce82e521aa2 Mon Sep 17 00:00:00 2001 From: Jean Boussier Date: Tue, 22 Oct 2024 16:05:23 +0200 Subject: [PATCH 1/2] Merge json and json-java gemspecs --- .gitignore | 2 ++ Gemfile | 36 +++++++++---------- README.md | 2 +- Rakefile | 3 +- ext/json/extconf.rb | 3 -- json-java.gemspec | 36 ------------------- json.gemspec | 88 ++++++++++++++++++++------------------------- 7 files changed, 59 insertions(+), 111 deletions(-) delete mode 100644 ext/json/extconf.rb delete mode 100644 json-java.gemspec diff --git a/.gitignore b/.gitignore index b621a3e90..8ae6ac119 100644 --- a/.gitignore +++ b/.gitignore @@ -20,3 +20,5 @@ Gemfile.lock */**/*.jar .byebug_history *.log +/tmp + diff --git a/Gemfile b/Gemfile index 3d74f7ffe..50249b0c7 100644 --- a/Gemfile +++ b/Gemfile @@ -1,27 +1,23 @@ -# vim: set ft=ruby: - source 'https://rubygems.org' -case ENV['JSON'] -when 'ext', nil - if ENV['RUBY_ENGINE'] == 'jruby' - gemspec :name => 'json-java' - else - gemspec :name => 'json' - end -when 'pure' - gemspec :name => 'json_pure' +if ENV['JSON'] == 'pure' + gemspec name: 'json_pure' +else + gemspec name: 'json' end -gem "rake" -gem "test-unit" -gem "test-unit-ruby-core" -gem "all_images", "~> 0" unless RUBY_PLATFORM =~ /java/ +group :development do + gem "rake" + gem "rake-compiler" + gem "test-unit" + gem "test-unit-ruby-core" + gem "all_images", "~> 0" unless RUBY_PLATFORM =~ /java/ -if ENV['BENCHMARK'] - gem "benchmark-ips" - unless RUBY_PLATFORM =~ /java/ - gem "oj" - gem "rapidjson" + if ENV['BENCHMARK'] + gem "benchmark-ips" + unless RUBY_PLATFORM =~ /java/ + gem "oj" + gem "rapidjson" + end end end diff --git a/README.md b/README.md index 3b0b6ebfe..94a35d7bd 100644 --- a/README.md +++ b/README.md @@ -231,7 +231,7 @@ the `pp` library's `pp` methods. ### Release -Update the json.gemspec and json-java.gemspec. +Update the `lib/json/version.rb` file. ``` rbenv shell 2.6.5 diff --git a/Rakefile b/Rakefile index 81e8bd9bb..307b86d3e 100644 --- a/Rakefile +++ b/Rakefile @@ -191,9 +191,8 @@ if defined?(RUBY_ENGINE) and RUBY_ENGINE == 'jruby' desc "Package the jruby gem" task :jruby_gem => :create_jar do - sh 'gem build json-java.gemspec' mkdir_p 'pkg' - mv "json-#{PKG_VERSION}-java.gem", 'pkg' + sh "gem build -o pkg/json-#{PKG_VERSION}-java.gem json.gemspec" end desc "Testing library (jruby)" diff --git a/ext/json/extconf.rb b/ext/json/extconf.rb deleted file mode 100644 index 8a99b6a5c..000000000 --- a/ext/json/extconf.rb +++ /dev/null @@ -1,3 +0,0 @@ -require 'mkmf' - -create_makefile('json') diff --git a/json-java.gemspec b/json-java.gemspec deleted file mode 100644 index ad357c881..000000000 --- a/json-java.gemspec +++ /dev/null @@ -1,36 +0,0 @@ -version = File.foreach(File.join(__dir__, "lib/json/version.rb")) do |line| - /^\s*VERSION\s*=\s*'(.*)'/ =~ line and break $1 -end rescue nil - -spec = Gem::Specification.new do |s| - s.name = "json" - s.version = version - - s.summary = "JSON Implementation for Ruby" - s.description = "A JSON implementation as a JRuby extension." - s.licenses = ["Ruby"] - s.author = "Daniel Luz" - s.email = "dev+ruby@mernen.com" - - s.platform = 'java' - - s.files = Dir["lib/**/*", "COPYING", "LEGAL", "BSDL"] - - s.homepage = "https://ruby.github.io/json" - s.metadata = { - 'bug_tracker_uri' => '/~https://github.com/ruby/json/issues', - 'changelog_uri' => '/~https://github.com/ruby/json/blob/master/CHANGES.md', - 'documentation_uri' => 'https://ruby.github.io/json/doc/index.html', - 'homepage_uri' => s.homepage, - 'source_code_uri' => '/~https://github.com/ruby/json', - 'wiki_uri' => '/~https://github.com/ruby/json/wiki' - } - - s.required_ruby_version = Gem::Requirement.new(">= 2.3") -end - -if $0 == __FILE__ - Gem::Builder.new(spec).build -else - spec -end diff --git a/json.gemspec b/json.gemspec index 39b0155d4..96721f909 100644 --- a/json.gemspec +++ b/json.gemspec @@ -2,70 +2,60 @@ version = File.foreach(File.join(__dir__, "lib/json/version.rb")) do |line| /^\s*VERSION\s*=\s*'(.*)'/ =~ line and break $1 end rescue nil -Gem::Specification.new do |s| +spec = Gem::Specification.new do |s| + java_ext = Gem::Platform === s.platform && s.platform =~ 'java' || RUBY_ENGINE == 'jruby' + s.name = "json" s.version = version s.summary = "JSON Implementation for Ruby" - s.description = "This is a JSON implementation as a Ruby extension in C." + s.homepage = "https://ruby.github.io/json" + s.metadata = { + 'bug_tracker_uri' => '/~https://github.com/ruby/json/issues', + 'changelog_uri' => '/~https://github.com/ruby/json/blob/master/CHANGES.md', + 'documentation_uri' => 'https://ruby.github.io/json/doc/index.html', + 'homepage_uri' => s.homepage, + 'source_code_uri' => '/~https://github.com/ruby/json', + 'wiki_uri' => '/~https://github.com/ruby/json/wiki' + } + + s.required_ruby_version = Gem::Requirement.new(">= 2.3") + + if java_ext + s.description = "A JSON implementation as a JRuby extension." + s.author = "Daniel Luz" + s.email = "dev+ruby@mernen.com" + else + s.description = "This is a JSON implementation as a Ruby extension in C." + s.authors = ["Florian Frank"] + s.email = "flori@ping.de" + end + s.licenses = ["Ruby"] - s.authors = ["Florian Frank"] - s.email = "flori@ping.de" - s.extensions = ["ext/json/ext/generator/extconf.rb", "ext/json/ext/parser/extconf.rb", "ext/json/extconf.rb"] s.extra_rdoc_files = ["README.md"] s.rdoc_options = ["--title", "JSON implementation for Ruby", "--main", "README.md"] + s.files = [ "CHANGES.md", "COPYING", "BSDL", "LEGAL", "README.md", - "ext/json/ext/fbuffer/fbuffer.h", - "ext/json/ext/generator/depend", - "ext/json/ext/generator/extconf.rb", - "ext/json/ext/generator/generator.c", - "ext/json/ext/generator/generator.h", - "ext/json/ext/parser/depend", - "ext/json/ext/parser/extconf.rb", - "ext/json/ext/parser/parser.c", - "ext/json/ext/parser/parser.h", - "ext/json/ext/parser/parser.rl", - "ext/json/extconf.rb", "json.gemspec", - "lib/json.rb", - "lib/json/add/bigdecimal.rb", - "lib/json/add/complex.rb", - "lib/json/add/core.rb", - "lib/json/add/date.rb", - "lib/json/add/date_time.rb", - "lib/json/add/exception.rb", - "lib/json/add/ostruct.rb", - "lib/json/add/range.rb", - "lib/json/add/rational.rb", - "lib/json/add/regexp.rb", - "lib/json/add/set.rb", - "lib/json/add/struct.rb", - "lib/json/add/symbol.rb", - "lib/json/add/time.rb", - "lib/json/common.rb", - "lib/json/ext.rb", - "lib/json/ext/generator/state.rb", - "lib/json/generic_object.rb", - "lib/json/pure.rb", - "lib/json/pure/generator.rb", - "lib/json/pure/parser.rb", - "lib/json/version.rb", + *Dir["lib/**/*.rb"], ] - s.homepage = "https://ruby.github.io/json" - s.metadata = { - 'bug_tracker_uri' => '/~https://github.com/ruby/json/issues', - 'changelog_uri' => '/~https://github.com/ruby/json/blob/master/CHANGES.md', - 'documentation_uri' => 'https://ruby.github.io/json/doc/index.html', - 'homepage_uri' => s.homepage, - 'source_code_uri' => '/~https://github.com/ruby/json', - 'wiki_uri' => '/~https://github.com/ruby/json/wiki' - } - s.required_ruby_version = Gem::Requirement.new(">= 2.3") + if java_ext + s.platform = 'java' + else + s.extensions = Dir["ext/json/**/extconf.rb"] + s.files += Dir["ext/json/**/*.{c,h,rl}"] + end +end + +if RUBY_ENGINE == 'jruby' && $0 == __FILE__ + Gem::Builder.new(spec).build +else + spec end From a48be35825931b7ddbce41c03bc4ce22e5a0bc9a Mon Sep 17 00:00:00 2001 From: Jean Boussier Date: Wed, 23 Oct 2024 10:17:23 +0200 Subject: [PATCH 2/2] Release 2.7.3.rc1 --- CHANGES.md | 2 ++ Rakefile | 24 +++--------------------- lib/json/version.rb | 8 ++------ 3 files changed, 7 insertions(+), 27 deletions(-) diff --git a/CHANGES.md b/CHANGES.md index 03b5a5522..7d2c7e140 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -1,5 +1,7 @@ # Changes +### 2024-10-23 (2.7.3.rc1) + * Numerous performance optimizations in `JSON.generate` and `JSON.dump`. * Limit the size of ParserError exception messages, only include up to 32 bytes of the unparseable source. * Fix json-pure's `Object#to_json` to accept non state arguments diff --git a/Rakefile b/Rakefile index 307b86d3e..e22a3ddd1 100644 --- a/Rakefile +++ b/Rakefile @@ -57,7 +57,7 @@ else end desc "Installing library (pure)" -task :install_pure => :version do +task :install_pure do ruby 'install.rb' end @@ -79,24 +79,6 @@ task :install_ext => [ :compile, :install_pure, :install_ext_really ] desc "Installing library (extension)" task :install => :install_ext -desc m = "Writing version information for #{PKG_VERSION}" -task :version do - puts m - File.open(File.join('lib', 'json', 'version.rb'), 'w') do |v| - v.puts < [ :create_parser_jar, :create_generator_jar ] desc "Build all gems and archives for a new release of the jruby extension." - task :build => [ :clean, :version, :jruby_gem ] + task :build => [ :clean, :jruby_gem ] task :release => :build else @@ -330,7 +312,7 @@ else end desc "Build all gems and archives for a new release of json and json_pure." - task :build => [ :clean, :version, :package ] + task :build => [ :clean, :package ] task :release => :build end diff --git a/lib/json/version.rb b/lib/json/version.rb index 3fc9b8c0d..0f002cfe0 100644 --- a/lib/json/version.rb +++ b/lib/json/version.rb @@ -1,9 +1,5 @@ # frozen_string_literal: true + module JSON - # JSON version - VERSION = '2.7.2' - VERSION_ARRAY = VERSION.split(/\./).map { |x| x.to_i } # :nodoc: - VERSION_MAJOR = VERSION_ARRAY[0] # :nodoc: - VERSION_MINOR = VERSION_ARRAY[1] # :nodoc: - VERSION_BUILD = VERSION_ARRAY[2] # :nodoc: + VERSION = '2.7.3.rc1' end