sproutit-sproutcore 1.0.0.20090416161445 → 1.0.0.20090720093355

Sign up to get free protection for your applications and to get access to all the features.
Files changed (754) hide show
  1. data/Buildfile +4 -2
  2. data/frameworks/sproutcore/Buildfile +3 -2
  3. data/frameworks/sproutcore/README +2 -1
  4. data/frameworks/sproutcore/apps/docs/core.js +27 -0
  5. data/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/QuickLook/Preview.pdf +0 -0
  6. data/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/QuickLook/Thumbnail.tiff +0 -0
  7. data/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/data.plist +14378 -0
  8. data/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/image10.png +0 -0
  9. data/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/image11.png +0 -0
  10. data/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/image13.png +0 -0
  11. data/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/image14.png +0 -0
  12. data/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/image8.png +0 -0
  13. data/frameworks/sproutcore/apps/docs/design/Doc Viewer.graffle/image9.tiff +0 -0
  14. data/frameworks/sproutcore/apps/docs/english.lproj/loading.rhtml +9 -0
  15. data/frameworks/sproutcore/apps/docs/english.lproj/main_page.js +22 -0
  16. data/frameworks/sproutcore/apps/{sc_jsdoc → docs}/english.lproj/strings.js +7 -7
  17. data/frameworks/sproutcore/apps/docs/main.js +30 -0
  18. data/frameworks/sproutcore/apps/tests/controllers/detail.js +16 -0
  19. data/frameworks/sproutcore/apps/tests/controllers/source.js +29 -0
  20. data/frameworks/sproutcore/apps/tests/controllers/target.js +26 -0
  21. data/frameworks/sproutcore/apps/tests/controllers/targets.js +65 -26
  22. data/frameworks/sproutcore/apps/tests/controllers/tests.js +14 -19
  23. data/frameworks/sproutcore/apps/tests/core.js +114 -16
  24. data/frameworks/sproutcore/apps/tests/data_source.js +96 -0
  25. data/frameworks/sproutcore/apps/tests/english.lproj/main_page.css +22 -2
  26. data/frameworks/sproutcore/apps/tests/english.lproj/main_page.js +168 -22
  27. data/frameworks/sproutcore/apps/tests/english.lproj/strings.js +14 -5
  28. data/frameworks/sproutcore/apps/tests/fixtures/target.js +81 -37
  29. data/frameworks/sproutcore/apps/tests/fixtures/test.js +38 -37
  30. data/frameworks/sproutcore/apps/tests/main.js +9 -20
  31. data/frameworks/sproutcore/apps/tests/models/target.js +74 -31
  32. data/frameworks/sproutcore/apps/tests/models/test.js +30 -2
  33. data/frameworks/sproutcore/{frameworks/desktop/mixins/collection_item.js → apps/tests/states/no_targets.js} +16 -12
  34. data/frameworks/sproutcore/apps/tests/states/ready.js +56 -0
  35. data/frameworks/sproutcore/apps/tests/states/ready_detail.js +41 -0
  36. data/frameworks/sproutcore/apps/tests/states/ready_empty.js +48 -0
  37. data/frameworks/sproutcore/apps/tests/states/ready_list.js +41 -0
  38. data/frameworks/sproutcore/apps/tests/states/ready_loading.js +44 -0
  39. data/frameworks/sproutcore/apps/tests/states/ready_no_tests.js +31 -0
  40. data/frameworks/sproutcore/apps/tests/states/start.js +39 -0
  41. data/frameworks/sproutcore/apps/tests/tests/controllers/{test.js → detail.js} +3 -3
  42. data/frameworks/sproutcore/apps/tests/tests/controllers/source.js +15 -0
  43. data/frameworks/sproutcore/apps/tests/tests/controllers/target.js +15 -0
  44. data/frameworks/sproutcore/apps/tests/tests/controllers/targets.js +3 -3
  45. data/frameworks/sproutcore/apps/tests/tests/views/offset_checkbox.js +15 -0
  46. data/frameworks/sproutcore/apps/tests/views/offset_checkbox.js +26 -0
  47. data/frameworks/sproutcore/design/CollectionView State Charts.graffle +4848 -0
  48. data/frameworks/sproutcore/design/Design Charts.graffle +8788 -6375
  49. data/frameworks/sproutcore/design/SproutCore Design Template.graffle/QuickLook/Preview.pdf +0 -0
  50. data/frameworks/sproutcore/design/SproutCore Design Template.graffle/QuickLook/Thumbnail.tiff +0 -0
  51. data/frameworks/sproutcore/design/SproutCore Design Template.graffle/data.plist +1452 -0
  52. data/frameworks/sproutcore/design/SproutCore Design Template.graffle/image8.png +0 -0
  53. data/frameworks/sproutcore/design/TestRunner Design.graffle/QuickLook/Preview.pdf +0 -0
  54. data/frameworks/sproutcore/design/TestRunner Design.graffle/QuickLook/Thumbnail.tiff +0 -0
  55. data/frameworks/sproutcore/design/TestRunner Design.graffle/data.plist +24187 -0
  56. data/frameworks/sproutcore/design/TestRunner Design.graffle/image10.png +0 -0
  57. data/frameworks/sproutcore/design/TestRunner Design.graffle/image11.png +0 -0
  58. data/frameworks/sproutcore/design/TestRunner Design.graffle/image13.png +0 -0
  59. data/frameworks/sproutcore/design/TestRunner Design.graffle/image15.png +0 -0
  60. data/frameworks/sproutcore/design/TestRunner Design.graffle/image16.png +0 -0
  61. data/frameworks/sproutcore/design/TestRunner Design.graffle/image17.png +0 -0
  62. data/frameworks/sproutcore/design/TestRunner Design.graffle/image18.png +0 -0
  63. data/frameworks/sproutcore/design/TestRunner Design.graffle/image19.png +0 -0
  64. data/frameworks/sproutcore/design/TestRunner Design.graffle/image22.tiff +0 -0
  65. data/frameworks/sproutcore/design/TestRunner Design.graffle/image23.png +0 -0
  66. data/frameworks/sproutcore/design/TestRunner Design.graffle/image24.png +0 -0
  67. data/frameworks/sproutcore/design/TestRunner Design.graffle/image25.png +0 -0
  68. data/frameworks/sproutcore/design/TestRunner Design.graffle/image30.png +0 -0
  69. data/frameworks/sproutcore/design/TestRunner Design.graffle/image31.png +0 -0
  70. data/frameworks/sproutcore/design/TestRunner Design.graffle/image8.png +0 -0
  71. data/frameworks/sproutcore/design/TestRunner Design.graffle/image9.png +0 -0
  72. data/frameworks/sproutcore/frameworks/datastore/data_sources/cascade.js +2 -2
  73. data/frameworks/sproutcore/frameworks/datastore/data_sources/data_source.js +66 -49
  74. data/frameworks/sproutcore/frameworks/datastore/data_sources/fixtures.js +146 -31
  75. data/frameworks/sproutcore/frameworks/datastore/data_sources/fixtures_with_queries.js +238 -0
  76. data/frameworks/sproutcore/frameworks/datastore/models/many_attribute.js +27 -11
  77. data/frameworks/sproutcore/frameworks/datastore/models/record.js +163 -32
  78. data/frameworks/sproutcore/frameworks/datastore/models/record_attribute.js +67 -5
  79. data/frameworks/sproutcore/frameworks/datastore/system/many_array.js +157 -0
  80. data/frameworks/sproutcore/frameworks/datastore/system/nested_store.js +202 -19
  81. data/frameworks/sproutcore/frameworks/datastore/system/query.js +929 -78
  82. data/frameworks/sproutcore/frameworks/datastore/system/record_array.js +143 -5
  83. data/frameworks/sproutcore/frameworks/datastore/system/store.js +443 -125
  84. data/frameworks/sproutcore/frameworks/datastore/tests/data_sources/fixtures.js +38 -3
  85. data/frameworks/sproutcore/frameworks/datastore/tests/models/many_attribute.js +94 -0
  86. data/frameworks/sproutcore/frameworks/datastore/tests/models/record/core_methods.js +30 -0
  87. data/frameworks/sproutcore/frameworks/datastore/tests/models/record/normalize.js +238 -0
  88. data/frameworks/sproutcore/frameworks/datastore/tests/models/record_attribute.js +105 -16
  89. data/frameworks/sproutcore/frameworks/datastore/tests/system/many_array/core_methods.js +178 -0
  90. data/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/chain.js +1 -1
  91. data/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/commitChanges.js +9 -8
  92. data/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/commitChangesFromNestedStore.js +6 -6
  93. data/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/dataHashDidChange.js +6 -6
  94. data/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/discardChanges.js +3 -3
  95. data/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/readDataHash.js +7 -7
  96. data/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/readEditableDataHash.js +4 -4
  97. data/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/removeDataHash.js +7 -7
  98. data/frameworks/sproutcore/frameworks/datastore/tests/system/nested_store/writeDataHash.js +7 -7
  99. data/frameworks/sproutcore/frameworks/datastore/tests/system/query/compare_records.js +126 -0
  100. data/frameworks/sproutcore/frameworks/datastore/tests/system/query/evaluation.js +165 -0
  101. data/frameworks/sproutcore/frameworks/datastore/tests/system/query/evaluation_of_records.js +82 -0
  102. data/frameworks/sproutcore/frameworks/datastore/tests/system/query/find_all.js +362 -0
  103. data/frameworks/sproutcore/frameworks/datastore/tests/system/query/parsing.js +170 -0
  104. data/frameworks/sproutcore/frameworks/datastore/tests/system/query/record_type_is.js +43 -0
  105. data/frameworks/sproutcore/frameworks/datastore/tests/system/query/registered_comparisons.js +60 -0
  106. data/frameworks/sproutcore/frameworks/datastore/tests/system/query/registered_query_extensions.js +67 -0
  107. data/frameworks/sproutcore/frameworks/datastore/tests/system/record_array/core_methods.js +2 -13
  108. data/frameworks/sproutcore/frameworks/datastore/tests/system/store/commitRecord.js +3 -4
  109. data/frameworks/sproutcore/frameworks/datastore/tests/system/store/core_methods.js +73 -0
  110. data/frameworks/sproutcore/frameworks/datastore/tests/system/store/createRecord.js +15 -0
  111. data/frameworks/sproutcore/frameworks/datastore/tests/system/store/dataSourceCallbacks.js +4 -2
  112. data/frameworks/sproutcore/frameworks/datastore/tests/system/store/destroyRecord.js +1 -1
  113. data/frameworks/sproutcore/frameworks/datastore/tests/system/store/pushChanges.js +2 -2
  114. data/frameworks/sproutcore/frameworks/datastore/tests/system/store/recordDidChange.js +1 -1
  115. data/frameworks/sproutcore/frameworks/datastore/tests/system/store/retrieveRecord.js +2 -2
  116. data/frameworks/sproutcore/frameworks/debug/core.js +60 -0
  117. data/frameworks/sproutcore/frameworks/deprecated/core.js +0 -2
  118. data/frameworks/sproutcore/frameworks/deprecated/server/server.js +0 -1
  119. data/frameworks/sproutcore/frameworks/deprecated/system/browser.js +0 -2
  120. data/frameworks/sproutcore/frameworks/deprecated/system/classic_responder.js +0 -2
  121. data/frameworks/sproutcore/frameworks/deprecated/system/event.js +0 -2
  122. data/frameworks/sproutcore/frameworks/deprecated/system/misc.js +0 -2
  123. data/frameworks/sproutcore/frameworks/deprecated/system/object.js +0 -2
  124. data/frameworks/sproutcore/frameworks/deprecated/system/path_module.js +0 -1
  125. data/frameworks/sproutcore/frameworks/deprecated/system/string.js +0 -2
  126. data/frameworks/sproutcore/frameworks/designer/coders/design.js +1 -2
  127. data/frameworks/sproutcore/frameworks/designer/coders/localization.js +1 -2
  128. data/frameworks/sproutcore/frameworks/designer/coders/object.js +1 -1
  129. data/frameworks/sproutcore/frameworks/designer/controllers/page_design.js +1 -1
  130. data/frameworks/sproutcore/frameworks/designer/ext/page.js +0 -2
  131. data/frameworks/sproutcore/frameworks/designer/ext/view.js +0 -2
  132. data/frameworks/sproutcore/frameworks/designer/views/controls/button.js +2 -3
  133. data/frameworks/sproutcore/frameworks/designer/views/designer.js +24 -8
  134. data/frameworks/sproutcore/frameworks/designer/views/label.js +1 -2
  135. data/frameworks/sproutcore/frameworks/designer/views/mixins/button.js +0 -2
  136. data/frameworks/sproutcore/frameworks/designer/views/tab.js +1 -2
  137. data/frameworks/sproutcore/frameworks/desktop/english.lproj/alert.css +2 -2
  138. data/frameworks/sproutcore/frameworks/desktop/english.lproj/drag.css +6 -0
  139. data/frameworks/sproutcore/frameworks/desktop/english.lproj/list_item.css +63 -10
  140. data/frameworks/sproutcore/frameworks/desktop/english.lproj/menu_item_view.css +5 -4
  141. data/frameworks/sproutcore/frameworks/desktop/english.lproj/modal.css +5 -0
  142. data/frameworks/sproutcore/frameworks/desktop/english.lproj/panel.css +1 -0
  143. data/frameworks/sproutcore/frameworks/desktop/english.lproj/slider.css +5 -0
  144. data/frameworks/sproutcore/frameworks/desktop/english.lproj/split_divider.css +1 -0
  145. data/frameworks/sproutcore/frameworks/desktop/english.lproj/tab.css +1 -1
  146. data/frameworks/sproutcore/frameworks/desktop/mixins/collection_row_delegate.js +61 -0
  147. data/frameworks/sproutcore/frameworks/desktop/mixins/collection_view_delegate.js +136 -79
  148. data/frameworks/sproutcore/frameworks/desktop/panes/alert.js +55 -24
  149. data/frameworks/sproutcore/frameworks/desktop/panes/menu.js +295 -147
  150. data/frameworks/sproutcore/frameworks/desktop/panes/palette.js +1 -1
  151. data/frameworks/sproutcore/frameworks/desktop/panes/panel.js +1 -1
  152. data/frameworks/sproutcore/frameworks/desktop/panes/picker.js +18 -20
  153. data/frameworks/sproutcore/frameworks/desktop/panes/sheet.js +2 -2
  154. data/frameworks/sproutcore/frameworks/desktop/protocols/drop_target.js +4 -4
  155. data/frameworks/sproutcore/frameworks/desktop/system/drag.js +337 -231
  156. data/frameworks/sproutcore/frameworks/desktop/system/root_responder.js +3 -3
  157. data/frameworks/sproutcore/frameworks/desktop/tests/integration/dialog.js +1 -1
  158. data/frameworks/sproutcore/frameworks/desktop/tests/panes/alert/ui.js +2 -2
  159. data/frameworks/sproutcore/frameworks/desktop/tests/panes/menu/methods.js +46 -1
  160. data/frameworks/sproutcore/frameworks/desktop/tests/panes/menu/ui.js +4 -2
  161. data/frameworks/sproutcore/frameworks/desktop/tests/panes/palette/ui.js +5 -6
  162. data/frameworks/sproutcore/frameworks/desktop/tests/panes/panel/ui.js +11 -11
  163. data/frameworks/sproutcore/frameworks/desktop/tests/panes/picker/ui.js +11 -7
  164. data/frameworks/sproutcore/frameworks/desktop/tests/panes/sheet/ui.js +9 -9
  165. data/frameworks/sproutcore/frameworks/desktop/tests/views/button/ui.js +19 -0
  166. data/frameworks/sproutcore/frameworks/desktop/tests/views/checkbox/methods.js +0 -1
  167. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/content.js +249 -0
  168. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/deleteSelection.js +82 -0
  169. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/deselect.js +199 -0
  170. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/itemViewForContentIndex.js +288 -0
  171. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/layerIdFor.js +65 -0
  172. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/length.js +88 -0
  173. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/mouse.js +165 -0
  174. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/nowShowing.js +121 -0
  175. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/reload.js +177 -0
  176. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/select.js +240 -0
  177. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/selectNextItem.js +191 -0
  178. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/selectPreviousItem.js +197 -39
  179. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/selection.js +141 -0
  180. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/ui_diagram.js +182 -0
  181. data/frameworks/sproutcore/frameworks/desktop/tests/views/list/rowDelegate.js +183 -0
  182. data/frameworks/sproutcore/frameworks/desktop/tests/views/list/rowHeightForContentIndex.js +133 -0
  183. data/frameworks/sproutcore/frameworks/desktop/tests/views/list/rowOffsetForContentIndex.js +132 -0
  184. data/frameworks/sproutcore/frameworks/desktop/tests/views/list/ui_outline.js +56 -0
  185. data/frameworks/sproutcore/frameworks/desktop/tests/views/list/ui_row_heights.js +167 -0
  186. data/frameworks/sproutcore/frameworks/desktop/tests/views/list/ui_simple.js +127 -0
  187. data/frameworks/sproutcore/frameworks/desktop/tests/views/list_item.js +30 -1
  188. data/frameworks/sproutcore/frameworks/desktop/tests/views/menu_item/ui.js +8 -8
  189. data/frameworks/sproutcore/frameworks/desktop/tests/views/progress/ui.js +9 -9
  190. data/frameworks/sproutcore/frameworks/desktop/tests/views/scroller/methods.js +45 -6
  191. data/frameworks/sproutcore/frameworks/desktop/tests/views/segmented/methods.js +2 -1
  192. data/frameworks/sproutcore/frameworks/desktop/tests/views/segmented/ui.js +17 -1
  193. data/frameworks/sproutcore/frameworks/desktop/tests/views/select_field/ui.js +44 -29
  194. data/frameworks/sproutcore/frameworks/desktop/tests/views/stacked/ui_comments.js +231 -0
  195. data/frameworks/sproutcore/frameworks/desktop/tests/views/web/ui.js +1 -1
  196. data/frameworks/sproutcore/frameworks/desktop/views/button.js +15 -4
  197. data/frameworks/sproutcore/frameworks/desktop/views/checkbox.js +8 -1
  198. data/frameworks/sproutcore/frameworks/desktop/views/collection.js +1739 -1123
  199. data/frameworks/sproutcore/frameworks/desktop/views/form.js +0 -1
  200. data/frameworks/sproutcore/frameworks/desktop/views/grid.js +13 -11
  201. data/frameworks/sproutcore/frameworks/desktop/views/list.js +405 -571
  202. data/frameworks/sproutcore/frameworks/desktop/views/list_item.js +211 -74
  203. data/frameworks/sproutcore/frameworks/desktop/views/menu_item.js +319 -169
  204. data/frameworks/sproutcore/frameworks/desktop/views/popup_button.js +57 -51
  205. data/frameworks/sproutcore/frameworks/desktop/views/progress.js +2 -2
  206. data/frameworks/sproutcore/frameworks/desktop/views/scene.js +150 -2
  207. data/frameworks/sproutcore/frameworks/desktop/views/scroll.js +92 -50
  208. data/frameworks/sproutcore/frameworks/desktop/views/scroller.js +86 -63
  209. data/frameworks/sproutcore/frameworks/desktop/views/segmented.js +38 -22
  210. data/frameworks/sproutcore/frameworks/desktop/views/select_field.js +51 -12
  211. data/frameworks/sproutcore/frameworks/desktop/views/slider.js +2 -0
  212. data/frameworks/sproutcore/frameworks/desktop/views/source_list.js +17 -1087
  213. data/frameworks/sproutcore/frameworks/desktop/views/source_list_group.js +3 -3
  214. data/frameworks/sproutcore/frameworks/desktop/views/split.js +35 -9
  215. data/frameworks/sproutcore/frameworks/desktop/views/stacked.js +101 -0
  216. data/frameworks/sproutcore/frameworks/desktop/views/tab.js +23 -22
  217. data/frameworks/sproutcore/frameworks/desktop/views/toolbar.js +1 -1
  218. data/frameworks/sproutcore/frameworks/foundation/controllers/array.js +382 -363
  219. data/frameworks/sproutcore/frameworks/foundation/controllers/controller.js +7 -279
  220. data/frameworks/sproutcore/frameworks/foundation/controllers/object.js +212 -310
  221. data/frameworks/sproutcore/frameworks/foundation/controllers/tree.js +109 -0
  222. data/frameworks/sproutcore/frameworks/foundation/core.js +25 -0
  223. data/frameworks/sproutcore/frameworks/foundation/debug/control_test_pane.js +30 -8
  224. data/frameworks/sproutcore/frameworks/foundation/english.lproj/bootstrap.rhtml +19 -4
  225. data/frameworks/sproutcore/frameworks/foundation/english.lproj/core.css +219 -3
  226. data/frameworks/sproutcore/frameworks/foundation/english.lproj/debug/control-test-pane.css +1 -0
  227. data/frameworks/sproutcore/frameworks/foundation/english.lproj/label.css +30 -0
  228. data/frameworks/sproutcore/frameworks/foundation/english.lproj/strings.js +15 -0
  229. data/frameworks/sproutcore/frameworks/{desktop → foundation}/english.lproj/text_field.css +19 -3
  230. data/frameworks/sproutcore/frameworks/foundation/english.lproj/view.css +6 -1
  231. data/frameworks/sproutcore/frameworks/foundation/license.js +19 -0
  232. data/frameworks/sproutcore/frameworks/foundation/mixins/button.js +15 -7
  233. data/frameworks/sproutcore/frameworks/foundation/mixins/collection_content.js +171 -0
  234. data/frameworks/sproutcore/frameworks/foundation/mixins/control.js +5 -5
  235. data/frameworks/sproutcore/frameworks/foundation/mixins/inline_text_field.js +462 -0
  236. data/frameworks/sproutcore/frameworks/foundation/mixins/selection_support.js +162 -84
  237. data/frameworks/sproutcore/frameworks/foundation/mixins/static_layout.js +33 -2
  238. data/frameworks/sproutcore/frameworks/foundation/mixins/string.js +17 -3
  239. data/frameworks/sproutcore/frameworks/foundation/mixins/tree_item_content.js +159 -0
  240. data/frameworks/sproutcore/frameworks/foundation/panes/pane.js +49 -20
  241. data/frameworks/sproutcore/frameworks/foundation/private/tree_item_observer.js +887 -0
  242. data/frameworks/sproutcore/frameworks/foundation/system/application.js +36 -0
  243. data/frameworks/sproutcore/frameworks/foundation/system/benchmark.js +310 -62
  244. data/frameworks/sproutcore/frameworks/foundation/system/datetime.js +729 -0
  245. data/frameworks/sproutcore/frameworks/foundation/system/event.js +57 -21
  246. data/frameworks/sproutcore/frameworks/foundation/system/ready.js +11 -5
  247. data/frameworks/sproutcore/frameworks/foundation/system/render_context.js +55 -16
  248. data/frameworks/sproutcore/frameworks/foundation/system/request.js +152 -27
  249. data/frameworks/sproutcore/frameworks/foundation/system/responder.js +120 -0
  250. data/frameworks/sproutcore/frameworks/foundation/system/responder_context.js +243 -0
  251. data/frameworks/sproutcore/frameworks/foundation/system/root_responder.js +29 -6
  252. data/frameworks/sproutcore/frameworks/foundation/system/routes.js +143 -102
  253. data/frameworks/sproutcore/frameworks/foundation/system/user_defaults.js +9 -2
  254. data/frameworks/sproutcore/frameworks/foundation/system/utils.js +104 -9
  255. data/frameworks/sproutcore/frameworks/foundation/tests/controllers/array/array_case.js +182 -0
  256. data/frameworks/sproutcore/frameworks/foundation/tests/controllers/array/enum_case.js +193 -0
  257. data/frameworks/sproutcore/frameworks/foundation/tests/controllers/array/null_case.js +64 -0
  258. data/frameworks/sproutcore/frameworks/foundation/tests/controllers/array/single_case.js +136 -0
  259. data/frameworks/sproutcore/frameworks/foundation/tests/controllers/object/empty_case.js +82 -0
  260. data/frameworks/sproutcore/frameworks/foundation/tests/controllers/object/multiple_case.js +111 -0
  261. data/frameworks/sproutcore/frameworks/foundation/tests/controllers/object/single_case.js +193 -0
  262. data/frameworks/sproutcore/frameworks/foundation/tests/controllers/object/single_enumerable_case.js +179 -0
  263. data/frameworks/sproutcore/frameworks/foundation/tests/controllers/tree/outline_case.js +108 -0
  264. data/frameworks/sproutcore/frameworks/foundation/tests/mixins/button/keyEquivalents.js +35 -0
  265. data/frameworks/sproutcore/frameworks/foundation/tests/mixins/staticLayout.js +128 -0
  266. data/frameworks/sproutcore/frameworks/foundation/tests/mixins/string.js +17 -0
  267. data/frameworks/sproutcore/frameworks/foundation/tests/private/tree_item_observer/flat_case.js +325 -0
  268. data/frameworks/sproutcore/frameworks/foundation/tests/private/tree_item_observer/group_case.js +718 -0
  269. data/frameworks/sproutcore/frameworks/foundation/tests/private/tree_item_observer/outline_case.js +484 -0
  270. data/frameworks/sproutcore/frameworks/foundation/tests/system/core_query/jquery_core.js +28 -28
  271. data/frameworks/sproutcore/frameworks/foundation/tests/system/core_query/jquery_selector.js +1 -1
  272. data/frameworks/sproutcore/frameworks/foundation/tests/system/datetime.js +151 -0
  273. data/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/get.js +2 -2
  274. data/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/helpers_attr.js +1 -1
  275. data/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/helpers_basic.js +1 -1
  276. data/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/helpers_className.js +12 -12
  277. data/frameworks/sproutcore/frameworks/foundation/tests/system/render_context/helpers_style.js +1 -1
  278. data/frameworks/sproutcore/frameworks/foundation/tests/system/request.js +52 -14
  279. data/frameworks/sproutcore/frameworks/foundation/tests/system/root_responder/root_responder.js +27 -23
  280. data/frameworks/sproutcore/frameworks/foundation/tests/system/timer/schedule.js +1 -1
  281. data/frameworks/sproutcore/frameworks/foundation/tests/validators/date.js +12 -10
  282. data/frameworks/sproutcore/frameworks/foundation/tests/views/label/ui.js +148 -0
  283. data/frameworks/sproutcore/frameworks/foundation/tests/views/pane/append_remove.js +1 -1
  284. data/frameworks/sproutcore/frameworks/{desktop → foundation}/tests/views/text_field/methods.js +0 -0
  285. data/frameworks/sproutcore/frameworks/{desktop → foundation}/tests/views/text_field/ui.js +53 -1
  286. data/frameworks/sproutcore/frameworks/foundation/tests/views/view/clippingFrame.js +1 -0
  287. data/frameworks/sproutcore/frameworks/foundation/tests/views/view/convertFrames.js +1 -1
  288. data/frameworks/sproutcore/frameworks/foundation/tests/views/view/createChildViews.js +35 -0
  289. data/frameworks/sproutcore/frameworks/foundation/tests/views/view/findLayerInParentLayer.js +1 -1
  290. data/frameworks/sproutcore/frameworks/foundation/tests/views/view/isVisible.js +51 -0
  291. data/frameworks/sproutcore/frameworks/foundation/tests/views/view/isVisibleInWindow.js +12 -1
  292. data/frameworks/sproutcore/frameworks/foundation/tests/views/view/layoutStyle.js +83 -3
  293. data/frameworks/sproutcore/frameworks/foundation/tests/views/view/prepareContext.js +1 -1
  294. data/frameworks/sproutcore/frameworks/foundation/tests/views/view/updateLayer.js +4 -0
  295. data/frameworks/sproutcore/frameworks/foundation/views/container.js +1 -1
  296. data/frameworks/sproutcore/frameworks/foundation/views/field.js +27 -16
  297. data/frameworks/sproutcore/frameworks/foundation/views/image.js +4 -1
  298. data/frameworks/sproutcore/frameworks/foundation/views/label.js +16 -6
  299. data/frameworks/sproutcore/frameworks/{desktop → foundation}/views/text_field.js +39 -15
  300. data/frameworks/sproutcore/frameworks/foundation/views/view.js +328 -83
  301. data/frameworks/sproutcore/frameworks/runtime/README +1 -0
  302. data/frameworks/sproutcore/frameworks/runtime/core.js +110 -31
  303. data/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/base.js +238 -0
  304. data/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/indexOf.js +33 -0
  305. data/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/insertAt.js +121 -0
  306. data/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/objectAt.js +34 -0
  307. data/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/popObject.js +50 -0
  308. data/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/pushObject.js +46 -0
  309. data/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/rangeObserver.js +371 -0
  310. data/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/removeAt.js +100 -0
  311. data/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/removeObject.js +49 -0
  312. data/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/replace.js +94 -0
  313. data/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/shiftObject.js +50 -0
  314. data/frameworks/sproutcore/frameworks/runtime/debug/test_suites/array/unshiftObject.js +47 -0
  315. data/frameworks/sproutcore/frameworks/runtime/mixins/array.js +320 -110
  316. data/frameworks/sproutcore/frameworks/runtime/mixins/copyable.js +64 -0
  317. data/frameworks/sproutcore/frameworks/runtime/mixins/delegate_support.js +44 -6
  318. data/frameworks/sproutcore/frameworks/runtime/mixins/enumerable.js +142 -77
  319. data/frameworks/sproutcore/frameworks/runtime/mixins/freezable.js +104 -0
  320. data/frameworks/sproutcore/frameworks/runtime/mixins/observable.js +298 -142
  321. data/frameworks/sproutcore/frameworks/runtime/private/chain_observer.js +17 -11
  322. data/frameworks/sproutcore/frameworks/runtime/private/observer_queue.js +55 -15
  323. data/frameworks/sproutcore/frameworks/runtime/private/observer_set.js +29 -5
  324. data/frameworks/sproutcore/frameworks/runtime/protocols/observable_protocol.js +40 -0
  325. data/frameworks/sproutcore/frameworks/runtime/system/binding.js +39 -15
  326. data/frameworks/sproutcore/frameworks/runtime/system/index_set.js +1166 -0
  327. data/frameworks/sproutcore/frameworks/runtime/system/object.js +33 -15
  328. data/frameworks/sproutcore/frameworks/runtime/system/range_observer.js +201 -35
  329. data/frameworks/sproutcore/frameworks/runtime/system/run_loop.js +42 -15
  330. data/frameworks/sproutcore/frameworks/runtime/system/selection_set.js +649 -0
  331. data/frameworks/sproutcore/frameworks/runtime/system/set.js +183 -54
  332. data/frameworks/sproutcore/frameworks/runtime/system/sparse_array.js +20 -11
  333. data/frameworks/sproutcore/frameworks/runtime/tests/core/clone.js +2 -2
  334. data/frameworks/sproutcore/frameworks/runtime/tests/core/compare.js +44 -0
  335. data/frameworks/sproutcore/frameworks/runtime/tests/core/console.js +16 -0
  336. data/frameworks/sproutcore/frameworks/runtime/tests/core/keys.js +1 -1
  337. data/frameworks/sproutcore/frameworks/runtime/tests/core/makeArray.js +1 -1
  338. data/frameworks/sproutcore/frameworks/runtime/tests/core/objectForPropertyPath.js +5 -5
  339. data/frameworks/sproutcore/frameworks/runtime/tests/mixins/array.js +57 -0
  340. data/frameworks/sproutcore/frameworks/runtime/tests/mixins/enumerable.js +21 -2
  341. data/frameworks/sproutcore/frameworks/runtime/tests/mixins/observable/observable.js +249 -129
  342. data/frameworks/sproutcore/frameworks/runtime/tests/mixins/observable/propertyChanges.js +11 -2
  343. data/frameworks/sproutcore/frameworks/runtime/tests/private/observer_queue/isObservingSuspended.js +55 -0
  344. data/frameworks/sproutcore/frameworks/runtime/tests/system/binding.js +81 -6
  345. data/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/add.js +195 -0
  346. data/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/clone.js +43 -0
  347. data/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/contains.js +74 -0
  348. data/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/create.js +42 -0
  349. data/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/indexAfter.js +38 -0
  350. data/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/indexBefore.js +38 -0
  351. data/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/intersects.js +74 -0
  352. data/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/max.js +40 -0
  353. data/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/min.js +40 -0
  354. data/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/rangeStartForIndex.js +36 -0
  355. data/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/remove.js +189 -0
  356. data/frameworks/sproutcore/frameworks/runtime/tests/system/index_set/without.js +89 -0
  357. data/frameworks/sproutcore/frameworks/runtime/tests/system/object/base.js +1 -1
  358. data/frameworks/sproutcore/frameworks/runtime/tests/system/range_observer/create.js +59 -0
  359. data/frameworks/sproutcore/frameworks/runtime/tests/system/range_observer/destroy.js +75 -0
  360. data/frameworks/sproutcore/frameworks/runtime/tests/system/range_observer/objectPropertyDidChange.js +117 -0
  361. data/frameworks/sproutcore/frameworks/runtime/tests/system/range_observer/rangeDidChange.js +110 -0
  362. data/frameworks/sproutcore/frameworks/runtime/tests/system/range_observer/update.js +65 -0
  363. data/frameworks/sproutcore/frameworks/runtime/tests/system/run_loop.js +3 -3
  364. data/frameworks/sproutcore/frameworks/runtime/tests/system/selection_set/add.js +92 -0
  365. data/frameworks/sproutcore/frameworks/runtime/tests/system/selection_set/copy.js +17 -0
  366. data/frameworks/sproutcore/frameworks/runtime/tests/system/selection_set/indexSetForSource.js +85 -0
  367. data/frameworks/sproutcore/frameworks/runtime/tests/system/selection_set/isEqual.js +60 -0
  368. data/frameworks/sproutcore/frameworks/runtime/tests/system/selection_set/remove.js +87 -0
  369. data/frameworks/sproutcore/frameworks/runtime/tests/system/set.js +4 -25
  370. data/frameworks/sproutcore/frameworks/runtime/tests/system/sparse_array.js +39 -1
  371. data/frameworks/sproutcore/frameworks/testing/core.js +183 -0
  372. data/frameworks/sproutcore/frameworks/testing/english.lproj/runner.css +126 -0
  373. data/frameworks/sproutcore/frameworks/testing/extras.js +0 -26
  374. data/frameworks/sproutcore/frameworks/testing/qunit.js +33 -25
  375. data/frameworks/sproutcore/frameworks/testing/system/dump.js +205 -0
  376. data/frameworks/sproutcore/frameworks/testing/system/equiv.js +201 -0
  377. data/frameworks/sproutcore/frameworks/testing/system/plan.js +691 -0
  378. data/frameworks/sproutcore/frameworks/testing/system/runner.js +209 -0
  379. data/frameworks/sproutcore/frameworks/testing/system/suite.js +228 -0
  380. data/frameworks/sproutcore/frameworks/testing/utils.js +8 -1
  381. data/frameworks/sproutcore/lib/index.rhtml +4 -1
  382. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/10.png +0 -0
  383. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/100.png +0 -0
  384. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/102.png +0 -0
  385. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/110.png +0 -0
  386. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/120.png +0 -0
  387. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/127.png +0 -0
  388. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/18.png +0 -0
  389. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/19.png +0 -0
  390. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/2.png +0 -0
  391. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/24.png +0 -0
  392. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/26.png +0 -0
  393. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/27.png +0 -0
  394. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/28.png +0 -0
  395. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/29.png +0 -0
  396. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/30.png +0 -0
  397. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/31.png +0 -0
  398. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/33.png +0 -0
  399. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/37.png +0 -0
  400. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/41.png +0 -0
  401. data/frameworks/sproutcore/themes/standard_theme/Source/icons/16/99.png +0 -0
  402. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/10.png +0 -0
  403. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/100.png +0 -0
  404. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/102.png +0 -0
  405. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/110.png +0 -0
  406. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/120.png +0 -0
  407. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/127.png +0 -0
  408. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/18.png +0 -0
  409. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/19.png +0 -0
  410. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/2.png +0 -0
  411. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/24.png +0 -0
  412. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/26.png +0 -0
  413. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/27.png +0 -0
  414. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/28.png +0 -0
  415. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/29.png +0 -0
  416. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/30.png +0 -0
  417. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/31.png +0 -0
  418. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/33.png +0 -0
  419. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/37.png +0 -0
  420. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/41.png +0 -0
  421. data/frameworks/sproutcore/themes/standard_theme/Source/icons/24/99.png +0 -0
  422. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/10.png +0 -0
  423. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/100.png +0 -0
  424. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/102.png +0 -0
  425. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/110.png +0 -0
  426. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/120.png +0 -0
  427. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/127.png +0 -0
  428. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/18.png +0 -0
  429. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/19.png +0 -0
  430. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/2.png +0 -0
  431. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/24.png +0 -0
  432. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/26.png +0 -0
  433. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/27.png +0 -0
  434. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/28.png +0 -0
  435. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/29.png +0 -0
  436. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/30.png +0 -0
  437. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/31.png +0 -0
  438. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/33.png +0 -0
  439. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/37.png +0 -0
  440. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/41.png +0 -0
  441. data/frameworks/sproutcore/themes/standard_theme/Source/icons/32/99.png +0 -0
  442. data/frameworks/sproutcore/themes/standard_theme/Source/icons/48/10.png +0 -0
  443. data/frameworks/sproutcore/themes/standard_theme/Source/icons/48/18.png +0 -0
  444. data/frameworks/sproutcore/themes/standard_theme/Source/icons/48/19.png +0 -0
  445. data/frameworks/sproutcore/themes/standard_theme/Source/icons/48/2.png +0 -0
  446. data/frameworks/sproutcore/themes/standard_theme/Source/sc-theme-repeat-x-2.psd +0 -0
  447. data/frameworks/sproutcore/themes/standard_theme/Source/sc-theme-repeat-x.psd +0 -0
  448. data/frameworks/sproutcore/themes/standard_theme/Source/sc-theme-sprite.psd +0 -0
  449. data/frameworks/sproutcore/themes/standard_theme/Source/sc-theme-ysprite.psd +0 -0
  450. data/frameworks/sproutcore/themes/standard_theme/Source/shared-icons.psd +0 -0
  451. data/frameworks/sproutcore/themes/standard_theme/Source/sproutcore-logo.psd +0 -0
  452. data/frameworks/sproutcore/themes/standard_theme/Source/sticky-note.psd +0 -0
  453. data/frameworks/sproutcore/themes/standard_theme/english.lproj/button.css +191 -193
  454. data/frameworks/sproutcore/themes/standard_theme/english.lproj/checkbox.css +11 -10
  455. data/frameworks/sproutcore/themes/standard_theme/english.lproj/collection.css +85 -4
  456. data/frameworks/sproutcore/themes/standard_theme/english.lproj/core.css +15 -2
  457. data/frameworks/sproutcore/themes/standard_theme/english.lproj/images/sc-theme-repeat-x.png +0 -0
  458. data/frameworks/sproutcore/themes/standard_theme/english.lproj/label.css +0 -26
  459. data/frameworks/sproutcore/themes/standard_theme/english.lproj/list_item.css +30 -0
  460. data/frameworks/sproutcore/themes/standard_theme/english.lproj/progress.css +9 -6
  461. data/frameworks/sproutcore/themes/standard_theme/english.lproj/radio.css +20 -11
  462. data/frameworks/sproutcore/themes/standard_theme/english.lproj/segmented.css +192 -54
  463. data/frameworks/sproutcore/themes/standard_theme/english.lproj/slider.css +56 -24
  464. data/frameworks/sproutcore/themes/standard_theme/english.lproj/tab.css +13 -7
  465. data/frameworks/sproutcore/themes/standard_theme/english.lproj/text_field.css +1 -4
  466. data/frameworks/sproutcore/themes/standard_theme/english.lproj/toolbar.css +4 -1
  467. data/lib/sproutcore/builders/minify.rb +2 -2
  468. data/lib/sproutcore/builders/test.rb +1 -1
  469. data/lib/sproutcore/buildfile.rb +1 -0
  470. data/lib/sproutcore/rack/dev.rb +1 -1
  471. data/lib/sproutcore/rack/filesystem.rb +265 -0
  472. data/lib/sproutcore/rack/proxy.rb +11 -3
  473. data/lib/sproutcore/rack/service.rb +11 -1
  474. data/lib/sproutcore/tools.rb +11 -1
  475. data/lib/sproutcore/tools/server.rb +6 -4
  476. data/vendor/jsdoc/README.txt +151 -0
  477. data/vendor/jsdoc/changes.txt +47 -0
  478. metadata +263 -308
  479. data/frameworks/sproutcore/apps/sc_jsdoc/controllers/docs.js +0 -149
  480. data/frameworks/sproutcore/apps/sc_jsdoc/core.js +0 -16
  481. data/frameworks/sproutcore/apps/sc_jsdoc/english.lproj/body.css +0 -17
  482. data/frameworks/sproutcore/apps/sc_jsdoc/english.lproj/body.js +0 -99
  483. data/frameworks/sproutcore/apps/sc_jsdoc/english.lproj/images/sproutcore-logo.png +0 -0
  484. data/frameworks/sproutcore/apps/sc_jsdoc/main.js +0 -27
  485. data/frameworks/sproutcore/apps/sc_jsdoc/models/doc.js +0 -21
  486. data/frameworks/sproutcore/apps/sc_qunit/controllers/runner.js +0 -209
  487. data/frameworks/sproutcore/apps/sc_qunit/core.js +0 -16
  488. data/frameworks/sproutcore/apps/sc_qunit/english.lproj/body.css +0 -17
  489. data/frameworks/sproutcore/apps/sc_qunit/english.lproj/body.js +0 -107
  490. data/frameworks/sproutcore/apps/sc_qunit/english.lproj/images/sproutcore-logo.png +0 -0
  491. data/frameworks/sproutcore/apps/sc_qunit/english.lproj/strings.js +0 -15
  492. data/frameworks/sproutcore/apps/sc_qunit/main.js +0 -18
  493. data/frameworks/sproutcore/apps/sc_qunit/models/test.js +0 -24
  494. data/frameworks/sproutcore/apps/sc_qunit/views/test_iframe.js +0 -52
  495. data/frameworks/sproutcore/apps/tests/controllers/test.js +0 -20
  496. data/frameworks/sproutcore/frameworks/desktop/english.lproj/images/blank.gif +0 -0
  497. data/frameworks/sproutcore/frameworks/desktop/english.lproj/menu.css +0 -83
  498. data/frameworks/sproutcore/frameworks/desktop/english.lproj/palette.css +0 -3
  499. data/frameworks/sproutcore/frameworks/desktop/tests/views/collection/methods.js +0 -10
  500. data/frameworks/sproutcore/frameworks/desktop/tests/views/list/methods.js +0 -10
  501. data/frameworks/sproutcore/frameworks/desktop/tests/views/list/ui.js +0 -110
  502. data/frameworks/sproutcore/frameworks/foundation/mixins/responder.js +0 -156
  503. data/frameworks/sproutcore/frameworks/foundation/tests/controllers/array.js +0 -118
  504. data/frameworks/sproutcore/frameworks/foundation/tests/controllers/controller.js +0 -268
  505. data/frameworks/sproutcore/frameworks/foundation/tests/controllers/object.js +0 -433
  506. data/frameworks/sproutcore/frameworks/runtime/tests/system/array.js +0 -263
  507. data/frameworks/sproutcore/frameworks/testing/tests/debug/qunit.js +0 -25
  508. data/spec/buildtasks/manifest/spec_helper.rb +0 -35
  509. data/spec/buildtasks/target_spec.rb +0 -214
  510. data/spec/fixtures/builder_tests/Buildfile +0 -15
  511. data/spec/fixtures/builder_tests/apps/combine_test/a.js +0 -1
  512. data/spec/fixtures/builder_tests/apps/combine_test/b.js +0 -1
  513. data/spec/fixtures/builder_tests/apps/combine_test/c.js +0 -1
  514. data/spec/fixtures/builder_tests/apps/combine_test/english.lproj/a.css +0 -1
  515. data/spec/fixtures/builder_tests/apps/combine_test/english.lproj/b.css +0 -1
  516. data/spec/fixtures/builder_tests/apps/combine_test/english.lproj/c.css +0 -1
  517. data/spec/fixtures/builder_tests/apps/html_test/english.lproj/bar1_sample.rhtml +0 -2
  518. data/spec/fixtures/builder_tests/apps/html_test/english.lproj/erb_sample.html.erb +0 -1
  519. data/spec/fixtures/builder_tests/apps/html_test/english.lproj/icons/image.png +0 -0
  520. data/spec/fixtures/builder_tests/apps/html_test/english.lproj/image.jpg +0 -0
  521. data/spec/fixtures/builder_tests/apps/html_test/english.lproj/rhtml_sample.rhtml +0 -1
  522. data/spec/fixtures/builder_tests/apps/html_test/english.lproj/strings.js +0 -4
  523. data/spec/fixtures/builder_tests/apps/html_test/english.lproj/style.css +0 -0
  524. data/spec/fixtures/builder_tests/apps/html_test/french.lproj/french-icons/fr.png +0 -0
  525. data/spec/fixtures/builder_tests/apps/html_test/french.lproj/strings.js +0 -4
  526. data/spec/fixtures/builder_tests/apps/html_test/lib/layout_template.rhtml +0 -1
  527. data/spec/fixtures/builder_tests/apps/html_test/scripts.js +0 -0
  528. data/spec/fixtures/builder_tests/apps/javascript_test/sc_static.js +0 -15
  529. data/spec/fixtures/builder_tests/apps/javascript_test/sc_super.js +0 -4
  530. data/spec/fixtures/builder_tests/apps/javascript_test/strings.js +0 -7
  531. data/spec/fixtures/builder_tests/apps/sass_test/sample.sass +0 -3
  532. data/spec/fixtures/builder_tests/apps/strings_test/lproj/strings.js +0 -8
  533. data/spec/fixtures/builder_tests/apps/stylesheet_test/build_directives.css +0 -9
  534. data/spec/fixtures/builder_tests/apps/stylesheet_test/sc_static.css +0 -12
  535. data/spec/fixtures/builder_tests/apps/test_test/lib/alt_layout.rhtml +0 -1
  536. data/spec/fixtures/builder_tests/apps/test_test/lib/test_layout.rhtml +0 -3
  537. data/spec/fixtures/builder_tests/apps/test_test/tests/qunit_test.js +0 -1
  538. data/spec/fixtures/builder_tests/apps/test_test/tests/qunit_test2.js +0 -1
  539. data/spec/fixtures/builder_tests/apps/test_test/tests/rhtml_test.rhtml +0 -4
  540. data/spec/fixtures/builder_tests/frameworks/debug/core.js +0 -0
  541. data/spec/fixtures/builder_tests/frameworks/debug/english.lproj/dummy.css +0 -0
  542. data/spec/fixtures/builder_tests/frameworks/qunit/core.js +0 -0
  543. data/spec/fixtures/builder_tests/frameworks/qunit/english.lproj/dummy.css +0 -0
  544. data/spec/fixtures/builder_tests/frameworks/req_target_1/english.lproj/req_style_1.css +0 -0
  545. data/spec/fixtures/builder_tests/frameworks/req_target_1/english.lproj/strings.js +0 -4
  546. data/spec/fixtures/builder_tests/frameworks/req_target_1/english.lproj/test.rhtml +0 -1
  547. data/spec/fixtures/builder_tests/frameworks/req_target_1/req_js_1.js +0 -0
  548. data/spec/fixtures/builder_tests/frameworks/req_target_2/english.lproj/req_style_2.css +0 -0
  549. data/spec/fixtures/builder_tests/frameworks/req_target_2/english.lproj/test.rhtml +0 -1
  550. data/spec/fixtures/builder_tests/frameworks/req_target_2/javascript.js +0 -1
  551. data/spec/fixtures/builder_tests/frameworks/req_target_2/lib/alt_layout.rhtml +0 -0
  552. data/spec/fixtures/builder_tests/frameworks/req_target_2/req_js_2.js +0 -0
  553. data/spec/fixtures/builder_tests/themes/sample_theme/Buildfile +0 -1
  554. data/spec/fixtures/buildfiles/basic/Buildfile +0 -16
  555. data/spec/fixtures/buildfiles/basic/task_module.rake +0 -6
  556. data/spec/fixtures/buildfiles/installed/Buildfile +0 -7
  557. data/spec/fixtures/buildfiles/installed/Buildfile2 +0 -5
  558. data/spec/fixtures/buildfiles/project_test/Buildfile +0 -4
  559. data/spec/fixtures/buildfiles/project_test/not_project/Buildfile +0 -2
  560. data/spec/fixtures/buildfiles/project_test/not_project/child/PLACEHOLDER +0 -0
  561. data/spec/fixtures/entry_for_project/Buildfile +0 -1
  562. data/spec/fixtures/entry_for_project/apps/test_app/frameworks/nested/PLACEHOLDER +0 -0
  563. data/spec/fixtures/entry_for_project/frameworks/shared/PLACEHOLDER +0 -0
  564. data/spec/fixtures/find_targets/custom/Buildfile +0 -8
  565. data/spec/fixtures/find_targets/custom/bars/bar1/bars/bar1/PLACEHOLDER +0 -0
  566. data/spec/fixtures/find_targets/custom/bars/bar1/bars/bar2/PLACEHOLDER +0 -0
  567. data/spec/fixtures/find_targets/custom/bars/bar1/foos/foo1/PLACEHOLDER +0 -0
  568. data/spec/fixtures/find_targets/custom/bars/bar1/foos/foo2/PLACEHOLDER +0 -0
  569. data/spec/fixtures/find_targets/custom/foos/custom_foos/Buildfile +0 -5
  570. data/spec/fixtures/find_targets/custom/foos/custom_foos/custom_foodir/foo1/PLACEHOLDER +0 -0
  571. data/spec/fixtures/find_targets/custom/foos/custom_foos/custom_foodir/foo2/PLACEHOLDER +0 -0
  572. data/spec/fixtures/find_targets/custom/foos/custom_foos/foos/not_foo1/PLACEHOLDER +0 -0
  573. data/spec/fixtures/find_targets/custom/foos/foo1/bars/bar1/PLACEHOLDER +0 -0
  574. data/spec/fixtures/find_targets/custom/foos/foo1/bars/bar2/PLACEHOLDER +0 -0
  575. data/spec/fixtures/find_targets/nested/Buildfile +0 -8
  576. data/spec/fixtures/find_targets/nested/apps/app1/Buildfile +0 -1
  577. data/spec/fixtures/find_targets/nested/apps/app1/apps/nested_app/PLACEHOLDER +0 -0
  578. data/spec/fixtures/find_targets/standard/Apps/app1/frameworks/framework1/PLACEHOLDER +0 -0
  579. data/spec/fixtures/find_targets/standard/Apps/app1/frameworks/framework2/PLACEHOLDER +0 -0
  580. data/spec/fixtures/find_targets/standard/clients/client1/PLACEHOLDER +0 -0
  581. data/spec/fixtures/find_targets/standard/frameworks/framework1/frameworks/framework1/PLACEHOLDER +0 -0
  582. data/spec/fixtures/find_targets/standard/frameworks/framework2/PLACEHOLDER +0 -0
  583. data/spec/fixtures/find_targets/standard/themes/theme1/PLACEHOLDER +0 -0
  584. data/spec/fixtures/find_targets/standard/themes/theme2/PLACEHOLDER +0 -0
  585. data/spec/fixtures/languages/apps/caps_long_names/English.lproj/PLACEHOLDER +0 -0
  586. data/spec/fixtures/languages/apps/caps_long_names/FreNCH.lproj/PLACEHOLDER +0 -0
  587. data/spec/fixtures/languages/apps/caps_long_names/UnknOWN.lproj/PLACEHOLDER +0 -0
  588. data/spec/fixtures/languages/apps/long_names/english.lproj/PLACEHOLDER +0 -0
  589. data/spec/fixtures/languages/apps/long_names/french.lproj/PLACEHOLDER +0 -0
  590. data/spec/fixtures/languages/apps/long_names/german.lproj/PLACEHOLDER +0 -0
  591. data/spec/fixtures/languages/apps/long_names/italian.lproj/PLACEHOLDER +0 -0
  592. data/spec/fixtures/languages/apps/long_names/japanese.lproj/PLACEHOLDER +0 -0
  593. data/spec/fixtures/languages/apps/long_names/spanish.lproj/PLACEHOLDER +0 -0
  594. data/spec/fixtures/languages/apps/long_names/unknown.lproj/PLACEHOLDER +0 -0
  595. data/spec/fixtures/languages/apps/no_names/PLACEHOLDER +0 -0
  596. data/spec/fixtures/languages/apps/short_names/de.lproj/PLACEHOLDER +0 -0
  597. data/spec/fixtures/languages/apps/short_names/en-CA.lproj/PLACEHOLDER +0 -0
  598. data/spec/fixtures/languages/apps/short_names/en-GB.lproj/PLACEHOLDER +0 -0
  599. data/spec/fixtures/languages/apps/short_names/en-US.lproj/PLACEHOLDER +0 -0
  600. data/spec/fixtures/languages/apps/short_names/en.lproj/PLACEHOLDER +0 -0
  601. data/spec/fixtures/languages/apps/short_names/es.lproj/PLACEHOLDER +0 -0
  602. data/spec/fixtures/languages/apps/short_names/foo.lproj/PLACEHOLDER +0 -0
  603. data/spec/fixtures/languages/apps/short_names/fr.lproj/PLACEHOLDER +0 -0
  604. data/spec/fixtures/languages/apps/short_names/it.lproj/PLACEHOLDER +0 -0
  605. data/spec/fixtures/languages/apps/short_names/ja.lproj/PLACEHOLDER +0 -0
  606. data/spec/fixtures/ordered_entries/apps/no_requires/1.js +0 -1
  607. data/spec/fixtures/ordered_entries/apps/no_requires/B.js +0 -1
  608. data/spec/fixtures/ordered_entries/apps/no_requires/a.js +0 -1
  609. data/spec/fixtures/ordered_entries/apps/no_requires/a/a.js +0 -1
  610. data/spec/fixtures/ordered_entries/apps/no_requires/a/b.js +0 -1
  611. data/spec/fixtures/ordered_entries/apps/no_requires/b/a.js +0 -1
  612. data/spec/fixtures/ordered_entries/apps/no_requires/c.js +0 -1
  613. data/spec/fixtures/ordered_entries/apps/no_requires/core.js +0 -1
  614. data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/B.css +0 -0
  615. data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/a.css +0 -0
  616. data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/a/a.css +0 -0
  617. data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/a/b.css +0 -0
  618. data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/b/a.css +0 -0
  619. data/spec/fixtures/ordered_entries/apps/no_requires/english.lproj/c.css +0 -0
  620. data/spec/fixtures/ordered_entries/apps/no_requires/lproj/strings.js +0 -1
  621. data/spec/fixtures/ordered_entries/apps/no_requires/utils.js +0 -1
  622. data/spec/fixtures/ordered_entries/apps/with_requires/a.js +0 -2
  623. data/spec/fixtures/ordered_entries/apps/with_requires/b.js +0 -3
  624. data/spec/fixtures/ordered_entries/apps/with_requires/c.js +0 -2
  625. data/spec/fixtures/ordered_entries/apps/with_requires/english.lproj/a.css +0 -2
  626. data/spec/fixtures/ordered_entries/apps/with_requires/english.lproj/b.css +0 -2
  627. data/spec/fixtures/ordered_entries/apps/with_requires/english.lproj/c.css +0 -2
  628. data/spec/fixtures/ordered_entries/apps/with_requires/english.lproj/d.js +0 -1
  629. data/spec/fixtures/real_world/Buildfile +0 -12
  630. data/spec/fixtures/real_world/apps/account/README +0 -1
  631. data/spec/fixtures/real_world/apps/calendar/README +0 -1
  632. data/spec/fixtures/real_world/apps/contacts/README_BEFORE_EDITING +0 -1
  633. data/spec/fixtures/real_world/apps/files/README +0 -1
  634. data/spec/fixtures/real_world/apps/mail/README +0 -1
  635. data/spec/fixtures/real_world/apps/mobile_photos/README +0 -1
  636. data/spec/fixtures/real_world/apps/photos/README +0 -1
  637. data/spec/fixtures/real_world/apps/uploader/README +0 -1
  638. data/spec/fixtures/real_world/frameworks/core_files/PLACEHOLDER +0 -0
  639. data/spec/fixtures/real_world/frameworks/core_photos/PLACEHOLDER +0 -0
  640. data/spec/fixtures/real_world/frameworks/shared/PLACEHOLDER +0 -0
  641. data/spec/fixtures/real_world/frameworks/sproutcore/Buildfile +0 -26
  642. data/spec/fixtures/real_world/frameworks/sproutcore/README +0 -1
  643. data/spec/fixtures/real_world/frameworks/sproutcore/apps/docs/PLACEHOLDER +0 -0
  644. data/spec/fixtures/real_world/frameworks/sproutcore/apps/test_runner/PLACEHOLDER +0 -0
  645. data/spec/fixtures/real_world/frameworks/sproutcore/core.js +0 -0
  646. data/spec/fixtures/real_world/frameworks/sproutcore/debug/debug-resource.html +0 -0
  647. data/spec/fixtures/real_world/frameworks/sproutcore/debug/sample_debug.js +0 -0
  648. data/spec/fixtures/real_world/frameworks/sproutcore/demo2.js +0 -0
  649. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/debug/sample_debug-loc.js +0 -0
  650. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/demo.css +0 -4
  651. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/demo.html +0 -1
  652. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/demo2.sass +0 -0
  653. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/file_extension_test.haml +0 -0
  654. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/file_extension_test.html.erb +0 -1
  655. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/file_extension_test.rhtml +0 -0
  656. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/fixtures/sample_fixtures-loc.js +0 -0
  657. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/has_require.css +0 -4
  658. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/no_require.css +0 -1
  659. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/no_sc_resource.rhtml +0 -1
  660. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/protocols/sample-loc.js +0 -0
  661. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/sc_resource.css +0 -6
  662. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/sc_resource.rhtml +0 -3
  663. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/strings.js +0 -1
  664. data/spec/fixtures/real_world/frameworks/sproutcore/english.lproj/tests/sample-loc.js +0 -0
  665. data/spec/fixtures/real_world/frameworks/sproutcore/fixtures/sample-json-fixture.json +0 -1
  666. data/spec/fixtures/real_world/frameworks/sproutcore/fixtures/sample_fixtures.js +0 -0
  667. data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/application/PLACEHOLDER +0 -0
  668. data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/costello/core.js +0 -0
  669. data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/data_store/PLACEHOLDER +0 -0
  670. data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/debug/PLACEHOLDER +0 -0
  671. data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/desktop/PLACEHOLDER +0 -0
  672. data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/empty_theme/PLACEHOLDER +0 -0
  673. data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/foundation/PLACEHOLDER +0 -0
  674. data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/mobile/PLACEHOLDER +0 -0
  675. data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/qunit/PLACEHOLDER +0 -0
  676. data/spec/fixtures/real_world/frameworks/sproutcore/frameworks/uploader/PLACEHOLDER +0 -0
  677. data/spec/fixtures/real_world/frameworks/sproutcore/french.lproj/french-resource.js +0 -0
  678. data/spec/fixtures/real_world/frameworks/sproutcore/french.lproj/strings.js +0 -1
  679. data/spec/fixtures/real_world/frameworks/sproutcore/german.lproj/german-resource.js +0 -0
  680. data/spec/fixtures/real_world/frameworks/sproutcore/german.lproj/strings.js +0 -0
  681. data/spec/fixtures/real_world/frameworks/sproutcore/has_require.js +0 -4
  682. data/spec/fixtures/real_world/frameworks/sproutcore/lib/index.html +0 -1
  683. data/spec/fixtures/real_world/frameworks/sproutcore/no_require.js +0 -1
  684. data/spec/fixtures/real_world/frameworks/sproutcore/protocols/sample.js +0 -0
  685. data/spec/fixtures/real_world/frameworks/sproutcore/sc_resource.js +0 -6
  686. data/spec/fixtures/real_world/frameworks/sproutcore/tests/nested/sample1.js +0 -0
  687. data/spec/fixtures/real_world/frameworks/sproutcore/tests/nested/sample2.js +0 -0
  688. data/spec/fixtures/real_world/frameworks/sproutcore/tests/sample.js +0 -0
  689. data/spec/fixtures/real_world/frameworks/sproutcore/tests/sample.rhtml +0 -1
  690. data/spec/fixtures/real_world/frameworks/sproutcore/themes/standard_theme/README +0 -0
  691. data/spec/fixtures/real_world/frameworks/sproutcore/views/view.js +0 -1
  692. data/spec/fixtures/real_world/generators/sample_custom/Buildfile +0 -0
  693. data/spec/fixtures/real_world/generators/sample_custom/templates/{filename}.js +0 -1
  694. data/spec/fixtures/recursive_project/Buildfile +0 -8
  695. data/spec/fixtures/recursive_project/frameworks/sproutcore/frameworks/costello/PLACEHOLDER +0 -0
  696. data/spec/lib/builders/combine_spec.rb +0 -67
  697. data/spec/lib/builders/html_spec.rb +0 -577
  698. data/spec/lib/builders/javascript_spec.rb +0 -81
  699. data/spec/lib/builders/sass_spec.rb +0 -43
  700. data/spec/lib/builders/spec_helper.rb +0 -30
  701. data/spec/lib/builders/strings_spec.rb +0 -52
  702. data/spec/lib/builders/stylesheet_spec.rb +0 -63
  703. data/spec/lib/builders/test_index_spec.rb +0 -44
  704. data/spec/lib/builders/test_spec.rb +0 -135
  705. data/spec/lib/buildfile/config_for_spec.rb +0 -81
  706. data/spec/lib/buildfile/define_spec.rb +0 -59
  707. data/spec/lib/buildfile/dup_spec.rb +0 -65
  708. data/spec/lib/buildfile/invoke_spec.rb +0 -130
  709. data/spec/lib/buildfile/load_spec.rb +0 -49
  710. data/spec/lib/buildfile/task/dup_spec.rb +0 -55
  711. data/spec/lib/buildfile/task_defined_spec.rb +0 -17
  712. data/spec/lib/buildfile_commands/build_task_spec.rb +0 -19
  713. data/spec/lib/buildfile_commands/config_spec.rb +0 -97
  714. data/spec/lib/buildfile_commands/import_spec.rb +0 -17
  715. data/spec/lib/buildfile_commands/namespace_spec.rb +0 -18
  716. data/spec/lib/buildfile_commands/proxies_spec.rb +0 -38
  717. data/spec/lib/buildfile_commands/replace_task_spec.rb +0 -29
  718. data/spec/lib/buildfile_commands/task_spec.rb +0 -36
  719. data/spec/lib/helpers/packing_optimizer/optimize_spec.rb +0 -26
  720. data/spec/lib/models/hash_struct/deep_clone_spec.rb +0 -27
  721. data/spec/lib/models/hash_struct/has_options_spec.rb +0 -32
  722. data/spec/lib/models/hash_struct/hash_spec.rb +0 -64
  723. data/spec/lib/models/hash_struct/merge_spec.rb +0 -26
  724. data/spec/lib/models/hash_struct/method_missing.rb +0 -41
  725. data/spec/lib/models/manifest/add_entry_spec.rb +0 -36
  726. data/spec/lib/models/manifest/add_transform_spec.rb +0 -90
  727. data/spec/lib/models/manifest/build_spec.rb +0 -78
  728. data/spec/lib/models/manifest/entry_for_spec.rb +0 -94
  729. data/spec/lib/models/manifest/find_entry.rb +0 -84
  730. data/spec/lib/models/manifest/prepare_spec.rb +0 -62
  731. data/spec/lib/models/manifest_entry/cacheable_url_spec.rb +0 -31
  732. data/spec/lib/models/manifest_entry/prepare_spec.rb +0 -54
  733. data/spec/lib/models/project/add_target_spec.rb +0 -44
  734. data/spec/lib/models/project/buildfile_spec.rb +0 -35
  735. data/spec/lib/models/project/find_targets_for_spec.rb +0 -77
  736. data/spec/lib/models/project/load_nearest_project_spec.rb +0 -23
  737. data/spec/lib/models/project/target_for_spec.rb +0 -33
  738. data/spec/lib/models/project/targets_spec.rb +0 -62
  739. data/spec/lib/models/target/compute_build_number_spec.rb +0 -125
  740. data/spec/lib/models/target/config_spec.rb +0 -30
  741. data/spec/lib/models/target/expand_required_targets_spec.rb +0 -48
  742. data/spec/lib/models/target/installed_languages_spec.rb +0 -47
  743. data/spec/lib/models/target/lproj_for_spec.rb +0 -38
  744. data/spec/lib/models/target/manifest_for_spec.rb +0 -42
  745. data/spec/lib/models/target/parent_target_spec.rb +0 -21
  746. data/spec/lib/models/target/prepare_spec.rb +0 -53
  747. data/spec/lib/models/target/required_targets_spec.rb +0 -119
  748. data/spec/lib/models/target/target_for_spec.rb +0 -56
  749. data/spec/lib/tools/build_number_spec.rb +0 -28
  750. data/spec/lib/tools/gen_spec.rb +0 -207
  751. data/spec/lib/tools/tools_spec.rb +0 -78
  752. data/spec/spec_helper.rb +0 -138
  753. data/vendor/github_gem_lint.rb +0 -22
  754. data/vendor/yui-compressor/yuicompressor-2.4.2.jar +0 -0
