yellow-brick-road 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (233) hide show
  1. data/README.rst +148 -0
  2. data/Rakefile +37 -0
  3. data/lib/tasks/yellow-brick-road_tasks.rake +4 -0
  4. data/lib/yellow-brick-road.rb +6 -0
  5. data/lib/yellow-brick-road/config.rb +15 -0
  6. data/lib/yellow-brick-road/directive_processor.rb +68 -0
  7. data/lib/yellow-brick-road/engine.rb +22 -0
  8. data/lib/yellow-brick-road/soy_processor.rb +56 -0
  9. data/lib/yellow-brick-road/utils.rb +38 -0
  10. data/lib/yellow-brick-road/version.rb +3 -0
  11. data/test/dummy/Rakefile +7 -0
  12. data/test/dummy/app/assets/javascripts/application.js +12 -0
  13. data/test/dummy/app/assets/javascripts/closure-deps.js +4 -0
  14. data/test/dummy/app/assets/javascripts/my-closure/simple.js.soy +14 -0
  15. data/test/dummy/app/assets/javascripts/my-closure/start.js +25 -0
  16. data/test/dummy/app/assets/stylesheets/application.css +7 -0
  17. data/test/dummy/app/controllers/application_controller.rb +7 -0
  18. data/test/dummy/app/helpers/application_helper.rb +2 -0
  19. data/test/dummy/app/views/application/index.html.erb +0 -0
  20. data/test/dummy/app/views/layouts/application.html.erb +18 -0
  21. data/test/dummy/config.ru +4 -0
  22. data/test/dummy/config/application.rb +51 -0
  23. data/test/dummy/config/boot.rb +10 -0
  24. data/test/dummy/config/environment.rb +5 -0
  25. data/test/dummy/config/environments/development.rb +30 -0
  26. data/test/dummy/config/environments/production.rb +60 -0
  27. data/test/dummy/config/environments/test.rb +39 -0
  28. data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
  29. data/test/dummy/config/initializers/inflections.rb +10 -0
  30. data/test/dummy/config/initializers/mime_types.rb +5 -0
  31. data/test/dummy/config/initializers/secret_token.rb +7 -0
  32. data/test/dummy/config/initializers/session_store.rb +8 -0
  33. data/test/dummy/config/initializers/wrap_parameters.rb +10 -0
  34. data/test/dummy/config/initializers/yellow_brick_road.rb +2 -0
  35. data/test/dummy/config/locales/en.yml +5 -0
  36. data/test/dummy/config/routes.rb +58 -0
  37. data/test/dummy/log/development.log +13924 -0
  38. data/test/dummy/log/test.log +0 -0
  39. data/test/dummy/public/404.html +26 -0
  40. data/test/dummy/public/422.html +26 -0
  41. data/test/dummy/public/500.html +26 -0
  42. data/test/dummy/public/favicon.ico +0 -0
  43. data/test/dummy/script/rails +6 -0
  44. data/test/dummy/tmp/cache/assets/BE0/120/sprockets%2F751842b8c6750008c7310d182600d173 +142 -0
  45. data/test/dummy/tmp/cache/assets/C19/950/sprockets%2F142437f1d8d9424007b4a882a5429333 +1372 -0
  46. data/test/dummy/tmp/cache/assets/C4B/D00/sprockets%2F400f22c081529179ce3d079457de3009 +806 -0
  47. data/test/dummy/tmp/cache/assets/C5A/EE0/sprockets%2Fb711429ed948c503b718d077037780f8 +0 -0
  48. data/test/dummy/tmp/cache/assets/C5B/A80/sprockets%2F508569b474262724c61a461f7777dab7 +1118 -0
  49. data/test/dummy/tmp/cache/assets/C6C/660/sprockets%2F2c298b3b02232a21527680685a3efc30 +9289 -0
  50. data/test/dummy/tmp/cache/assets/C72/8A0/sprockets%2F167b265129e30d87d253c406db305c60 +293 -0
  51. data/test/dummy/tmp/cache/assets/C7E/9F0/sprockets%2F89862076204c62c4593ac20de32da909 +9 -0
  52. data/test/dummy/tmp/cache/assets/C8B/5F0/sprockets%2Fc6a4470b5c21e285e829a99365839b24 +0 -0
  53. data/test/dummy/tmp/cache/assets/C92/D20/sprockets%2F2e618f7805f445889aec94885a500f03 +457 -0
  54. data/test/dummy/tmp/cache/assets/C98/FD0/sprockets%2Fb11442af041f96e87a43a1dc11231745 +283 -0
  55. data/test/dummy/tmp/cache/assets/CA3/520/sprockets%2F5379d7143c6c52b11b88dc0ab5436133 +277 -0
  56. data/test/dummy/tmp/cache/assets/CA5/450/sprockets%2F6bb727c9312a749134ad67323a317f0d +73 -0
  57. data/test/dummy/tmp/cache/assets/CA5/4F0/sprockets%2Feeb7de7771527700af194c0441d29101 +709 -0
  58. data/test/dummy/tmp/cache/assets/CA6/E90/sprockets%2F611f68180f43c4181f06ae5c5f8201e2 +1546 -0
  59. data/test/dummy/tmp/cache/assets/CA7/310/sprockets%2F45664cf816315200b574e029fde6f10a +0 -0
  60. data/test/dummy/tmp/cache/assets/CA9/9D0/sprockets%2F2672e32464cf7267c4ba3d028f54b153 +224 -0
  61. data/test/dummy/tmp/cache/assets/CAB/5A0/sprockets%2F7f50e0289f150c8636ac9253129bc13c +2556 -0
  62. data/test/dummy/tmp/cache/assets/CB5/7E0/sprockets%2F42ff6672683b2029233a800e7539eeee +474 -0
  63. data/test/dummy/tmp/cache/assets/CB6/DC0/sprockets%2F2f9882155bb2d4d3ab5d708951857c60 +494 -0
  64. data/test/dummy/tmp/cache/assets/CBB/680/sprockets%2F1dc336d96fb52df34b458185559922b5 +1018 -0
  65. data/test/dummy/tmp/cache/assets/CBC/640/sprockets%2F67d2e0d9e5129d237e575d2780c64b47 +1260 -0
  66. data/test/dummy/tmp/cache/assets/CBE/550/sprockets%2Fd680cac830e0b3408ba910f0b0421147 +25 -0
  67. data/test/dummy/tmp/cache/assets/CC7/790/sprockets%2F69941f32a12e4f99d4a57f65386d870d +608 -0
  68. data/test/dummy/tmp/cache/assets/CCB/F80/sprockets%2Fa865701ef2ec41155e524772c31a1a2b +1088 -0
  69. data/test/dummy/tmp/cache/assets/CCE/580/sprockets%2F879411ed27ed1c557d57853d8f579b56 +0 -0
  70. data/test/dummy/tmp/cache/assets/CD0/070/sprockets%2F6748fe8481965f260d9c56b7f9f508a2 +1530 -0
  71. data/test/dummy/tmp/cache/assets/CD4/750/sprockets%2Faf3505141ecb3169ce41ce519d136924 +0 -0
  72. data/test/dummy/tmp/cache/assets/CD6/A90/sprockets%2F3f55ac75b9fb8426312116bcb940a580 +2539 -0
  73. data/test/dummy/tmp/cache/assets/CD9/6C0/sprockets%2F5e2458bc52da90ba349a66035e3b6752 +0 -0
  74. data/test/dummy/tmp/cache/assets/CD9/F50/sprockets%2F9008bf696500cfae1d61f045f209181e +256 -0
  75. data/test/dummy/tmp/cache/assets/CDB/B40/sprockets%2F53529a22c994570a0df4742c0bfe61f4 +0 -0
  76. data/test/dummy/tmp/cache/assets/CDC/D10/sprockets%2F1e775b4ff06b4401c07503ce95a839b5 +75 -0
  77. data/test/dummy/tmp/cache/assets/CDE/CD0/sprockets%2F141066798b4acf07053f7e3a6cb4e555 +1613 -0
  78. data/test/dummy/tmp/cache/assets/CE1/760/sprockets%2F245fe11803630fe30d0cf8a869886ab5 +357 -0
  79. data/test/dummy/tmp/cache/assets/CE1/FA0/sprockets%2F863d1650ef066e4a2168bc57c7c0e096 +0 -0
  80. data/test/dummy/tmp/cache/assets/CE2/310/sprockets%2Fd38075d5592ecaf82e43526c03b467c4 +1545 -0
  81. data/test/dummy/tmp/cache/assets/CE2/420/sprockets%2F30f2e8f30477e80cf6416dfe27307c07 +204 -0
  82. data/test/dummy/tmp/cache/assets/CE2/D70/sprockets%2F467c44b63644e0f44dd06a585f36f1a6 +522 -0
  83. data/test/dummy/tmp/cache/assets/CE3/670/sprockets%2Fddd11860b444cd0f9996be0c46762318 +796 -0
  84. data/test/dummy/tmp/cache/assets/CE4/0B0/sprockets%2Ff11535d785c0d34349c64d673bd4b28f +1105 -0
  85. data/test/dummy/tmp/cache/assets/CE4/590/sprockets%2Fd68edcc87a4ae302794093081b45b819 +10 -0
  86. data/test/dummy/tmp/cache/assets/CE4/D60/sprockets%2F61772e4a60b616f74da91b838a2f4f82 +0 -0
  87. data/test/dummy/tmp/cache/assets/CE6/DD0/sprockets%2F2fe073024a2bf26bd98458388b57af37 +1355 -0
  88. data/test/dummy/tmp/cache/assets/CE7/160/sprockets%2Fba1f9939f031b4356ec1869d40fc2747 +1261 -0
  89. data/test/dummy/tmp/cache/assets/CE8/C70/sprockets%2Fc6c9ba3c677b5e2af8520395192c9445 +173 -0
  90. data/test/dummy/tmp/cache/assets/CEA/8B0/sprockets%2Ff77e549cb6d37604105f35d4e67d8c21 +511 -0
  91. data/test/dummy/tmp/cache/assets/CEA/AA0/sprockets%2F5f816982c86d2e6b72b2f5f65c51d070 +1529 -0
  92. data/test/dummy/tmp/cache/assets/CEA/C10/sprockets%2F9dcd541e67c299ab076a44a2183872f8 +0 -0
  93. data/test/dummy/tmp/cache/assets/CF1/5A0/sprockets%2F1a697695edf2bb7b49a2896904218bc7 +115 -0
  94. data/test/dummy/tmp/cache/assets/CF4/480/sprockets%2F5e99c77e93f4a522c84357e62b25e0f7 +43 -0
  95. data/test/dummy/tmp/cache/assets/CF7/460/sprockets%2Fd12ea9733fe3c92456f57f9145569b9c +0 -0
  96. data/test/dummy/tmp/cache/assets/CF7/470/sprockets%2F2897897a166ca3369fecb88f83f211b5 +435 -0
  97. data/test/dummy/tmp/cache/assets/CFA/760/sprockets%2Fa9024adba14091e0635c6874d1db4e22 +0 -0
  98. data/test/dummy/tmp/cache/assets/D01/F30/sprockets%2Fe639a15b6e0cca37d12443b408e1166f +25 -0
  99. data/test/dummy/tmp/cache/assets/D02/9F0/sprockets%2Fb99eae308897fe88cb9414b96824098b +0 -0
  100. data/test/dummy/tmp/cache/assets/D03/330/sprockets%2F1e003cdb3e7dcc9307e84090ad457127 +454 -0
  101. data/test/dummy/tmp/cache/assets/D03/8B0/sprockets%2Ff74632bddf2c0b2018ca7b736309380e +365 -0
  102. data/test/dummy/tmp/cache/assets/D05/0A0/sprockets%2Fe57658220260db13eb5577aef42cb61b +257 -0
  103. data/test/dummy/tmp/cache/assets/D05/920/sprockets%2F909507434dcc270db4853e4c147f0aac +31 -0
  104. data/test/dummy/tmp/cache/assets/D08/510/sprockets%2Fa567be6cb6d7310096f1739b25a5a3f0 +50 -0
  105. data/test/dummy/tmp/cache/assets/D08/9F0/sprockets%2F1d61d2c89ca50957066bacc5b69011f5 +1424 -0
  106. data/test/dummy/tmp/cache/assets/D0A/790/sprockets%2Feb16913e6504c9b0d3be431de39e4751 +300 -0
  107. data/test/dummy/tmp/cache/assets/D0C/C50/sprockets%2Fd6613bee8b40d50459af6b52a7084f34 +796 -0
  108. data/test/dummy/tmp/cache/assets/D0D/030/sprockets%2Fba3f13b4a444679e8bc2549226ec743b +21 -0
  109. data/test/dummy/tmp/cache/assets/D0D/350/sprockets%2F2670bce036d485e15d059c0f1e98f24a +207 -0
  110. data/test/dummy/tmp/cache/assets/D13/270/sprockets%2F497cb163e6317e3fc1565d832f406cfb +348 -0
  111. data/test/dummy/tmp/cache/assets/D13/380/sprockets%2F786d003c9c7fb759dd26c1030c087cf6 +813 -0
  112. data/test/dummy/tmp/cache/assets/D13/7C0/sprockets%2F528d22310a9ab8e6fba08d82844ce795 +0 -0
  113. data/test/dummy/tmp/cache/assets/D15/F60/sprockets%2Fa28394e3f80365b5bc86794dd46daa22 +0 -0
  114. data/test/dummy/tmp/cache/assets/D18/500/sprockets%2Fd22c2d97d1db2154f2f7592906e957ea +1001 -0
  115. data/test/dummy/tmp/cache/assets/D1B/C70/sprockets%2F1c04848b1e1d6e8e33b8581f8c8128ff +223 -0
  116. data/test/dummy/tmp/cache/assets/D1C/600/sprockets%2Fa0601f99147f59ddd6266e6aff077e14 +0 -0
  117. data/test/dummy/tmp/cache/assets/D1E/470/sprockets%2Fb3933e694547b78bf6fb15f44a4623fe +53 -0
  118. data/test/dummy/tmp/cache/assets/D1F/480/sprockets%2F545164168becf42b289efc8708f1db68 +1278 -0
  119. data/test/dummy/tmp/cache/assets/D21/630/sprockets%2F0a14114729c14637f2e8f122acabd1ab +823 -0
  120. data/test/dummy/tmp/cache/assets/D24/A90/sprockets%2F21c8a0d48c51b8585ba03bc112ecd153 +692 -0
  121. data/test/dummy/tmp/cache/assets/D25/D30/sprockets%2F3b937f4c16d2aa0a28fc02a0e922712b +1441 -0
  122. data/test/dummy/tmp/cache/assets/D25/F30/sprockets%2Fe251527c0c018f4b4ad44b2ad7064fb0 +2255 -0
  123. data/test/dummy/tmp/cache/assets/D26/DE0/sprockets%2F761ac1bdb0739cc56fa0c1224b137b09 +0 -0
  124. data/test/dummy/tmp/cache/assets/D2A/C30/sprockets%2F978fe7268754f451c59b9ccb323ffa56 +0 -0
  125. data/test/dummy/tmp/cache/assets/D2B/0F0/sprockets%2Fbf223af03335cfc08a71e549e10c0e27 +2539 -0
  126. data/test/dummy/tmp/cache/assets/D2E/6D0/sprockets%2F9e7fda3affb389313cc50223f01c0324 +0 -0
  127. data/test/dummy/tmp/cache/assets/D2F/110/sprockets%2F3730ffe2ed34c1219d580bd1615ea7b0 +2239 -0
  128. data/test/dummy/tmp/cache/assets/D2F/F10/sprockets%2F9cac242f0bf5ec00079ea3a463e26552 +153 -0
  129. data/test/dummy/tmp/cache/assets/D30/1D0/sprockets%2Fd690a26a0b0ae138c1c48d257a7674bc +589 -0
  130. data/test/dummy/tmp/cache/assets/D32/A10/sprockets%2F13fe41fee1fe35b49d145bcc06610705 +0 -0
  131. data/test/dummy/tmp/cache/assets/D36/940/sprockets%2Fb4ba462ac9f4aac561c36e60367c1378 +572 -0
  132. data/test/dummy/tmp/cache/assets/D37/090/sprockets%2F2f2e71ebbc240014ebf648f0917e854a +798 -0
  133. data/test/dummy/tmp/cache/assets/D3A/440/sprockets%2F6d332243647c841dea36ed822cdfc23e +165 -0
  134. data/test/dummy/tmp/cache/assets/D3B/5A0/sprockets%2F82e05cf8c88ba8cb1c87e50d51372a03 +0 -0
  135. data/test/dummy/tmp/cache/assets/D41/B30/sprockets%2Fba1b93913dd01d83ac9a96df334456f8 +0 -0
  136. data/test/dummy/tmp/cache/assets/D43/D90/sprockets%2F04f3a5926d5a7672456dc7afa73d0c7f +38 -0
  137. data/test/dummy/tmp/cache/assets/D45/1F0/sprockets%2F1bfa855d9c10ff2431a9a548958cc5e4 +83 -0
  138. data/test/dummy/tmp/cache/assets/D45/B10/sprockets%2F643f3d9b216e48df952b7f150a46a7ec +60 -0
  139. data/test/dummy/tmp/cache/assets/D46/040/sprockets%2F199546844e5939721a5afcbcce4ea43a +143 -0
  140. data/test/dummy/tmp/cache/assets/D49/320/sprockets%2Fd8123eb229e34c9f507f7b1876f1c4ee +506 -0
  141. data/test/dummy/tmp/cache/assets/D49/750/sprockets%2Ff41ef1c0832b7294fb15588ff5c783cb +0 -0
  142. data/test/dummy/tmp/cache/assets/D49/930/sprockets%2F1071926698fa55abc71e1b6fd966dfe1 +72 -0
  143. data/test/dummy/tmp/cache/assets/D49/D10/sprockets%2Fb67b8d7cc7579352a91694f9ae10cdb0 +127 -0
  144. data/test/dummy/tmp/cache/assets/D4A/160/sprockets%2Fcbd8988b5e18d153eff6230d72e9046a +516 -0
  145. data/test/dummy/tmp/cache/assets/D4A/2B0/sprockets%2Ffcdf002d38fd938bf7226b46b76706c8 +1101 -0
  146. data/test/dummy/tmp/cache/assets/D4E/2F0/sprockets%2F77cb87ae57f0d8c25cdaa74181a64997 +1441 -0
  147. data/test/dummy/tmp/cache/assets/D4F/060/sprockets%2Fa9e66b39ada7394a29bf44f3a682f665 +511 -0
  148. data/test/dummy/tmp/cache/assets/D50/BD0/sprockets%2F88650dd57ef64075462e6dae757dbe2c +0 -0
  149. data/test/dummy/tmp/cache/assets/D53/CA0/sprockets%2Fa85032e82709a043fbb2ec00e04f2bbd +0 -0
  150. data/test/dummy/tmp/cache/assets/D54/BF0/sprockets%2F91970514ff528e8d2bfd81f1ec83c9c8 +240 -0
  151. data/test/dummy/tmp/cache/assets/D54/ED0/sprockets%2F71c9fa01091d432b131da3bb73faf3d4 +10 -0
  152. data/test/dummy/tmp/cache/assets/D56/500/sprockets%2F75ebadd035f1324b194034af92eac3a0 +0 -0
  153. data/test/dummy/tmp/cache/assets/D5A/900/sprockets%2F5729f77d97fdee53b1942cf17f6f05e4 +474 -0
  154. data/test/dummy/tmp/cache/assets/D5A/D50/sprockets%2F81bace3db2c2f1241175ff3c5009d08c +0 -0
  155. data/test/dummy/tmp/cache/assets/D5B/C70/sprockets%2Fe64119a9db7017b7ab3b0da1b6076f0d +44 -0
  156. data/test/dummy/tmp/cache/assets/D5E/4D0/sprockets%2F756f25e4ad861a050cdc41bb8414e4ab +126 -0
  157. data/test/dummy/tmp/cache/assets/D5E/730/sprockets%2Fd30caf70b387c4604326bdda32aeb549 +0 -0
  158. data/test/dummy/tmp/cache/assets/D5E/AA0/sprockets%2F790dd07caaaacb30ceb0174664e90817 +136 -0
  159. data/test/dummy/tmp/cache/assets/D64/D30/sprockets%2Fe4bd8f60a3a446274c3cb2f5d16563ac +590 -0
  160. data/test/dummy/tmp/cache/assets/D66/400/sprockets%2Fecb7401d20daf25605a7afad3a793778 +0 -0
  161. data/test/dummy/tmp/cache/assets/D67/250/sprockets%2F8422eb26855ca9c953a3bf1aeade8004 +0 -0
  162. data/test/dummy/tmp/cache/assets/D69/900/sprockets%2F28ae64f52cb18f77b1a1bd9c51293da4 +0 -0
  163. data/test/dummy/tmp/cache/assets/D6A/870/sprockets%2F1ece6a51b42f9280f4cee9020c94b72e +197 -0
  164. data/test/dummy/tmp/cache/assets/D6B/DD0/sprockets%2F9a0abc735e27fc61dab019788518eba4 +164 -0
  165. data/test/dummy/tmp/cache/assets/D6E/CC0/sprockets%2F8b4fbcec2475e7203b8859baf8e310a3 +0 -0
  166. data/test/dummy/tmp/cache/assets/D72/470/sprockets%2Fbc0c6d850e7c769e83d58eb3e6061b2a +2556 -0
  167. data/test/dummy/tmp/cache/assets/D72/9D0/sprockets%2F9402daf6da6f7eed331a9d78216cb761 +0 -0
  168. data/test/dummy/tmp/cache/assets/D74/070/sprockets%2F91ae68f698a39bd7d0d11150fc46e4cd +418 -0
  169. data/test/dummy/tmp/cache/assets/D74/7F0/sprockets%2F22dad1069ea6a8f29ae757c44e18ec83 +0 -0
  170. data/test/dummy/tmp/cache/assets/D75/3C0/sprockets%2F44e2ae51b97853d8ecda7b264a267c7d +1630 -0
  171. data/test/dummy/tmp/cache/assets/D77/780/sprockets%2Ffa2abdfb0b62867c346f79187b8e42d5 +823 -0
  172. data/test/dummy/tmp/cache/assets/D79/850/sprockets%2F4d540586ed379fd9a70fa0b7ce4f5b27 +306 -0
  173. data/test/dummy/tmp/cache/assets/D7A/B60/sprockets%2F5925c92f48caff053d08853dc69e5bba +0 -0
  174. data/test/dummy/tmp/cache/assets/D81/C90/sprockets%2F19aca5c835efce74878c23e581e2a89e +2239 -0
  175. data/test/dummy/tmp/cache/assets/D84/210/sprockets%2Fabd0103ccec2b428ac62c94e4c40b384 +11228 -0
  176. data/test/dummy/tmp/cache/assets/D8B/B10/sprockets%2Fbb7a2305a8f2832631863bbababb67be +301 -0
  177. data/test/dummy/tmp/cache/assets/D92/3B0/sprockets%2F93dc71f411faf72ec8ef0b5d217b51a0 +505 -0
  178. data/test/dummy/tmp/cache/assets/D92/EE0/sprockets%2Ffd051ea0abf6be6970754aa732e40c8b +289 -0
  179. data/test/dummy/tmp/cache/assets/D93/810/sprockets%2F7dc1ac5e1b83ba5144e34cf156d48a8a +471 -0
  180. data/test/dummy/tmp/cache/assets/D94/020/sprockets%2F35cb4ce22488fb5bdd260508ca47a3fb +239 -0
  181. data/test/dummy/tmp/cache/assets/D94/EC0/sprockets%2F8b900fba18f8e046f5f12e6d1f0ac15b +74 -0
  182. data/test/dummy/tmp/cache/assets/D95/470/sprockets%2F5be5d361a52575c433831b5e8cccbace +9273 -0
  183. data/test/dummy/tmp/cache/assets/D97/9D0/sprockets%2F524a2a94a88c1d392dabcba654e365fc +103 -0
  184. data/test/dummy/tmp/cache/assets/D9D/800/sprockets%2Ff8387220eb4dda9b29a37b5deb9f2a40 +54 -0
  185. data/test/dummy/tmp/cache/assets/D9E/DD0/sprockets%2Fb6b4ffad6485eda046b327a196e8c44a +0 -0
  186. data/test/dummy/tmp/cache/assets/DA1/0A0/sprockets%2F359c94aee6ba2e15fc9666aa4de311c8 +166 -0
  187. data/test/dummy/tmp/cache/assets/DA1/0D0/sprockets%2F798de3c28452e164a7fc1a3a6e8cdb4b +652 -0
  188. data/test/dummy/tmp/cache/assets/DA3/CB0/sprockets%2Fdfad6bb1857a8af91f98ba137c18504e +815 -0
  189. data/test/dummy/tmp/cache/assets/DA4/E10/sprockets%2Fbda7705734ace95f12a7d79df9c14af2 +1354 -0
  190. data/test/dummy/tmp/cache/assets/DA5/E30/sprockets%2F2e6707a119e94a784efbadca18d7e8d1 +129 -0
  191. data/test/dummy/tmp/cache/assets/DA6/4B0/sprockets%2F4f7a708b6aa2d42eb577493dea7cef55 +115 -0
  192. data/test/dummy/tmp/cache/assets/DA8/A10/sprockets%2F0ae5bbb4ca200e74db3b64d72c2be120 +0 -0
  193. data/test/dummy/tmp/cache/assets/DA9/3F0/sprockets%2Fdd0af9cfd65fb7d02fe778c8f6015361 +499 -0
  194. data/test/dummy/tmp/cache/assets/DA9/780/sprockets%2Fe3559a635e8f92dec7727a3db2ae7b4c +813 -0
  195. data/test/dummy/tmp/cache/assets/DAC/0E0/sprockets%2F04cef8243a9ef7321846debc977ea8db +607 -0
  196. data/test/dummy/tmp/cache/assets/DB1/260/sprockets%2Fb879ff7530bf8cc175e0c7e70dc4e79b +0 -0
  197. data/test/dummy/tmp/cache/assets/DB4/4C0/sprockets%2F30a76cbd98dedb56742cd8ecaf858757 +0 -0
  198. data/test/dummy/tmp/cache/assets/DBD/7E0/sprockets%2F236fb1ac5ed9f2e3fe32203acc3a842d +0 -0
  199. data/test/dummy/tmp/cache/assets/DC2/DF0/sprockets%2Fe233bcaba8beff15626c35cb5e0e0936 +845 -0
  200. data/test/dummy/tmp/cache/assets/DC4/600/sprockets%2F59c96aa6c1cbebc61bff6c050a5351d7 +225 -0
  201. data/test/dummy/tmp/cache/assets/DC5/030/sprockets%2Fcb2fe864a0177eec19017c43ce9aa4ad +187 -0
  202. data/test/dummy/tmp/cache/assets/DC8/A60/sprockets%2F9fcb9f5c3f679ce749ee4c3f93869ba6 +74 -0
  203. data/test/dummy/tmp/cache/assets/DCB/D40/sprockets%2Ffd5542bfb7660a8d8cac3a2e46fb01f8 +828 -0
  204. data/test/dummy/tmp/cache/assets/DCC/020/sprockets%2F0c129c5f2784c96fa1dc3da6c19c1efc +128 -0
  205. data/test/dummy/tmp/cache/assets/DCF/520/sprockets%2F975162fb97a3ec7033db5f2fdba4fcd3 +70 -0
  206. data/test/dummy/tmp/cache/assets/DD0/000/sprockets%2F0d5d631cce6f0b078bb29cf98b3d78bb +276 -0
  207. data/test/dummy/tmp/cache/assets/DD0/C90/sprockets%2F84eeca4ef8f5eb29b13f7e1ea3c71324 +591 -0
  208. data/test/dummy/tmp/cache/assets/DD6/710/sprockets%2F9e83f2ebbe3e349efca2de390e15d635 +204 -0
  209. data/test/dummy/tmp/cache/assets/DE1/830/sprockets%2Fd23d3cafef2e2a9055bc103dffc1a023 +208 -0
  210. data/test/dummy/tmp/cache/assets/DEB/470/sprockets%2Fae2de0fcbc2214b71d3f2a875d2bc8c3 +2255 -0
  211. data/test/dummy/tmp/cache/assets/DEE/690/sprockets%2F5d824bcadef29060cc13eed71af4b4d0 +550 -0
  212. data/test/dummy/tmp/cache/assets/DF0/5D0/sprockets%2F25a875eb0a5d4c49bcc3fa39ea0adb26 +567 -0
  213. data/test/dummy/tmp/cache/assets/DF3/E20/sprockets%2Fada770c49a5d6b38d1cc43ed4d51c1fc +0 -0
  214. data/test/dummy/tmp/cache/assets/DF5/C80/sprockets%2F03ad7d7b3a8feba9ed9be82ae2083b20 +340 -0
  215. data/test/dummy/tmp/cache/assets/DF6/560/sprockets%2Fafceb2b55eb108efe4446dfb02b519b8 +0 -0
  216. data/test/dummy/tmp/cache/assets/DFC/030/sprockets%2Fcbdd3679eaba219b4e1ff20677af1c6f +1371 -0
  217. data/test/dummy/tmp/cache/assets/E00/970/sprockets%2F8bc6dde8d05c382dd07cbcec70f54e09 +378 -0
  218. data/test/dummy/tmp/cache/assets/E04/890/sprockets%2F2f5173deea6c795b8fdde723bb4b63af +0 -0
  219. data/test/dummy/tmp/cache/assets/E12/2F0/sprockets%2F5c45062ecfbe512dcba176ba6ddacc00 +523 -0
  220. data/test/dummy/tmp/cache/assets/E21/5D0/sprockets%2Fd4fe6d611bfb0e63c04de5dbfb128a8a +0 -0
  221. data/test/dummy/tmp/cache/assets/E22/770/sprockets%2F2ccebcabfbb9b59159e4b73b3b30a74d +208 -0
  222. data/test/dummy/tmp/cache/assets/E31/A90/sprockets%2F26b98bbbc15eee9b370c7dcde88d16aa +394 -0
  223. data/test/dummy/tmp/cache/assets/E31/E30/sprockets%2Ffbdafcc4e2f44bb9fc653bcf9625b750 +284 -0
  224. data/test/dummy/tmp/cache/assets/E37/1C0/sprockets%2Fa5eb45fc86dafe2bee4e4fa3f53c4785 +0 -0
  225. data/test/dummy/tmp/cache/assets/E4C/960/sprockets%2F13fd6e4bfdf031acb3dedca8d0f407b4 +1277 -0
  226. data/test/dummy/tmp/cache/assets/E88/330/sprockets%2Fe02d0adb5529ffafcea1b9e5ccf69a5b +669 -0
  227. data/test/dummy/tmp/pids/server.pid +1 -0
  228. data/test/dummy/tmp/simple.js.js +20 -0
  229. data/test/dummy/tmp/soy-1325274421.js +20 -0
  230. data/test/dummy/tmp/soy-1325286267.js +20 -0
  231. data/test/test_helper.rb +10 -0
  232. data/test/yellow-brick-road_test.rb +7 -0
  233. metadata +538 -0
