marty 0.5.12

Sign up to get free protection for your applications and to get access to all the features.
Files changed (345) hide show
  1. checksums.yaml +7 -0
  2. data/MIT-LICENSE +20 -0
  3. data/README.md +84 -0
  4. data/Rakefile +29 -0
  5. data/app/assets/javascripts/marty/application.js +15 -0
  6. data/app/assets/stylesheets/marty/application.css +13 -0
  7. data/app/components/marty/api_auth_view.rb +32 -0
  8. data/app/components/marty/auth_app.rb +55 -0
  9. data/app/components/marty/auth_app.rb~ +51 -0
  10. data/app/components/marty/auth_app/javascripts/auth_app.js +91 -0
  11. data/app/components/marty/auth_app/javascripts/auth_app.js~ +91 -0
  12. data/app/components/marty/cm_form_panel.rb~ +5 -0
  13. data/app/components/marty/cm_grid_panel.rb~ +35 -0
  14. data/app/components/marty/data_import_view.rb~ +142 -0
  15. data/app/components/marty/extras/layout.rb +46 -0
  16. data/app/components/marty/extras/layout.rb~ +46 -0
  17. data/app/components/marty/extras/misc.rb +18 -0
  18. data/app/components/marty/form.rb +6 -0
  19. data/app/components/marty/grid.rb +45 -0
  20. data/app/components/marty/grid_append_only.rb +12 -0
  21. data/app/components/marty/import_type_view.rb +53 -0
  22. data/app/components/marty/live_search_grid_panel.rb +46 -0
  23. data/app/components/marty/live_search_grid_panel.rb~ +49 -0
  24. data/app/components/marty/main_auth_app.rb +269 -0
  25. data/app/components/marty/main_auth_app.rb~ +238 -0
  26. data/app/components/marty/mcfly_grid_panel.rb +62 -0
  27. data/app/components/marty/mcfly_grid_panel.rb~ +80 -0
  28. data/app/components/marty/new_posting_form.rb +46 -0
  29. data/app/components/marty/new_posting_form.rb~ +46 -0
  30. data/app/components/marty/new_posting_window.rb +21 -0
  31. data/app/components/marty/new_posting_window.rb~ +21 -0
  32. data/app/components/marty/panel.rb +12 -0
  33. data/app/components/marty/pivot_grid.rb +52 -0
  34. data/app/components/marty/pivot_grid/endpoints.rb +45 -0
  35. data/app/components/marty/pivot_grid/javascripts/extensions.js +150 -0
  36. data/app/components/marty/pivot_grid/javascripts/pivot_grid.js +86 -0
  37. data/app/components/marty/pivot_grid/services.rb +44 -0
  38. data/app/components/marty/posting_grid.rb +139 -0
  39. data/app/components/marty/posting_grid.rb~ +140 -0
  40. data/app/components/marty/posting_window.rb +27 -0
  41. data/app/components/marty/promise_view.rb +177 -0
  42. data/app/components/marty/promise_view.rb~ +157 -0
  43. data/app/components/marty/promise_view/stylesheets/promise_view.css +26 -0
  44. data/app/components/marty/promise_view/stylesheets/promise_view.css~ +15 -0
  45. data/app/components/marty/report_form.rb +225 -0
  46. data/app/components/marty/report_form.rb~ +217 -0
  47. data/app/components/marty/report_select.rb +145 -0
  48. data/app/components/marty/report_select.rb~ +133 -0
  49. data/app/components/marty/reporting.rb +39 -0
  50. data/app/components/marty/reporting.rb~ +39 -0
  51. data/app/components/marty/script_detail.rb~ +430 -0
  52. data/app/components/marty/script_form.rb +233 -0
  53. data/app/components/marty/script_form.rb~ +233 -0
  54. data/app/components/marty/script_form/javascripts/Ext.ux.form.field.CodeMirror.js +698 -0
  55. data/app/components/marty/script_form/javascripts/Ext.ux.form.field.CodeMirror.js~ +909 -0
  56. data/app/components/marty/script_form/javascripts/codemirror.js +3130 -0
  57. data/app/components/marty/script_form/javascripts/mode/clike/clike.js +284 -0
  58. data/app/components/marty/script_form/javascripts/mode/clike/index.html +102 -0
  59. data/app/components/marty/script_form/javascripts/mode/clike/scala.html +766 -0
  60. data/app/components/marty/script_form/javascripts/mode/clojure/clojure.js +206 -0
  61. data/app/components/marty/script_form/javascripts/mode/clojure/index.html +67 -0
  62. data/app/components/marty/script_form/javascripts/mode/coffeescript/LICENSE +22 -0
  63. data/app/components/marty/script_form/javascripts/mode/coffeescript/coffeescript.js +346 -0
  64. data/app/components/marty/script_form/javascripts/mode/coffeescript/index.html +728 -0
  65. data/app/components/marty/script_form/javascripts/mode/commonlisp/commonlisp.js +101 -0
  66. data/app/components/marty/script_form/javascripts/mode/commonlisp/index.html +165 -0
  67. data/app/components/marty/script_form/javascripts/mode/css/css.js +448 -0
  68. data/app/components/marty/script_form/javascripts/mode/css/index.html +58 -0
  69. data/app/components/marty/script_form/javascripts/mode/css/test.js +501 -0
  70. data/app/components/marty/script_form/javascripts/mode/delorean/delorean.js +189 -0
  71. data/app/components/marty/script_form/javascripts/mode/diff/diff.js +32 -0
  72. data/app/components/marty/script_form/javascripts/mode/diff/index.html +105 -0
  73. data/app/components/marty/script_form/javascripts/mode/ecl/ecl.js +203 -0
  74. data/app/components/marty/script_form/javascripts/mode/ecl/index.html +42 -0
  75. data/app/components/marty/script_form/javascripts/mode/erlang/erlang.js +463 -0
  76. data/app/components/marty/script_form/javascripts/mode/erlang/index.html +63 -0
  77. data/app/components/marty/script_form/javascripts/mode/gfm/gfm.js +150 -0
  78. data/app/components/marty/script_form/javascripts/mode/gfm/index.html +48 -0
  79. data/app/components/marty/script_form/javascripts/mode/go/go.js +170 -0
  80. data/app/components/marty/script_form/javascripts/mode/go/index.html +73 -0
  81. data/app/components/marty/script_form/javascripts/mode/groovy/groovy.js +210 -0
  82. data/app/components/marty/script_form/javascripts/mode/groovy/index.html +72 -0
  83. data/app/components/marty/script_form/javascripts/mode/haskell/haskell.js +242 -0
  84. data/app/components/marty/script_form/javascripts/mode/haskell/index.html +61 -0
  85. data/app/components/marty/script_form/javascripts/mode/haxe/haxe.js +429 -0
  86. data/app/components/marty/script_form/javascripts/mode/haxe/index.html +91 -0
  87. data/app/components/marty/script_form/javascripts/mode/htmlembedded/htmlembedded.js +72 -0
  88. data/app/components/marty/script_form/javascripts/mode/htmlembedded/index.html +50 -0
  89. data/app/components/marty/script_form/javascripts/mode/htmlmixed/htmlmixed.js +84 -0
  90. data/app/components/marty/script_form/javascripts/mode/htmlmixed/index.html +52 -0
  91. data/app/components/marty/script_form/javascripts/mode/javascript/index.html +78 -0
  92. data/app/components/marty/script_form/javascripts/mode/javascript/javascript.js +361 -0
  93. data/app/components/marty/script_form/javascripts/mode/jinja2/index.html +38 -0
  94. data/app/components/marty/script_form/javascripts/mode/jinja2/jinja2.js +42 -0
  95. data/app/components/marty/script_form/javascripts/mode/less/index.html +740 -0
  96. data/app/components/marty/script_form/javascripts/mode/less/less.js +266 -0
  97. data/app/components/marty/script_form/javascripts/mode/lua/index.html +73 -0
  98. data/app/components/marty/script_form/javascripts/mode/lua/lua.js +140 -0
  99. data/app/components/marty/script_form/javascripts/mode/markdown/index.html +343 -0
  100. data/app/components/marty/script_form/javascripts/mode/markdown/markdown.js +382 -0
  101. data/app/components/marty/script_form/javascripts/mode/markdown/test.js +1084 -0
  102. data/app/components/marty/script_form/javascripts/mode/mysql/index.html +42 -0
  103. data/app/components/marty/script_form/javascripts/mode/mysql/mysql.js +186 -0
  104. data/app/components/marty/script_form/javascripts/mode/ntriples/index.html +33 -0
  105. data/app/components/marty/script_form/javascripts/mode/ntriples/ntriples.js +172 -0
  106. data/app/components/marty/script_form/javascripts/mode/ocaml/index.html +130 -0
  107. data/app/components/marty/script_form/javascripts/mode/ocaml/ocaml.js +114 -0
  108. data/app/components/marty/script_form/javascripts/mode/pascal/LICENSE +7 -0
  109. data/app/components/marty/script_form/javascripts/mode/pascal/index.html +49 -0
  110. data/app/components/marty/script_form/javascripts/mode/pascal/pascal.js +94 -0
  111. data/app/components/marty/script_form/javascripts/mode/perl/LICENSE +19 -0
  112. data/app/components/marty/script_form/javascripts/mode/perl/index.html +63 -0
  113. data/app/components/marty/script_form/javascripts/mode/perl/perl.js +816 -0
  114. data/app/components/marty/script_form/javascripts/mode/php/index.html +49 -0
  115. data/app/components/marty/script_form/javascripts/mode/php/php.js +148 -0
  116. data/app/components/marty/script_form/javascripts/mode/pig/index.html +43 -0
  117. data/app/components/marty/script_form/javascripts/mode/pig/pig.js +172 -0
  118. data/app/components/marty/script_form/javascripts/mode/plsql/index.html +63 -0
  119. data/app/components/marty/script_form/javascripts/mode/plsql/plsql.js +217 -0
  120. data/app/components/marty/script_form/javascripts/mode/properties/index.html +41 -0
  121. data/app/components/marty/script_form/javascripts/mode/properties/properties.js +63 -0
  122. data/app/components/marty/script_form/javascripts/mode/python/LICENSE.txt +21 -0
  123. data/app/components/marty/script_form/javascripts/mode/python/index.html +123 -0
  124. data/app/components/marty/script_form/javascripts/mode/python/python.js +338 -0
  125. data/app/components/marty/script_form/javascripts/mode/r/LICENSE +24 -0
  126. data/app/components/marty/script_form/javascripts/mode/r/index.html +74 -0
  127. data/app/components/marty/script_form/javascripts/mode/r/r.js +141 -0
  128. data/app/components/marty/script_form/javascripts/mode/rpm/changes/changes.js +19 -0
  129. data/app/components/marty/script_form/javascripts/mode/rpm/changes/index.html +54 -0
  130. data/app/components/marty/script_form/javascripts/mode/rpm/spec/index.html +100 -0
  131. data/app/components/marty/script_form/javascripts/mode/rpm/spec/spec.css +5 -0
  132. data/app/components/marty/script_form/javascripts/mode/rpm/spec/spec.js +66 -0
  133. data/app/components/marty/script_form/javascripts/mode/rst/index.html +526 -0
  134. data/app/components/marty/script_form/javascripts/mode/rst/rst.js +326 -0
  135. data/app/components/marty/script_form/javascripts/mode/ruby/LICENSE +24 -0
  136. data/app/components/marty/script_form/javascripts/mode/ruby/index.html +172 -0
  137. data/app/components/marty/script_form/javascripts/mode/ruby/ruby.js +195 -0
  138. data/app/components/marty/script_form/javascripts/mode/rust/index.html +49 -0
  139. data/app/components/marty/script_form/javascripts/mode/rust/rust.js +432 -0
  140. data/app/components/marty/script_form/javascripts/mode/scheme/index.html +65 -0
  141. data/app/components/marty/script_form/javascripts/mode/scheme/scheme.js +230 -0
  142. data/app/components/marty/script_form/javascripts/mode/shell/index.html +50 -0
  143. data/app/components/marty/script_form/javascripts/mode/shell/shell.js +118 -0
  144. data/app/components/marty/script_form/javascripts/mode/sieve/LICENSE +23 -0
  145. data/app/components/marty/script_form/javascripts/mode/sieve/index.html +81 -0
  146. data/app/components/marty/script_form/javascripts/mode/sieve/sieve.js +156 -0
  147. data/app/components/marty/script_form/javascripts/mode/smalltalk/index.html +56 -0
  148. data/app/components/marty/script_form/javascripts/mode/smalltalk/smalltalk.js +139 -0
  149. data/app/components/marty/script_form/javascripts/mode/smarty/index.html +83 -0
  150. data/app/components/marty/script_form/javascripts/mode/smarty/smarty.js +148 -0
  151. data/app/components/marty/script_form/javascripts/mode/sparql/index.html +41 -0
  152. data/app/components/marty/script_form/javascripts/mode/sparql/sparql.js +143 -0
  153. data/app/components/marty/script_form/javascripts/mode/stex/index.html +98 -0
  154. data/app/components/marty/script_form/javascripts/mode/stex/stex.js +182 -0
  155. data/app/components/marty/script_form/javascripts/mode/stex/test.js +343 -0
  156. data/app/components/marty/script_form/javascripts/mode/tiddlywiki/index.html +141 -0
  157. data/app/components/marty/script_form/javascripts/mode/tiddlywiki/tiddlywiki.css +14 -0
  158. data/app/components/marty/script_form/javascripts/mode/tiddlywiki/tiddlywiki.js +384 -0
  159. data/app/components/marty/script_form/javascripts/mode/tiki/index.html +83 -0
  160. data/app/components/marty/script_form/javascripts/mode/tiki/tiki.css +26 -0
  161. data/app/components/marty/script_form/javascripts/mode/tiki/tiki.js +309 -0
  162. data/app/components/marty/script_form/javascripts/mode/vb/LICENSE.txt +21 -0
  163. data/app/components/marty/script_form/javascripts/mode/vb/index.html +89 -0
  164. data/app/components/marty/script_form/javascripts/mode/vb/vb.js +260 -0
  165. data/app/components/marty/script_form/javascripts/mode/vbscript/index.html +43 -0
  166. data/app/components/marty/script_form/javascripts/mode/vbscript/vbscript.js +26 -0
  167. data/app/components/marty/script_form/javascripts/mode/velocity/index.html +104 -0
  168. data/app/components/marty/script_form/javascripts/mode/velocity/velocity.js +146 -0
  169. data/app/components/marty/script_form/javascripts/mode/verilog/index.html +211 -0
  170. data/app/components/marty/script_form/javascripts/mode/verilog/verilog.js +194 -0
  171. data/app/components/marty/script_form/javascripts/mode/xml/index.html +45 -0
  172. data/app/components/marty/script_form/javascripts/mode/xml/xml.js +318 -0
  173. data/app/components/marty/script_form/javascripts/mode/xquery/LICENSE +20 -0
  174. data/app/components/marty/script_form/javascripts/mode/xquery/index.html +223 -0
  175. data/app/components/marty/script_form/javascripts/mode/xquery/test/index.html +27 -0
  176. data/app/components/marty/script_form/javascripts/mode/xquery/test/testBase.js +42 -0
  177. data/app/components/marty/script_form/javascripts/mode/xquery/test/testEmptySequenceKeyword.js +16 -0
  178. data/app/components/marty/script_form/javascripts/mode/xquery/test/testMultiAttr.js +16 -0
  179. data/app/components/marty/script_form/javascripts/mode/xquery/test/testNamespaces.js +91 -0
  180. data/app/components/marty/script_form/javascripts/mode/xquery/test/testProcessingInstructions.js +16 -0
  181. data/app/components/marty/script_form/javascripts/mode/xquery/test/testQuotes.js +19 -0
  182. data/app/components/marty/script_form/javascripts/mode/xquery/xquery.js +451 -0
  183. data/app/components/marty/script_form/javascripts/mode/yaml/index.html +68 -0
  184. data/app/components/marty/script_form/javascripts/mode/yaml/yaml.js +95 -0
  185. data/app/components/marty/script_form/javascripts/util/closetag.js +164 -0
  186. data/app/components/marty/script_form/javascripts/util/dialog.css +27 -0
  187. data/app/components/marty/script_form/javascripts/util/dialog.js +70 -0
  188. data/app/components/marty/script_form/javascripts/util/foldcode.js +196 -0
  189. data/app/components/marty/script_form/javascripts/util/formatting.js +193 -0
  190. data/app/components/marty/script_form/javascripts/util/javascript-hint.js +134 -0
  191. data/app/components/marty/script_form/javascripts/util/loadmode.js +51 -0
  192. data/app/components/marty/script_form/javascripts/util/match-highlighter.js +44 -0
  193. data/app/components/marty/script_form/javascripts/util/multiplex.js +77 -0
  194. data/app/components/marty/script_form/javascripts/util/overlay.js +54 -0
  195. data/app/components/marty/script_form/javascripts/util/pig-hint.js +123 -0
  196. data/app/components/marty/script_form/javascripts/util/runmode-standalone.js +90 -0
  197. data/app/components/marty/script_form/javascripts/util/runmode.js +53 -0
  198. data/app/components/marty/script_form/javascripts/util/search.js +118 -0
  199. data/app/components/marty/script_form/javascripts/util/searchcursor.js +119 -0
  200. data/app/components/marty/script_form/javascripts/util/simple-hint.css +16 -0
  201. data/app/components/marty/script_form/javascripts/util/simple-hint.js +97 -0
  202. data/app/components/marty/script_form/javascripts/util/xml-hint.js +137 -0
  203. data/app/components/marty/script_form/stylesheets/codemirror.css +172 -0
  204. data/app/components/marty/script_form/stylesheets/delorean.css +10 -0
  205. data/app/components/marty/script_form/stylesheets/theme/ambiance.css +81 -0
  206. data/app/components/marty/script_form/stylesheets/theme/blackboard.css +25 -0
  207. data/app/components/marty/script_form/stylesheets/theme/cobalt.css +18 -0
  208. data/app/components/marty/script_form/stylesheets/theme/eclipse.css +25 -0
  209. data/app/components/marty/script_form/stylesheets/theme/elegant.css +10 -0
  210. data/app/components/marty/script_form/stylesheets/theme/erlang-dark.css +21 -0
  211. data/app/components/marty/script_form/stylesheets/theme/lesser-dark.css +44 -0
  212. data/app/components/marty/script_form/stylesheets/theme/monokai.css +28 -0
  213. data/app/components/marty/script_form/stylesheets/theme/neat.css +9 -0
  214. data/app/components/marty/script_form/stylesheets/theme/night.css +21 -0
  215. data/app/components/marty/script_form/stylesheets/theme/rubyblue.css +21 -0
  216. data/app/components/marty/script_form/stylesheets/theme/vibrant-ink.css +27 -0
  217. data/app/components/marty/script_form/stylesheets/theme/xq-dark.css +46 -0
  218. data/app/components/marty/script_grid.rb +104 -0
  219. data/app/components/marty/script_grid.rb~ +99 -0
  220. data/app/components/marty/script_tester.rb +114 -0
  221. data/app/components/marty/script_tester.rb~ +213 -0
  222. data/app/components/marty/scripting.rb +132 -0
  223. data/app/components/marty/scripting.rb~ +124 -0
  224. data/app/components/marty/select_report.rb~ +143 -0
  225. data/app/components/marty/simple_app.rb +97 -0
  226. data/app/components/marty/simple_app.rb~ +101 -0
  227. data/app/components/marty/simple_app/javascripts/simple_app.js +50 -0
  228. data/app/components/marty/simple_app/javascripts/statusbar_ext.js +8 -0
  229. data/app/components/marty/tag_grid.rb +83 -0
  230. data/app/components/marty/tag_grid.rb~ +89 -0
  231. data/app/components/marty/tree_panel.rb~ +256 -0
  232. data/app/components/marty/tree_panel/javascripts/tree_panel.js~ +317 -0
  233. data/app/components/marty/user_pivot.rb +128 -0
  234. data/app/components/marty/user_view.rb +181 -0
  235. data/app/components/marty/user_view.rb~ +188 -0
  236. data/app/controllers/marty/application_controller.rb +124 -0
  237. data/app/controllers/marty/application_controller.rb~ +133 -0
  238. data/app/controllers/marty/components_controller.rb +41 -0
  239. data/app/controllers/marty/components_controller.rb~ +37 -0
  240. data/app/controllers/marty/job_controller.rb +28 -0
  241. data/app/controllers/marty/job_controller.rb~ +28 -0
  242. data/app/controllers/marty/rpc_controller.rb +64 -0
  243. data/app/controllers/marty/rpc_controller.rb~ +61 -0
  244. data/app/helpers/marty/application_helper.rb +4 -0
  245. data/app/helpers/marty/script_set.rb +57 -0
  246. data/app/helpers/marty/script_set.rb~ +59 -0
  247. data/app/models/marty/api_auth.rb +44 -0
  248. data/app/models/marty/api_auth.rb~ +48 -0
  249. data/app/models/marty/base.rb +4 -0
  250. data/app/models/marty/data_change.rb +179 -0
  251. data/app/models/marty/data_change.rb~ +141 -0
  252. data/app/models/marty/enum.rb +22 -0
  253. data/app/models/marty/enum.rb~ +16 -0
  254. data/app/models/marty/import_type.rb +44 -0
  255. data/app/models/marty/import_type.rb~ +48 -0
  256. data/app/models/marty/poop.rb~ +169 -0
  257. data/app/models/marty/posting.rb +101 -0
  258. data/app/models/marty/posting.rb~ +86 -0
  259. data/app/models/marty/posting_type.rb +12 -0
  260. data/app/models/marty/posting_type.rb~ +21 -0
  261. data/app/models/marty/promise.rb +252 -0
  262. data/app/models/marty/promise.rb~ +196 -0
  263. data/app/models/marty/role.rb +6 -0
  264. data/app/models/marty/role.rb~ +10 -0
  265. data/app/models/marty/script.rb +144 -0
  266. data/app/models/marty/script.rb~ +62 -0
  267. data/app/models/marty/tag.rb +96 -0
  268. data/app/models/marty/tag.rb~ +91 -0
  269. data/app/models/marty/token.rb +30 -0
  270. data/app/models/marty/user.rb +146 -0
  271. data/app/models/marty/user.rb~ +148 -0
  272. data/app/models/marty/user_role.rb +7 -0
  273. data/app/models/marty/user_role.rb~ +13 -0
  274. data/app/views/layouts/marty/application.html.erb +12 -0
  275. data/app/views/layouts/marty/application.html.erb~ +11 -0
  276. data/config/locales/en.yml +134 -0
  277. data/config/routes.rb +6 -0
  278. data/config/routes.rb~ +10 -0
  279. data/db/migrate/001_create_marty_scripts.rb +14 -0
  280. data/db/migrate/003_create_marty_users.rb +12 -0
  281. data/db/migrate/004_create_marty_roles.rb +7 -0
  282. data/db/migrate/005_create_marty_user_roles.rb +14 -0
  283. data/db/migrate/006_create_marty_tokens.rb +14 -0
  284. data/db/migrate/008_create_marty_posting_types.rb +7 -0
  285. data/db/migrate/019_create_marty_postings.rb +18 -0
  286. data/db/migrate/019_create_marty_postings.rb~ +19 -0
  287. data/db/migrate/068_create_marty_import_types.rb +12 -0
  288. data/db/migrate/069_create_marty_import_synonyms.rb +15 -0
  289. data/db/migrate/070_create_versions.rb +18 -0
  290. data/db/migrate/071_add_object_changes_column_to_versions.rb +9 -0
  291. data/db/migrate/072_add_validation_function_to_import_types.rb +6 -0
  292. data/db/migrate/073_add_preprocess_function_to_import_types.rb +5 -0
  293. data/db/migrate/090_create_delayed_jobs.rb +22 -0
  294. data/db/migrate/091_create_marty_promises.rb +36 -0
  295. data/db/migrate/095_create_marty_tags.rb +14 -0
  296. data/db/migrate/095_create_marty_tags.rb~ +19 -0
  297. data/db/migrate/096_add_user_roles_to_import_types.rb +11 -0
  298. data/db/migrate/097_drop_versions.rb +9 -0
  299. data/db/migrate/098_create_marty_api_auths.rb +20 -0
  300. data/db/seeds.rb +48 -0
  301. data/lib/marty.rb +18 -0
  302. data/lib/marty.rb~ +13 -0
  303. data/lib/marty/content_handler.rb +97 -0
  304. data/lib/marty/content_handler.rb~ +93 -0
  305. data/lib/marty/data_conversion.rb +298 -0
  306. data/lib/marty/data_exporter.rb +150 -0
  307. data/lib/marty/data_exporter.rb~ +137 -0
  308. data/lib/marty/data_importer.rb +122 -0
  309. data/lib/marty/data_importer.rb~ +114 -0
  310. data/lib/marty/data_row_processor.rb~ +206 -0
  311. data/lib/marty/drop_folder_hook.rb~ +17 -0
  312. data/lib/marty/engine.rb +10 -0
  313. data/lib/marty/folder_hook.rb~ +9 -0
  314. data/lib/marty/lazy_column_loader.rb +57 -0
  315. data/lib/marty/lazy_column_loader.rb~ +47 -0
  316. data/lib/marty/mcfly_query.rb +189 -0
  317. data/lib/marty/mcfly_query.rb~ +188 -0
  318. data/lib/marty/migrations.rb +108 -0
  319. data/lib/marty/migrations.rb~ +65 -0
  320. data/lib/marty/monkey.rb +163 -0
  321. data/lib/marty/monkey.rb~ +160 -0
  322. data/lib/marty/permissions.rb +64 -0
  323. data/lib/marty/permissions.rb~ +69 -0
  324. data/lib/marty/promise.rb~ +41 -0
  325. data/lib/marty/promise_job.rb +123 -0
  326. data/lib/marty/promise_job.rb~ +121 -0
  327. data/lib/marty/promise_proxy.rb +94 -0
  328. data/lib/marty/promise_proxy.rb~ +69 -0
  329. data/lib/marty/railtie.rb +5 -0
  330. data/lib/marty/relation.rb +39 -0
  331. data/lib/marty/util.rb +110 -0
  332. data/lib/marty/util.rb~ +80 -0
  333. data/lib/marty/version.rb +3 -0
  334. data/lib/marty/version.rb~ +3 -0
  335. data/lib/marty/xl.rb +527 -0
  336. data/lib/marty/xl.rb~ +526 -0
  337. data/lib/pyxll/README.txt +19 -0
  338. data/lib/pyxll/README.txt~ +16 -0
  339. data/lib/pyxll/gemini.py +155 -0
  340. data/lib/pyxll/gemini.py~ +110 -0
  341. data/lib/pyxll/pyxll.cfg +12 -0
  342. data/lib/pyxll/pyxll.cfg~ +12 -0
  343. data/lib/pyxll/sample.xlsx +0 -0
  344. data/lib/tasks/marty_tasks.rake +37 -0
  345. metadata +517 -0
