bluecloth 2.0.7 → 2.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data.tar.gz.sig +0 -0
 - data/ChangeLog +36 -6
 - data/Rakefile +46 -26
 - data/Rakefile.local +13 -6
 - data/ext/VERSION +1 -1
 - data/ext/bluecloth.c +46 -21
 - data/ext/bluecloth.h +13 -2
 - data/ext/cstring.h +3 -1
 - data/ext/emmatch.c +188 -0
 - data/ext/generate.c +203 -248
 - data/ext/html5.c +24 -0
 - data/ext/markdown.c +122 -98
 - data/ext/markdown.h +16 -2
 - data/ext/mkdio.c +43 -9
 - data/ext/mkdio.h +11 -0
 - data/ext/resource.c +1 -1
 - data/ext/tags.c +110 -0
 - data/ext/tags.h +18 -0
 - data/lib/bluecloth.rb +33 -26
 - data/rake/documentation.rb +115 -0
 - data/rake/helpers.rb +375 -308
 - data/rake/hg.rb +17 -3
 - data/rake/manual.rb +11 -6
 - data/rake/packaging.rb +7 -1
 - data/rake/publishing.rb +162 -88
 - data/spec/bluecloth/101_changes_spec.rb +1 -0
 - data/spec/bluecloth/autolinks_spec.rb +1 -0
 - data/spec/bluecloth/blockquotes_spec.rb +1 -0
 - data/spec/bluecloth/code_spans_spec.rb +1 -0
 - data/spec/bluecloth/emphasis_spec.rb +1 -0
 - data/spec/bluecloth/entities_spec.rb +1 -0
 - data/spec/bluecloth/hrules_spec.rb +1 -0
 - data/spec/bluecloth/images_spec.rb +1 -0
 - data/spec/bluecloth/inline_html_spec.rb +25 -61
 - data/spec/bluecloth/lists_spec.rb +1 -0
 - data/spec/bluecloth/paragraphs_spec.rb +1 -0
 - data/spec/bluecloth/titles_spec.rb +1 -0
 - data/spec/bluecloth_spec.rb +22 -6
 - data/spec/bugfix_spec.rb +79 -2
 - data/spec/contributions_spec.rb +1 -0
 - data/spec/discount_spec.rb +46 -2
 - data/spec/lib/helpers.rb +8 -8
 - data/spec/lib/matchers.rb +5 -17
 - data/spec/markdowntest_spec.rb +2 -34
 - metadata +48 -17
 - metadata.gz.sig +0 -0
 - data/rake/rdoc.rb +0 -30
 
    
        data/rake/hg.rb
    CHANGED
    
    | 
         @@ -22,6 +22,8 @@ unless defined?( HG_DOTDIR ) 
     | 
|
| 
       22 
22 
     | 
    
         
             
            	### 
         
     | 
| 
       23 
23 
     | 
    
         | 
| 
       24 
24 
     | 
    
         
             
            	module MercurialHelpers
         
     | 
| 
      
 25 
     | 
    
         
            +
            		require './helpers.rb' unless defined?( RakefileHelpers )
         
     | 
| 
      
 26 
     | 
    
         
            +
            		include RakefileHelpers
         
     | 
| 
       25 
27 
     | 
    
         | 
| 
       26 
28 
     | 
    
         
             
            		###############
         
     | 
| 
       27 
29 
     | 
    
         
             
            		module_function
         
     | 
| 
         @@ -83,7 +85,7 @@ unless defined?( HG_DOTDIR ) 
     | 
|
| 
       83 
85 
     | 
    
         | 
| 
       84 
86 
     | 
    
         
             
            		### Return the list of files which are of status 'unknown'
         
     | 
| 
       85 
87 
     | 
    
         
             
            		def get_unknown_files
         
     | 
