dm-is-authenticatable.gemspec in dm-is-authenticatable-0.2.0 vs dm-is-authenticatable.gemspec in dm-is-authenticatable-0.3.0

- old
+ new

@@ -1,127 +1,60 @@ # encoding: utf-8 require 'yaml' -Gem::Specification.new do |gemspec| - files = if File.directory?('.git') - `git ls-files`.split($/) - elsif File.directory?('.hg') - `hg manifest`.split($/) - elsif File.directory?('.svn') - `svn ls -R`.split($/).select { |path| File.file?(path) } - else - Dir['{**/}{.*,*}'].select { |path| File.file?(path) } - end +Gem::Specification.new do |gem| + gemspec = YAML.load_file('gemspec.yml') - filter_files = lambda { |paths| - case paths - when Array - (files & paths) - when String - (files & Dir[paths]) - end - } + gem.name = gemspec.fetch('name') + gem.version = gemspec.fetch('version') do + lib_dir = File.join(File.dirname(__FILE__),'lib') + $LOAD_PATH << lib_dir unless $LOAD_PATH.include?(lib_dir) - version = { - :file => 'lib/dm-is-authenticatable/version.rb', - :constant => 'DataMapper::Is::Authenticatable::VERSION' - } + require 'dm-is-authenticatable/is/authenticatable/version' + DataMapper::Is::Authenticatable::VERSION + end - defaults = { - 'name' => File.basename(File.dirname(__FILE__)), - 'files' => files, - 'executables' => filter_files['bin/*'].map { |path| File.basename(path) }, - 'test_files' => filter_files['{test/{**/}*_test.rb,spec/{**/}*_spec.rb}'], - 'extra_doc_files' => filter_files['*.{txt,rdoc,md,markdown,tt,textile}'], - } + gem.summary = gemspec['summary'] + gem.description = gemspec['description'] + gem.licenses = Array(gemspec['license']) + gem.authors = Array(gemspec['authors']) + gem.email = gemspec['email'] + gem.homepage = gemspec['homepage'] - metadata = defaults.merge(YAML.load_file('gemspec.yml')) + glob = lambda { |patterns| gem.files & Dir[*patterns] } - gemspec.name = metadata.fetch('name',defaults[:name]) - gemspec.version = if metadata['version'] - metadata['version'] - elsif File.file?(version[:file]) - require File.join('.',version[:file]) - eval(version[:constant]) - end + gem.files = `git ls-files`.split($/) + gem.files = glob[gemspec['files']] if gemspec['files'] - gemspec.summary = metadata.fetch('summary',metadata['description']) - gemspec.description = metadata.fetch('description',metadata['summary']) - - case metadata['license'] - when Array - gemspec.licenses = metadata['license'] - when String - gemspec.license = metadata['license'] + gem.executables = gemspec.fetch('executables') do + glob['bin/*'].map { |path| File.basename(path) } end + gem.default_executable = gem.executables.first if Gem::VERSION < '1.7.' - case metadata['authors'] - when Array - gemspec.authors = metadata['authors'] - when String - gemspec.author = metadata['authors'] - end + gem.extensions = glob[gemspec['extensions'] || 'ext/**/extconf.rb'] + gem.test_files = glob[gemspec['test_files'] || '{test/{**/}*_test.rb'] + gem.extra_rdoc_files = glob[gemspec['extra_doc_files'] || '*.{txt,md}'] - gemspec.email = metadata['email'] - gemspec.homepage = metadata['homepage'] + gem.require_paths = Array(gemspec.fetch('require_paths') { + %w[ext lib].select { |dir| File.directory?(dir) } + }) - case metadata['require_paths'] - when Array - gemspec.require_paths = metadata['require_paths'] - when String - gemspec.require_path = metadata['require_paths'] - end + gem.requirements = gemspec['requirements'] + gem.required_ruby_version = gemspec['required_ruby_version'] + gem.required_rubygems_version = gemspec['required_rubygems_version'] + gem.post_install_message = gemspec['post_install_message'] - gemspec.files = filter_files[metadata['files']] + split = lambda { |string| string.split(/,\s*/) } - gemspec.executables = metadata['executables'] - gemspec.extensions = metadata['extensions'] - - if Gem::VERSION < '1.7.' - gemspec.default_executable = gemspec.executables.first - end - - gemspec.test_files = filter_files[metadata['test_files']] - - unless gemspec.files.include?('.document') - gemspec.extra_rdoc_files = metadata['extra_doc_files'] - end - - gemspec.post_install_message = metadata['post_install_message'] - gemspec.requirements = metadata['requirements'] - - if gemspec.respond_to?(:required_ruby_version=) - gemspec.required_ruby_version = metadata['required_ruby_version'] - end - - if gemspec.respond_to?(:required_rubygems_version=) - gemspec.required_rubygems_version = metadata['required_rubygems_version'] - end - - parse_versions = lambda { |versions| - case versions - when Array - versions.map { |v| v.to_s } - when String - versions.split(/,\s*/) + if gemspec['dependencies'] + gemspec['dependencies'].each do |name,versions| + gem.add_dependency(name,split[versions]) end - } - - if metadata['dependencies'] - metadata['dependencies'].each do |name,versions| - gemspec.add_dependency(name,parse_versions[versions]) - end end - if metadata['runtime_dependencies'] - metadata['runtime_dependencies'].each do |name,versions| - gemspec.add_runtime_dependency(name,parse_versions[versions]) - end - end - - if metadata['development_dependencies'] - metadata['development_dependencies'].each do |name,versions| - gemspec.add_development_dependency(name,parse_versions[versions]) + if gemspec['development_dependencies'] + gemspec['development_dependencies'].each do |name,versions| + gem.add_development_dependency(name,split[versions]) end end end