@@ -0,0 +1,19 @@
1
+ CodeMirror.defineMode("changes", function(config, modeConfig) {
2
+ var headerSeperator = /^-+$/;
3
+ var headerLine = /^(Mon|Tue|Wed|Thu|Fri|Sat|Sun) (Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec) ?\d{1,2} \d{2}:\d{2}(:\d{2})? [A-Z]{3,4} \d{4} - /;
4
+ var simpleEmail = /^[\w+.-]+@[\w.-]+/;
5
+
6
+ return {
7
+ token: function(stream) {
8
+ if (stream.sol()) {
9
+ if (stream.match(headerSeperator)) { return 'tag'; }
10
+ if (stream.match(headerLine)) { return 'tag'; }
11
+ }
12
+ if (stream.match(simpleEmail)) { return 'string'; }
13
+ stream.next();
14
+ return null;
15
+ }
16
+ };
17
+ });
18
+
19
+ CodeMirror.defineMIME("text/x-rpm-changes", "changes");
@@ -0,0 +1,54 @@
1
+ <!doctype html>
2
+ <html>
3
+ <head>
4
+ <meta charset="utf-8">
5
+ <title>CodeMirror: RPM changes mode</title>
6
+ <link rel="stylesheet" href="../../../lib/codemirror.css">
7
+ <script src="../../../lib/codemirror.js"></script>
8
+ <script src="changes.js"></script>
9
+ <link rel="stylesheet" href="../../../doc/docs.css">
10
+ <style type="text/css">.CodeMirror {border-top: 1px solid black; border-bottom: 1px solid black;}</style>
11
+ </head>
12
+ <body>
13
+ <h1>CodeMirror: RPM changes mode</h1>
14
+
15
+ <div><textarea id="code" name="code">
16
+ -------------------------------------------------------------------
17
+ Tue Oct 18 13:58:40 UTC 2011 - misterx@example.com
18
+
19
+ - Update to r60.3
20
+ - Fixes bug in the reflect package
21
+ * disallow Interface method on Value obtained via unexported name
22
+
23
+ -------------------------------------------------------------------
24
+ Thu Oct 6 08:14:24 UTC 2011 - misterx@example.com
25
+
26
+ - Update to r60.2
27
+ - Fixes memory leak in certain map types
28
+
29
+ -------------------------------------------------------------------
30
+ Wed Oct 5 14:34:10 UTC 2011 - misterx@example.com
31
+
32
+ - Tweaks for gdb debugging
33
+ - go.spec changes:
34
+ - move %go_arch definition to %prep section
35
+ - pass correct location of go specific gdb pretty printer and
36
+ functions to cpp as HOST_EXTRA_CFLAGS macro
37
+ - install go gdb functions & printer
38
+ - gdb-printer.patch
39
+ - patch linker (src/cmd/ld/dwarf.c) to emit correct location of go
40
+ gdb functions and pretty printer
41
+ </textarea></div>
42
+ <script>
43
+ var editor = CodeMirror.fromTextArea(document.getElementById("code"), {
44
+ mode: {name: "changes"},
45
+ lineNumbers: true,
46
+ indentUnit: 4,
47
+ tabMode: "shift",
48
+ matchBrackets: true
49
+ });
50
+ </script>
51
+
52
+ <p><strong>MIME types defined:</strong> <code>text/x-rpm-changes</code>.</p>
53
+ </body>
54
+ </html>
@@ -0,0 +1,100 @@
1
+ <!doctype html>
2
+ <html>
3
+ <head>
4
+ <meta charset="utf-8">
5
+ <title>CodeMirror: RPM spec mode</title>
6
+ <link rel="stylesheet" href="../../../lib/codemirror.css">
7
+ <script src="../../../lib/codemirror.js"></script>
8
+ <script src="spec.js"></script>
9
+ <link rel="stylesheet" href="spec.css">
10
+ <link rel="stylesheet" href="../../../doc/docs.css">
11
+ <style type="text/css">.CodeMirror {border-top: 1px solid black; border-bottom: 1px solid black;}</style>
12
+ </head>
13
+ <body>
14
+ <h1>CodeMirror: RPM spec mode</h1>
15
+
16
+ <div><textarea id="code" name="code">
17
+ #
18
+ # spec file for package minidlna
19
+ #
20
+ # Copyright (c) 2011, Sascha Peilicke <saschpe@gmx.de>
21
+ #
22
+ # All modifications and additions to the file contributed by third parties
23
+ # remain the property of their copyright owners, unless otherwise agreed
24
+ # upon. The license for this file, and modifications and additions to the
25
+ # file, is the same license as for the pristine package itself (unless the
26
+ # license for the pristine package is not an Open Source License, in which
27
+ # case the license is the MIT License). An "Open Source License" is a
28
+ # license that conforms to the Open Source Definition (Version 1.9)
29
+ # published by the Open Source Initiative.
30
+
31
+
32
+ Name: libupnp6
33
+ Version: 1.6.13
34
+ Release: 0
35
+ Summary: Portable Universal Plug and Play (UPnP) SDK
36
+ Group: System/Libraries
37
+ License: BSD-3-Clause
38
+ Url: http://sourceforge.net/projects/pupnp/
39
+ Source0: http://downloads.sourceforge.net/pupnp/libupnp-%{version}.tar.bz2
40
+ BuildRoot: %{_tmppath}/%{name}-%{version}-build
41
+
42
+ %description
43
+ The portable Universal Plug and Play (UPnP) SDK provides support for building
44
+ UPnP-compliant control points, devices, and bridges on several operating
45
+ systems.
46
+
47
+ %package -n libupnp-devel
48
+ Summary: Portable Universal Plug and Play (UPnP) SDK
49
+ Group: Development/Libraries/C and C++
50
+ Provides: pkgconfig(libupnp)
51
+ Requires: %{name} = %{version}
52
+
53
+ %description -n libupnp-devel
54
+ The portable Universal Plug and Play (UPnP) SDK provides support for building
55
+ UPnP-compliant control points, devices, and bridges on several operating
56
+ systems.
57
+
58
+ %prep
59
+ %setup -n libupnp-%{version}
60
+
61
+ %build
62
+ %configure --disable-static
63
+ make %{?_smp_mflags}
64
+
65
+ %install
66
+ %makeinstall
67
+ find %{buildroot} -type f -name '*.la' -exec rm -f {} ';'
68
+
69
+ %post -p /sbin/ldconfig
70
+
71
+ %postun -p /sbin/ldconfig
72
+
73
+ %files
74
+ %defattr(-,root,root,-)
75
+ %doc ChangeLog NEWS README TODO
76
+ %{_libdir}/libixml.so.*
77
+ %{_libdir}/libthreadutil.so.*
78
+ %{_libdir}/libupnp.so.*
79
+
80
+ %files -n libupnp-devel
81
+ %defattr(-,root,root,-)
82
+ %{_libdir}/pkgconfig/libupnp.pc
83
+ %{_libdir}/libixml.so
84
+ %{_libdir}/libthreadutil.so
85
+ %{_libdir}/libupnp.so
86
+ %{_includedir}/upnp/
87
+
88
+ %changelog</textarea></div>
89
+ <script>
90
+ var editor = CodeMirror.fromTextArea(document.getElementById("code"), {
91
+ mode: {name: "spec"},
92
+ lineNumbers: true,
93
+ indentUnit: 4,
94
+ matchBrackets: true
95
+ });
96
+ </script>
97
+
98
+ <p><strong>MIME types defined:</strong> <code>text/x-rpm-spec</code>.</p>
99
+ </body>
100
+ </html>
@@ -0,0 +1,5 @@
1
+ .cm-s-default span.cm-preamble {color: #b26818; font-weight: bold;}
2
+ .cm-s-default span.cm-macro {color: #b218b2;}
3
+ .cm-s-default span.cm-section {color: green; font-weight: bold;}
4
+ .cm-s-default span.cm-script {color: red;}
5
+ .cm-s-default span.cm-issue {color: yellow;}
@@ -0,0 +1,66 @@
1
+ // Quick and dirty spec file highlighting
2
+
3
+ CodeMirror.defineMode("spec", function(config, modeConfig) {
4
+ var arch = /^(i386|i586|i686|x86_64|ppc64|ppc|ia64|s390x|s390|sparc64|sparcv9|sparc|noarch|alphaev6|alpha|hppa|mipsel)/;
5
+
6
+ var preamble = /^(Name|Version|Release|License|Summary|Url|Group|Source|BuildArch|BuildRequires|BuildRoot|AutoReqProv|Provides|Requires(\(\w+\))?|Obsoletes|Conflicts|Recommends|Source\d*|Patch\d*|ExclusiveArch|NoSource|Supplements):/;
7
+ var section = /^%(debug_package|package|description|prep|build|install|files|clean|changelog|preun|postun|pre|post|triggerin|triggerun|pretrans|posttrans|verifyscript|check|triggerpostun|triggerprein|trigger)/;
8
+ var control_flow_complex = /^%(ifnarch|ifarch|if)/; // rpm control flow macros
9
+ var control_flow_simple = /^%(else|endif)/; // rpm control flow macros
10
+ var operators = /^(\!|\?|\<\=|\<|\>\=|\>|\=\=|\&\&|\|\|)/; // operators in control flow macros
11
+
12
+ return {
13
+ startState: function () {
14
+ return {
15
+ controlFlow: false,
16
+ macroParameters: false,
17
+ section: false
18
+ };
19
+ },
20
+ token: function (stream, state) {
21
+ var ch = stream.peek();
22
+ if (ch == "#") { stream.skipToEnd(); return "comment"; }
23
+
24
+ if (stream.sol()) {
25
+ if (stream.match(preamble)) { return "preamble"; }
26
+ if (stream.match(section)) { return "section"; }
27
+ }
28
+
29
+ if (stream.match(/^\$\w+/)) { return "def"; } // Variables like '$RPM_BUILD_ROOT'
30
+ if (stream.match(/^\$\{\w+\}/)) { return "def"; } // Variables like '${RPM_BUILD_ROOT}'
31
+
32
+ if (stream.match(control_flow_simple)) { return "keyword"; }
33
+ if (stream.match(control_flow_complex)) {
34
+ state.controlFlow = true;
35
+ return "keyword";
36
+ }
37
+ if (state.controlFlow) {
38
+ if (stream.match(operators)) { return "operator"; }
39
+ if (stream.match(/^(\d+)/)) { return "number"; }
40
+ if (stream.eol()) { state.controlFlow = false; }
41
+ }
42
+
43
+ if (stream.match(arch)) { return "number"; }
44
+
45
+ // Macros like '%make_install' or '%attr(0775,root,root)'
46
+ if (stream.match(/^%[\w]+/)) {
47
+ if (stream.match(/^\(/)) { state.macroParameters = true; }
48
+ return "macro";
49
+ }
50
+ if (state.macroParameters) {
51
+ if (stream.match(/^\d+/)) { return "number";}
52
+ if (stream.match(/^\)/)) {
53
+ state.macroParameters = false;
54
+ return "macro";
55
+ }
56
+ }
57
+ if (stream.match(/^%\{\??[\w \-]+\}/)) { return "macro"; } // Macros like '%{defined fedora}'
58
+
59
+ //TODO: Include bash script sub-parser (CodeMirror supports that)
60
+ stream.next();
61
+ return null;
62
+ }
63
+ };
64
+ });
65
+
66
+ CodeMirror.defineMIME("text/x-rpm-spec", "spec");
@@ -0,0 +1,526 @@
1
+ <!doctype html>
2
+ <html>
3
+ <head>
4
+ <meta charset="utf-8">
5
+ <title>CodeMirror: reStructuredText mode</title>
6
+ <link rel="stylesheet" href="../../lib/codemirror.css">
7
+ <script src="../../lib/codemirror.js"></script>
8
+ <script src="rst.js"></script>
9
+ <style type="text/css">.CodeMirror {border-top: 1px solid black; border-bottom: 1px solid black;}</style>
10
+ <link rel="stylesheet" href="../../doc/docs.css">
11
+ </head>
12
+ <body>
13
+ <h1>CodeMirror: reStructuredText mode</h1>
14
+
15
+ <form><textarea id="code" name="code">
16
+ .. This is an excerpt from Sphinx documentation: http://sphinx.pocoo.org/_sources/rest.txt
17
+
18
+ .. highlightlang:: rest
19
+
20
+ .. _rst-primer:
21
+
22
+ reStructuredText Primer
23
+ =======================
24
+
25
+ This section is a brief introduction to reStructuredText (reST) concepts and
26
+ syntax, intended to provide authors with enough information to author documents
27
+ productively. Since reST was designed to be a simple, unobtrusive markup
28
+ language, this will not take too long.
29
+
30
+ .. seealso::
31
+
32
+ The authoritative `reStructuredText User Documentation
33
+ &lt;http://docutils.sourceforge.net/rst.html&gt;`_. The "ref" links in this
34
+ document link to the description of the individual constructs in the reST
35
+ reference.
36
+
37
+
38
+ Paragraphs
39
+ ----------
40
+
41
+ The paragraph (:duref:`ref &lt;paragraphs&gt;`) is the most basic block in a reST
42
+ document. Paragraphs are simply chunks of text separated by one or more blank
43
+ lines. As in Python, indentation is significant in reST, so all lines of the
44
+ same paragraph must be left-aligned to the same level of indentation.
45
+
46
+
47
+ .. _inlinemarkup:
48
+
49
+ Inline markup
50
+ -------------
51
+
52
+ The standard reST inline markup is quite simple: use
53
+
54
+ * one asterisk: ``*text*`` for emphasis (italics),
55
+ * two asterisks: ``**text**`` for strong emphasis (boldface), and
56
+ * backquotes: ````text```` for code samples.
57
+
58
+ If asterisks or backquotes appear in running text and could be confused with
59
+ inline markup delimiters, they have to be escaped with a backslash.
60
+
61
+ Be aware of some restrictions of this markup:
62
+
63
+ * it may not be nested,
64
+ * content may not start or end with whitespace: ``* text*`` is wrong,
65
+ * it must be separated from surrounding text by non-word characters. Use a
66
+ backslash escaped space to work around that: ``thisis\ *one*\ word``.
67
+
68
+ These restrictions may be lifted in future versions of the docutils.
69
+
70
+ reST also allows for custom "interpreted text roles"', which signify that the
71
+ enclosed text should be interpreted in a specific way. Sphinx uses this to
72
+ provide semantic markup and cross-referencing of identifiers, as described in
73
+ the appropriate section. The general syntax is ``:rolename:`content```.
74
+
75
+ Standard reST provides the following roles:
76
+
77
+ * :durole:`emphasis` -- alternate spelling for ``*emphasis*``
78
+ * :durole:`strong` -- alternate spelling for ``**strong**``
79
+ * :durole:`literal` -- alternate spelling for ````literal````
80
+ * :durole:`subscript` -- subscript text
81
+ * :durole:`superscript` -- superscript text
82
+ * :durole:`title-reference` -- for titles of books, periodicals, and other
83
+ materials
84
+
85
+ See :ref:`inline-markup` for roles added by Sphinx.
86
+
87
+
88
+ Lists and Quote-like blocks
89
+ ---------------------------
90
+
91
+ List markup (:duref:`ref &lt;bullet-lists&gt;`) is natural: just place an asterisk at
92
+ the start of a paragraph and indent properly. The same goes for numbered lists;
93
+ they can also be autonumbered using a ``#`` sign::
94
+
95
+ * This is a bulleted list.
96
+ * It has two items, the second
97
+ item uses two lines.
98
+
99
+ 1. This is a numbered list.
100
+ 2. It has two items too.
101
+
102
+ #. This is a numbered list.
103
+ #. It has two items too.
104
+
105
+
106
+ Nested lists are possible, but be aware that they must be separated from the
107
+ parent list items by blank lines::
108
+
109
+ * this is
110
+ * a list
111
+
112
+ * with a nested list
113
+ * and some subitems
114
+
115
+ * and here the parent list continues
116
+
117
+ Definition lists (:duref:`ref &lt;definition-lists&gt;`) are created as follows::
118
+
119
+ term (up to a line of text)
120
+ Definition of the term, which must be indented
121
+
122
+ and can even consist of multiple paragraphs
123
+
124
+ next term
125
+ Description.
126
+
127
+ Note that the term cannot have more than one line of text.
128
+
129
+ Quoted paragraphs (:duref:`ref &lt;block-quotes&gt;`) are created by just indenting
130
+ them more than the surrounding paragraphs.
131
+
132
+ Line blocks (:duref:`ref &lt;line-blocks&gt;`) are a way of preserving line breaks::
133
+
134
+ | These lines are
135
+ | broken exactly like in
136
+ | the source file.
137
+
138
+ There are also several more special blocks available:
139
+
140
+ * field lists (:duref:`ref &lt;field-lists&gt;`)
141
+ * option lists (:duref:`ref &lt;option-lists&gt;`)
142
+ * quoted literal blocks (:duref:`ref &lt;quoted-literal-blocks&gt;`)
143
+ * doctest blocks (:duref:`ref &lt;doctest-blocks&gt;`)
144
+
145
+
146
+ Source Code
147
+ -----------
148
+
149
+ Literal code blocks (:duref:`ref &lt;literal-blocks&gt;`) are introduced by ending a
150
+ paragraph with the special marker ``::``. The literal block must be indented
151
+ (and, like all paragraphs, separated from the surrounding ones by blank lines)::
152
+
153
+ This is a normal text paragraph. The next paragraph is a code sample::
154
+
155
+ It is not processed in any way, except
156
+ that the indentation is removed.
157
+
158
+ It can span multiple lines.
159
+
160
+ This is a normal text paragraph again.
161
+
162
+ The handling of the ``::`` marker is smart:
163
+
164
+ * If it occurs as a paragraph of its own, that paragraph is completely left
165
+ out of the document.
166
+ * If it is preceded by whitespace, the marker is removed.
167
+ * If it is preceded by non-whitespace, the marker is replaced by a single
168
+ colon.
169
+
170
+ That way, the second sentence in the above example's first paragraph would be
171
+ rendered as "The next paragraph is a code sample:".
172
+
173
+
174
+ .. _rst-tables:
175
+
176
+ Tables
177
+ ------
178
+
179
+ Two forms of tables are supported. For *grid tables* (:duref:`ref
180
+ &lt;grid-tables&gt;`), you have to "paint" the cell grid yourself. They look like
181
+ this::
182
+
183
+ +------------------------+------------+----------+----------+
184
+ | Header row, column 1 | Header 2 | Header 3 | Header 4 |
185
+ | (header rows optional) | | | |
186
+ +========================+============+==========+==========+
187
+ | body row 1, column 1 | column 2 | column 3 | column 4 |
188
+ +------------------------+------------+----------+----------+
189
+ | body row 2 | ... | ... | |
190
+ +------------------------+------------+----------+----------+
191
+
192
+ *Simple tables* (:duref:`ref &lt;simple-tables&gt;`) are easier to write, but
193
+ limited: they must contain more than one row, and the first column cannot
194
+ contain multiple lines. They look like this::
195
+
196
+ ===== ===== =======
197
+ A B A and B
198
+ ===== ===== =======
199
+ False False False
200
+ True False False
201
+ False True False
202
+ True True True
203
+ ===== ===== =======
204
+
205
+
206
+ Hyperlinks
207
+ ----------
208
+
209
+ External links
210
+ ^^^^^^^^^^^^^^
211
+
212
+ Use ```Link text &lt;http://example.com/&gt;`_`` for inline web links. If the link
213
+ text should be the web address, you don't need special markup at all, the parser
214
+ finds links and mail addresses in ordinary text.
215
+
216
+ You can also separate the link and the target definition (:duref:`ref
217
+ &lt;hyperlink-targets&gt;`), like this::
218
+
219
+ This is a paragraph that contains `a link`_.
220
+
221
+ .. _a link: http://example.com/
222
+
223
+
224
+ Internal links
225
+ ^^^^^^^^^^^^^^
226
+
227
+ Internal linking is done via a special reST role provided by Sphinx, see the
228
+ section on specific markup, :ref:`ref-role`.
229
+
230
+
231
+ Sections
232
+ --------
233
+
234
+ Section headers (:duref:`ref &lt;sections&gt;`) are created by underlining (and
235
+ optionally overlining) the section title with a punctuation character, at least
236
+ as long as the text::
237
+
238
+ =================
239
+ This is a heading
240
+ =================
241
+
242
+ Normally, there are no heading levels assigned to certain characters as the
243
+ structure is determined from the succession of headings. However, for the
244
+ Python documentation, this convention is used which you may follow:
245
+
246
+ * ``#`` with overline, for parts
247
+ * ``*`` with overline, for chapters
248
+ * ``=``, for sections
249
+ * ``-``, for subsections
250
+ * ``^``, for subsubsections
251
+ * ``"``, for paragraphs
252
+
253
+ Of course, you are free to use your own marker characters (see the reST
254
+ documentation), and use a deeper nesting level, but keep in mind that most
255
+ target formats (HTML, LaTeX) have a limited supported nesting depth.
256
+
257
+
258
+ Explicit Markup
259
+ ---------------
260
+
261
+ "Explicit markup" (:duref:`ref &lt;explicit-markup-blocks&gt;`) is used in reST for
262
+ most constructs that need special handling, such as footnotes,
263
+ specially-highlighted paragraphs, comments, and generic directives.
264
+
265
+ An explicit markup block begins with a line starting with ``..`` followed by
266
+ whitespace and is terminated by the next paragraph at the same level of
267
+ indentation. (There needs to be a blank line between explicit markup and normal
268
+ paragraphs. This may all sound a bit complicated, but it is intuitive enough
269
+ when you write it.)
270
+
271
+
272
+ .. _directives:
273
+
274
+ Directives
275
+ ----------
276
+
277
+ A directive (:duref:`ref &lt;directives&gt;`) is a generic block of explicit markup.
278
+ Besides roles, it is one of the extension mechanisms of reST, and Sphinx makes
279
+ heavy use of it.
280
+
281
+ Docutils supports the following directives:
282
+
283
+ * Admonitions: :dudir:`attention`, :dudir:`caution`, :dudir:`danger`,
284
+ :dudir:`error`, :dudir:`hint`, :dudir:`important`, :dudir:`note`,
285
+ :dudir:`tip`, :dudir:`warning` and the generic :dudir:`admonition`.
286
+ (Most themes style only "note" and "warning" specially.)
287
+
288
+ * Images:
289
+
290
+ - :dudir:`image` (see also Images_ below)
291
+ - :dudir:`figure` (an image with caption and optional legend)
292
+
293
+ * Additional body elements:
294
+
295
+ - :dudir:`contents` (a local, i.e. for the current file only, table of
296
+ contents)
297
+ - :dudir:`container` (a container with a custom class, useful to generate an
298
+ outer ``&lt;div&gt;`` in HTML)
299
+ - :dudir:`rubric` (a heading without relation to the document sectioning)
300
+ - :dudir:`topic`, :dudir:`sidebar` (special highlighted body elements)
301
+ - :dudir:`parsed-literal` (literal block that supports inline markup)
302
+ - :dudir:`epigraph` (a block quote with optional attribution line)
303
+ - :dudir:`highlights`, :dudir:`pull-quote` (block quotes with their own
304
+ class attribute)
305
+ - :dudir:`compound` (a compound paragraph)
306
+
307
+ * Special tables:
308
+
309
+ - :dudir:`table` (a table with title)
310
+ - :dudir:`csv-table` (a table generated from comma-separated values)
311
+ - :dudir:`list-table` (a table generated from a list of lists)
312
+
313
+ * Special directives:
314
+
315
+ - :dudir:`raw` (include raw target-format markup)
316
+ - :dudir:`include` (include reStructuredText from another file)
317
+ -- in Sphinx, when given an absolute include file path, this directive takes
318
+ it as relative to the source directory
319
+ - :dudir:`class` (assign a class attribute to the next element) [1]_
320
+
321
+ * HTML specifics:
322
+
323
+ - :dudir:`meta` (generation of HTML ``&lt;meta&gt;`` tags)
324
+ - :dudir:`title` (override document title)
325
+
326
+ * Influencing markup:
327
+
328
+ - :dudir:`default-role` (set a new default role)
329
+ - :dudir:`role` (create a new role)
330
+
331
+ Since these are only per-file, better use Sphinx' facilities for setting the
332
+ :confval:`default_role`.
333
+
334
+ Do *not* use the directives :dudir:`sectnum`, :dudir:`header` and
335
+ :dudir:`footer`.
336
+
337
+ Directives added by Sphinx are described in :ref:`sphinxmarkup`.
338
+
339
+ Basically, a directive consists of a name, arguments, options and content. (Keep
340
+ this terminology in mind, it is used in the next chapter describing custom
341
+ directives.) Looking at this example, ::
342
+
343
+ .. function:: foo(x)
344
+ foo(y, z)
345
+ :module: some.module.name
346
+
347
+ Return a line of text input from the user.
348
+
349
+ ``function`` is the directive name. It is given two arguments here, the
350
+ remainder of the first line and the second line, as well as one option
351
+ ``module`` (as you can see, options are given in the lines immediately following
352
+ the arguments and indicated by the colons). Options must be indented to the
353
+ same level as the directive content.
354
+
355
+ The directive content follows after a blank line and is indented relative to the
356
+ directive start.
357
+
358
+
359
+ Images
360
+ ------
361
+
362
+ reST supports an image directive (:dudir:`ref &lt;image&gt;`), used like so::
363
+
364
+ .. image:: gnu.png
365
+ (options)
366
+
367
+ When used within Sphinx, the file name given (here ``gnu.png``) must either be
368
+ relative to the source file, or absolute which means that they are relative to
369
+ the top source directory. For example, the file ``sketch/spam.rst`` could refer
370
+ to the image ``images/spam.png`` as ``../images/spam.png`` or
371
+ ``/images/spam.png``.
372
+
373
+ Sphinx will automatically copy image files over to a subdirectory of the output
374
+ directory on building (e.g. the ``_static`` directory for HTML output.)
375
+
376
+ Interpretation of image size options (``width`` and ``height``) is as follows:
377
+ if the size has no unit or the unit is pixels, the given size will only be
378
+ respected for output channels that support pixels (i.e. not in LaTeX output).
379
+ Other units (like ``pt`` for points) will be used for HTML and LaTeX output.
380
+
381
+ Sphinx extends the standard docutils behavior by allowing an asterisk for the
382
+ extension::
383
+
384
+ .. image:: gnu.*
385
+
386
+ Sphinx then searches for all images matching the provided pattern and determines
387
+ their type. Each builder then chooses the best image out of these candidates.
388
+ For instance, if the file name ``gnu.*`` was given and two files :file:`gnu.pdf`
389
+ and :file:`gnu.png` existed in the source tree, the LaTeX builder would choose
390
+ the former, while the HTML builder would prefer the latter.
391
+
392
+ .. versionchanged:: 0.4
393
+ Added the support for file names ending in an asterisk.
394
+
395
+ .. versionchanged:: 0.6
396
+ Image paths can now be absolute.
397
+
398
+
399
+ Footnotes
400
+ ---------
401
+
402
+ For footnotes (:duref:`ref &lt;footnotes&gt;`), use ``[#name]_`` to mark the footnote
403
+ location, and add the footnote body at the bottom of the document after a
404
+ "Footnotes" rubric heading, like so::
405
+
406
+ Lorem ipsum [#f1]_ dolor sit amet ... [#f2]_
407
+
408
+ .. rubric:: Footnotes
409
+
410
+ .. [#f1] Text of the first footnote.
411
+ .. [#f2] Text of the second footnote.
412
+
413
+ You can also explicitly number the footnotes (``[1]_``) or use auto-numbered
414
+ footnotes without names (``[#]_``).
415
+
416
+
417
+ Citations
418
+ ---------
419
+
420
+ Standard reST citations (:duref:`ref &lt;citations&gt;`) are supported, with the
421
+ additional feature that they are "global", i.e. all citations can be referenced
422
+ from all files. Use them like so::
423
+
424
+ Lorem ipsum [Ref]_ dolor sit amet.
425
+
426
+ .. [Ref] Book or article reference, URL or whatever.
427
+
428
+ Citation usage is similar to footnote usage, but with a label that is not
429
+ numeric or begins with ``#``.
430
+
431
+
432
+ Substitutions
433
+ -------------
434
+
435
+ reST supports "substitutions" (:duref:`ref &lt;substitution-definitions&gt;`), which
436
+ are pieces of text and/or markup referred to in the text by ``|name|``. They
437
+ are defined like footnotes with explicit markup blocks, like this::
438
+
439
+ .. |name| replace:: replacement *text*
440
+
441
+ or this::
442
+
443
+ .. |caution| image:: warning.png
444
+ :alt: Warning!
445
+
446
+ See the :duref:`reST reference for substitutions &lt;substitution-definitions&gt;`
447
+ for details.
448
+
449
+ If you want to use some substitutions for all documents, put them into
450
+ :confval:`rst_prolog` or put them into a separate file and include it into all
451
+ documents you want to use them in, using the :rst:dir:`include` directive. (Be
452
+ sure to give the include file a file name extension differing from that of other
453
+ source files, to avoid Sphinx finding it as a standalone document.)
454
+
455
+ Sphinx defines some default substitutions, see :ref:`default-substitutions`.
456
+
457
+
458
+ Comments
459
+ --------
460
+
461
+ Every explicit markup block which isn't a valid markup construct (like the
462
+ footnotes above) is regarded as a comment (:duref:`ref &lt;comments&gt;`). For
463
+ example::
464
+
465
+ .. This is a comment.
466
+
467
+ You can indent text after a comment start to form multiline comments::
468
+
469
+ ..
470
+ This whole indented block
471
+ is a comment.
472
+
473
+ Still in the comment.
474
+
475
+
476
+ Source encoding
477
+ ---------------
478
+
479
+ Since the easiest way to include special characters like em dashes or copyright
480
+ signs in reST is to directly write them as Unicode characters, one has to
481
+ specify an encoding. Sphinx assumes source files to be encoded in UTF-8 by
482
+ default; you can change this with the :confval:`source_encoding` config value.
483
+
484
+
485
+ Gotchas
486
+ -------
487
+
488
+ There are some problems one commonly runs into while authoring reST documents:
489
+
490
+ * **Separation of inline markup:** As said above, inline markup spans must be
491
+ separated from the surrounding text by non-word characters, you have to use a
492
+ backslash-escaped space to get around that. See `the reference
493
+ &lt;http://docutils.sf.net/docs/ref/rst/restructuredtext.html#inline-markup&gt;`_
494
+ for the details.
495
+
496
+ * **No nested inline markup:** Something like ``*see :func:`foo`*`` is not
497
+ possible.
498
+
499
+
500
+ .. rubric:: Footnotes
501
+
502
+ .. [1] When the default domain contains a :rst:dir:`class` directive, this directive
503
+ will be shadowed. Therefore, Sphinx re-exports it as :rst:dir:`rst-class`.
504
+ </textarea></form>
505
+
506
+ <script>
507
+ var editor = CodeMirror.fromTextArea(document.getElementById("code"), {
508
+ lineNumbers: true,
509
+ });
510
+ </script>
511
+ <p>The reStructuredText mode supports one configuration parameter:</p>
512
+ <dl>
513
+ <dt><code>verbatim (string)</code></dt>
514
+ <dd>A name or MIME type of a mode that will be used for highlighting
515
+ verbatim blocks. By default, reStructuredText mode uses uniform color
516
+ for whole block of verbatim text if no mode is given.</dd>
517
+ </dl>
518
+ <p>If <code>python</code> mode is available,
519
+ it will be used for highlighting blocks containing Python/IPython terminal
520
+ sessions (blocks starting with <code>&gt;&gt;&gt;</code> (for Python) or
521
+ <code>In [num]:</code> (for IPython).
522
+
523
+ <p><strong>MIME types defined:</strong> <code>text/x-rst</code>.</p>
524
+ </body>
525
+ </html>
526
+