opal 0.1.0 → 0.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (255) hide show
  1. data/.gitignore +0 -0
  2. data/.gitmodules +6 -0
  3. data/Opalfile +14 -1
  4. data/README.md +3 -44
  5. data/Rakefile +39 -131
  6. data/VERSION +1 -1
  7. data/extras/compiler.jar +0 -0
  8. data/gen/browser/__PROJECT_NAME__/Rakefile +12 -0
  9. data/gen/browser/__PROJECT_NAME__/index.html +1 -0
  10. data/gen/browser/__PROJECT_NAME__/javascripts/opal.debug.js +4687 -0
  11. data/gen/browser/__PROJECT_NAME__/javascripts/opal.min.js +175 -0
  12. data/lib/opal.rb +1 -0
  13. data/lib/opal/models/project.rb +45 -8
  14. data/lib/opal/opal/build.rb +169 -0
  15. data/lib/opal/opal/env/fs.rb +1 -1
  16. data/lib/opal/opal/environment.rb +2 -2
  17. data/lib/opal/opal/opal.rb +10 -3
  18. data/lib/opal/rake/opal_task.rb +34 -0
  19. data/opal.gemspec +260 -0
  20. data/opals/opal/README.md +37 -0
  21. data/opals/opal/Rakefile +1 -0
  22. data/opals/{browser → opal/browser}/Opalfile +0 -0
  23. data/opals/{browser → opal/browser}/README.md +0 -0
  24. data/opals/{browser → opal/browser}/SIZZLE_LICESNSE.txt +0 -0
  25. data/opals/{browser → opal/browser}/lib/browser.rb +0 -0
  26. data/opals/{browser → opal/browser}/lib/browser/builder.rb +0 -0
  27. data/opals/{browser → opal/browser}/lib/browser/canvas_context.rb +0 -0
  28. data/opals/{browser → opal/browser}/lib/browser/dimensions.rb +0 -0
  29. data/opals/{browser → opal/browser}/lib/browser/document.rb +0 -0
  30. data/opals/{browser → opal/browser}/lib/browser/element.rb +0 -0
  31. data/opals/{browser → opal/browser}/lib/browser/element/attributes.rb +0 -0
  32. data/opals/{browser → opal/browser}/lib/browser/element/css.rb +0 -0
  33. data/opals/{browser → opal/browser}/lib/browser/element/form.rb +0 -0
  34. data/opals/{browser → opal/browser}/lib/browser/event/dom_events.rb +0 -0
  35. data/opals/{browser → opal/browser}/lib/browser/event/event.rb +0 -0
  36. data/opals/{browser → opal/browser}/lib/browser/event/trigger_events.rb +0 -0
  37. data/opals/{browser → opal/browser}/lib/browser/geometry.rb +0 -0
  38. data/opals/{browser → opal/browser}/lib/browser/json.rb +0 -0
  39. data/opals/{browser → opal/browser}/lib/browser/json_parse.js +0 -0
  40. data/opals/{browser → opal/browser}/lib/browser/request/request.rb +0 -0
  41. data/opals/{browser → opal/browser}/lib/browser/sizzle.js +0 -0
  42. data/opals/{browser → opal/browser}/lib/browser/string.rb +0 -0
  43. data/opals/{browser → opal/browser}/lib/browser/touch.rb +0 -0
  44. data/opals/{browser → opal/browser}/lib/browser/vml_context.js +0 -0
  45. data/opals/{browser → opal/browser}/lib/browser/window.rb +0 -0
  46. data/opals/{browser → opal/browser}/spec/browser/browser_detection_spec.rb +0 -0
  47. data/opals/{browser → opal/browser}/spec/document/aref_spec.rb +0 -0
  48. data/opals/{browser → opal/browser}/spec/document/ready_spec.rb +0 -0
  49. data/opals/{browser → opal/browser}/spec/element/body_spec.rb +0 -0
  50. data/opals/{browser → opal/browser}/spec/element/clear_spec.rb +0 -0
  51. data/opals/{browser → opal/browser}/spec/element/empty_spec.rb +0 -0
  52. data/opals/{browser → opal/browser}/spec/element/has_class_spec.rb +0 -0
  53. data/opals/{browser → opal/browser}/spec/element/hidden_spec.rb +0 -0
  54. data/opals/{browser → opal/browser}/spec/element/hide_spec.rb +0 -0
  55. data/opals/{browser → opal/browser}/spec/element/remove_spec.rb +0 -0
  56. data/opals/{browser → opal/browser}/spec/element/show_spec.rb +0 -0
  57. data/opals/{browser → opal/browser}/spec/element/style_spec.rb +0 -0
  58. data/opals/{browser → opal/browser}/spec/element/toggle_spec.rb +0 -0
  59. data/opals/{browser → opal/browser}/spec/element/visible_spec.rb +0 -0
  60. data/opals/{browser → opal/browser}/spec/spec_helper.rb +0 -0
  61. data/opals/opal/{Opalfile → opal/Opalfile} +0 -0
  62. data/opals/opal/{spec → opal/spec}/core/array/append_spec.rb +0 -0
  63. data/opals/opal/{spec → opal/spec}/core/array/assoc_spec.rb +0 -0
  64. data/opals/opal/{spec → opal/spec}/core/array/at_spec.rb +0 -0
  65. data/opals/opal/{spec → opal/spec}/core/array/clear_spec.rb +0 -0
  66. data/opals/opal/{spec → opal/spec}/core/array/collect_bang_spec.rb +0 -0
  67. data/opals/opal/{spec → opal/spec}/core/array/collect_spec.rb +0 -0
  68. data/opals/opal/{spec → opal/spec}/core/array/compact_spec.rb +0 -0
  69. data/opals/opal/{spec → opal/spec}/core/array/concat_spec.rb +0 -0
  70. data/opals/opal/{spec → opal/spec}/core/array/constructor_spec.rb +0 -0
  71. data/opals/opal/{spec → opal/spec}/core/array/each_spec.rb +0 -0
  72. data/opals/opal/{spec → opal/spec}/core/array/element_reference_spec.rb +0 -0
  73. data/opals/opal/{spec → opal/spec}/core/array/first_spec.rb +0 -0
  74. data/opals/opal/{spec → opal/spec}/core/array/include_spec.rb +0 -0
  75. data/opals/opal/{spec → opal/spec}/core/array/map_spec.rb +0 -0
  76. data/opals/opal/{spec → opal/spec}/core/builtin_constants/builtin_constants_spec.rb +0 -0
  77. data/opals/opal/{spec → opal/spec}/core/false/and_spec.rb +0 -0
  78. data/opals/opal/{spec → opal/spec}/core/false/inspect_spec.rb +0 -0
  79. data/opals/opal/{spec → opal/spec}/core/false/or_spec.rb +0 -0
  80. data/opals/opal/{spec → opal/spec}/core/false/to_s_spec.rb +0 -0
  81. data/opals/opal/{spec → opal/spec}/core/false/xor_spec.rb +0 -0
  82. data/opals/opal/{spec → opal/spec}/core/file/join_spec.rb +0 -0
  83. data/opals/opal/{spec → opal/spec}/core/kernel/instance_eval_spec.rb +0 -0
  84. data/opals/opal/{spec → opal/spec}/core/kernel/loop_spec.rb +0 -0
  85. data/opals/opal/{spec → opal/spec}/core/kernel/raise_spec.rb +0 -0
  86. data/opals/opal/{spec → opal/spec}/core/module/attr_accessor_spec.rb +0 -0
  87. data/opals/opal/{spec → opal/spec}/core/number/lt_spec.rb +0 -0
  88. data/opals/opal/{spec → opal/spec}/core/true/and_spec.rb +0 -0
  89. data/opals/opal/{spec → opal/spec}/core/true/inspect_spec.rb +0 -0
  90. data/opals/opal/{spec → opal/spec}/core/true/or_spec.rb +0 -0
  91. data/opals/opal/{spec → opal/spec}/core/true/to_s_spec.rb +0 -0
  92. data/opals/opal/{spec → opal/spec}/core/true/xor_spec.rb +0 -0
  93. data/opals/opal/{spec → opal/spec}/fixtures/super.rb +0 -0
  94. data/opals/opal/{spec → opal/spec}/language/____temp_remove_this.rb +0 -0
  95. data/opals/opal/{spec → opal/spec}/language/and_spec.rb +0 -0
  96. data/opals/opal/{spec → opal/spec}/language/array_spec.rb +0 -0
  97. data/opals/opal/{spec → opal/spec}/language/block_spec.rb +0 -0
  98. data/opals/opal/{spec → opal/spec}/language/break_spec.rb +0 -0
  99. data/opals/opal/{spec → opal/spec}/language/case_spec.rb +0 -0
  100. data/opals/opal/{spec → opal/spec}/language/def_spec.rb +0 -0
  101. data/opals/opal/{spec → opal/spec}/language/eigenclass_spec.rb +0 -0
  102. data/opals/opal/{spec → opal/spec}/language/hash_spec.rb +0 -0
  103. data/opals/opal/{spec → opal/spec}/language/if_spec.rb +0 -0
  104. data/opals/opal/{spec → opal/spec}/language/loop_spec.rb +0 -0
  105. data/opals/opal/{spec → opal/spec}/language/metaclass_spec.rb +0 -0
  106. data/opals/opal/{spec → opal/spec}/language/method_spec.rb +0 -0
  107. data/opals/opal/{spec → opal/spec}/language/next_spec.rb +0 -0
  108. data/opals/opal/{spec → opal/spec}/language/or_spec.rb +0 -0
  109. data/opals/opal/{spec → opal/spec}/language/redo_spec.rb +0 -0
  110. data/opals/opal/{spec → opal/spec}/language/rescue_spec.rb +0 -0
  111. data/opals/opal/{spec → opal/spec}/language/return_spec.rb +0 -0
  112. data/opals/opal/{spec → opal/spec}/language/string_spec.rb +0 -0
  113. data/opals/opal/{spec → opal/spec}/language/super_spec.rb +0 -0
  114. data/opals/opal/{spec → opal/spec}/language/until_spec.rb +0 -0
  115. data/opals/opal/{spec → opal/spec}/language/while_spec.rb +0 -0
  116. data/opals/opal/{spec → opal/spec}/spec_helper.rb +0 -0
  117. data/opals/{runtime → opal/runtime}/Opalfile +10 -0
  118. data/opals/{runtime → opal/runtime}/README.md +0 -0
  119. data/opals/{runtime → opal/runtime}/docs/debugging.md +0 -0
  120. data/opals/{runtime → opal/runtime}/lib/array.rb +0 -0
  121. data/opals/{runtime → opal/runtime}/lib/basic_object.rb +0 -0
  122. data/opals/{runtime → opal/runtime}/lib/class.rb +0 -0
  123. data/opals/{runtime → opal/runtime}/lib/dir.rb +0 -0
  124. data/opals/{runtime → opal/runtime}/lib/error.rb +0 -0
  125. data/opals/{runtime → opal/runtime}/lib/false_class.rb +0 -0
  126. data/opals/{runtime → opal/runtime}/lib/file.rb +0 -0
  127. data/opals/{runtime → opal/runtime}/lib/hash.rb +0 -0
  128. data/opals/{runtime → opal/runtime}/lib/io.rb +0 -0
  129. data/opals/{runtime → opal/runtime}/lib/kernel.rb +0 -0
  130. data/opals/{runtime → opal/runtime}/lib/match_data.rb +0 -0
  131. data/opals/{runtime → opal/runtime}/lib/module.rb +0 -0
  132. data/opals/{runtime → opal/runtime}/lib/nil_class.rb +0 -0
  133. data/opals/{runtime → opal/runtime}/lib/number.rb +0 -0
  134. data/opals/{runtime → opal/runtime}/lib/proc.rb +0 -0
  135. data/opals/{runtime → opal/runtime}/lib/range.rb +0 -0
  136. data/opals/{runtime → opal/runtime}/lib/regexp.rb +0 -0
  137. data/opals/{runtime → opal/runtime}/lib/ruby.rb +0 -0
  138. data/opals/{runtime → opal/runtime}/lib/string.rb +0 -0
  139. data/opals/{runtime → opal/runtime}/lib/symbol.rb +0 -0
  140. data/opals/{runtime → opal/runtime}/lib/top_self.rb +0 -0
  141. data/opals/{runtime → opal/runtime}/lib/true_class.rb +0 -0
  142. data/opals/{runtime → opal/runtime}/runtime/browser.js +0 -0
  143. data/opals/{runtime → opal/runtime}/runtime/debug.js +0 -2
  144. data/opals/{runtime → opal/runtime}/runtime/opal.js +0 -2
  145. data/opals/{runtime → opal/runtime}/runtime/post_opal.js +0 -0
  146. data/opals/{runtime → opal/runtime}/runtime/pre_opal.js +0 -0
  147. data/opals/{runtime → opal/runtime}/runtime/server_side.js +0 -0
  148. data/opals/{spec → opal/spec}/LICENSE.txt +0 -0
  149. data/opals/{spec → opal/spec}/Opalfile +0 -0
  150. data/opals/{spec → opal/spec}/bin/spec.rb +0 -0
  151. data/opals/{spec → opal/spec}/lib/spec.rb +0 -0
  152. data/opals/{spec → opal/spec}/lib/spec/dsl.rb +0 -0
  153. data/opals/{spec → opal/spec}/lib/spec/example.rb +0 -0
  154. data/opals/{spec → opal/spec}/lib/spec/example/before_and_after_hooks.rb +0 -0
  155. data/opals/{spec → opal/spec}/lib/spec/example/errors.rb +0 -0
  156. data/opals/{spec → opal/spec}/lib/spec/example/example_group.rb +0 -0
  157. data/opals/{spec → opal/spec}/lib/spec/example/example_group_factory.rb +0 -0
  158. data/opals/{spec → opal/spec}/lib/spec/example/example_group_hierarchy.rb +0 -0
  159. data/opals/{spec → opal/spec}/lib/spec/example/example_group_methods.rb +0 -0
  160. data/opals/{spec → opal/spec}/lib/spec/example/example_group_proxy.rb +0 -0
  161. data/opals/{spec → opal/spec}/lib/spec/example/example_methods.rb +0 -0
  162. data/opals/{spec → opal/spec}/lib/spec/example/example_proxy.rb +0 -0
  163. data/opals/{spec → opal/spec}/lib/spec/expectations.rb +0 -0
  164. data/opals/{spec → opal/spec}/lib/spec/expectations/errors.rb +0 -0
  165. data/opals/{spec → opal/spec}/lib/spec/expectations/fail_with.rb +0 -0
  166. data/opals/{spec → opal/spec}/lib/spec/expectations/handler.rb +0 -0
  167. data/opals/{spec → opal/spec}/lib/spec/matchers.rb +0 -0
  168. data/opals/{spec → opal/spec}/lib/spec/matchers/be.rb +0 -0
  169. data/opals/{spec → opal/spec}/lib/spec/matchers/generated_descriptions.rb +0 -0
  170. data/opals/{spec → opal/spec}/lib/spec/matchers/operator_matcher.rb +0 -0
  171. data/opals/{spec → opal/spec}/lib/spec/runner.rb +0 -0
  172. data/opals/{spec → opal/spec}/lib/spec/runner/example_group_runner.rb +0 -0
  173. data/opals/{spec → opal/spec}/lib/spec/runner/formatter/html_formatter.rb +0 -0
  174. data/opals/{spec → opal/spec}/lib/spec/runner/formatter/terminal_formatter.rb +0 -0
  175. data/opals/{spec → opal/spec}/lib/spec/runner/options.rb +0 -0
  176. data/opals/{spec → opal/spec}/lib/spec/runner/reporter.rb +0 -0
  177. data/opals/{spec → opal/spec}/resources/index.html +0 -0
  178. data/opals/{spec → opal/spec}/resources/spec.css +0 -0
  179. metadata +170 -238
  180. data/opals/aristo/README.md +0 -16
  181. data/opals/cherry_kit/Opalfile +0 -6
  182. data/opals/cherry_kit/bin/cherry_kit.rb +0 -11
  183. data/opals/cherry_kit/lib/cherry_kit.rb +0 -29
  184. data/opals/foundation/Opalfile +0 -11
  185. data/opals/foundation/bin/foundation.rb +0 -12
  186. data/opals/foundation/lib/foundation.rb +0 -32
  187. data/opals/foundation/lib/foundation/__table_view_desktop/outline_view.rb +0 -57
  188. data/opals/foundation/lib/foundation/__table_view_desktop/table_column.rb +0 -59
  189. data/opals/foundation/lib/foundation/__table_view_desktop/table_header_view.rb +0 -34
  190. data/opals/foundation/lib/foundation/__table_view_desktop/table_view.rb +0 -304
  191. data/opals/foundation/lib/foundation/controllers/array_controller.rb +0 -54
  192. data/opals/foundation/lib/foundation/controllers/controller.rb +0 -74
  193. data/opals/foundation/lib/foundation/controllers/controller_selection_proxy.rb +0 -67
  194. data/opals/foundation/lib/foundation/controllers/object_controller.rb +0 -145
  195. data/opals/foundation/lib/foundation/controllers/view.rb +0 -40
  196. data/opals/foundation/lib/foundation/core/application.rb +0 -476
  197. data/opals/foundation/lib/foundation/core/attributes.rb +0 -146
  198. data/opals/foundation/lib/foundation/core/bindings.rb +0 -125
  199. data/opals/foundation/lib/foundation/core/builder.rb +0 -101
  200. data/opals/foundation/lib/foundation/core/event.rb +0 -112
  201. data/opals/foundation/lib/foundation/core/index_path.rb +0 -49
  202. data/opals/foundation/lib/foundation/core/index_set.rb +0 -97
  203. data/opals/foundation/lib/foundation/core/notification.rb +0 -113
  204. data/opals/foundation/lib/foundation/core/observable.rb +0 -275
  205. data/opals/foundation/lib/foundation/core/observable_array.rb +0 -30
  206. data/opals/foundation/lib/foundation/core/responder.rb +0 -85
  207. data/opals/foundation/lib/foundation/core/run_loop.rb +0 -89
  208. data/opals/foundation/lib/foundation/core/touch.rb +0 -95
  209. data/opals/foundation/lib/foundation/gestures/gesture_recognizer.rb +0 -35
  210. data/opals/foundation/lib/foundation/rendering/render_context.rb +0 -100
  211. data/opals/foundation/lib/foundation/rendering/renderer.rb +0 -137
  212. data/opals/foundation/lib/foundation/rendering/root_theme.rb +0 -77
  213. data/opals/foundation/lib/foundation/rendering/root_theme/button.rb +0 -62
  214. data/opals/foundation/lib/foundation/rendering/root_theme/control.rb +0 -72
  215. data/opals/foundation/lib/foundation/rendering/root_theme/label.rb +0 -54
  216. data/opals/foundation/lib/foundation/rendering/root_theme/scroller.rb +0 -58
  217. data/opals/foundation/lib/foundation/rendering/root_theme/slider.rb +0 -72
  218. data/opals/foundation/lib/foundation/rendering/root_theme/table_view.rb +0 -97
  219. data/opals/foundation/lib/foundation/rendering/root_theme/text_field.rb +0 -55
  220. data/opals/foundation/lib/foundation/rendering/root_theme/view.rb +0 -81
  221. data/opals/foundation/lib/foundation/rendering/theme.rb +0 -38
  222. data/opals/foundation/lib/foundation/table_view/cell.rb +0 -39
  223. data/opals/foundation/lib/foundation/table_view/table.rb +0 -171
  224. data/opals/foundation/lib/foundation/views/button.rb +0 -63
  225. data/opals/foundation/lib/foundation/views/checkbox.rb +0 -28
  226. data/opals/foundation/lib/foundation/views/clip.rb +0 -47
  227. data/opals/foundation/lib/foundation/views/control.rb +0 -199
  228. data/opals/foundation/lib/foundation/views/label.rb +0 -54
  229. data/opals/foundation/lib/foundation/views/scroll.rb +0 -294
  230. data/opals/foundation/lib/foundation/views/scroll_view_desktop.rb +0 -152
  231. data/opals/foundation/lib/foundation/views/scroller.rb +0 -54
  232. data/opals/foundation/lib/foundation/views/slider.rb +0 -93
  233. data/opals/foundation/lib/foundation/views/text_field.rb +0 -83
  234. data/opals/foundation/lib/foundation/views/view.rb +0 -426
  235. data/opals/foundation/lib/foundation/windows/window.rb +0 -191
  236. data/opals/foundation/resources/button/button.css +0 -23
  237. data/opals/foundation/resources/foundation.css +0 -53
  238. data/opals/foundation/resources/scroll/scroll.css +0 -22
  239. data/opals/foundation/resources/scroll_view/scroll_view.css +0 -3
  240. data/opals/foundation/resources/scroll_view/scroller.css +0 -3
  241. data/opals/foundation/resources/slider/regular/slider.css +0 -3
  242. data/opals/foundation/resources/slider/slider.css +0 -27
  243. data/opals/foundation/resources/table_view/outline_view.css +0 -3
  244. data/opals/foundation/resources/table_view/table_view.css +0 -15
  245. data/opals/foundation/resources/text_field/text_field.css +0 -71
  246. data/opals/foundation/spec/spec_helper.rb +0 -1
  247. data/opals/foundation/spec/system/attributes/get_attribute_spec.rb +0 -69
  248. data/opals/foundation/spec/system/attributes/get_path_spec.rb +0 -44
  249. data/opals/foundation/spec/system/attributes/set_path_spec.rb +0 -24
  250. data/opals/foundation/spec/system/attributes/set_spec.rb +0 -58
  251. data/opals/foundation/spec/system/bindings/bindings.rb +0 -85
  252. data/opals/foundation/spec/system/key_value_binding/bind_spec.rb +0 -43
  253. data/opals/foundation/spec/system/observable/dependant_keys_spec.rb +0 -74
  254. data/opals/foundation/spec/system/observable/observe_spec.rb +0 -292
  255. data/opals/foundation/spec/system/observable/remove_observer_spec.rb +0 -60
