forked from yorickvP/muflax.com
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Rules
174 lines (146 loc) · 3.34 KB
/
Rules
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
#!/usr/bin/env ruby
# -*- coding: utf-8 -*-
# A few helpful tips about the Rules file:
#
# * The string given to #compile and #route are matching patterns for
# identifiers--not for paths. Therefore, you can’t match on extension.
#
# * The order of rules is important: for each item, only the first matching
# rule is applied.
#
# * Item identifiers start and end with a slash (e.g. “/about/” for the file
# “content/about.html”). To select all children, grandchildren, … of an
# item, use the pattern “/about/*/”; “/about/*” will also select the parent,
# because “*” matches zero or more characters.
preprocess do
def reference_links
# find reference items
references = @items.select{|item| item.identifier.start_with? '/references/'}
# load references
ref_content = references.map{|r| File.open(r[:filename]).readlines}.join("\n\n")
# add references to every markdown item
unless references.nil?
@site.printed_items.each do |item|
if item[:extension] == "mkd"
item.add_references ref_content
end
end
end
end
def hide_pages
@items.each do |item|
if item.identifier.match %r{^/(styles|references)/}
item[:is_hidden] = true
end
end
end
hide_pages # must be first
@site.initialize_items
reference_links
end
compile '/styles/*' do
if @item.binary?
# pass images used for styling
else
filter :sass, :syntax => :scss
end
end
compile '/stuff/*' do
# pass
end
compile '/references/*' do
# link references are only added to other files
end
compile '/feed/' do
filter :erb
end
compile '/feed-merged/' do
filter :erb
end
compile '*' do
if @item.binary?
# don't filter binary items
else
# little sanity check
unless @item[:is_category] or @item[:non_cognitive]
[:techne, :episteme, :date, :title].each do |header|
if @item[header].nil?
puts "#{@item.identifier} is missing #{header}."
end
end
end
# file-specific changes
case @item[:extension]
when "mkd" # normal pages
filter :erb
filter :kramdown, :toc_levels => [1,2]
filter :markdown_link_check unless @item.draft?
filter :colorize_syntax, :default_colorizer => :pygmentize
when "org" # org-mode pages
filter :org
when "erb" # general erb files
filter :erb
end
# layout
unless @item[:is_hidden]
if @site.blog?
layout 'blog'
else
layout 'default'
end
# clean up
filter :tidy
end
end
end
compile '/log/*', :rep => :wordcount do
if @item[:extension] == "mkd"
filter :erb
filter :kramdown
filter :tidy
end
end
route '*', :rep => :wordcount do
# pass
end
route '/feed/' do
'/rss.xml'
end
route '/feed-merged/' do
'/rss-merged.xml'
end
route '/htaccess/' do
'/.htaccess'
end
route '/robots/' do
'/robots.txt'
end
route '/sitemap/' do
'/sitemap.xml'
end
route '/styles/*' do
if @item.binary?
route_unchanged
else
route_with_new_extension "css"
end
end
route '/references/*' do
# pass
end
# never change /stuff
route '/stuff/*' do
route_unchanged
end
route '/pigs/*' do
route_unchanged
end
route '*' do
if item.binary?
route_unchanged
else
# Write item with identifier /foo/ to /foo/index.html
item.identifier + 'index.html'
end
end
layout '*', :erb