@@ -75,6 +75,7 @@ require('views/view');
75
75
  that should not steal keyboard control from another view.
76
76
 
77
77
  @extends SC.View
78
+ @extends SC.ResponderContext
78
79
  @since SproutCore 1.0
79
80
  */
80
81
  SC.Pane = SC.View.extend({
@@ -115,7 +116,12 @@ SC.Pane = SC.View.extend({
115
116
  height: (pframe) ? pframe.height : 1000
116
117
  } ;
117
118
  },
118
-
119
+
120
+ /** @private Disable caching due to an known bug in SC. */
121
+ frame: function() {
122
+ return this.computeFrameWithParentFrame(null) ;
123
+ }.property(),
124
+
119
125
  /**
120
126
  Invoked by the root responder whenever the window resizes. This should
121
127
  simply begin the process of notifying children that the view size has
@@ -152,7 +158,14 @@ SC.Pane = SC.View.extend({
152
158
 
153
159
  // if no handler was found in the responder chain, try the default
154
160
  if (!target && (target = this.get('defaultResponder'))) {
155
- target = target.tryToPerform(action, evt) ? target : null ;
161
+ if (typeof target === SC.T_STRING) {
162
+ target = SC.objectForPropertyPath(target);
163
+ }
164
+
165
+ if (!target) target = null;
166
+ else if (target.isResponderContext) {
167
+ target = target.sendAction(action, this, evt);
168
+ } else target = target.tryToPerform(action, evt) ? target : null ;
156
169
  }
157
170
 
158
171
  return evt.mouseHandler || target ;
@@ -169,11 +182,11 @@ SC.Pane = SC.View.extend({
169
182
  defaultResponder: null,
170
183
 
171
184
  /** @property
172
- The next responder for the pane is always its defaultResponder.
185
+ Pane's never have a next responder
173
186
  */
174
187
  nextResponder: function() {
175
- return this.get('defaultResponder');
176
- }.property('defaultResponder').cacheable(),
188
+ return null;
189
+ }.property().cacheable(),
177
190
 
178
191
  /** @property
179
192
  The first responder. This is the first view that should receive action
@@ -231,7 +244,7 @@ SC.Pane = SC.View.extend({
231
244
  if (current === view) return this ; // nothing to do
232
245
 
233
246
  // notify current of firstResponder change
234
- if (current) current.willLoseFirstResponder();
247
+ if (current) current.willLoseFirstResponder(current);
235
248
 
236
249
  // if we are currently key pane, then notify key views of change also
237
250
  if (isKeyPane) {
@@ -260,7 +273,7 @@ SC.Pane = SC.View.extend({
260
273
  if (current) current.didLoseKeyResponderTo(view) ;
261
274
  }
262
275
 
263
- if (view) view.didBecomeFirstResponder();
276
+ if (view) view.didBecomeFirstResponder(view);
264
277
  return this ;
265
278
  },
266
279
 
@@ -344,6 +357,20 @@ SC.Pane = SC.View.extend({
344
357
 
345
358
  isMainPane: NO,
346
359
 
360
+ /**
361
+ Invoked when the pane is about to become the focused pane.
362
+
363
+ @param {SC.Pane} pane the pane that currently have focus
364
+ */
365
+ focusFrom: function(pane) {},
366
+
367
+ /**
368
+ Invoked when the the pane is about to lose its focused pane status.
369
+
370
+ @param {SC.Pane} pane the pane that will receive focus next
371
+ */
372
+ blurTo: function(pane) {},
373
+
347
374
  /**
348
375
  Invoked when the view is about to lose its mainPane status. The default
349
376
  implementation will also remove the pane from the document since you can't
@@ -373,37 +400,39 @@ SC.Pane = SC.View.extend({
373
400
 
374
401
  @param {SC.RootResponder} rootResponder
375
402
  @returns {SC.Pane} receiver
376
-
403
+
377
404
  */
378
- append: function() {
405
+ append: function() {
379
406
  return this.appendTo(document.body) ;
380
407
  },
381
-
408
+
382
409
  /**
383
410
  Removes the pane from the document. This will remove the
384
411
  DOM node and deregister you from the document window.
385
412
  */
386
413
  remove: function() {
387
- if (!this.get('isVisibleInWindow')) return this; // nothing to do
388
-
414
+ if (!this.get('isVisibleInWindow')) return this ; // nothing to do
415
+ if (!this.get('isPaneAttached')) return this ; // nothing to do
416
+
389
417
  // remove layer...
390
418
  var dom = this.get('layer') ;
391
- if (dom.parentNode) dom.parentNode.removeChild(dom);
392
- dom = null;
419
+ if (dom.parentNode) dom.parentNode.removeChild(dom) ;
420
+ dom = null ;
393
421
 
394
422
  // remove from the RootResponder also
395
423
  var responder = this.rootResponder ;
396
424
  if (this.get('isKeyPane')) responder.makeKeyPane(null) ; // orders matter, remove keyPane first
397
- if (this.get('isMainPane')) responder.makeMainPane(null);
398
- responder.panes.remove(this);
425
+ if (this.get('isMainPane')) responder.makeMainPane(null) ;
426
+ responder.panes.remove(this) ;
399
427
  this.rootResponder = responder = null ;
400
-
401
- // clean up some of my own properties
428
+
429
+ // clean up some of my own properties
402
430
  this.set('isPaneAttached', NO) ;
403
431
  this.parentViewDidChange() ;
432
+ return this ;
404
433
  },
405
-
406
- /**
434
+
435
+ /**
407
436
  Inserts the pane into the DOM as the last child of the passed DOM element.
408
437
  You can pass in either a CoreQuery object or a selector, which will be
409
438
  converted to a CQ object. You can optionally pass in the rootResponder
@@ -0,0 +1,887 @@
1
+ // ==========================================================================
2
+ // Project: SproutCore - JavaScript Application Framework
3
+ // Copyright: ©2006-2009 Sprout Systems, Inc. and contributors.
4
+ // Portions ©2008-2009 Apple, Inc. All rights reserved.
5
+ // License: Licened under MIT license (see license.js)
6
+ // ==========================================================================
7
+
8
+ sc_require('mixins/tree_item_content');
9
+ sc_require('mixins/collection_content');
10
+
11
+ /**
12
+ @class
13
+
14
+ A TreeNode is an internal class that will manage a single item in a tree
15
+ when trying to display the item in a hierarchy.
16
+
17
+ When displaying a tree of objects, a tree item object will be nested to
18
+ cover every object that might have child views.
19
+
20
+ TreeNode stores an array which contains either a number pointing to the
21
+ next place in the array there is a child item or it contains a child item.
22
+
23
+ @extends SC.Object
24
+ @extends SC.Array
25
+ @extends SC.CollectionContent
26
+ @since SproutCore 1.0
27
+ */
28
+ SC.TreeItemObserver = SC.Object.extend(SC.Array, SC.CollectionContent, {
29
+
30
+ /**
31
+ The node in the tree this observer will manage. Set when creating the
32
+ object. If you are creating an observer manually, you must set this to
33
+ a non-null value.
34
+ */
35
+ item: null,
36
+
37
+ /**
38
+ The controller delegate. If the item does not implement the
39
+ TreeItemContent method, delegate properties will be used to determine how
40
+ to access the content. Set automatically when a tree item is created.
41
+
42
+ If you are creating an observer manually, you must set this to a non-null
43
+ value.
44
+ */
45
+ delegate: null,
46
+
47
+ // ..........................................................
48
+ // FOR NESTED OBSERVERS
49
+ //
50
+
51
+ /**
52
+ The parent TreeItemObserver for this observer. Must be set on create.
53
+ */
54
+ parentObserver: null,
55
+
56
+ /**
57
+ The parent item for the observer item. Computed automatically from the
58
+ parent. If the value of this is null, then this is the root of the tree.
59
+ */
60
+ parentItem: function() {
61
+ var p = this.get('parentObserver');
62
+ return p ? p.get('item') : null;
63
+ }.property('parentObserver').cacheable(),
64
+
65
+ /**
66
+ Index location in parent's children array. If this is the root item
67
+ in the tree, should be null.
68
+ */
69
+ index: null,
70
+
71
+ outlineLevel: 0,
72
+
73
+ // ..........................................................
74
+ // EXTRACTED FROM ITEM
75
+ //
76
+
77
+ /**
78
+ Array of child tree items. Extracted from the item automatically on init.
79
+ */
80
+ children: null,
81
+
82
+ /**
83
+ Disclosure state of this item. Must be SC.BRANCH_OPEN or SC.BRANCH_CLOSED
84
+ If this is the root of a item tree, the observer will have children but
85
+ no parent or parent item. IN this case the disclosure state is always
86
+ SC.BRANCH_OPEN.
87
+
88
+ @property
89
+ @type Number
90
+ */
91
+ disclosureState: SC.BRANCH_OPEN,
92
+
93
+ /**
94
+ IndexSet of children with branches. This will ask the delegate to name
95
+ these indexes. The default implementation will iterate over the children
96
+ of the item but a more optimized version could avoid touching each item.
97
+
98
+ @property
99
+ @type SC.IndexSet
100
+ */
101
+ branchIndexes: function() {
102
+ var item = this.get('item'),
103
+ len, pitem, idx, children, ret;
104
+
105
+ // no item - no branches
106
+ if (!item) return SC.IndexSet.EMPTY;
107
+
108
+ // if item is treeItemContent then ask it directly
109
+ else if (item.isTreeItemContent) {
110
+ pitem = this.get('parentItem');
111
+ idx = this.get('index') ;
112
+ return item.treeItemBranchIndexes(pitem, idx);
113
+
114
+ // otherwise, loop over children and determine disclosure state for each
115
+ } else {
116
+ children = this.get('children');
117
+ if (!children) return null; // no children - no branches
118
+ ret = SC.IndexSet.create();
119
+ len = children.get('length');
120
+ pitem = item ; // save parent
121
+
122
+ for(idx=0;idx<len;idx++) {
123
+ if (!(item = children.objectAt(idx))) continue ;
124
+ if (!this._computeChildren(item, pitem, idx)) continue; // no chil'en
125
+ if (this._computeDisclosureState(item, pitem, idx) !== SC.LEAF_NODE) {
126
+ ret.add(idx);
127
+ }
128
+ }
129
+
130
+ return ret.get('length')>0 ? ret : null;
131
+ }
132
+ }.property('children').cacheable(),
133
+
134
+ /**
135
+ Returns YES if the item itself should be shown, NO if only its children
136
+ should be shown. Normally returns YES unless the parentObject is null.
137
+ */
138
+ isHeaderVisible: function() {
139
+ return !!this.get('parentObserver');
140
+ }.property('parentObserver').cacheable(),
141
+
142
+ /**
143
+ Get the current length of the tree item including any of its children.
144
+ */
145
+ length: 0,
146
+
147
+ // ..........................................................
148
+ // SC.ARRAY SUPPORT
149
+ //
150
+
151
+ /**
152
+ Get the object at the specified index. This will talk the tree info
153
+ to determine the proper place. The offset should be relative to the
154
+ start of this tree item. Calls recursively down the tree.
155
+
156
+ This should only be called with an index you know is in the range of item
157
+ or its children based on looking at the length.
158
+ */
159
+ objectAt: function(index) {
160
+ var len = this.get('length'),
161
+ item = this.get('item'),
162
+ cache = this._objectAtCache,
163
+ cur = index,
164
+ loc = 0,
165
+ indexes, children;
166
+
167
+ if (index >= len) return undefined;
168
+ if (this.get('isHeaderVisible')) {
169
+ if (index === 0) return item;
170
+ else cur--;
171
+ }
172
+ item = null;
173
+
174
+ if (!cache) cache = this._objectAtCache = [];
175
+ if ((item = cache[index]) !== undefined) return item ;
176
+
177
+ children = this.get('children');
178
+ if (!children) return undefined; // no children - nothing to get
179
+
180
+ // loop through branch indexes, reducing the offset until it matches
181
+ // something we might actually return.
182
+ if (indexes = this.get('branchIndexes')) {
183
+ indexes.forEach(function(i) {
184
+ if (item || (i > cur)) return ; // past end - nothing to do
185
+
186
+ var observer = this.branchObserverAt(i), len;
187
+ if (!observer) return ; // nothing to do
188
+
189
+ // if cur lands inside of this observer's length, use objectAt to get
190
+ // otherwise, just remove len from cur.
191
+ len = observer.get('length') ;
192
+ if (i+len > cur) {
193
+ item = observer.objectAt(cur-i);
194
+ cur = -1;
195
+ } else cur -= len-1 ;
196
+
197
+ },this);
198
+ }
199
+
200
+ if (cur>=0) item = children.objectAt(cur); // get internal if needed
201
+ cache[index] = item ; // save in cache
202
+
203
+ return item ;
204
+ },
205
+
206
+ /**
207
+ Implements SC.Array.replace() primitive. For this method to succeed, the
208
+ range you replace must lie entirely within the same parent item, otherwise
209
+ this will raise an exception.
210
+
211
+ Note that this replace method accepts an additional parameter "operation"
212
+ which is used when you try to insert an item on a boundary between
213
+ branches whether it should be inserted at the end of the previous group
214
+ after the group. If you don't pass operation, the default is
215
+ SC.DROP_BEFORE, which is the expected behavior.
216
+ */
217
+ replace: function(start, amt, objects, operation) {
218
+
219
+ var cur = start,
220
+ observer = null,
221
+ indexes, len, max;
222
+
223
+ if (operation === undefined) operation = SC.DROP_BEFORE;
224
+
225
+ // adjust the start location based on branches, possibly passing on to an
226
+ // observer.
227
+ if (this.get('isHeaderVisible')) cur--; // exclude my own header item
228
+ if (cur < 0) throw "Tree Item cannot replace itself";
229
+
230
+ // remove branch lengths. If the adjusted start location lands inside of
231
+ // another branch, then just let that observer handle it.
232
+ if (indexes = this.get('branchIndexes')) {
233
+ indexes.forEach(function(i) {
234
+ if (observer || (i>=cur)) return ; // nothing to do
235
+ if (!(observer = this.branchObserverAt(i))) return; // nothing to do
236
+ len = observer.get('length');
237
+
238
+ // if this branch range is before the start loc, just remove it and
239
+ // go on. If cur is somewhere inside of the range, then save to pass
240
+ // on. Note use of operation to determine the abiguous end op.
241
+ if ((i+len === cur) && operation === SC.DROP_AFTER) cur -= i;
242
+ else if (i+len > cur) cur -= i; // put inside of nested range
243
+ else {
244
+ cur -= len-1; observer = null ;
245
+ }
246
+ }, this);
247
+ }
248
+
249
+ // if an observer was saved, pass on call.
250
+ if (observer) {
251
+ observer.replace(cur, amt, objects, operation);
252
+ return this;
253
+ }
254
+
255
+ // no observer was saved, which means cur points to an index inside of
256
+ // our own range. Now amt just needs to be adjusted to remove any
257
+ // visible branches as well.
258
+ max = cur + amt;
259
+ if (amt>1 && indexes) { // if amt is 1 no need...
260
+ indexes.forEachIn(cur, indexes.get('max')-cur, function(i) {
261
+ if (i > max) return; // nothing to do
262
+ if (!(observer = this.branchObserverAt(i))) return; // nothing to do
263
+ len = observer.get('length');
264
+ max -= len-1;
265
+ }, this);
266
+ }
267
+
268
+ // get amt back out. if amt is negative, it means that the range passed
269
+ // was not cleanly inside of this range. raise an exception.
270
+ amt = max-cur;
271
+
272
+ // ok, now that we are adjusted, get the children and forward the replace
273
+ // call on. if there are no children, bad news...
274
+ var children = this.get('children');
275
+ if (!children) throw "cannot replace() tree item with no children";
276
+
277
+ if ((amt < 0) || (max>children.get('length'))) {
278
+ throw "replace() range must lie within a single tree item";
279
+ }
280
+
281
+ children.replace(cur, amt, objects, operation);
282
+
283
+ // don't call enumerableContentDidChange() here because, as an observer,
284
+ // we should be notified by the children array itself.
285
+
286
+ return this;
287
+ },
288
+
289
+ /**
290
+ Called whenever the content for the passed observer has changed. Default
291
+ version notifies the parent if it exists and updates the length.
292
+
293
+ The start, amt and delta params should reflect changes to the children
294
+ array, not to the expanded range for the wrapper.
295
+ */
296
+ observerContentDidChange: function(start, amt, delta) {
297
+
298
+ // clear caches
299
+ this.invalidateBranchObserversAt(start);
300
+ this._objectAtCache = this._outlineLevelCache = null;
301
+ this._disclosureStateCache = null;
302
+ this._contentGroupIndexes = NO;
303
+ this.notifyPropertyChange('branchIndexes');
304
+
305
+ var oldlen = this.get('length'),
306
+ newlen = this._computeLength(),
307
+ parent = this.get('parentObserver'), set;
308
+
309
+ // update length if needed
310
+ if (oldlen !== newlen) this.set('length', newlen);
311
+
312
+ // if we have a parent, notify that parent that we have changed.
313
+ if (!this._notifyParent) return this; // nothing more to do
314
+
315
+ if (parent) {
316
+ set = SC.IndexSet.create(this.get('index'));
317
+ parent._childrenRangeDidChange(parent.get('children'), null, '[]', set);
318
+
319
+ // otherwise, note the enumerable content has changed. note that we need
320
+ // to convert the passed change to reflect the computed range
321
+ } else {
322
+ if (oldlen === newlen) {
323
+ amt = this.expandChildIndex(start+amt);
324
+ start = this.expandChildIndex(start);
325
+ amt = amt - start ;
326
+ delta = 0 ;
327
+
328
+ } else {
329
+ start = this.expandChildIndex(start);
330
+ amt = newlen - start;
331
+ delta = newlen - oldlen ;
332
+ }
333
+
334
+ this.enumerableContentDidChange(start, amt, delta);
335
+ }
336
+ },
337
+
338
+ /**
339
+ Accepts a child index and expands it to reflect any nested groups.
340
+ */
341
+ expandChildIndex: function(index) {
342
+
343
+ var ret = index;
344
+ if (this.get('isHeaderVisible')) index++;
345
+
346
+ // fast path
347
+ var branches = this.get('branchIndexes');
348
+ if (!branches || branches.get('length')===0) return ret;
349
+
350
+ // we have branches, adjust for their length
351
+ branches.forEachIn(0, index, function(idx) {
352
+ ret += this.branchObserverAt(idx).get('length')-1;
353
+ }, this);
354
+
355
+ return ret; // add 1 for item header
356
+ },
357
+
358
+ // ..........................................................
359
+ // SC.COLLECTION CONTENT SUPPORT
360
+ //
361
+
362
+ _contentGroupIndexes: NO,
363
+
364
+ /**
365
+ Called by the collection view to return any group indexes. The default
366
+ implementation will compute the indexes one time based on the delegate
367
+ treeItemIsGrouped
368
+ */
369
+ contentGroupIndexes: function(view, content) {
370
+
371
+ if (content !== this) return null; // only care about receiver
372
+
373
+ var ret = this._contentGroupIndexes;
374
+ if (ret !== NO) return ret ;
375
+
376
+ // if this is not the root item, never do grouping
377
+ if (this.get('parentObserver')) return null;
378
+
379
+ var item = this.get('item'), group, indexes, len, cur, loc, children;
380
+
381
+ if (item && item.isTreeItemContent) group = item.get('treeItemIsGrouped');
382
+ else group = !!this.delegate.get('treeItemIsGrouped');
383
+
384
+ // if grouping is enabled, build an index set with all of our local
385
+ // groups.
386
+ if (group) {
387
+ ret = SC.IndexSet.create();
388
+ indexes = this.get('branchIndexes');
389
+ children = this.get('children');
390
+ len = children ? children.get('length') : 0;
391
+ cur = loc = 0;
392
+
393
+ if (indexes) {
394
+ indexes.forEach(function(i) {
395
+ ret.add(cur, (i+1)-loc); // add loc -> i to set
396
+ cur += (i+1)-loc;
397
+ loc = i+1 ;
398
+
399
+ var observer = this.branchObserverAt(i);
400
+ if (observer) cur += observer.get('length')-1;
401
+ }, this);
402
+ }
403
+
404
+ if (loc<len) ret.add(cur, len-loc);
405
+ } else ret = null;
406
+
407
+ this._contentGroupIndexes = ret ;
408
+ return ret;
409
+ },
410
+
411
+ contentIndexIsGroup: function(view, content, idx) {
412
+ var indexes = this.contentGroupIndexes(view, content);
413
+ return indexes ? indexes.contains(idx) : NO ;
414
+ },
415
+
416
+ /**
417
+ Returns the outline level for the specified index.
418
+ */
419
+ contentIndexOutlineLevel: function(view, content, index) {
420
+ if (content !== this) return -1; // only care about us
421
+
422
+ var cache = this._outlineLevelCache;
423
+ if (cache && (cache[index] !== undefined)) return cache[index];
424
+ if (!cache) cache = this._outlineLevelCache = [];
425
+
426
+ var len = this.get('length'),
427
+ cur = index,
428
+ loc = 0,
429
+ ret = null,
430
+ indexes, children, observer;
431
+
432
+ if (index >= len) return -1;
433
+
434
+ if (this.get('isHeaderVisible')) {
435
+ if (index === 0) return cache[0] = this.get('outlineLevel')-1;
436
+ else cur--;
437
+ }
438
+
439
+ // loop through branch indexes, reducing the offset until it matches
440
+ // something we might actually return.
441
+ if (indexes = this.get('branchIndexes')) {
442
+ indexes.forEach(function(i) {
443
+ if ((ret!==null) || (i > cur)) return ; // past end - nothing to do
444
+
445
+ var observer = this.branchObserverAt(i), len;
446
+ if (!observer) return ; // nothing to do
447
+
448
+ // if cur lands inside of this observer's length, use objectAt to get
449
+ // otherwise, just remove len from cur.
450
+ len = observer.get('length') ;
451
+ if (i+len > cur) {
452
+ ret = observer.contentIndexOutlineLevel(view, observer, cur-i);
453
+ cur = -1;
454
+ } else cur -= len-1 ;
455
+
456
+ },this);
457
+ }
458
+
459
+ if (cur>=0) ret = this.get('outlineLevel'); // get internal if needed
460
+ cache[index] = ret ; // save in cache
461
+ return ret ;
462
+ },
463
+
464
+ /**
465
+ Returns the disclosure state for the specified index.
466
+ */
467
+ contentIndexDisclosureState: function(view, content, index) {
468
+ if (content !== this) return -1; // only care about us
469
+
470
+ var cache = this._disclosureStateCache;
471
+ if (cache && (cache[index] !== undefined)) return cache[index];
472
+ if (!cache) cache = this._disclosureStateCache = [];
473
+
474
+ var len = this.get('length'),
475
+ cur = index,
476
+ loc = 0,
477
+ ret = null,
478
+ indexes, children, observer;
479
+
480
+ if (index >= len) return SC.LEAF_NODE;
481
+
482
+ if (this.get('isHeaderVisible')) {
483
+ if (index === 0) return cache[0] = this.get('disclosureState');
484
+ else cur--;
485
+ }
486
+
487
+ // loop through branch indexes, reducing the offset until it matches
488
+ // something we might actually return.
489
+ if (indexes = this.get('branchIndexes')) {
490
+ indexes.forEach(function(i) {
491
+ if ((ret!==null) || (i > cur)) return ; // past end - nothing to do
492
+
493
+ var observer = this.branchObserverAt(i), len;
494
+ if (!observer) return ; // nothing to do
495
+
496
+ // if cur lands inside of this observer's length, use objectAt to get
497
+ // otherwise, just remove len from cur.
498
+ len = observer.get('length') ;
499
+ if (i+len > cur) {
500
+ ret = observer.contentIndexDisclosureState(view, observer, cur-i);
501
+ cur = -1;
502
+ } else cur -= len-1 ;
503
+
504
+ },this);
505
+ }
506
+
507
+ if (cur>=0) ret = SC.LEAF_NODE; // otherwise its a leaf node
508
+ cache[index] = ret ; // save in cache
509
+ return ret ;
510
+ },
511
+
512
+ /**
513
+ Expands the specified content index. This will search down until it finds
514
+ the branchObserver responsible for this item and then calls _collapse on
515
+ it.
516
+ */
517
+ contentIndexExpand: function(view, content, idx) {
518
+
519
+ var indexes, cur = idx, children, item;
520
+
521
+ if (content !== this) return; // only care about us
522
+ if (this.get('isHeaderVisible')) {
523
+ if (idx===0) {
524
+ this._expand(this.get('item'));
525
+ return;
526
+ } else cur--;
527
+ }
528
+
529
+ if (indexes = this.get('branchIndexes')) {
530
+ indexes.forEach(function(i) {
531
+ if (i >= cur) return; // past end - nothing to do
532
+ var observer = this.branchObserverAt(i), len;
533
+ if (!observer) return ;
534
+
535
+ len = observer.get('length');
536
+ if (i+len > cur) {
537
+ observer.contentIndexExpand(view, observer, cur-i);
538
+ cur = -1 ; //done
539
+ } else cur -= len-1;
540
+
541
+ }, this);
542
+ }
543
+
544
+ // if we are still inside of the range then maybe pass on to a child item
545
+ if (cur>=0) {
546
+ children = this.get('children');
547
+ item = children ? children.objectAt(cur) : null;
548
+ if (item) this._expand(item, this.get('item'), cur);
549
+ }
550
+ },
551
+
552
+ /**
553
+ Called to collapse a content index item if it is currently in an open
554
+ disclosure state. The default implementation does nothing.
555
+
556
+ @param {SC.CollectionView} view the collection view
557
+ @param {SC.Array} content the content object
558
+ @param {Number} idx the content index
559
+ @returns {void}
560
+ */
561
+ contentIndexCollapse: function(view, content, idx) {
562
+
563
+ var indexes, children, item, cur = idx;
564
+
565
+ if (content !== this) return; // only care about us
566
+ if (this.get('isHeaderVisible')) {
567
+ if (idx===0) {
568
+ this._collapse(this.get('item'));
569
+ return;
570
+ } else cur--;
571
+ }
572
+
573
+
574
+ if (indexes = this.get('branchIndexes')) {
575
+ indexes.forEach(function(i) {
576
+ if (i >= cur) return; // past end - nothing to do
577
+ var observer = this.branchObserverAt(i), len;
578
+ if (!observer) return ;
579
+
580
+ len = observer.get('length');
581
+ if (i+len > cur) {
582
+ observer.contentIndexCollapse(view, observer, cur-i);
583
+ cur = -1 ; //done
584
+ } else cur -= len-1;
585
+
586
+ }, this);
587
+ }
588
+
589
+ // if we are still inside of the range then maybe pass on to a child item
590
+ if (cur>=0) {
591
+ children = this.get('children');
592
+ item = children ? children.objectAt(cur) : null;
593
+ if (item) this._collapse(item, this.get('item'), cur);
594
+ }
595
+ },
596
+
597
+ // ..........................................................
598
+ // BRANCH NODES
599
+ //
600
+
601
+ /**
602
+ Returns the branch item for the specified index. If none exists yet, it
603
+ will be created.
604
+ */
605
+ branchObserverAt: function(index) {
606
+ var byIndex = this._branchObserversByIndex,
607
+ indexes = this._branchObserverIndexes,
608
+ ret, parent, pitem, item, children, guid, del ;
609
+
610
+ if (!byIndex) byIndex = this._branchObserversByIndex = [];
611
+ if (!indexes) {
612
+ indexes = this._branchObserverIndexes = SC.IndexSet.create();
613
+ }
614
+
615
+ if (ret = byIndex[index]) return ret ; // use cache
616
+
617
+ // no observer for this content exists, create one
618
+ children = this.get('children');
619
+ item = children ? children.objectAt(index) : null ;
620
+ if (!item) return null ; // can't create an observer for a null item
621
+
622
+ byIndex[index] = ret = SC.TreeItemObserver.create({
623
+ item: item,
624
+ delegate: this.get('delegate'),
625
+ parentObserver: this,
626
+ index: index,
627
+ outlineLevel: this.get('outlineLevel')+1
628
+ });
629
+
630
+ indexes.add(index); // save for later invalidation
631
+ return ret ;
632
+ },
633
+
634
+ /**
635
+ Invalidates any branch observers on or after the specified index range.
636
+ */
637
+ invalidateBranchObserversAt: function(index) {
638
+ var byIndex = this._branchObserversByIndex,
639
+ indexes = this._branchObserverIndexes;
640
+
641
+ if (!byIndex || byIndex.length<=index) return this ; // nothing to do
642
+ if (index < 0) index = 0 ;
643
+
644
+ // destroy any observer on or after the range
645
+ indexes.forEachIn(index, indexes.get('max')-index, function(i) {
646
+ var observer = byIndex[i];
647
+ if (observer) observer.destroy();
648
+ }, this);
649
+
650
+ byIndex.length = index; // truncate to dump extra indexes
651
+
652
+ return this;
653
+ },
654
+
655
+ // ..........................................................
656
+ // INTERNAL METHODS
657
+ //
658
+
659
+ init: function() {
660
+ sc_super();
661
+
662
+ // begin all properties on item if there is one. This will allow us to
663
+ // track important property changes.
664
+ var item = this.get('item');
665
+ if (!item) throw "SC.TreeItemObserver.item cannot be null";
666
+
667
+ item.addObserver('*', this, this._itemPropertyDidChange);
668
+ this._itemPropertyDidChange(item, '*');
669
+ this._notifyParent = YES ; // avoid infinite loops
670
+ },
671
+
672
+ /**
673
+ Called just before a branch observer is removed. Should stop any
674
+ observering and invalidate any child observers.
675
+ */
676
+ destroy: function() {
677
+ this.invalidateBranchObserversAt(0);
678
+ this._objectAtCache = null ;
679
+
680
+ // cleanup observing
681
+ var item = this.get('item');
682
+ if (item) item.removeObserver('*', this, this._itemPropertyDidChange);
683
+
684
+ var children = this._children,
685
+ ro = this._childrenRangeObserver;
686
+ if (children && ro) children.removeRangeObserver(ro);
687
+
688
+ sc_super();
689
+ },
690
+
691
+ /**
692
+ Called whenever a property changes on the item. Determines if either the
693
+ children array or the disclosure state has changed and then notifies as
694
+ necessary..
695
+ */
696
+ _itemPropertyDidChange: function(target, key) {
697
+ var children = this.get('children'),
698
+ state = this.get('disclosureState'),
699
+ item = this.get('item'),
700
+ next ;
701
+
702
+ this.beginPropertyChanges();
703
+
704
+ next = this._computeDisclosureState(item);
705
+ if (state !== next) this.set('disclosureState', next);
706
+
707
+ next = this._computeChildren(item);
708
+ if (children !== next) this.set('children', next);
709
+
710
+ this.endPropertyChanges();
711
+ },
712
+
713
+ /**
714
+ Called whenever the children or disclosure state changes. Begins or ends
715
+ observing on the children array so that changes can propogate outward.
716
+ */
717
+ _childrenDidChange: function() {
718
+ var state = this.get('disclosureState'),
719
+ cur = state === SC.BRANCH_OPEN ? this.get('children') : null,
720
+ last = this._children,
721
+ ro = this._childrenRangeObserver;
722
+
723
+ if (last === cur) return this; //nothing to do
724
+ if (ro) last.removeRangeObserver(ro);
725
+ if (cur) {
726
+ this._childrenRangeObserver =
727
+ cur.addRangeObserver(null, this, this._childrenRangeDidChange);
728
+ } else this._childrenRangeObserver = null;
729
+
730
+ this._children = cur ;
731
+ this._childrenRangeDidChange(cur, null, '[]', null);
732
+
733
+ }.observes("children", "disclosureState"),
734
+
735
+ /**
736
+ Called anytime the actual content of the children has changed. If this
737
+ changes the length property, then notifies the parent that the content
738
+ might have changed.
739
+ */
740
+ _childrenRangeDidChange: function(array, objects, key, indexes) {
741
+ var children = this.get('children'),
742
+ len = children ? children.get('length') : 0,
743
+ min = indexes ? indexes.get('min') : 0,
744
+ max = indexes ? indexes.get('max') : len,
745
+ old = this._childrenLen || 0;
746
+
747
+ this._childrenLen = len; // save for future calls
748
+ this.observerContentDidChange(min, max-min, len-old);
749
+ },
750
+
751
+ /**
752
+ Computes the current disclosure state of the item by asking the item or
753
+ the delegate. If no pitem or index is passed, the parentItem and idex
754
+ will be used.
755
+ */
756
+ _computeDisclosureState: function(item, pitem, index) {
757
+ var key, del;
758
+
759
+ // no item - assume leaf node
760
+ if (!item || !this._computeChildren(item)) return SC.LEAF_NODE;
761
+
762
+ // item implement TreeItemContent - call directly
763
+ else if (item.isTreeItemContent) {
764
+ if (pitem === undefined) pitem = this.get('parentItem');
765
+ if (index === undefined) index = this.get('index');
766
+ return item.treeItemDisclosureState(pitem, index);
767
+
768
+ // otherwise get treeItemDisclosureStateKey from delegate
769
+ } else {
770
+ key = this._treeItemIsExpandedKey ;
771
+ if (!key) {
772
+ del = this.get('delegate');
773
+ key = del ? del.get('treeItemIsExpandedKey') : 'treeItemIsExpanded';
774
+ this._treeItemIsExpandedKey = key ;
775
+ }
776
+ return item.get(key) ? SC.BRANCH_OPEN : SC.BRANCH_CLOSED;
777
+ }
778
+ },
779
+
780
+ /**
781
+ Collapse the item at the specified index. This will either directly
782
+ modify the property on the item or call the treeItemCollapse() method.
783
+ */
784
+ _collapse: function(item, pitem, index) {
785
+ var key, del;
786
+
787
+ // no item - assume leaf node
788
+ if (!item || !this._computeChildren(item)) return this;
789
+
790
+ // item implement TreeItemContent - call directly
791
+ else if (item.isTreeItemContent) {
792
+ if (pitem === undefined) pitem = this.get('parentItem');
793
+ if (index === undefined) index = this.get('index');
794
+ item.treeItemCollapse(pitem, index);
795
+
796
+ // otherwise get treeItemDisclosureStateKey from delegate
797
+ } else {
798
+ key = this._treeItemIsExpandedKey ;
799
+ if (!key) {
800
+ del = this.get('delegate');
801
+ key = del ? del.get('treeItemIsExpandedKey') : 'treeItemIsExpanded';
802
+ this._treeItemIsExpandedKey = key ;
803
+ }
804
+ item.setIfChanged(key, NO);
805
+ }
806
+
807
+ return this ;
808
+ },
809
+
810
+ /**
811
+ Expand the item at the specified index. This will either directly
812
+ modify the property on the item or call the treeItemExpand() method.
813
+ */
814
+ _expand: function(item, pitem, index) {
815
+ var key, del;
816
+
817
+ // no item - assume leaf node
818
+ if (!item || !this._computeChildren(item)) return this;
819
+
820
+ // item implement TreeItemContent - call directly
821
+ else if (item.isTreeItemContent) {
822
+ if (pitem === undefined) pitem = this.get('parentItem');
823
+ if (index === undefined) index = this.get('index');
824
+ item.treeItemExpand(pitem, index);
825
+
826
+ // otherwise get treeItemDisclosureStateKey from delegate
827
+ } else {
828
+ key = this._treeItemIsExpandedKey ;
829
+ if (!key) {
830
+ del = this.get('delegate');
831
+ key = del ? del.get('treeItemIsExpandedKey') : 'treeItemIsExpanded';
832
+ this._treeItemIsExpandedKey = key ;
833
+ }
834
+ item.setIfChanged(key, YES);
835
+ }
836
+
837
+ return this ;
838
+ },
839
+
840
+ /**
841
+ Computes the children for the passed item.
842
+ */
843
+ _computeChildren: function(item) {
844
+ var del, key;
845
+
846
+ // no item - no children
847
+ if (!item) return null;
848
+
849
+ // item implement TreeItemContent - call directly
850
+ else if (item.isTreeItemContent) return item.get('treeItemChildren');
851
+
852
+ // otherwise get treeItemChildrenKey from delegate
853
+ else {
854
+ key = this._treeItemChildrenKey ;
855
+ if (!key) {
856
+ del = this.get('delegate');
857
+ key = del ? del.get('treeItemChildrenKey') : 'treeItemChildren';
858
+ this._treeItemChildrenKey = key ;
859
+ }
860
+ return item.get(key);
861
+ }
862
+ },
863
+
864
+ /**
865
+ Computes the length of the array by looking at children.
866
+ */
867
+ _computeLength: function() {
868
+ var ret = this.get('isHeaderVisible') ? 1 : 0,
869
+ state = this.get('disclosureState'),
870
+ children = this.get('children'),
871
+ indexes ;
872
+
873
+ // if disclosure is open, add children count + length of branch observers.
874
+ if ((state === SC.BRANCH_OPEN) && children) {
875
+ ret += children.get('length');
876
+ if (indexes = this.get('branchIndexes')) {
877
+ indexes.forEach(function(idx) {
878
+ var observer = this.branchObserverAt(idx);
879
+ ret += observer.get('length')-1;
880
+ }, this);
881
+ }
882
+ }
883
+ return ret ;
884
+ }
885
+
886
+ });
887
+