calavera-jekyll 0.4.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (43) hide show
  1. data/History.txt +113 -0
  2. data/README.textile +548 -0
  3. data/VERSION.yml +4 -0
  4. data/bin/jekyll +150 -0
  5. data/lib/jekyll.rb +68 -0
  6. data/lib/jekyll/albino.rb +120 -0
  7. data/lib/jekyll/converters/csv.rb +26 -0
  8. data/lib/jekyll/converters/mephisto.rb +78 -0
  9. data/lib/jekyll/converters/mt.rb +59 -0
  10. data/lib/jekyll/converters/textpattern.rb +50 -0
  11. data/lib/jekyll/converters/typo.rb +49 -0
  12. data/lib/jekyll/converters/wordpress.rb +55 -0
  13. data/lib/jekyll/convertible.rb +71 -0
  14. data/lib/jekyll/core_ext.rb +29 -0
  15. data/lib/jekyll/filters.rb +55 -0
  16. data/lib/jekyll/layout.rb +33 -0
  17. data/lib/jekyll/page.rb +67 -0
  18. data/lib/jekyll/pager.rb +47 -0
  19. data/lib/jekyll/post.rb +201 -0
  20. data/lib/jekyll/site.rb +198 -0
  21. data/lib/jekyll/tags/highlight.rb +53 -0
  22. data/lib/jekyll/tags/include.rb +31 -0
  23. data/test/helper.rb +14 -0
  24. data/test/source/_includes/sig.markdown +3 -0
  25. data/test/source/_layouts/default.html +27 -0
  26. data/test/source/_layouts/simple.html +1 -0
  27. data/test/source/_posts/2008-10-18-foo-bar.textile +8 -0
  28. data/test/source/_posts/2008-11-21-complex.textile +8 -0
  29. data/test/source/_posts/2008-12-03-permalinked-post.textile +9 -0
  30. data/test/source/_posts/2008-12-13-include.markdown +8 -0
  31. data/test/source/category/_posts/2008-9-23-categories.textile +6 -0
  32. data/test/source/css/screen.css +76 -0
  33. data/test/source/foo/_posts/bar/2008-12-12-topical-post.textile +8 -0
  34. data/test/source/index.html +23 -0
  35. data/test/source/z_category/_posts/2008-9-23-categories.textile +6 -0
  36. data/test/suite.rb +9 -0
  37. data/test/test_filters.rb +41 -0
  38. data/test/test_generated_site.rb +36 -0
  39. data/test/test_jekyll.rb +0 -0
  40. data/test/test_post.rb +141 -0
  41. data/test/test_site.rb +45 -0
  42. data/test/test_tags.rb +31 -0
  43. metadata +212 -0