@@ -0,0 +1,828 @@
1
+ o: ActiveSupport::Cache::Entry :@compressedF:@expires_in0:@created_atf1325441614.764896: @value{ I" length:EFi�aI" digest;
2
+ F"%db72d57879855b552d12a1c96960a50bI" source;
3
+ FI"�a// Copyright 2006 The Closure Library Authors. All Rights Reserved.
4
+ //
5
+ // Licensed under the Apache License, Version 2.0 (the "License");
6
+ // you may not use this file except in compliance with the License.
7
+ // You may obtain a copy of the License at
8
+ //
9
+ // http://www.apache.org/licenses/LICENSE-2.0
10
+ //
11
+ // Unless required by applicable law or agreed to in writing, software
12
+ // distributed under the License is distributed on an "AS-IS" BASIS,
13
+ // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ // See the License for the specific language governing permissions and
15
+ // limitations under the License.
16
+
17
+ /**
18
+ * @fileoverview Definition of the Logger class. Please minimize dependencies
19
+ * this file has on other closure classes as any dependency it takes won't be
20
+ * able to use the logging infrastructure.
21
+ *
22
+ * @see ../demos/debug.html
23
+ */
24
+
25
+
26
+ goog.provide('goog.debug.LogManager');
27
+ goog.provide('goog.debug.Logger');
28
+ goog.provide('goog.debug.Logger.Level');
29
+
30
+ goog.require('goog.array');
31
+ goog.require('goog.asserts');
32
+ goog.require('goog.debug');
33
+ goog.require('goog.debug.LogBuffer');
34
+ goog.require('goog.debug.LogRecord');
35
+
36
+
37
+
38
+ /**
39
+ * The Logger is an object used for logging debug messages. Loggers are
40
+ * normally named, using a hierarchical dot-separated namespace. Logger names
41
+ * can be arbitrary strings, but they should normally be based on the package
42
+ * name or class name of the logged component, such as goog.net.BrowserChannel.
43
+ *
44
+ * The Logger object is loosely based on the java class
45
+ * java.util.logging.Logger. It supports different levels of filtering for
46
+ * different loggers.
47
+ *
48
+ * The logger object should never be instantiated by application code. It
49
+ * should always use the goog.debug.Logger.getLogger function.
50
+ *
51
+ * @constructor
52
+ * @param {string} name The name of the Logger.
53
+ */
54
+ goog.debug.Logger = function(name) {
55
+ /**
56
+ * Name of the Logger. Generally a dot-separated namespace
57
+ * @type {string}
58
+ * @private
59
+ */
60
+ this.name_ = name;
61
+ };
62
+
63
+
64
+ /**
65
+ * Parent Logger.
66
+ * @type {goog.debug.Logger}
67
+ * @private
68
+ */
69
+ goog.debug.Logger.prototype.parent_ = null;
70
+
71
+
72
+ /**
73
+ * Level that this logger only filters above. Null indicates it should
74
+ * inherit from the parent.
75
+ * @type {goog.debug.Logger.Level}
76
+ * @private
77
+ */
78
+ goog.debug.Logger.prototype.level_ = null;
79
+
80
+
81
+ /**
82
+ * Map of children loggers. The keys are the leaf names of the children and
83
+ * the values are the child loggers.
84
+ * @type {Object}
85
+ * @private
86
+ */
87
+ goog.debug.Logger.prototype.children_ = null;
88
+
89
+
90
+ /**
91
+ * Handlers that are listening to this logger.
92
+ * @type {Array.<Function>}
93
+ * @private
94
+ */
95
+ goog.debug.Logger.prototype.handlers_ = null;
96
+
97
+
98
+ /**
99
+ * @define {boolean} Toggles whether loggers other than the root logger can have
100
+ * log handlers attached to them and whether they can have their log level
101
+ * set. Logging is a bit faster when this is set to false.
102
+ */
103
+ goog.debug.Logger.ENABLE_HIERARCHY = true;
104
+
105
+
106
+ if (!goog.debug.Logger.ENABLE_HIERARCHY) {
107
+ /**
108
+ * @type {!Array.<Function>}
109
+ * @private
110
+ */
111
+ goog.debug.Logger.rootHandlers_ = [];
112
+
113
+
114
+ /**
115
+ * @type {goog.debug.Logger.Level}
116
+ * @private
117
+ */
118
+ goog.debug.Logger.rootLevel_;
119
+ }
120
+
121
+
122
+
123
+ /**
124
+ * The Level class defines a set of standard logging levels that
125
+ * can be used to control logging output. The logging Level objects
126
+ * are ordered and are specified by ordered integers. Enabling logging
127
+ * at a given level also enables logging at all higher levels.
128
+ * <p>
129
+ * Clients should normally use the predefined Level constants such
130
+ * as Level.SEVERE.
131
+ * <p>
132
+ * The levels in descending order are:
133
+ * <ul>
134
+ * <li>SEVERE (highest value)
135
+ * <li>WARNING
136
+ * <li>INFO
137
+ * <li>CONFIG
138
+ * <li>FINE
139
+ * <li>FINER
140
+ * <li>FINEST (lowest value)
141
+ * </ul>
142
+ * In addition there is a level OFF that can be used to turn
143
+ * off logging, and a level ALL that can be used to enable
144
+ * logging of all messages.
145
+ *
146
+ * @param {string} name The name of the level.
147
+ * @param {number} value The numeric value of the level.
148
+ * @constructor
149
+ */
150
+ goog.debug.Logger.Level = function(name, value) {
151
+ /**
152
+ * The name of the level
153
+ * @type {string}
154
+ */
155
+ this.name = name;
156
+
157
+ /**
158
+ * The numeric value of the level
159
+ * @type {number}
160
+ */
161
+ this.value = value;
162
+ };
163
+
164
+
165
+ /**
166
+ * @return {string} String representation of the logger level.
167
+ */
168
+ goog.debug.Logger.Level.prototype.toString = function() {
169
+ return this.name;
170
+ };
171
+
172
+
173
+ /**
174
+ * OFF is a special level that can be used to turn off logging.
175
+ * This level is initialized to <CODE>Number.MAX_VALUE</CODE>.
176
+ * @type {!goog.debug.Logger.Level}
177
+ */
178
+ goog.debug.Logger.Level.OFF =
179
+ new goog.debug.Logger.Level('OFF', Infinity);
180
+
181
+
182
+ /**
183
+ * SHOUT is a message level for extra debugging loudness.
184
+ * This level is initialized to <CODE>1200</CODE>.
185
+ * @type {!goog.debug.Logger.Level}
186
+ */
187
+ goog.debug.Logger.Level.SHOUT = new goog.debug.Logger.Level('SHOUT', 1200);
188
+
189
+
190
+ /**
191
+ * SEVERE is a message level indicating a serious failure.
192
+ * This level is initialized to <CODE>1000</CODE>.
193
+ * @type {!goog.debug.Logger.Level}
194
+ */
195
+ goog.debug.Logger.Level.SEVERE = new goog.debug.Logger.Level('SEVERE', 1000);
196
+
197
+
198
+ /**
199
+ * WARNING is a message level indicating a potential problem.
200
+ * This level is initialized to <CODE>900</CODE>.
201
+ * @type {!goog.debug.Logger.Level}
202
+ */
203
+ goog.debug.Logger.Level.WARNING = new goog.debug.Logger.Level('WARNING', 900);
204
+
205
+
206
+ /**
207
+ * INFO is a message level for informational messages.
208
+ * This level is initialized to <CODE>800</CODE>.
209
+ * @type {!goog.debug.Logger.Level}
210
+ */
211
+ goog.debug.Logger.Level.INFO = new goog.debug.Logger.Level('INFO', 800);
212
+
213
+
214
+ /**
215
+ * CONFIG is a message level for static configuration messages.
216
+ * This level is initialized to <CODE>700</CODE>.
217
+ * @type {!goog.debug.Logger.Level}
218
+ */
219
+ goog.debug.Logger.Level.CONFIG = new goog.debug.Logger.Level('CONFIG', 700);
220
+
221
+
222
+ /**
223
+ * FINE is a message level providing tracing information.
224
+ * This level is initialized to <CODE>500</CODE>.
225
+ * @type {!goog.debug.Logger.Level}
226
+ */
227
+ goog.debug.Logger.Level.FINE = new goog.debug.Logger.Level('FINE', 500);
228
+
229
+
230
+ /**
231
+ * FINER indicates a fairly detailed tracing message.
232
+ * This level is initialized to <CODE>400</CODE>.
233
+ * @type {!goog.debug.Logger.Level}
234
+ */
235
+ goog.debug.Logger.Level.FINER = new goog.debug.Logger.Level('FINER', 400);
236
+
237
+ /**
238
+ * FINEST indicates a highly detailed tracing message.
239
+ * This level is initialized to <CODE>300</CODE>.
240
+ * @type {!goog.debug.Logger.Level}
241
+ */
242
+
243
+ goog.debug.Logger.Level.FINEST = new goog.debug.Logger.Level('FINEST', 300);
244
+
245
+
246
+ /**
247
+ * ALL indicates that all messages should be logged.
248
+ * This level is initialized to <CODE>Number.MIN_VALUE</CODE>.
249
+ * @type {!goog.debug.Logger.Level}
250
+ */
251
+ goog.debug.Logger.Level.ALL = new goog.debug.Logger.Level('ALL', 0);
252
+
253
+
254
+ /**
255
+ * The predefined levels.
256
+ * @type {!Array.<!goog.debug.Logger.Level>}
257
+ * @final
258
+ */
259
+ goog.debug.Logger.Level.PREDEFINED_LEVELS = [
260
+ goog.debug.Logger.Level.OFF,
261
+ goog.debug.Logger.Level.SHOUT,
262
+ goog.debug.Logger.Level.SEVERE,
263
+ goog.debug.Logger.Level.WARNING,
264
+ goog.debug.Logger.Level.INFO,
265
+ goog.debug.Logger.Level.CONFIG,
266
+ goog.debug.Logger.Level.FINE,
267
+ goog.debug.Logger.Level.FINER,
268
+ goog.debug.Logger.Level.FINEST,
269
+ goog.debug.Logger.Level.ALL];
270
+
271
+
272
+ /**
273
+ * A lookup map used to find the level object based on the name or value of
274
+ * the level object.
275
+ * @type {Object}
276
+ * @private
277
+ */
278
+ goog.debug.Logger.Level.predefinedLevelsCache_ = null;
279
+
280
+
281
+ /**
282
+ * Creates the predefined levels cache and populates it.
283
+ * @private
284
+ */
285
+ goog.debug.Logger.Level.createPredefinedLevelsCache_ = function() {
286
+ goog.debug.Logger.Level.predefinedLevelsCache_ = {};
287
+ for (var i = 0, level; level = goog.debug.Logger.Level.PREDEFINED_LEVELS[i];
288
+ i++) {
289
+ goog.debug.Logger.Level.predefinedLevelsCache_[level.value] = level;
290
+ goog.debug.Logger.Level.predefinedLevelsCache_[level.name] = level;
291
+ }
292
+ };
293
+
294
+
295
+ /**
296
+ * Gets the predefined level with the given name.
297
+ * @param {string} name The name of the level.
298
+ * @return {goog.debug.Logger.Level} The level, or null if none found.
299
+ */
300
+ goog.debug.Logger.Level.getPredefinedLevel = function(name) {
301
+ if (!goog.debug.Logger.Level.predefinedLevelsCache_) {
302
+ goog.debug.Logger.Level.createPredefinedLevelsCache_();
303
+ }
304
+
305
+ return goog.debug.Logger.Level.predefinedLevelsCache_[name] || null;
306
+ };
307
+
308
+
309
+ /**
310
+ * Gets the highest predefined level <= #value.
311
+ * @param {number} value Level value.
312
+ * @return {goog.debug.Logger.Level} The level, or null if none found.
313
+ */
314
+ goog.debug.Logger.Level.getPredefinedLevelByValue = function(value) {
315
+ if (!goog.debug.Logger.Level.predefinedLevelsCache_) {
316
+ goog.debug.Logger.Level.createPredefinedLevelsCache_();
317
+ }
318
+
319
+ if (value in goog.debug.Logger.Level.predefinedLevelsCache_) {
320
+ return goog.debug.Logger.Level.predefinedLevelsCache_[value];
321
+ }
322
+
323
+ for (var i = 0; i < goog.debug.Logger.Level.PREDEFINED_LEVELS.length; ++i) {
324
+ var level = goog.debug.Logger.Level.PREDEFINED_LEVELS[i];
325
+ if (level.value <= value) {
326
+ return level;
327
+ }
328
+ }
329
+ return null;
330
+ };
331
+
332
+
333
+ /**
334
+ * Find or create a logger for a named subsystem. If a logger has already been
335
+ * created with the given name it is returned. Otherwise a new logger is
336
+ * created. If a new logger is created its log level will be configured based
337
+ * on the LogManager configuration and it will configured to also send logging
338
+ * output to its parent's handlers. It will be registered in the LogManager
339
+ * global namespace.
340
+ *
341
+ * @param {string} name A name for the logger. This should be a dot-separated
342
+ * name and should normally be based on the package name or class name of the
343
+ * subsystem, such as goog.net.BrowserChannel.
344
+ * @return {!goog.debug.Logger} The named logger.
345
+ */
346
+ goog.debug.Logger.getLogger = function(name) {
347
+ return goog.debug.LogManager.getLogger(name);
348
+ };
349
+
350
+
351
+ /**
352
+ * Logs a message to profiling tools, if available.
353
+ * {@see http://code.google.com/webtoolkit/speedtracer/logging-api.html}
354
+ * {@see http://msdn.microsoft.com/en-us/library/dd433074(VS.85).aspx}
355
+ * @param {string} msg The message to log.
356
+ */
357
+ goog.debug.Logger.logToProfilers = function(msg) {
358
+ // Using goog.global, as loggers might be used in window-less contexts.
359
+ if (goog.global['console']) {
360
+ if (goog.global['console']['timeStamp']) {
361
+ // Logs a message to Firebug, Web Inspector, SpeedTracer, etc.
362
+ goog.global['console']['timeStamp'](msg);
363
+ } else if (goog.global['console']['markTimeline']) {
364
+ // TODO(user): markTimeline is deprecated. Drop this else clause entirely
365
+ // after Chrome M14 hits stable.
366
+ goog.global['console']['markTimeline'](msg);
367
+ }
368
+ }
369
+
370
+ if (goog.global['msWriteProfilerMark']) {
371
+ // Logs a message to the Microsoft profiler
372
+ goog.global['msWriteProfilerMark'](msg);
373
+ }
374
+ };
375
+
376
+
377
+ /**
378
+ * Gets the name of this logger.
379
+ * @return {string} The name of this logger.
380
+ */
381
+ goog.debug.Logger.prototype.getName = function() {
382
+ return this.name_;
383
+ };
384
+
385
+
386
+ /**
387
+ * Adds a handler to the logger. This doesn't use the event system because
388
+ * we want to be able to add logging to the event system.
389
+ * @param {Function} handler Handler function to add.
390
+ */
391
+ goog.debug.Logger.prototype.addHandler = function(handler) {
392
+ if (goog.debug.Logger.ENABLE_HIERARCHY) {
393
+ if (!this.handlers_) {
394
+ this.handlers_ = [];
395
+ }
396
+ this.handlers_.push(handler);
397
+ } else {
398
+ goog.asserts.assert(!this.name_,
399
+ 'Cannot call addHandler on a non-root logger when ' +
400
+ 'goog.debug.Logger.ENABLE_HIERARCHY is false.');
401
+ goog.debug.Logger.rootHandlers_.push(handler);
402
+ }
403
+ };
404
+
405
+
406
+ /**
407
+ * Removes a handler from the logger. This doesn't use the event system because
408
+ * we want to be able to add logging to the event system.
409
+ * @param {Function} handler Handler function to remove.
410
+ * @return {boolean} Whether the handler was removed.
411
+ */
412
+ goog.debug.Logger.prototype.removeHandler = function(handler) {
413
+ var handlers = goog.debug.Logger.ENABLE_HIERARCHY ? this.handlers_ :
414
+ goog.debug.Logger.rootHandlers_;
415
+ return !!handlers && goog.array.remove(handlers, handler);
416
+ };
417
+
418
+
419
+ /**
420
+ * Returns the parent of this logger.
421
+ * @return {goog.debug.Logger} The parent logger or null if this is the root.
422
+ */
423
+ goog.debug.Logger.prototype.getParent = function() {
424
+ return this.parent_;
425
+ };
426
+
427
+
428
+ /**
429
+ * Returns the children of this logger as a map of the child name to the logger.
430
+ * @return {!Object} The map where the keys are the child leaf names and the
431
+ * values are the Logger objects.
432
+ */
433
+ goog.debug.Logger.prototype.getChildren = function() {
434
+ if (!this.children_) {
435
+ this.children_ = {};
436
+ }
437
+ return this.children_;
438
+ };
439
+
440
+
441
+ /**
442
+ * Set the log level specifying which message levels will be logged by this
443
+ * logger. Message levels lower than this value will be discarded.
444
+ * The level value Level.OFF can be used to turn off logging. If the new level
445
+ * is null, it means that this node should inherit its level from its nearest
446
+ * ancestor with a specific (non-null) level value.
447
+ *
448
+ * @param {goog.debug.Logger.Level} level The new level.
449
+ */
450
+ goog.debug.Logger.prototype.setLevel = function(level) {
451
+ if (goog.debug.Logger.ENABLE_HIERARCHY) {
452
+ this.level_ = level;
453
+ } else {
454
+ goog.asserts.assert(!this.name_,
455
+ 'Cannot call setLevel() on a non-root logger when ' +
456
+ 'goog.debug.Logger.ENABLE_HIERARCHY is false.');
457
+ goog.debug.Logger.rootLevel_ = level;
458
+ }
459
+ };
460
+
461
+
462
+ /**
463
+ * Gets the log level specifying which message levels will be logged by this
464
+ * logger. Message levels lower than this value will be discarded.
465
+ * The level value Level.OFF can be used to turn off logging. If the level
466
+ * is null, it means that this node should inherit its level from its nearest
467
+ * ancestor with a specific (non-null) level value.
468
+ *
469
+ * @return {goog.debug.Logger.Level} The level.
470
+ */
471
+ goog.debug.Logger.prototype.getLevel = function() {
472
+ return this.level_;
473
+ };
474
+
475
+
476
+ /**
477
+ * Returns the effective level of the logger based on its ancestors' levels.
478
+ * @return {goog.debug.Logger.Level} The level.
479
+ */
480
+ goog.debug.Logger.prototype.getEffectiveLevel = function() {
481
+ if (!goog.debug.Logger.ENABLE_HIERARCHY) {
482
+ return goog.debug.Logger.rootLevel_;
483
+ }
484
+ if (this.level_) {
485
+ return this.level_;
486
+ }
487
+ if (this.parent_) {
488
+ return this.parent_.getEffectiveLevel();
489
+ }
490
+ goog.asserts.fail('Root logger has no level set.');
491
+ return null;
492
+ };
493
+
494
+
495
+ /**
496
+ * Check if a message of the given level would actually be logged by this
497
+ * logger. This check is based on the Loggers effective level, which may be
498
+ * inherited from its parent.
499
+ * @param {goog.debug.Logger.Level} level The level to check.
500
+ * @return {boolean} Whether the message would be logged.
501
+ */
502
+ goog.debug.Logger.prototype.isLoggable = function(level) {
503
+ return level.value >= this.getEffectiveLevel().value;
504
+ };
505
+
506
+
507
+ /**
508
+ * Log a message. If the logger is currently enabled for the
509
+ * given message level then the given message is forwarded to all the
510
+ * registered output Handler objects.
511
+ * @param {goog.debug.Logger.Level} level One of the level identifiers.
512
+ * @param {string} msg The string message.
513
+ * @param {Error|Object=} opt_exception An exception associated with the
514
+ * message.
515
+ */
516
+ goog.debug.Logger.prototype.log = function(level, msg, opt_exception) {
517
+ // java caches the effective level, not sure it's necessary here
518
+ if (this.isLoggable(level)) {
519
+ this.doLogRecord_(this.getLogRecord(level, msg, opt_exception));
520
+ }
521
+ };
522
+
523
+
524
+ /**
525
+ * Creates a new log record and adds the exception (if present) to it.
526
+ * @param {goog.debug.Logger.Level} level One of the level identifiers.
527
+ * @param {string} msg The string message.
528
+ * @param {Error|Object=} opt_exception An exception associated with the
529
+ * message.
530
+ * @return {!goog.debug.LogRecord} A log record.
531
+ */
532
+ goog.debug.Logger.prototype.getLogRecord = function(level, msg, opt_exception) {
533
+ if (goog.debug.LogBuffer.isBufferingEnabled()) {
534
+ var logRecord =
535
+ goog.debug.LogBuffer.getInstance().addRecord(level, msg, this.name_);
536
+ } else {
537
+ logRecord = new goog.debug.LogRecord(level, String(msg), this.name_);
538
+ }
539
+ if (opt_exception) {
540
+ logRecord.setException(opt_exception);
541
+ logRecord.setExceptionText(
542
+ goog.debug.exposeException(opt_exception, arguments.callee.caller));
543
+ }
544
+ return logRecord;
545
+ };
546
+
547
+
548
+ /**
549
+ * Log a message at the Logger.Level.SHOUT level.
550
+ * If the logger is currently enabled for the given message level then the
551
+ * given message is forwarded to all the registered output Handler objects.
552
+ * @param {string} msg The string message.
553
+ * @param {Error=} opt_exception An exception associated with the message.
554
+ */
555
+ goog.debug.Logger.prototype.shout = function(msg, opt_exception) {
556
+ this.log(goog.debug.Logger.Level.SHOUT, msg, opt_exception);
557
+ };
558
+
559
+
560
+ /**
561
+ * Log a message at the Logger.Level.SEVERE level.
562
+ * If the logger is currently enabled for the given message level then the
563
+ * given message is forwarded to all the registered output Handler objects.
564
+ * @param {string} msg The string message.
565
+ * @param {Error=} opt_exception An exception associated with the message.
566
+ */
567
+ goog.debug.Logger.prototype.severe = function(msg, opt_exception) {
568
+ this.log(goog.debug.Logger.Level.SEVERE, msg, opt_exception);
569
+ };
570
+
571
+
572
+ /**
573
+ * Log a message at the Logger.Level.WARNING level.
574
+ * If the logger is currently enabled for the given message level then the
575
+ * given message is forwarded to all the registered output Handler objects.
576
+ * @param {string} msg The string message.
577
+ * @param {Error=} opt_exception An exception associated with the message.
578
+ */
579
+ goog.debug.Logger.prototype.warning = function(msg, opt_exception) {
580
+ this.log(goog.debug.Logger.Level.WARNING, msg, opt_exception);
581
+ };
582
+
583
+
584
+ /**
585
+ * Log a message at the Logger.Level.INFO level.
586
+ * If the logger is currently enabled for the given message level then the
587
+ * given message is forwarded to all the registered output Handler objects.
588
+ * @param {string} msg The string message.
589
+ * @param {Error=} opt_exception An exception associated with the message.
590
+ */
591
+ goog.debug.Logger.prototype.info = function(msg, opt_exception) {
592
+ this.log(goog.debug.Logger.Level.INFO, msg, opt_exception);
593
+ };
594
+
595
+
596
+ /**
597
+ * Log a message at the Logger.Level.CONFIG level.
598
+ * If the logger is currently enabled for the given message level then the
599
+ * given message is forwarded to all the registered output Handler objects.
600
+ * @param {string} msg The string message.
601
+ * @param {Error=} opt_exception An exception associated with the message.
602
+ */
603
+ goog.debug.Logger.prototype.config = function(msg, opt_exception) {
604
+ this.log(goog.debug.Logger.Level.CONFIG, msg, opt_exception);
605
+ };
606
+
607
+
608
+ /**
609
+ * Log a message at the Logger.Level.FINE level.
610
+ * If the logger is currently enabled for the given message level then the
611
+ * given message is forwarded to all the registered output Handler objects.
612
+ * @param {string} msg The string message.
613
+ * @param {Error=} opt_exception An exception associated with the message.
614
+ */
615
+ goog.debug.Logger.prototype.fine = function(msg, opt_exception) {
616
+ this.log(goog.debug.Logger.Level.FINE, msg, opt_exception);
617
+ };
618
+
619
+
620
+ /**
621
+ * Log a message at the Logger.Level.FINER level.
622
+ * If the logger is currently enabled for the given message level then the
623
+ * given message is forwarded to all the registered output Handler objects.
624
+ * @param {string} msg The string message.
625
+ * @param {Error=} opt_exception An exception associated with the message.
626
+ */
627
+ goog.debug.Logger.prototype.finer = function(msg, opt_exception) {
628
+ this.log(goog.debug.Logger.Level.FINER, msg, opt_exception);
629
+ };
630
+
631
+
632
+ /**
633
+ * Log a message at the Logger.Level.FINEST level.
634
+ * If the logger is currently enabled for the given message level then the
635
+ * given message is forwarded to all the registered output Handler objects.
636
+ * @param {string} msg The string message.
637
+ * @param {Error=} opt_exception An exception associated with the message.
638
+ */
639
+ goog.debug.Logger.prototype.finest = function(msg, opt_exception) {
640
+ this.log(goog.debug.Logger.Level.FINEST, msg, opt_exception);
641
+ };
642
+
643
+
644
+ /**
645
+ * Log a LogRecord. If the logger is currently enabled for the
646
+ * given message level then the given message is forwarded to all the
647
+ * registered output Handler objects.
648
+ * @param {goog.debug.LogRecord} logRecord A log record to log.
649
+ */
650
+ goog.debug.Logger.prototype.logRecord = function(logRecord) {
651
+ if (this.isLoggable(logRecord.getLevel())) {
652
+ this.doLogRecord_(logRecord);
653
+ }
654
+ };
655
+
656
+
657
+ /**
658
+ * Log a LogRecord.
659
+ * @param {goog.debug.LogRecord} logRecord A log record to log.
660
+ * @private
661
+ */
662
+ goog.debug.Logger.prototype.doLogRecord_ = function(logRecord) {
663
+ goog.debug.Logger.logToProfilers('log:' + logRecord.getMessage());
664
+ if (goog.debug.Logger.ENABLE_HIERARCHY) {
665
+ var target = this;
666
+ while (target) {
667
+ target.callPublish_(logRecord);
668
+ target = target.getParent();
669
+ }
670
+ } else {
671
+ for (var i = 0, handler; handler = goog.debug.Logger.rootHandlers_[i++]; ) {
672
+ handler(logRecord);
673
+ }
674
+ }
675
+ };
676
+
677
+
678
+ /**
679
+ * Calls the handlers for publish.
680
+ * @param {goog.debug.LogRecord} logRecord The log record to publish.
681
+ * @private
682
+ */
683
+ goog.debug.Logger.prototype.callPublish_ = function(logRecord) {
684
+ if (this.handlers_) {
685
+ for (var i = 0, handler; handler = this.handlers_[i]; i++) {
686
+ handler(logRecord);
687
+ }
688
+ }
689
+ };
690
+
691
+
692
+ /**
693
+ * Sets the parent of this logger. This is used for setting up the logger tree.
694
+ * @param {goog.debug.Logger} parent The parent logger.
695
+ * @private
696
+ */
697
+ goog.debug.Logger.prototype.setParent_ = function(parent) {
698
+ this.parent_ = parent;
699
+ };
700
+
701
+
702
+ /**
703
+ * Adds a child to this logger. This is used for setting up the logger tree.
704
+ * @param {string} name The leaf name of the child.
705
+ * @param {goog.debug.Logger} logger The child logger.
706
+ * @private
707
+ */
708
+ goog.debug.Logger.prototype.addChild_ = function(name, logger) {
709
+ this.getChildren()[name] = logger;
710
+ };
711
+
712
+
713
+ /**
714
+ * There is a single global LogManager object that is used to maintain a set of
715
+ * shared state about Loggers and log services. This is loosely based on the
716
+ * java class java.util.logging.LogManager.
717
+ */
718
+ goog.debug.LogManager = {};
719
+
720
+
721
+ /**
722
+ * Map of logger names to logger objects
723
+ *
724
+ * @type {!Object}
725
+ * @private
726
+ */
727
+ goog.debug.LogManager.loggers_ = {};
728
+
729
+
730
+ /**
731
+ * The root logger which is the root of the logger tree.
732
+ * @type {goog.debug.Logger}
733
+ * @private
734
+ */
735
+ goog.debug.LogManager.rootLogger_ = null;
736
+
737
+
738
+ /**
739
+ * Initialize the LogManager if not already initialized
740
+ */
741
+ goog.debug.LogManager.initialize = function() {
742
+ if (!goog.debug.LogManager.rootLogger_) {
743
+ goog.debug.LogManager.rootLogger_ = new goog.debug.Logger('');
744
+ goog.debug.LogManager.loggers_[''] = goog.debug.LogManager.rootLogger_;
745
+ goog.debug.LogManager.rootLogger_.setLevel(goog.debug.Logger.Level.CONFIG);
746
+ }
747
+ };
748
+
749
+
750
+ /**
751
+ * Returns all the loggers
752
+ * @return {!Object} Map of logger names to logger objects.
753
+ */
754
+ goog.debug.LogManager.getLoggers = function() {
755
+ return goog.debug.LogManager.loggers_;
756
+ };
757
+
758
+
759
+ /**
760
+ * Returns the root of the logger tree namespace, the logger with the empty
761
+ * string as its name
762
+ *
763
+ * @return {!goog.debug.Logger} The root logger.
764
+ */
765
+ goog.debug.LogManager.getRoot = function() {
766
+ goog.debug.LogManager.initialize();
767
+ return /** @type {!goog.debug.Logger} */ (goog.debug.LogManager.rootLogger_);
768
+ };
769
+
770
+
771
+ /**
772
+ * Method to find a named logger.
773
+ *
774
+ * @param {string} name A name for the logger. This should be a dot-separated
775
+ * name and should normally be based on the package name or class name of the
776
+ * subsystem, such as goog.net.BrowserChannel.
777
+ * @return {!goog.debug.Logger} The named logger.
778
+ */
779
+ goog.debug.LogManager.getLogger = function(name) {
780
+ goog.debug.LogManager.initialize();
781
+ var ret = goog.debug.LogManager.loggers_[name];
782
+ return ret || goog.debug.LogManager.createLogger_(name);
783
+ };
784
+
785
+
786
+ /**
787
+ * Creates a function that can be passed to goog.debug.catchErrors. The function
788
+ * will log all reported errors using the given logger.
789
+ * @param {goog.debug.Logger=} opt_logger The logger to log the errors to.
790
+ * Defaults to the root logger.
791
+ * @return {function(Object)} The created function.
792
+ */
793
+ goog.debug.LogManager.createFunctionForCatchErrors = function(opt_logger) {
794
+ return function(info) {
795
+ var logger = opt_logger || goog.debug.LogManager.getRoot();
796
+ logger.severe('Error: ' + info.message + ' (' + info.fileName +
797
+ ' @ Line: ' + info.line + ')');
798
+ };
799
+ };
800
+
801
+
802
+ /**
803
+ * Creates the named logger. Will also create the parents of the named logger
804
+ * if they don't yet exist.
805
+ * @param {string} name The name of the logger.
806
+ * @return {!goog.debug.Logger} The named logger.
807
+ * @private
808
+ */
809
+ goog.debug.LogManager.createLogger_ = function(name) {
810
+ // find parent logger
811
+ var logger = new goog.debug.Logger(name);
812
+ if (goog.debug.Logger.ENABLE_HIERARCHY) {
813
+ var lastDotIndex = name.lastIndexOf('.');
814
+ var parentName = name.substr(0, lastDotIndex);
815
+ var leafName = name.substr(lastDotIndex + 1);
816
+ var parentLogger = goog.debug.LogManager.getLogger(parentName);
817
+
818
+ // tell the parent about the child and the child about the parent
819
+ parentLogger.addChild_(leafName, logger);
820
+ logger.setParent_(parentLogger);
821
+ }
822
+
823
+ goog.debug.LogManager.loggers_[name] = logger;
824
+ return logger;
825
+ };
826
+ ;
827
+ FI"
828
+ F"%5e602c7fbacfc87d68385860ea676d59