@@ -1,54 +0,0 @@
1
- #
2
- # array_controller.rb
3
- # vienna
4
- #
5
- # Created by Adam Beynon.
6
- # Copyright 2010 Adam Beynon.
7
- #
8
- # Permission is hereby granted, free of charge, to any person obtaining a copy
9
- # of this software and associated documentation files (the "Software"), to deal
10
- # in the Software without restriction, including without limitation the rights
11
- # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12
- # copies of the Software, and to permit persons to whom the Software is
13
- # furnished to do so, subject to the following conditions:
14
- #
15
- # The above copyright notice and this permission notice shall be included in
16
- # all copies or substantial portions of the Software.
17
- #
18
- # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19
- # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20
- # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21
- # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22
- # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23
- # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24
- # THE SOFTWARE.
25
- #
26
-
27
- require 'foundation/controllers/object_controller'
28
-
29
- module CherryKit
30
-
31
- class ArrayController < ObjectController
32
-
33
- expose_binding :content_array
34
-
35
- attr_accessor :content_array
36
-
37
- attr_writer :preserves_selection
38
-
39
- def preserves_selection?
40
- @preserves_selection
41
- end
42
-
43
- def content=(content)
44
- # make sure content is an array
45
- # unless content.is_a? Array
46
- # content = [content]
47
- # end
48
-
49
-
50
- end
51
-
52
-
53
- end
54
- end
@@ -1,74 +0,0 @@
1
- #
2
- # controller.rb
3
- # vienna
4
- #
5
- # Created by Adam Beynon.
6
- # Copyright 2010 Adam Beynon.
7
- #
8
- # Permission is hereby granted, free of charge, to any person obtaining a copy
9
- # of this software and associated documentation files (the "Software"), to deal
10
- # in the Software without restriction, including without limitation the rights
11
- # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12
- # copies of the Software, and to permit persons to whom the Software is
13
- # furnished to do so, subject to the following conditions:
14
- #
15
- # The above copyright notice and this permission notice shall be included in
16
- # all copies or substantial portions of the Software.
17
- #
18
- # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19
- # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20
- # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21
- # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22
- # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23
- # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24
- # THE SOFTWARE.
25
- #
26
-
27
- require 'foundation/core/bindings'
28
-
29
- module CherryKit
30
-
31
- class Controller
32
-
33
- def initialize
34
- @editors = []
35
- end
36
-
37
- # Returns whether or not this controller is currently editing content
38
- #
39
- # @returns true or false
40
- #
41
- def editing?
42
- @editors.length > 0
43
- end
44
-
45
- def commit_editing?
46
- return true if @editors.length == 0
47
-
48
- result = true
49
-
50
- @editors.each do |editor|
51
- unless editor.commit_editing?
52
- result = false
53
- end
54
- end
55
-
56
- result
57
- end
58
-
59
- def discard_editing
60
- @editors.each do |editor|
61
- editor.discard_editing
62
- end
63
- end
64
-
65
- def object_did_begin_editing(editor)
66
- @editors << editor
67
- end
68
-
69
- def object_did_end_editing(editor)
70
- @editors.delete editor
71
- end
72
-
73
- end
74
- end
@@ -1,67 +0,0 @@
1
- #
2
- # controller_selection_proxy.rb
3
- # vienna
4
- #
5
- # Created by Adam Beynon.
6
- # Copyright 2010 Adam Beynon.
7
- #
8
- # Permission is hereby granted, free of charge, to any person obtaining a copy
9
- # of this software and associated documentation files (the "Software"), to deal
10
- # in the Software without restriction, including without limitation the rights
11
- # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12
- # copies of the Software, and to permit persons to whom the Software is
13
- # furnished to do so, subject to the following conditions:
14
- #
15
- # The above copyright notice and this permission notice shall be included in
16
- # all copies or substantial portions of the Software.
17
- #
18
- # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19
- # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20
- # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21
- # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22
- # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23
- # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24
- # THE SOFTWARE.
25
- #
26
-
27
- module CherryKit
28
-
29
- class ControllerSelectionProxy
30
-
31
- def initialize(controller)
32
- @controller = controller
33
- @values = {}
34
- @proxies = []
35
- end
36
-
37
- def controller_will_change
38
- puts "controller_will_change"
39
- end
40
-
41
- def controller_did_change
42
- puts "controller_did_change"
43
- end
44
-
45
- def get_attribute(attribute)
46
- attribute = attribute.to_s
47
- value = @values[attribute]
48
- return value if value
49
-
50
- values = @controller.selected_objects.get_path attribute
51
- length = values.length
52
-
53
- if length == 0
54
- value = :no_selection
55
- elsif length == 1
56
- value = values[0]
57
- else
58
- value = :selected_objects_many
59
- end
60
-
61
- @values[attribute] = value
62
-
63
- value
64
- # puts "values: #{values.inspect}"
65
- end
66
- end
67
- end
@@ -1,145 +0,0 @@
1
- #
2
- # object_controller.rb
3
- # vienna
4
- #
5
- # Created by Adam Beynon.
6
- # Copyright 2010 Adam Beynon.
7
- #
8
- # Permission is hereby granted, free of charge, to any person obtaining a copy
9
- # of this software and associated documentation files (the "Software"), to deal
10
- # in the Software without restriction, including without limitation the rights
11
- # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12
- # copies of the Software, and to permit persons to whom the Software is
13
- # furnished to do so, subject to the following conditions:
14
- #
15
- # The above copyright notice and this permission notice shall be included in
16
- # all copies or substantial portions of the Software.
17
- #
18
- # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19
- # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20
- # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21
- # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22
- # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23
- # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24
- # THE SOFTWARE.
25
- #
26
-
27
- require 'foundation/controllers/controller'
28
-
29
- module CherryKit
30
-
31
- class ObjectController < Controller
32
-
33
- expose_binding :editable
34
-
35
- expose_binding :content_object
36
-
37
- keys_affecting :can_add => [:editable]
38
-
39
- keys_affecting :can_insert => [:editable]
40
-
41
- keys_affecting :can_remove => [:editable, :selection]
42
-
43
- keys_affecting :content_object => [:content]
44
-
45
- attr_reader :content
46
-
47
- attr_accessor :selection
48
-
49
- attr_accessor :object_class
50
-
51
- def initialize(content)
52
- super
53
- self.content = `#{content} || #{nil}`
54
- self.editable = true
55
- self.object_class = Hash
56
- end
57
-
58
- def content=(content)
59
- # puts "setting content to #{content}"
60
- unless @content == content
61
- will_change_attribute :content_object
62
- _selection_will_change
63
- @content = content
64
- did_change_attribute :content_object
65
- _selection_did_change
66
- end
67
-
68
- content
69
- end
70
-
71
- def _selection_will_change
72
- will_change_attribute :selection
73
- @selection.controller_will_change if @selection
74
- end
75
-
76
- def _selection_did_change
77
- @selection = ControllerSelectionProxy.new(self) unless @selection
78
- @selection.controller_did_change
79
- did_change_attribute :selection
80
- end
81
-
82
- def selected_objects
83
- [@content]
84
- # []
85
- end
86
-
87
- # Create a new instance of the object_class
88
- #
89
- def new_object
90
- object_class.new
91
- end
92
-
93
- # Add the given object
94
- #
95
- def add_object(object)
96
- self.content = object
97
- end
98
-
99
- # An action to add a new object. This simply adds a new instance of our
100
- # object class.
101
- #
102
- def add(sender)
103
- add_object new_object
104
- end
105
-
106
- # True/false whether this object controller is able to add an object. This
107
- # is determined by whether the receiver is editable or not
108
- #
109
- # @returns {true|false}
110
- #
111
- def can_add?
112
- editable?
113
- end
114
-
115
- def can_remove?
116
- editable? && selected_objects.length > 0
117
- end
118
-
119
- def editable?
120
- @editable
121
- end
122
-
123
- def editable=(editable)
124
- @editable = editable
125
- end
126
-
127
- def automatically_prepares_content?
128
- @automatically_prepares_content
129
- end
130
-
131
- attr_writer :automatically_prepares_content
132
-
133
- # def observe
134
-
135
- attr_reader :_observed_keys
136
-
137
- def _content_object
138
- content
139
- end
140
-
141
- def _content_object=(value)
142
- self.content = value
143
- end
144
- end
145
- end
@@ -1,40 +0,0 @@
1
- #
2
- # view.rb
3
- # vienna
4
- #
5
- # Created by Adam Beynon.
6
- # Copyright 2010 Adam Beynon.
7
- #
8
- # Permission is hereby granted, free of charge, to any person obtaining a copy
9
- # of this software and associated documentation files (the "Software"), to deal
10
- # in the Software without restriction, including without limitation the rights
11
- # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12
- # copies of the Software, and to permit persons to whom the Software is
13
- # furnished to do so, subject to the following conditions:
14
- #
15
- # The above copyright notice and this permission notice shall be included in
16
- # all copies or substantial portions of the Software.
17
- #
18
- # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19
- # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20
- # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21
- # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22
- # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23
- # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24
- # THE SOFTWARE.
25
- #
26
-
27
- require 'foundation/core/responder'
28
-
29
- module CherryKit
30
-
31
- class ViewController
32
-
33
- attr_reader :first_name
34
-
35
- def initialize
36
-
37
- end
38
-
39
- end
40
- end
@@ -1,476 +0,0 @@
1
- #
2
- # application.rb
3
- # vienna
4
- #
5
- # Created by Adam Beynon.
6
- # Copyright 2010 Adam Beynon.
7
- #
8
- # Permission is hereby granted, free of charge, to any person obtaining a copy
9
- # of this software and associated documentation files (the "Software"), to deal
10
- # in the Software without restriction, including without limitation the rights
11
- # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12
- # copies of the Software, and to permit persons to whom the Software is
13
- # furnished to do so, subject to the following conditions:
14
- #
15
- # The above copyright notice and this permission notice shall be included in
16
- # all copies or substantial portions of the Software.
17
- #
18
- # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19
- # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20
- # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21
- # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22
- # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23
- # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24
- # THE SOFTWARE.
25
- #
26
-
27
- require 'foundation/core/responder'
28
-
29
- module CherryKit
30
-
31
- # Main Application class to control the lifetime and control flow of events
32
- # through a cherry kit application. Custom behaviour can be setup through
33
- # the application delegate, which by default is the custom AppController
34
- # class.
35
- #
36
- # Notifications
37
- # -------------
38
- #
39
- # On setting the delegate, the delegate is automatically registered to receive
40
- # all of the following notifications on the presumtion that it has a method
41
- # named the same as the notification name. Any methods that are not
42
- # implemented will simply not receive the relevant notification. All
43
- # notifications and methods are optional, but application_did_finish_launching
44
- # is highly recomended as it is the best/required place to setup the
45
- # application GUI.
46
- #
47
- # :application_will_finish_launching - sent when the application is nearly
48
- # ready to run, but before any global events are registered. This is a
49
- # suitable place to perform any additional tasks before the DOM is likely to
50
- # be ready.
51
- #
52
- # :application_did_finish_launching - sent once the DOM has been setup and all
53
- # relevant events are in place. This is a suitable time to load the main
54
- # interface for the application by loading some windows, or using the
55
- # Builder class and its related methods.
56
- #
57
- class Application < Responder
58
-
59
- # The application delegate.
60
- #
61
- attr_reader :delegate
62
-
63
- def initialize
64
- # an array of all our windows
65
- @windows = []
66
- # hash of our touch identifiers to the touches themselves.
67
- @touches = {}
68
- # hash of views to an array of touch identifiers
69
- @touches_for_views = {}
70
- end
71
-
72
- # Register the window for the application
73
- def register_window(window)
74
- @windows << window
75
- end
76
-
77
- # Set the application delegate. This method will register the delegate for
78
- # all notification messages that it has a defined method for.
79
- #
80
- # @param {Object} delegate to set
81
- # @returns delegate
82
- #
83
- def delegate=(delegate)
84
- @delegate = delegate
85
-
86
- center = NotificationCenter.default_center
87
-
88
- notifications = [
89
- :application_will_finish_launching,
90
- :application_did_finish_launching
91
- ]
92
-
93
- notifications.each do |notification|
94
- if delegate.respond_to? notification
95
- center.add_observer delegate, notification, notification, self
96
- end
97
- end
98
-
99
- delegate
100
- end
101
-
102
- # Run the application.
103
- def run
104
- RunLoop.run do
105
- # body class names for css etc
106
- setup_body_class_names
107
- # global application
108
- Object.const_set('CKApp', self)
109
- # our main application window that we create ourselves and give (for
110
- # free to AppController)
111
- window = CherryKit::Window.build({})
112
- window.show
113
- @delegate.window = window
114
- # puts "need to add window to #{@delegate}"
115
- # initial notification that we will finish launching (before events)
116
- notify :application_will_finish_launching
117
- # setup/create all event handlers
118
- setup_event_handlers
119
- # we can post our did finish launching once we have all our events setup
120
- notify :application_did_finish_launching
121
- end
122
- end
123
-
124
- def setup_body_class_names
125
- body = Browser::Element.body
126
- if Browser.safari?
127
- body.class_name = 'safari'
128
- elsif Browser.opera?
129
- body.class_name = 'opera'
130
- elsif Browser.msie?
131
- # also set ie7, ie6, ie8 respectively?
132
- body.class_name = 'msie'
133
- end
134
- end
135
-
136
- def setup_event_handlers
137
- # touch based events..
138
- listen_for Browser.document, :touchstart, :touchmove, :touchend, :touchcancel
139
- # standard mouse events
140
- listen_for Browser.document, :mousedown, :mouseup, :mousemove
141
-
142
- listen_for Browser.document, :keydown, :keyup, :keypress
143
-
144
- # browser window resizing
145
- listen_for Browser.window, :resize
146
-
147
- # browser dependant focus/blur events
148
- if Browser.msie?
149
- # event_handler Browser.document, :focusin
150
- # event_handler Browser.document, :focusout
151
- else
152
- # event_handler Browser.window, :focus
153
- # event_handler Browser.window, :blur
154
- end
155
- end
156
-
157
- def listen_for(target, *events)
158
- events.each do |event|
159
- Browser::Event.listen target, event, __send__("on_#{event}")
160
- end
161
- end
162
-
163
- # Dispatch the event
164
- #
165
- # @param {CherryKit::Event} event to send
166
- # @returns nil
167
- #
168
- def send_event(event)
169
- # keep track of our current event
170
- @current_event = event
171
- # if we have an event handler registered, delegate events to that
172
- if @event_handler
173
- event.view = @event_handler_view
174
- RunLoop.run do
175
- `#{@event_handler}.apply(#{@event_handler}.__self__, [#{event}]);`
176
- end
177
- else
178
- # send event within a runloop block so that all action calls etc are
179
- # caught, as well as view display requests, so we can run them on
180
- # completion of sending the event
181
- RunLoop.run do
182
- # puts "============= sending event on within runloop!"
183
- # puts event.type
184
- # return
185
- # # `console.log(#{event});`
186
- # puts "view for event is: #{event.view}"
187
- # puts "window for event is: #{event.window}"
188
- res = event.window.send_event event
189
- # puts "res is #{res}"
190
- res
191
- end
192
- end
193
- end
194
-
195
- # Set a block delegate for dealing with all events matching the given event
196
- # array. Any other event will simply be ignored until the removal of this
197
- # block.
198
- #
199
- # Note
200
- # ----
201
- # This method will also pass the current event to the block, so in the
202
- # following example, the mouse_down event will be passed as well.
203
- #
204
- # Usage
205
- # -----
206
- #
207
- # app.handle_events([:mouse_down, :mouse_dragged]) do |event|
208
- # puts "got new event #{event}"
209
- # end
210
- #
211
- # @param {Proc} block
212
- #
213
- def handle_events(events, &block)
214
- @event_handler = block
215
- @event_handler_events = events
216
- @event_handler_view = @current_event.view
217
- # resend current event
218
- `#{@event_handler}.apply(#{@event_handler}.__self__, [#{@current_event}]);`
219
- end
220
-
221
- # Discard event capture.
222
- #
223
- def finish_handling_events
224
- @event_handler = nil
225
- @event_handler_events = nil
226
- @event_handler_view = nil
227
- end
228
-
229
- # Get the array for the view, or make it if it does not exist
230
- def touches_for_view(view)
231
- if @touches_for_views[view]
232
- @touches_for_views[view]
233
- else
234
- @touches_for_views[view] = []
235
- end
236
- end
237
-
238
- def setup_touch_began(touch, event)
239
- touch_hierarchy = []
240
- view = touch.view
241
- # get all views in hierarchy
242
- `while(#{view}.r) {
243
- #{touch_hierarchy}.unshift(#{view});
244
- #{view} = #{view.superview};
245
- }`
246
-
247
- capturing_view = nil
248
- to_try = nil
249
-
250
- # find first view that will capture_touches? .. if any
251
- `for (var i = 0; i < #{touch_hierarchy}.length; i++) {
252
- #{to_try} = #{touch_hierarchy}[i];
253
- if (#{to_try.capture_touches?}.r) {
254
- #{capturing_view} = #{to_try};
255
- break;
256
- }
257
- }`
258
-
259
- if capturing_view
260
- touch.view = capturing_view
261
- else
262
- touch.view = event.view
263
- end
264
-
265
- # puts "touch hierarchy is #{touch_hierarchy.inspect}"
266
- # puts "capturing view is #{capturing_view}"
267
- end
268
-
269
- # When the user touches their finger on the document.
270
- def on_touchstart
271
- proc do |event|
272
- RunLoop.run do
273
- # puts "touchstart!"
274
- touches = event.changed_touches
275
- touches.each do |touch|
276
- # keep track of this touch (with identifier)
277
- @touches[touch.identifier] = touch
278
- # assign the event for the touch
279
- touch.event = event
280
- # touch.view = event.view
281
- # puts "touch began #{touch.identifier}"
282
- setup_touch_began touch, event
283
- # we have our right view, so make sure that we can send events to it
284
- # i.e. is it multi touch enabled? cannot send more than one touch
285
- # to non multi touch views
286
- view = touch.view
287
- view_touches = touches_for_view(view)
288
-
289
- if view.multiple_touch_enabled?
290
- puts "can send event!"
291
- view_touches << touch.identifier
292
- touch.view.touches_began(touches, event)
293
- else
294
- # puts "#{view} is not multi touch friendly"
295
- if view_touches.length > 0
296
- # puts "need to drop touch: multitouch not enabled for view"
297
- puts "touch_start: #{touch.identifier} being dropped"
298
- else
299
- view_touches << touch.identifier
300
- puts "touch_start: #{touch.identifier} sending!"
301
- touch.view.touches_began(touches, event)
302
- end
303
- end
304
- end
305
-
306
- # puts event.changed_touches
307
- # puts event.view
308
-
309
- false
310
- end
311
- end
312
- end
313
-
314
- def on_touchend
315
- proc do |event|
316
-
317
- RunLoop.run do
318
- touches = event.changed_touches
319
- touches.each do |touch|
320
- entry = @touches[touch.identifier]
321
-
322
- if @touches_for_views[entry.view].include? touch.identifier
323
- puts "sending touchend for #{entry.identifier}"
324
- entry.event = event
325
- entry.view.touches_ended(touches, event)
326
- @touches_for_views[entry.view].delete touch.identifier
327
- else
328
- # drop event otherwise
329
- # puts "dropping touch end for #{entry.identifier}"
330
- end
331
- end
332
- end
333
-
334
- false
335
- end
336
- end
337
-
338
- def on_touchmove
339
- proc do |event|
340
- RunLoop.run do
341
- # hash of views => touches for that view
342
- view_touches = {}
343
- touches = event.changed_touches
344
- touches.each do |touch|
345
- entry = @touches[touch.identifier]
346
-
347
- unless entry
348
- raise "Application: touchmove: unknown touch #{touch.identifier}"
349
- end
350
-
351
- if @touches_for_views[entry.view].include? touch.identifier
352
- entry.event = event
353
-
354
- view_array = view_touches[entry.view]
355
-
356
- unless view_array
357
- view_array = view_touches[entry.view] = []
358
- end
359
-
360
- view_array << touch
361
-
362
- entry.view.touches_moved(touches, event)
363
- else
364
- # puts "dropping move event for touch #{touch.identifier}"
365
- end
366
-
367
- end
368
- end
369
-
370
- false
371
- end
372
- end
373
-
374
- def on_touchcancel
375
- proc do |event|
376
- puts "touchcancel!"
377
- true
378
- end
379
- end
380
-
381
- # Handles the window's 'resize' event. This method simply posts out
382
- # notifications to alert receivers that the browser window, i.e. screen
383
- # space is being adjusted. By default, every window will listen for these
384
- # notifications so that they can resize and /or move to suit
385
- #
386
- # @param {Browser::Event} event from browser
387
- # @returns self
388
- #
389
- def on_resize
390
- proc do |event|
391
-
392
- end
393
- end
394
-
395
- def on_keydown
396
- proc do |event|
397
- event.type = :key_down
398
- # puts "sending keydown event for #{event.key_code} for #{event.key}"
399
- res = send_event event
400
- # puts "on_keydown handler result is #{res}"
401
- res
402
- end
403
- end
404
-
405
- def on_keyup
406
- proc do |event|
407
- event.type = :key_up
408
- # puts "sending keyup event for #{event.key_code} for #{event.key}"
409
- send_event event
410
- end
411
- end
412
-
413
- def on_keypress
414
- proc do |event|
415
- event.type = :key_down
416
- # puts "sending keypress event for #{event.key_code} for #{event.key}"
417
- return true
418
- end
419
- end
420
-
421
- def on_mousemove
422
- proc do |event|
423
- # must make ruby friendly name - should check if mouse_dragged
424
- event.type = :mouse_moved
425
- # puts "mouse moved!"
426
- send_event event
427
-
428
- true
429
- end
430
- end
431
-
432
- # Handles raw events from the browser for mousedown
433
- #
434
- # @param [Browser::Event] event received
435
- # @returns self
436
- #
437
- def on_mousedown
438
- proc do |event|
439
- # begin
440
- # first we rename the event to our ruby friendly name
441
- event.type = :mouse_down
442
- @mouse_down_view = view = event.view
443
- window = view.window
444
- # get current first responder
445
- first_responder = window.first_responder
446
- # make the view the first responder (if it accepts it)
447
- if view != first_responder && view.accepts_first_responder?
448
- window.make_first_responder? view
449
- end
450
-
451
- send_event event
452
- # rescue Exception => e
453
- # puts "exception occured within Application#on_mousedown"
454
- # raise e
455
- # end
456
-
457
- true
458
- end
459
- end
460
-
461
- # Handles raw mouseup events from browser
462
- #
463
- # @para, [Browser::Event] event received
464
- # @returns self
465
- #
466
- def on_mouseup
467
- proc do |event|
468
- event.type = :mouse_up
469
- send_event event
470
-
471
- true
472
- end
473
- end
474
-
475
- end
476
- end