@@ -0,0 +1,4 @@
1
+ ---
2
+ :minor: 4
3
+ :patch: 1
4
+ :major: 0
@@ -0,0 +1,150 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ $:.unshift File.join(File.dirname(__FILE__), *%w[.. lib])
4
+
5
+ help = <<HELP
6
+ Jekyll is a blog-aware, static site generator.
7
+
8
+ Basic Command Line Usage:
9
+ jekyll # . -> ./_site
10
+ jekyll <path to write generated site> # . -> <path>
11
+ jekyll <path to source> <path to write generated site> # <path> -> <path>
12
+
13
+ Options:
14
+ HELP
15
+
16
+ require 'optparse'
17
+ require 'jekyll'
18
+
19
+ options = {}
20
+
21
+ opts = OptionParser.new do |opts|
22
+ opts.banner = help
23
+
24
+ opts.on("--auto", "Auto-regenerate") do
25
+ options[:auto] = true
26
+ end
27
+
28
+ opts.on("--server [PORT]", "Start web server (default port 4000)") do |port|
29
+ options[:server] = true
30
+ options[:server_port] = port || 4000
31
+ end
32
+
33
+ opts.on("--lsi", "Use LSI for better related posts") do
34
+ Jekyll.lsi = true
35
+ end
36
+
37
+ opts.on("--pygments", "Use pygments to highlight code") do
38
+ Jekyll.pygments = true
39
+ end
40
+
41
+ opts.on("--rdiscount", "Use rdiscount gem for Markdown") do
42
+ begin
43
+ require 'rdiscount'
44
+ Jekyll.markdown_proc = Proc.new { |x| RDiscount.new(x).to_html }
45
+ puts 'Using rdiscount for Markdown'
46
+ rescue LoadError
47
+ puts 'You must have the rdiscount gem installed first'
48
+ end
49
+ end
50
+
51
+ opts.on("--permalink [TYPE]", "Use 'date' (default) for YYYY/MM/DD") do |style|
52
+ Jekyll.permalink_style = (style || 'date').to_sym
53
+ end
54
+
55
+ opts.on("--paginate [PER_PAGE]", "Paginate the blog's posts") do |per_page|
56
+ begin
57
+ Jekyll.paginate = per_page.to_i
58
+ raise ArgumentError if Jekyll.paginate == 0
59
+ rescue
60
+ puts 'you must specify a numeric number of posts by page bigger than 0'
61
+ exit 0
62
+ end
63
+ end
64
+
65
+ opts.on("--version", "Display current version") do
66
+ puts "Jekyll " + Jekyll.version
67
+ exit 0
68
+ end
69
+ end
70
+
71
+ def merge_args!(args)
72
+ File.exist?('jekyll.ini') ? args + IO.read('jekyll.ini').split : args
73
+ end
74
+
75
+ opts.parse! merge_args!(ARGV)
76
+
77
+ def clean(dest)
78
+ FileUtils.rm_rf(dest)
79
+ FileUtils.mkdir_p(dest)
80
+ end
81
+
82
+ def globs(source)
83
+ Dir.chdir(source) do
84
+ dirs = Dir['*'].select { |x| File.directory?(x) }
85
+ dirs -= ['_site']
86
+ dirs = dirs.map { |x| "#{x}/**/*" }
87
+ dirs += ['*']
88
+ end
89
+ end
90
+
91
+ source = nil
92
+ destination = nil
93
+
94
+ case ARGV.size
95
+ when 0
96
+ source = '.'
97
+ destination = File.join('.', '_site')
98
+ when 1
99
+ source = '.'
100
+ destination = ARGV[0]
101
+ when 2
102
+ source = ARGV[0]
103
+ destination = ARGV[1]
104
+ else
105
+ puts "Invalid options. Run `jekyll --help` for assistance."
106
+ exit(1)
107
+ end
108
+
109
+ if options[:auto]
110
+ require 'directory_watcher'
111
+
112
+ puts "Auto-regenerating enabled: #{source} -> #{destination}"
113
+
114
+ dw = DirectoryWatcher.new(source)
115
+ dw.interval = 1
116
+ dw.glob = globs(source)
117
+
118
+ dw.add_observer do |*args|
119
+ t = Time.now.strftime("%Y-%m-%d %H:%M:%S")
120
+ puts "[#{t}] regeneration: #{args.size} files changed"
121
+ Jekyll.process(source, destination)
122
+ end
123
+
124
+ dw.start
125
+
126
+ unless options[:server]
127
+ loop { sleep 1000 }
128
+ end
129
+ else
130
+ Jekyll.process(source, destination)
131
+ puts "Successfully generated site in #{destination}"
132
+ end
133
+
134
+ if options[:server]
135
+ require 'webrick'
136
+ include WEBrick
137
+
138
+ FileUtils.mkdir_p(destination)
139
+
140
+ s = HTTPServer.new(
141
+ :Port => options[:server_port],
142
+ :DocumentRoot => destination
143
+ )
144
+ t = Thread.new {
145
+ s.start
146
+ }
147
+
148
+ trap("INT") { s.shutdown }
149
+ t.join()
150
+ end
@@ -0,0 +1,68 @@
1
+ $:.unshift File.dirname(__FILE__) # For use/testing when no gem is installed
2
+
3
+ # rubygems
4
+ require 'rubygems'
5
+
6
+ # core
7
+ require 'fileutils'
8
+ require 'time'
9
+ require 'yaml'
10
+
11
+ # stdlib
12
+
13
+ # 3rd party
14
+ require 'liquid'
15
+ require 'redcloth'
16
+ begin
17
+ require 'maruku'
18
+ require 'maruku/ext/math'
19
+ # Switch off MathML output
20
+ MaRuKu::Globals[:html_math_output_mathml] = false
21
+ MaRuKu::Globals[:html_math_engine] = 'none'
22
+
23
+ # Turn on math to PNG support with blahtex
24
+ # Resulting PNGs stored in `images/latex`
25
+ MaRuKu::Globals[:html_math_output_png] = true
26
+ MaRuKu::Globals[:html_png_engine] = 'blahtex'
27
+ MaRuKu::Globals[:html_png_dir] = 'images/latex'
28
+ MaRuKu::Globals[:html_png_url] = '/images/latex/'
29
+ rescue LoadError
30
+ puts "The maruku gem is required for markdown support!"
31
+ end
32
+
33
+ # internal requires
34
+ require 'jekyll/core_ext'
35
+ require 'jekyll/pager'
36
+ require 'jekyll/site'
37
+ require 'jekyll/convertible'
38
+ require 'jekyll/layout'
39
+ require 'jekyll/page'
40
+ require 'jekyll/post'
41
+ require 'jekyll/filters'
42
+ require 'jekyll/tags/highlight'
43
+ require 'jekyll/tags/include'
44
+ require 'jekyll/albino'
45
+
46
+ module Jekyll
47
+ class << self
48
+ attr_accessor :source, :dest, :lsi, :pygments, :markdown_proc, :content_type, :permalink_style, :paginate
49
+ end
50
+
51
+ Jekyll.lsi = false
52
+ Jekyll.pygments = false
53
+ Jekyll.markdown_proc = Proc.new { |x| Maruku.new(x).to_html }
54
+ Jekyll.permalink_style = :date
55
+
56
+ def self.process(source, dest)
57
+ require 'classifier' if Jekyll.lsi
58
+
59
+ Jekyll.source = source
60
+ Jekyll.dest = dest
61
+ Jekyll::Site.new(source, dest).process
62
+ end
63
+
64
+ def self.version
65
+ yml = YAML.load(File.read(File.join(File.dirname(__FILE__), *%w[.. VERSION.yml])))
66
+ "#{yml[:major]}.#{yml[:minor]}.#{yml[:patch]}"
67
+ end
68
+ end
@@ -0,0 +1,120 @@
1
+ ##
2
+ # Wrapper for the Pygments command line tool, pygmentize.
3
+ #
4
+ # Pygments: http://pygments.org/
5
+ #
6
+ # Assumes pygmentize is in the path. If not, set its location
7
+ # with Albino.bin = '/path/to/pygmentize'
8
+ #
9
+ # Use like so:
10
+ #
11
+ # @syntaxer = Albino.new('/some/file.rb', :ruby)
12
+ # puts @syntaxer.colorize
13
+ #
14
+ # This'll print out an HTMLized, Ruby-highlighted version
15
+ # of '/some/file.rb'.
16
+ #
17
+ # To use another formatter, pass it as the third argument:
18
+ #
19
+ # @syntaxer = Albino.new('/some/file.rb', :ruby, :bbcode)
20
+ # puts @syntaxer.colorize
21
+ #
22
+ # You can also use the #colorize class method:
23
+ #
24
+ # puts Albino.colorize('/some/file.rb', :ruby)
25
+ #
26
+ # Another also: you get a #to_s, for somewhat nicer use in Rails views.
27
+ #
28
+ # ... helper file ...
29
+ # def highlight(text)
30
+ # Albino.new(text, :ruby)
31
+ # end
32
+ #
33
+ # ... view file ...
34
+ # <%= highlight text %>
35
+ #
36
+ # The default lexer is 'text'. You need to specify a lexer yourself;
37
+ # because we are using STDIN there is no auto-detect.
38
+ #
39
+ # To see all lexers and formatters available, run `pygmentize -L`.
40
+ #
41
+ # Chris Wanstrath // chris@ozmm.org
42
+ # GitHub // http://github.com
43
+ #
44
+ require 'open4'
45
+
46
+ class Albino
47
+ @@bin = Rails.development? ? 'pygmentize' : '/usr/bin/pygmentize' rescue 'pygmentize'
48
+
49
+ def self.bin=(path)
50
+ @@bin = path
51
+ end
52
+
53
+ def self.colorize(*args)
54
+ new(*args).colorize
55
+ end
56
+
57
+ def initialize(target, lexer = :text, format = :html)
58
+ @target = File.exists?(target) ? File.read(target) : target rescue target
59
+ @options = { :l => lexer, :f => format }
60
+ end
61
+
62
+ def execute(command)
63
+ output = ''
64
+ Open4.popen4(command) do |pid, stdin, stdout, stderr|
65
+ stdin.puts @target
66
+ stdin.close
67
+ output = stdout.read.strip
68
+ [stdout, stderr].each { |io| io.close }
69
+ end
70
+ output
71
+ end
72
+
73
+ def colorize(options = {})
74
+ execute @@bin + convert_options(options)
75
+ end
76
+ alias_method :to_s, :colorize
77
+
78
+ def convert_options(options = {})
79
+ @options.merge(options).inject('') do |string, (flag, value)|
80
+ string + " -#{flag} #{value}"
81
+ end
82
+ end
83
+ end
84
+
85
+ if $0 == __FILE__
86
+ require 'rubygems'
87
+ require 'test/spec'
88
+ require 'mocha'
89
+ begin require 'redgreen'; rescue LoadError; end
90
+
91
+ context "Albino" do
92
+ setup do
93
+ @syntaxer = Albino.new(__FILE__, :ruby)
94
+ end
95
+
96
+ specify "defaults to text" do
97
+ syntaxer = Albino.new(__FILE__)
98
+ syntaxer.expects(:execute).with('pygmentize -f html -l text').returns(true)
99
+ syntaxer.colorize
100
+ end
101
+
102
+ specify "accepts options" do
103
+ @syntaxer.expects(:execute).with('pygmentize -f html -l ruby').returns(true)
104
+ @syntaxer.colorize
105
+ end
106
+
107
+ specify "works with strings" do
108
+ syntaxer = Albino.new('class New; end', :ruby)
109
+ assert_match %r(highlight), syntaxer.colorize
110
+ end
111
+
112
+ specify "aliases to_s" do
113
+ assert_equal @syntaxer.colorize, @syntaxer.to_s
114
+ end
115
+
116
+ specify "class method colorize" do
117
+ assert_equal @syntaxer.colorize, Albino.colorize(__FILE__, :ruby)
118
+ end
119
+ end
120
+ end
@@ -0,0 +1,26 @@
1
+ module Jekyll
2
+ module CSV
3
+ #Reads a csv with title, permalink, body, published_at, and filter.
4
+ #It creates a post file for each row in the csv
5
+ def self.process(file = "posts.csv")
6
+ FileUtils.mkdir_p "_posts"
7
+ posts = 0
8
+ FasterCSV.foreach(file) do |row|
9
+ next if row[0] == "title"
10
+ posts += 1
11
+ name = row[3].split(" ")[0]+"-"+row[1]+(row[4] =~ /markdown/ ? ".markdown" : ".textile")
12
+ File.open("_posts/#{name}", "w") do |f|
13
+ f.puts <<-HEADER
14
+ ---
15
+ layout: post
16
+ title: #{row[0]}
17
+ ---
18
+
19
+ HEADER
20
+ f.puts row[2]
21
+ end
22
+ end
23
+ "Created #{posts} posts!"
24
+ end
25
+ end
26
+ end
@@ -0,0 +1,78 @@
1
+ # Quickly hacked together my Michael Ivey
2
+ # Based on mt.rb by Nick Gerakines, open source and publically
3
+ # available under the MIT license. Use this module at your own risk.
4
+
5
+ require 'rubygems'
6
+ require 'sequel'
7
+ require 'fastercsv'
8
+ require 'fileutils'
9
+ require File.join(File.dirname(__FILE__),"csv.rb")
10
+
11
+ # NOTE: This converter requires Sequel and the MySQL gems.
12
+ # The MySQL gem can be difficult to install on OS X. Once you have MySQL
13
+ # installed, running the following commands should work:
14
+ # $ sudo gem install sequel
15
+ # $ sudo gem install mysql -- --with-mysql-config=/usr/local/mysql/bin/mysql_config
16
+
17
+ module Jekyll
18
+ module Mephisto
19
+ #Accepts a hash with database config variables, exports mephisto posts into a csv
20
+ #export PGPASSWORD if you must
21
+ def self.postgres(c)
22
+ sql = <<-SQL
23
+ BEGIN;
24
+ CREATE TEMP TABLE jekyll AS
25
+ SELECT title, permalink, body, published_at, filter FROM contents
26
+ WHERE user_id = 1 AND type = 'Article' ORDER BY published_at;
27
+ COPY jekyll TO STDOUT WITH CSV HEADER;
28
+ ROLLBACK;
29
+ SQL
30
+ command = %Q(psql -h #{c[:host] || "localhost"} -c "#{sql.strip}" #{c[:database]} #{c[:username]} -o #{c[:filename] || "posts.csv"})
31
+ puts command
32
+ `#{command}`
33
+ CSV.process
34
+ end
35
+
36
+ # This query will pull blog posts from all entries across all blogs. If
37
+ # you've got unpublished, deleted or otherwise hidden posts please sift
38
+ # through the created posts to make sure nothing is accidently published.
39
+
40
+ QUERY = "SELECT id, permalink, body, published_at, title FROM contents WHERE user_id = ? AND type = 'Article' AND published_at IS NOT NULL ORDER BY published_at"
41
+
42
+ def self.process(dbname, user, pass, user_id = 1, host = 'localhost')
43
+ db = Sequel.mysql(dbname, :user => user, :password => pass, :host => host)
44
+
45
+ FileUtils.mkdir_p "_posts"
46
+
47
+ db[QUERY, user_id].each do |post|
48
+ title = post[:title]
49
+ slug = post[:permalink]
50
+ date = post[:published_at]
51
+ content = post[:body]
52
+ # more_content = ''
53
+
54
+ # Be sure to include the body and extended body.
55
+ # if more_content != nil
56
+ # content = content + " \n" + more_content
57
+ # end
58
+
59
+ # Ideally, this script would determine the post format (markdown, html
60
+ # , etc) and create files with proper extensions. At this point it
61
+ # just assumes that markdown will be acceptable.
62
+ name = [date.year, date.month, date.day, slug].join('-') + ".markdown"
63
+
64
+ data = {
65
+ 'layout' => 'post',
66
+ 'title' => title.to_s,
67
+ 'id' => post[:id],
68
+ }.delete_if { |k,v| v.nil? || v == ''}.to_yaml
69
+
70
+ File.open("_posts/#{name}", "w") do |f|
71
+ f.puts data
72
+ f.puts "---"
73
+ f.puts content
74
+ end
75
+ end
76
+ end
77
+ end
78
+ end