| 
       86 
     | 
    
         
            -
            			list = read_command_output( 'hg', 'status', '-un', '-- 
     | 
| 
      
 88 
     | 
    
         
            +
            			list = read_command_output( 'hg', 'status', '-un', '--color', 'never' )
         
     | 
| 
       87 
89 
     | 
    
         
             
            			list = list.split( /\n/ )
         
     | 
| 
       88 
90 
     | 
    
         | 
| 
       89 
91 
     | 
    
         
             
            			trace "New files: %p" % [ list ]
         
     | 
| 
         @@ -213,13 +215,20 @@ unless defined?( HG_DOTDIR ) 
     | 
|
| 
       213 
215 
     | 
    
         
             
            			paths = get_repo_paths()
         
     | 
| 
       214 
216 
     | 
    
         
             
            			if origin_url = paths['default']
         
     | 
| 
       215 
217 
     | 
    
         
             
            				ask_for_confirmation( "Pull and update from '#{origin_url}'?", false ) do
         
     | 
| 
       216 
     | 
    
         
            -
            					 
     | 
| 
      
 218 
     | 
    
         
            +
            					Rake::Task['hg:pull_without_confirmation'].invoke
         
     | 
| 
       217 
219 
     | 
    
         
             
            				end
         
     | 
| 
       218 
220 
     | 
    
         
             
            			else
         
     | 
| 
       219 
221 
     | 
    
         
             
            				trace "Skipping pull: No 'default' path."
         
     | 
| 
       220 
222 
     | 
    
         
             
            			end
         
     | 
| 
       221 
223 
     | 
    
         
             
            		end
         
     | 
| 
       222 
224 
     | 
    
         | 
| 
      
 225 
     | 
    
         
            +
             
     | 
| 
      
 226 
     | 
    
         
            +
            		desc "Pull and update without confirmation"
         
     | 
| 
      
 227 
     | 
    
         
            +
            		task :pull_without_confirmation do
         
     | 
| 
      
 228 
     | 
    
         
            +
            			run 'hg', 'pull', '-u'
         
     | 
| 
      
 229 
     | 
    
         
            +
            		end
         
     | 
| 
      
 230 
     | 
    
         
            +
             
     | 
| 
      
 231 
     | 
    
         
            +
             
     | 
| 
       223 
232 
     | 
    
         
             
            		desc "Check the current code in if tests pass"
         
     | 
| 
       224 
233 
     | 
    
         
             
            		task :checkin => ['hg:pull', 'hg:newfiles', 'test', COMMIT_MSG_FILE] do
         
     | 
| 
       225 
234 
     | 
    
         
             
            			targets = get_target_args()
         
     | 
| 
         @@ -240,13 +249,18 @@ unless defined?( HG_DOTDIR ) 
     | 
|
| 
       240 
249 
     | 
    
         
             
            			paths = get_repo_paths()
         
     | 
| 
       241 
250 
     | 
    
         
             
            			if origin_url = paths['default']
         
     | 
| 
       242 
251 
     | 
    
         
             
            				ask_for_confirmation( "Push to '#{origin_url}'?", false ) do
         
     | 
| 
       243 
     | 
    
         
            -
            					 
     | 
| 
      
 252 
     | 
    
         
            +
            					Rake::Task['hg:push_without_confirmation'].invoke
         
     | 
| 
       244 
253 
     | 
    
         
             
            				end
         
     | 
| 
       245 
254 
     | 
    
         
             
            			else
         
     | 
| 
       246 
255 
     | 
    
         
             
            				trace "Skipping push: No 'default' path."
         
     | 
| 
       247 
256 
     | 
    
         
             
            			end
         
     | 
| 
       248 
257 
     | 
    
         
             
            		end
         
     | 
| 
       249 
258 
     | 
    
         | 
| 
      
 259 
     | 
    
         
            +
            		desc "Push to the default repo without confirmation"
         
     | 
| 
      
 260 
     | 
    
         
            +
            		task :push_without_confirmation do
         
     | 
| 
      
 261 
     | 
    
         
            +
            			run 'hg', 'push'
         
     | 
| 
      
 262 
     | 
    
         
            +
            		end
         
     | 
| 
      
 263 
     | 
    
         
            +
             
     | 
| 
       250 
264 
     | 
    
         
             
            	end
         
     | 
| 
       251 
265 
     | 
    
         | 
| 
       252 
266 
     | 
    
         
             
            	if HG_DOTDIR.exist?
         
     | 
    
        data/rake/manual.rb
    CHANGED
    
    | 
         @@ -147,9 +147,14 @@ module Manual 
     | 
|
| 
       147 
147 
     | 
    
         | 
| 
       148 
148 
     | 
    
         
             
            			layout = self.config['layout'].sub( /\.page$/, '' )
         
     | 
| 
       149 
149 
     | 
    
         
             
            			templatepath = @layouts_dir + "#{layout}.page"
         
     | 
| 
       150 
     | 
    
         
            -
            			template =  
     | 
| 
       151 
     | 
    
         
            -
            			 
     | 
| 
      
 150 
     | 
    
         
            +
            			template = nil
         
     | 
| 
      
 151 
     | 
    
         
            +
            			if Object.const_defined?( :Encoding )
         
     | 
| 
      
 152 
     | 
    
         
            +
            				template = ERB.new( templatepath.read(:encoding => 'UTF-8') )
         
     | 
| 
      
 153 
     | 
    
         
            +
            			else
         
     | 
| 
      
 154 
     | 
    
         
            +
            				template = ERB.new( templatepath.read )
         
     | 
| 
      
 155 
     | 
    
         
            +
            			end
         
     | 
| 
       152 
156 
     | 
    
         | 
| 
      
 157 
     | 
    
         
            +
            			page = self
         
     | 
| 
       153 
158 
     | 
    
         
             
            			html = template.result( binding() )
         
     | 
| 
       154 
159 
     | 
    
         | 
| 
       155 
160 
     | 
    
         
             
            			# Use Tidy to clean up the html if 'cleanup' is turned on, but remove the Tidy
         
     | 
| 
         @@ -565,7 +570,7 @@ module Manual 
     | 
|
| 
       565 
570 
     | 
    
         
             
            				manual_pages = setup_page_conversion_tasks( sourcedir, outputdir, catalog )
         
     | 
| 
       566 
571 
     | 
    
         | 
| 
       567 
572 
     | 
    
         
             
            				desc "Build the manual"
         
     | 
| 
       568 
     | 
    
         
            -
            				task :build => [ : 
     | 
| 
      
 573 
     | 
    
         
            +
            				task :build => [ :apidocs, :copy_resources, :copy_apidocs, :generate_pages ]
         
     | 
| 
       569 
574 
     | 
    
         | 
| 
       570 
575 
     | 
    
         
             
            				task :clobber do
         
     | 
| 
       571 
576 
     | 
    
         
             
            					RakeFileUtils.verbose( $verbose ) do
         
     | 
| 
         @@ -686,8 +691,8 @@ module Manual 
     | 
|
| 
       686 
691 
     | 
    
         
             
            			end
         
     | 
| 
       687 
692 
     | 
    
         | 
| 
       688 
693 
     | 
    
         
             
            			desc "Copy API documentation to the manual output directory"
         
     | 
| 
       689 
     | 
    
         
            -
            			task :copy_apidocs => : 
     | 
| 
       690 
     | 
    
         
            -
            				cp_r(  
     | 
| 
      
 694 
     | 
    
         
            +
            			task :copy_apidocs => :apidocs do
         
     | 
| 
      
 695 
     | 
    
         
            +
            				cp_r( API_DOCSDIR, outputdir )
         
     | 
| 
       691 
696 
     | 
    
         
             
            			end
         
     | 
| 
       692 
697 
     | 
    
         | 
| 
       693 
698 
     | 
    
         
             
            			# Now group all the resource file tasks into a containing task
         
     | 
| 
         @@ -713,7 +718,7 @@ if MANUALDIR.exist? 
     | 
|
| 
       713 
718 
     | 
    
         | 
| 
       714 
719 
     | 
    
         
             
            		Manual::GenTask.new do |manual|
         
     | 
| 
       715 
720 
     | 
    
         
             
            			manual.metadata.version = PKG_VERSION
         
     | 
| 
       716 
     | 
    
         
            -
            			manual.metadata.api_dir =  
     | 
| 
      
 721 
     | 
    
         
            +
            			manual.metadata.api_dir = API_DOCSDIR
         
     | 
| 
       717 
722 
     | 
    
         
             
            			manual.output_dir = MANUALOUTPUTDIR
         
     | 
| 
       718 
723 
     | 
    
         
             
            			manual.base_dir = MANUALDIR
         
     | 
| 
       719 
724 
     | 
    
         
             
            			manual.source_dir = 'src'
         
     | 
    
        data/rake/packaging.rb
    CHANGED
    
    | 
         @@ -12,7 +12,13 @@ include Config 
     | 
|
| 
       12 
12 
     | 
    
         
             
            ### Task: prerelease
         
     | 
| 
       13 
13 
     | 
    
         
             
            desc "Append the package build number to package versions"
         
     | 
| 
       14 
14 
     | 
    
         
             
            task :prerelease do
         
     | 
| 
       15 
     | 
    
         
            -
            	GEMSPEC.version.version  
     | 
| 
      
 15 
     | 
    
         
            +
            	GEMSPEC.version.version << ".#{PKG_BUILD}"
         
     | 
| 
      
 16 
     | 
    
         
            +
            	Rake::Task[:gem].clear
         
     | 
| 
      
 17 
     | 
    
         
            +
             
     | 
| 
      
 18 
     | 
    
         
            +
            	Gem::PackageTask.new( GEMSPEC ) do |pkg|
         
     | 
| 
      
 19 
     | 
    
         
            +
            		pkg.need_zip = true
         
     | 
| 
      
 20 
     | 
    
         
            +
            		pkg.need_tar = true
         
     | 
| 
      
 21 
     | 
    
         
            +
            	end
         
     | 
| 
       16 
22 
     | 
    
         
             
            end
         
     | 
| 
       17 
23 
     | 
    
         | 
| 
       18 
24 
     | 
    
         | 
    
        data/rake/publishing.rb
    CHANGED
    
    | 
         @@ -13,6 +13,7 @@ $publish_privately = false 
     | 
|
| 
       13 
13 
     | 
    
         | 
| 
       14 
14 
     | 
    
         
             
            ### Add SSL to Net::SMTP
         
     | 
| 
       15 
15 
     | 
    
         
             
            class Net::SMTP
         
     | 
| 
      
 16 
     | 
    
         
            +
             
     | 
| 
       16 
17 
     | 
    
         
             
            	def ssl_start( helo='localhost.localdomain', user=nil, secret=nil, authtype=nil )
         
     | 
| 
       17 
18 
     | 
    
         
             
            		if block_given?
         
     | 
| 
       18 
19 
     | 
    
         
             
            			begin
         
     | 
| 
         @@ -93,6 +94,9 @@ begin 
     | 
|
| 
       93 
94 
     | 
    
         
             
            	require 'etc'
         
     | 
| 
       94 
95 
     | 
    
         
             
            	require 'socket'
         
     | 
| 
       95 
96 
     | 
    
         
             
            	require 'text/format'
         
     | 
| 
      
 97 
     | 
    
         
            +
            	require 'rubygems/gemcutter_utilities'
         
     | 
| 
      
 98 
     | 
    
         
            +
             
     | 
| 
      
 99 
     | 
    
         
            +
            	include Gem::GemcutterUtilities
         
     | 
| 
       96 
100 
     | 
    
         | 
| 
       97 
101 
     | 
    
         
             
            	### Generate a valid RFC822 message-id
         
     | 
| 
       98 
102 
     | 
    
         
             
            	def gen_message_id
         
     | 
| 
         @@ -104,6 +108,48 @@ begin 
     | 
|
| 
       104 
108 
     | 
    
         
             
            	end
         
     | 
| 
       105 
109 
     | 
    
         | 
| 
       106 
110 
     | 
    
         | 
| 
      
 111 
     | 
    
         
            +
            	### Fetch the rubygems API token if it hasn't been already.
         
     | 
| 
      
 112 
     | 
    
         
            +
            	def sign_in_to_rubygems
         
     | 
| 
      
 113 
     | 
    
         
            +
            		return if Gem.configuration.rubygems_api_key
         
     | 
| 
      
 114 
     | 
    
         
            +
             
     | 
| 
      
 115 
     | 
    
         
            +
            		log "Enter your RubyGems.org credentials."
         
     | 
| 
      
 116 
     | 
    
         
            +
             
     | 
| 
      
 117 
     | 
    
         
            +
            		email    = prompt "   Email: "
         
     | 
| 
      
 118 
     | 
    
         
            +
            		password = prompt_for_password( "Password: " )
         
     | 
| 
      
 119 
     | 
    
         
            +
             
     | 
| 
      
 120 
     | 
    
         
            +
            		response = rubygems_api_request( :get, "api/v1/api_key" ) do |request|
         
     | 
| 
      
 121 
     | 
    
         
            +
            			request.basic_auth( email, password )
         
     | 
| 
      
 122 
     | 
    
         
            +
            		end
         
     | 
| 
      
 123 
     | 
    
         
            +
             
     | 
| 
      
 124 
     | 
    
         
            +
            		with_response( response ) do |resp|
         
     | 
| 
      
 125 
     | 
    
         
            +
            			log "Signed in."
         
     | 
| 
      
 126 
     | 
    
         
            +
            			Gem.configuration.rubygems_api_key = resp.body
         
     | 
| 
      
 127 
     | 
    
         
            +
            		end
         
     | 
| 
      
 128 
     | 
    
         
            +
            	end
         
     | 
| 
      
 129 
     | 
    
         
            +
             
     | 
| 
      
 130 
     | 
    
         
            +
             
     | 
| 
      
 131 
     | 
    
         
            +
            	### Push the gem at the specified +path+ to the rubygems server at +gemhost+.
         
     | 
| 
      
 132 
     | 
    
         
            +
            	def push_gem( path, gemhost )
         
     | 
| 
      
 133 
     | 
    
         
            +
            		ENV['RUBYGEMS_HOST'] = "http://#{gemhost}"
         
     | 
| 
      
 134 
     | 
    
         
            +
             
     | 
| 
      
 135 
     | 
    
         
            +
            		sign_in_to_rubygems()
         
     | 
| 
      
 136 
     | 
    
         
            +
             
     | 
| 
      
 137 
     | 
    
         
            +
            		response = rubygems_api_request( :post, "api/v1/gems" ) do |request|
         
     | 
| 
      
 138 
     | 
    
         
            +
            			request.body = Gem.read_binary( path )
         
     | 
| 
      
 139 
     | 
    
         
            +
            			request.add_field "Content-Length", request.body.size
         
     | 
| 
      
 140 
     | 
    
         
            +
            			request.add_field "Content-Type",   "application/octet-stream"
         
     | 
| 
      
 141 
     | 
    
         
            +
            			request.add_field "Authorization",  Gem.configuration.rubygems_api_key
         
     | 
| 
      
 142 
     | 
    
         
            +
            		end
         
     | 
| 
      
 143 
     | 
    
         
            +
             
     | 
| 
      
 144 
     | 
    
         
            +
            		case response
         
     | 
| 
      
 145 
     | 
    
         
            +
            		when Net::HTTPSuccess
         
     | 
| 
      
 146 
     | 
    
         
            +
            			log( response.body )
         
     | 
| 
      
 147 
     | 
    
         
            +
            		else
         
     | 
| 
      
 148 
     | 
    
         
            +
            			fail( response.body )
         
     | 
| 
      
 149 
     | 
    
         
            +
            		end
         
     | 
| 
      
 150 
     | 
    
         
            +
            	end
         
     | 
| 
      
 151 
     | 
    
         
            +
             
     | 
| 
      
 152 
     | 
    
         
            +
             
     | 
| 
       107 
153 
     | 
    
         
             
            	namespace :release do
         
     | 
| 
       108 
154 
     | 
    
         
             
            		task :default => [ :prep_release, :upload, :publish, :announce ]
         
     | 
| 
       109 
155 
     | 
    
         | 
| 
         @@ -133,120 +179,147 @@ begin 
     | 
|
| 
       133 
179 
     | 
    
         
             
            		end
         
     | 
| 
       134 
180 
     | 
    
         
             
            		CLOBBER.include( RELEASE_NOTES_FILE )
         
     | 
| 
       135 
181 
     | 
    
         | 
| 
      
 182 
     | 
    
         
            +
            		# Only define upload tasks if there's an upload host
         
     | 
| 
      
 183 
     | 
    
         
            +
            		if PROJECT_HOST.empty?
         
     | 
| 
      
 184 
     | 
    
         
            +
            			task :no_upload_host do
         
     | 
| 
      
 185 
     | 
    
         
            +
            				log "Skipping upload: no upload host."
         
     | 
| 
      
 186 
     | 
    
         
            +
            			end
         
     | 
| 
      
 187 
     | 
    
         
            +
            			task :upload => :no_upload_host
         
     | 
| 
      
 188 
     | 
    
         
            +
            			task :upload_docs => :no_upload_host
         
     | 
| 
      
 189 
     | 
    
         
            +
            			task :upload_packages => :no_upload_host
         
     | 
| 
      
 190 
     | 
    
         
            +
            		else
         
     | 
| 
      
 191 
     | 
    
         
            +
            			desc "Upload project documentation and packages to #{PROJECT_HOST}"
         
     | 
| 
      
 192 
     | 
    
         
            +
            			task :upload => [ :upload_docs, :upload_packages ]
         
     | 
| 
      
 193 
     | 
    
         
            +
            			task :project => :upload # the old name
         
     | 
| 
      
 194 
     | 
    
         
            +
             
     | 
| 
      
 195 
     | 
    
         
            +
            			desc "Publish the project docs to #{PROJECT_HOST}"
         
     | 
| 
      
 196 
     | 
    
         
            +
            			task :upload_docs => [ :apidocs ] do
         
     | 
| 
      
 197 
     | 
    
         
            +
            				when_writing( "Publishing docs to #{PROJECT_SCPDOCURL}" ) do
         
     | 
| 
      
 198 
     | 
    
         
            +
            					log "Uploading API documentation to %s:%s" % [ PROJECT_HOST, PROJECT_DOCDIR ]
         
     | 
| 
      
 199 
     | 
    
         
            +
            					run 'ssh', PROJECT_HOST, "rm -rf #{PROJECT_DOCDIR}"
         
     | 
| 
      
 200 
     | 
    
         
            +
            					run 'scp', '-qCr', API_DOCSDIR, PROJECT_SCPDOCURL
         
     | 
| 
      
 201 
     | 
    
         
            +
            				end
         
     | 
| 
      
 202 
     | 
    
         
            +
            			end
         
     | 
| 
       136 
203 
     | 
    
         | 
| 
       137 
     | 
    
         
            -
             
     | 
| 
       138 
     | 
    
         
            -
             
     | 
| 
       139 
     | 
    
         
            -
             
     | 
| 
       140 
     | 
    
         
            -
             
     | 
| 
       141 
     | 
    
         
            -
             
     | 
| 
       142 
     | 
    
         
            -
             
     | 
| 
       143 
     | 
    
         
            -
             
     | 
| 
       144 
     | 
    
         
            -
             
     | 
| 
       145 
     | 
    
         
            -
             
     | 
| 
       146 
     | 
    
         
            -
            				run 'scp', '-qCr', RDOCDIR, PROJECT_SCPDOCURL
         
     | 
| 
      
 204 
     | 
    
         
            +
            			desc "Publish the project packages to #{PROJECT_HOST}"
         
     | 
| 
      
 205 
     | 
    
         
            +
            			task :upload_packages => [ :package ] do
         
     | 
| 
      
 206 
     | 
    
         
            +
            				when_writing( "Uploading packages") do
         
     | 
| 
      
 207 
     | 
    
         
            +
            					pkgs = Pathname.glob( PKGDIR + "#{PKG_FILE_NAME}.{gem,tar.gz,tar.bz2,zip}" )
         
     | 
| 
      
 208 
     | 
    
         
            +
            					log "Uploading %d packages to #{PROJECT_SCPPUBURL}" % [ pkgs.length ]
         
     | 
| 
      
 209 
     | 
    
         
            +
            					pkgs.each do |pkgfile|
         
     | 
| 
      
 210 
     | 
    
         
            +
            						run 'scp', '-qC', pkgfile, PROJECT_SCPPUBURL
         
     | 
| 
      
 211 
     | 
    
         
            +
            	                end
         
     | 
| 
      
 212 
     | 
    
         
            +
            	            end
         
     | 
| 
       147 
213 
     | 
    
         
             
            			end
         
     | 
| 
       148 
214 
     | 
    
         
             
            		end
         
     | 
| 
       149 
215 
     | 
    
         | 
| 
       150 
     | 
    
         
            -
            		 
     | 
| 
       151 
     | 
    
         
            -
            		 
     | 
| 
       152 
     | 
    
         
            -
            			 
     | 
| 
       153 
     | 
    
         
            -
            				 
     | 
| 
       154 
     | 
    
         
            -
             
     | 
| 
       155 
     | 
    
         
            -
             
     | 
| 
       156 
     | 
    
         
            -
            					run 'scp', '-qC', pkgfile, PROJECT_SCPPUBURL
         
     | 
| 
       157 
     | 
    
         
            -
                            end
         
     | 
| 
       158 
     | 
    
         
            -
                        end
         
     | 
| 
       159 
     | 
    
         
            -
            		end
         
     | 
| 
      
 216 
     | 
    
         
            +
            		# Only define the announcement tasks if there are addresses to announce to
         
     | 
| 
      
 217 
     | 
    
         
            +
            		if RELEASE_ANNOUNCE_ADDRESSES.empty?
         
     | 
| 
      
 218 
     | 
    
         
            +
            			task :no_announce_addresses do
         
     | 
| 
      
 219 
     | 
    
         
            +
            				log "Skipping announcement: no announce addresses"
         
     | 
| 
      
 220 
     | 
    
         
            +
            			end
         
     | 
| 
      
 221 
     | 
    
         
            +
            			task :announce => :no_announce_addresses
         
     | 
| 
       160 
222 
     | 
    
         | 
| 
      
 223 
     | 
    
         
            +
            		else
         
     | 
| 
      
 224 
     | 
    
         
            +
            			file RELEASE_ANNOUNCE_FILE => [RELEASE_NOTES_FILE] do |task|
         
     | 
| 
      
 225 
     | 
    
         
            +
            				relnotes = File.read( RELEASE_NOTES_FILE )
         
     | 
| 
      
 226 
     | 
    
         
            +
            				announce_body = %{
         
     | 
| 
       161 
227 
     | 
    
         | 
| 
       162 
     | 
    
         
            -
             
     | 
| 
       163 
     | 
    
         
            -
            			relnotes = File.read( RELEASE_NOTES_FILE )
         
     | 
| 
       164 
     | 
    
         
            -
            			announce_body = %{
         
     | 
| 
      
 228 
     | 
    
         
            +
            					Version #{PKG_VERSION} of #{PKG_NAME} has been released.
         
     | 
| 
       165 
229 
     | 
    
         | 
| 
       166 
     | 
    
         
            -
             
     | 
| 
      
 230 
     | 
    
         
            +
            					#{Text::Format.new(:first_indent => 0).format_one_paragraph(GEMSPEC.description)}
         
     | 
| 
       167 
231 
     | 
    
         | 
| 
       168 
     | 
    
         
            -
             
     | 
| 
      
 232 
     | 
    
         
            +
            					== Project Page
         
     | 
| 
       169 
233 
     | 
    
         | 
| 
       170 
     | 
    
         
            -
             
     | 
| 
      
 234 
     | 
    
         
            +
            					  #{GEMSPEC.homepage}
         
     | 
| 
       171 
235 
     | 
    
         | 
| 
       172 
     | 
    
         
            -
             
     | 
| 
      
 236 
     | 
    
         
            +
            					== Installation
         
     | 
| 
       173 
237 
     | 
    
         | 
| 
       174 
     | 
    
         
            -
             
     | 
| 
      
 238 
     | 
    
         
            +
            					Via gems:
         
     | 
| 
       175 
239 
     | 
    
         | 
| 
       176 
     | 
    
         
            -
             
     | 
| 
      
 240 
     | 
    
         
            +
            					  $ sudo gem install #{GEMSPEC.name}
         
     | 
| 
       177 
241 
     | 
    
         | 
| 
       178 
     | 
    
         
            -
             
     | 
| 
      
 242 
     | 
    
         
            +
            					or from source:
         
     | 
| 
       179 
243 
     | 
    
         | 
| 
       180 
     | 
    
         
            -
             
     | 
| 
      
 244 
     | 
    
         
            +
            					  $ wget http://deveiate.org/code/#{PKG_FILE_NAME}.tar.gz
         
     | 
| 
      
 245 
     | 
    
         
            +
            					  $ tar -xzvf #{PKG_FILE_NAME}.tar.gz
         
     | 
| 
      
 246 
     | 
    
         
            +
            					  $ cd #{PKG_FILE_NAME}
         
     | 
| 
      
 247 
     | 
    
         
            +
            					  $ sudo rake install
         
     | 
| 
       181 
248 
     | 
    
         | 
| 
       182 
     | 
    
         
            -
             
     | 
| 
       183 
     | 
    
         
            -
             
     | 
| 
       184 
     | 
    
         
            -
             
     | 
| 
       185 
     | 
    
         
            -
            				  $ sudo rake install
         
     | 
| 
      
 249 
     | 
    
         
            +
            					== Changes
         
     | 
| 
      
 250 
     | 
    
         
            +
            					#{relnotes}
         
     | 
| 
      
 251 
     | 
    
         
            +
            				}.gsub( /^\t+/, '' )
         
     | 
| 
       186 
252 
     | 
    
         | 
| 
       187 
     | 
    
         
            -
            				 
     | 
| 
       188 
     | 
    
         
            -
             
     | 
| 
       189 
     | 
    
         
            -
             
     | 
| 
      
 253 
     | 
    
         
            +
            				File.open( task.name, File::WRONLY|File::TRUNC|File::CREAT ) do |fh|
         
     | 
| 
      
 254 
     | 
    
         
            +
            					fh.print( announce_body )
         
     | 
| 
      
 255 
     | 
    
         
            +
            				end
         
     | 
| 
       190 
256 
     | 
    
         | 
| 
       191 
     | 
    
         
            -
             
     | 
| 
       192 
     | 
    
         
            -
            				fh.print( announce_body )
         
     | 
| 
      
 257 
     | 
    
         
            +
            				edit task.name
         
     | 
| 
       193 
258 
     | 
    
         
             
            			end
         
     | 
| 
      
 259 
     | 
    
         
            +
            			CLOBBER.include( RELEASE_ANNOUNCE_FILE )
         
     | 
| 
       194 
260 
     | 
    
         | 
| 
       195 
     | 
    
         
            -
            			edit task.name
         
     | 
| 
       196 
     | 
    
         
            -
            		end
         
     | 
| 
       197 
     | 
    
         
            -
            		CLOBBER.include( RELEASE_ANNOUNCE_FILE )
         
     | 
| 
       198 
261 
     | 
    
         | 
| 
      
 262 
     | 
    
         
            +
            			desc 'Send out a release announcement'
         
     | 
| 
      
 263 
     | 
    
         
            +
            			task :announce => [RELEASE_ANNOUNCE_FILE] do
         
     | 
| 
      
 264 
     | 
    
         
            +
            				email         = TMail::Mail.new
         
     | 
| 
       199 
265 
     | 
    
         | 
| 
       200 
     | 
    
         
            -
             
     | 
| 
       201 
     | 
    
         
            -
             
     | 
| 
       202 
     | 
    
         
            -
             
     | 
| 
      
 266 
     | 
    
         
            +
            				if $publish_privately || RELEASE_ANNOUNCE_ADDRESSES.empty?
         
     | 
| 
      
 267 
     | 
    
         
            +
            					trace "Sending private announce mail"
         
     | 
| 
      
 268 
     | 
    
         
            +
            					email.to = 'rubymage@gmail.com'
         
     | 
| 
      
 269 
     | 
    
         
            +
            				else
         
     | 
| 
      
 270 
     | 
    
         
            +
            					trace "Sending public announce mail"
         
     | 
| 
      
 271 
     | 
    
         
            +
            					email.to  = RELEASE_ANNOUNCE_ADDRESSES
         
     | 
| 
      
 272 
     | 
    
         
            +
            					email.bcc = 'rubymage@gmail.com'
         
     | 
| 
      
 273 
     | 
    
         
            +
            				end
         
     | 
| 
       203 
274 
     | 
    
         | 
| 
       204 
     | 
    
         
            -
             
     | 
| 
       205 
     | 
    
         
            -
             
     | 
| 
       206 
     | 
    
         
            -
             
     | 
| 
       207 
     | 
    
         
            -
             
     | 
| 
       208 
     | 
    
         
            -
            				 
     | 
| 
       209 
     | 
    
         
            -
            				email. 
     | 
| 
       210 
     | 
    
         
            -
            				email. 
     | 
| 
       211 
     | 
    
         
            -
             
     | 
| 
       212 
     | 
    
         
            -
             
     | 
| 
       213 
     | 
    
         
            -
             
     | 
| 
       214 
     | 
    
         
            -
             
     | 
| 
       215 
     | 
    
         
            -
             
     | 
| 
       216 
     | 
    
         
            -
             
     | 
| 
       217 
     | 
    
         
            -
             
     | 
| 
       218 
     | 
    
         
            -
             
     | 
| 
       219 
     | 
    
         
            -
             
     | 
| 
       220 
     | 
    
         
            -
             
     | 
| 
       221 
     | 
    
         
            -
             
     | 
| 
       222 
     | 
    
         
            -
             
     | 
| 
       223 
     | 
    
         
            -
             
     | 
| 
       224 
     | 
    
         
            -
             
     | 
| 
       225 
     | 
    
         
            -
             
     | 
| 
       226 
     | 
    
         
            -
             
     | 
| 
       227 
     | 
    
         
            -
             
     | 
| 
       228 
     | 
    
         
            -
             
     | 
| 
       229 
     | 
    
         
            -
             
     | 
| 
       230 
     | 
    
         
            -
             
     | 
| 
       231 
     | 
    
         
            -
             
     | 
| 
       232 
     | 
    
         
            -
             
     | 
| 
       233 
     | 
    
         
            -
             
     | 
| 
       234 
     | 
    
         
            -
             
     | 
| 
       235 
     | 
    
         
            -
             
     | 
| 
       236 
     | 
    
         
            -
            				smtp.ssl_start( Socket.gethostname, username, password, :plain ) do |smtp|
         
     | 
| 
       237 
     | 
    
         
            -
            					trace "sending message..."
         
     | 
| 
       238 
     | 
    
         
            -
            					smtp.send_message( email.to_s, email.from, email.to )
         
     | 
| 
      
 275 
     | 
    
         
            +
            				from = prompt_with_default( "Send announcement as:",
         
     | 
| 
      
 276 
     | 
    
         
            +
            					'Michael Granger <ged@FaerieMUD.org>' ) or fail
         
     | 
| 
      
 277 
     | 
    
         
            +
             
     | 
| 
      
 278 
     | 
    
         
            +
            				email.from    = from
         
     | 
| 
      
 279 
     | 
    
         
            +
            				email.subject = "[ANN] #{PKG_NAME} #{PKG_VERSION}"
         
     | 
| 
      
 280 
     | 
    
         
            +
            				email.body    = File.read( RELEASE_ANNOUNCE_FILE )
         
     | 
| 
      
 281 
     | 
    
         
            +
            				email.date    = Time.new
         
     | 
| 
      
 282 
     | 
    
         
            +
             
     | 
| 
      
 283 
     | 
    
         
            +
            				email.message_id = gen_message_id()
         
     | 
| 
      
 284 
     | 
    
         
            +
             
     | 
| 
      
 285 
     | 
    
         
            +
            				log "About to send the following email:"
         
     | 
| 
      
 286 
     | 
    
         
            +
            				puts '---',
         
     | 
| 
      
 287 
     | 
    
         
            +
            				     email.to_s,
         
     | 
| 
      
 288 
     | 
    
         
            +
            				     '---'
         
     | 
| 
      
 289 
     | 
    
         
            +
             
     | 
| 
      
 290 
     | 
    
         
            +
            					ask_for_confirmation( "Will send via #{SMTP_HOST}." ) do
         
     | 
| 
      
 291 
     | 
    
         
            +
            					pwent = Etc.getpwuid( Process.euid )
         
     | 
| 
      
 292 
     | 
    
         
            +
            					curuser = pwent ? pwent.name : 'unknown'
         
     | 
| 
      
 293 
     | 
    
         
            +
            					username = prompt_with_default( "SMTP user", curuser )
         
     | 
| 
      
 294 
     | 
    
         
            +
            					password = prompt_for_password()
         
     | 
| 
      
 295 
     | 
    
         
            +
             
     | 
| 
      
 296 
     | 
    
         
            +
            					trace "Creating SMTP connection to #{SMTP_HOST}:#{SMTP_PORT}"
         
     | 
| 
      
 297 
     | 
    
         
            +
            					smtp = Net::SMTP.new( SMTP_HOST, SMTP_PORT )
         
     | 
| 
      
 298 
     | 
    
         
            +
            					smtp.set_debug_output( $stdout )
         
     | 
| 
      
 299 
     | 
    
         
            +
            					smtp.esmtp = true
         
     | 
| 
      
 300 
     | 
    
         
            +
             
     | 
| 
      
 301 
     | 
    
         
            +
            					trace "connecting..."
         
     | 
| 
      
 302 
     | 
    
         
            +
            					smtp.ssl_start( Socket.gethostname, username, password, :plain ) do |smtp|
         
     | 
| 
      
 303 
     | 
    
         
            +
            						trace "sending message..."
         
     | 
| 
      
 304 
     | 
    
         
            +
            						smtp.send_message( email.to_s, email.from, email.to )
         
     | 
| 
      
 305 
     | 
    
         
            +
            					end
         
     | 
| 
      
 306 
     | 
    
         
            +
            					trace "done."
         
     | 
| 
       239 
307 
     | 
    
         
             
            				end
         
     | 
| 
       240 
     | 
    
         
            -
            				trace "done."
         
     | 
| 
       241 
308 
     | 
    
         
             
            			end
         
     | 
| 
       242 
309 
     | 
    
         
             
            		end
         
     | 
| 
       243 
310 
     | 
    
         | 
| 
       244 
     | 
    
         
            -
             
     | 
| 
       245 
     | 
    
         
            -
             
     | 
| 
       246 
     | 
    
         
            -
             
     | 
| 
       247 
     | 
    
         
            -
            			 
     | 
| 
       248 
     | 
    
         
            -
             
     | 
| 
       249 
     | 
    
         
            -
             
     | 
| 
      
 311 
     | 
    
         
            +
            		if GEM_PUBHOST.empty?
         
     | 
| 
      
 312 
     | 
    
         
            +
            			task :no_gem_host do
         
     | 
| 
      
 313 
     | 
    
         
            +
            				log "Skipping gem push: no gem publication host."
         
     | 
| 
      
 314 
     | 
    
         
            +
            			end
         
     | 
| 
      
 315 
     | 
    
         
            +
            			task :publish => :no_gem_host
         
     | 
| 
      
 316 
     | 
    
         
            +
            		else
         
     | 
| 
      
 317 
     | 
    
         
            +
            			desc 'Publish the new gem to #{GEM_PUBHOST}'
         
     | 
| 
      
 318 
     | 
    
         
            +
            			task :publish => [:clean, :gem, :notes] do |task|
         
     | 
| 
      
 319 
     | 
    
         
            +
            				ask_for_confirmation( "Publish #{GEM_FILE_NAME} to #{GEM_PUBHOST}?", false ) do
         
     | 
| 
      
 320 
     | 
    
         
            +
            					gempath = PKGDIR + GEM_FILE_NAME
         
     | 
| 
      
 321 
     | 
    
         
            +
            					push_gem( gempath, GEM_PUBHOST )
         
     | 
| 
      
 322 
     | 
    
         
            +
            				end
         
     | 
| 
       250 
323 
     | 
    
         
             
            			end
         
     | 
| 
       251 
324 
     | 
    
         
             
            		end
         
     | 
| 
       252 
325 
     | 
    
         
             
            	end
         
     | 
| 
         @@ -262,6 +335,7 @@ rescue LoadError => err 
     | 
|
| 
       262 
335 
     | 
    
         
             
            	end
         
     | 
| 
       263 
336 
     | 
    
         | 
| 
       264 
337 
     | 
    
         
             
            	task :release => :no_release_tasks
         
     | 
| 
      
 338 
     | 
    
         
            +
            	task "release:rerelease" => :no_release_tasks
         
     | 
| 
       265 
339 
     | 
    
         
             
            	task "release:announce" => :no_release_tasks
         
     | 
| 
       266 
340 
     | 
    
         
             
            	task "release:publish" => :no_release_tasks
         
     | 
| 
       267 
341 
     | 
    
         
             
            	task "release:notes" => :no_release_tasks
         
     | 
| 
         @@ -8,6 +8,7 @@ BEGIN { 
     | 
|
| 
       8 
8 
     | 
    
         
             
            	libdir = basedir + 'lib'
         
     | 
| 
       9 
9 
     | 
    
         
             
            	extdir = basedir + 'ext'
         
     | 
| 
       10 
10 
     | 
    
         | 
| 
      
 11 
     | 
    
         
            +
            	$LOAD_PATH.unshift( basedir ) unless $LOAD_PATH.include?( basedir )
         
     | 
| 
       11 
12 
     | 
    
         
             
            	$LOAD_PATH.unshift( libdir ) unless $LOAD_PATH.include?( libdir )
         
     | 
| 
       12 
13 
     | 
    
         
             
            	$LOAD_PATH.unshift( extdir ) unless $LOAD_PATH.include?( extdir )
         
     | 
| 
       13 
14 
     | 
    
         
             
            }
         
     | 
| 
         @@ -8,6 +8,7 @@ BEGIN { 
     | 
|
| 
       8 
8 
     | 
    
         
             
            	libdir = basedir + 'lib'
         
     | 
| 
       9 
9 
     | 
    
         
             
            	extdir = basedir + 'ext'
         
     | 
| 
       10 
10 
     | 
    
         | 
| 
      
 11 
     | 
    
         
            +
            	$LOAD_PATH.unshift( basedir ) unless $LOAD_PATH.include?( basedir )
         
     | 
| 
       11 
12 
     | 
    
         
             
            	$LOAD_PATH.unshift( libdir ) unless $LOAD_PATH.include?( libdir )
         
     | 
| 
       12 
13 
     | 
    
         
             
            	$LOAD_PATH.unshift( extdir ) unless $LOAD_PATH.include?( extdir )
         
     | 
| 
       13 
14 
     | 
    
         
             
            }
         
     | 
| 
         @@ -8,6 +8,7 @@ BEGIN { 
     | 
|
| 
       8 
8 
     | 
    
         
             
            	libdir = basedir + 'lib'
         
     | 
| 
       9 
9 
     | 
    
         
             
            	extdir = basedir + 'ext'
         
     | 
| 
       10 
10 
     | 
    
         | 
| 
      
 11 
     | 
    
         
            +
            	$LOAD_PATH.unshift( basedir ) unless $LOAD_PATH.include?( basedir )
         
     | 
| 
       11 
12 
     | 
    
         
             
            	$LOAD_PATH.unshift( libdir ) unless $LOAD_PATH.include?( libdir )
         
     | 
| 
       12 
13 
     | 
    
         
             
            	$LOAD_PATH.unshift( extdir ) unless $LOAD_PATH.include?( extdir )
         
     | 
| 
       13 
14 
     | 
    
         
             
            }
         
     |