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,31 @@
1
+ o: ActiveSupport::Cache::Entry :@compressedF:@expires_in0:@created_atf1325461605.095962: @value{ I" length:EFi-I" digest;
2
+ F"%48752de6df41f88201d301a25fdc8db5I" source;
3
+ FI"-goog.provide('myproject.start');
4
+
5
+ goog.require('goog.dom');
6
+
7
+ goog.require('myproject.templates');
8
+
9
+ myproject.start = function() {
10
+ var header = goog.dom.createDom('h1', {'style': 'background-color: #ccc'},
11
+ 'You are on yellow-brick-road!');
12
+ var text = goog.dom.createDom('p', {'style': 'background-color: #eee'},
13
+ 'These doms were generated by yellow-brick-road: closure library on rails.');
14
+ goog.dom.appendChild(document.body, header);
15
+ goog.dom.appendChild(document.body, text);
16
+
17
+ var header2 = goog.dom.createDom('p', {'style': 'background-color: #ccc; margin-top: 50px;'},
18
+ 'Closure soy template test');
19
+ goog.dom.appendChild(document.body, header2);
20
+ var template = goog.dom.createDom('p', {'style': 'background-color: #FAE9CE'},
21
+ 'If the closure template works, you should not see this dom.');
22
+ goog.dom.appendChild(document.body, template);
23
+ template.innerHTML = myproject.templates.hello({name: 'Cowardly Lion'});
24
+ };
25
+
26
+ // Ensures the symbol will be visible after compiler renaming.
27
+ goog.exportSymbol('myproject.start', myproject.start);
28
+
29
+ ;
30
+ FI"
31
+ F"%f784ad8da63be9b0772d4235bd79536b
@@ -0,0 +1,50 @@
1
+ o: ActiveSupport::Cache::Entry :@compressedF:@expires_in0:@created_atf1325441615.216: @value{ I" length:EFiPI" digest;
2
+ F"%045f58f213f51c8aabe1c5edcf79de11I" source;
3
+ FI"P// Copyright 2011 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 disposable interface. A disposable object
19
+ * has a dispose method to to clean up references and resources.
20
+ */
21
+
22
+
23
+
24
+ goog.provide('goog.disposable.IDisposable');
25
+
26
+
27
+
28
+ /**
29
+ * Interface for a disposable object. If a instance requires cleanup
30
+ * (references COM objects, DOM notes, or other disposable objects), it should
31
+ * implement this interface (it may subclass goog.Disposable).
32
+ * @interface
33
+ */
34
+ goog.disposable.IDisposable = function() {};
35
+
36
+
37
+ /**
38
+ * Disposes of the object and its resources.
39
+ * @return {void} Nothing.
40
+ */
41
+ goog.disposable.IDisposable.prototype.dispose;
42
+
43
+
44
+ /**
45
+ * @return {boolean} Whether the object has been disposed of.
46
+ */
47
+ goog.disposable.IDisposable.prototype.isDisposed;
48
+ ;
49
+ FI"
50
+ F"%45a1985ca0a3f7e692295e4db2681381
@@ -0,0 +1,1424 @@
1
+ o: ActiveSupport::Cache::Entry :@compressedF:@expires_in0:@created_atf1325288157.600996: @value{ I" length:EFi�I" digest;
2
+ F"%2cf70b6e0b196b6cfe607eb1a927d0f6I" source;
3
+ FI"�/*
4
+ * Copyright 2008 Google Inc.
5
+ *
6
+ * Licensed under the Apache License, Version 2.0 (the "License");
7
+ * you may not use this file except in compliance with the License.
8
+ * You may obtain a copy of the License at
9
+ *
10
+ * http://www.apache.org/licenses/LICENSE-2.0
11
+ *
12
+ * Unless required by applicable law or agreed to in writing, software
13
+ * distributed under the License is distributed on an "AS IS" BASIS,
14
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ * See the License for the specific language governing permissions and
16
+ * limitations under the License.
17
+ */
18
+
19
+ /**
20
+ * @fileoverview
21
+ * Utility functions and classes for Soy.
22
+ *
23
+ * <p>
24
+ * The top portion of this file contains utilities for Soy users:<ul>
25
+ * <li> soy.StringBuilder: Compatible with the 'stringbuilder' code style.
26
+ * <li> soy.renderElement: Render template and set as innerHTML of an element.
27
+ * <li> soy.renderAsFragment: Render template and return as HTML fragment.
28
+ * </ul>
29
+ *
30
+ * <p>
31
+ * The bottom portion of this file contains utilities that should only be called
32
+ * by Soy-generated JS code. Please do not use these functions directly from
33
+ * your hand-writen code. Their names all start with '$$'.
34
+ *
35
+ */
36
+
37
+
38
+ goog.provide('soy');
39
+ goog.provide('soy.StringBuilder');
40
+ goog.provide('soy.esc');
41
+ goog.provide('soydata');
42
+ goog.provide('soydata.SanitizedHtml');
43
+ goog.provide('soydata.SanitizedHtmlAttribute');
44
+ goog.provide('soydata.SanitizedJsStrChars');
45
+ goog.provide('soydata.SanitizedUri');
46
+
47
+ goog.require('goog.asserts');
48
+ goog.require('goog.dom.DomHelper');
49
+ goog.require('goog.format');
50
+ goog.require('goog.i18n.BidiFormatter');
51
+ goog.require('goog.i18n.bidi');
52
+ goog.require('goog.soy');
53
+ goog.require('goog.string');
54
+ goog.require('goog.string.StringBuffer');
55
+
56
+
57
+ // -----------------------------------------------------------------------------
58
+ // StringBuilder (compatible with the 'stringbuilder' code style).
59
+
60
+
61
+ /**
62
+ * Utility class to facilitate much faster string concatenation in IE,
63
+ * using Array.join() rather than the '+' operator. For other browsers
64
+ * we simply use the '+' operator.
65
+ *
66
+ * @param {Object} var_args Initial items to append,
67
+ * e.g., new soy.StringBuilder('foo', 'bar').
68
+ * @constructor
69
+ */
70
+ soy.StringBuilder = goog.string.StringBuffer;
71
+
72
+
73
+ // -----------------------------------------------------------------------------
74
+ // soydata: Defines typed strings, e.g. an HTML string {@code "a<b>c"} is
75
+ // semantically distinct from the plain text string {@code "a<b>c"} and smart
76
+ // templates can take that distinction into account.
77
+
78
+ /**
79
+ * A type of textual content.
80
+ * @enum {number}
81
+ */
82
+ soydata.SanitizedContentKind = {
83
+
84
+ /**
85
+ * A snippet of HTML that does not start or end inside a tag, comment, entity,
86
+ * or DOCTYPE; and that does not contain any executable code
87
+ * (JS, {@code <object>}s, etc.) from a different trust domain.
88
+ */
89
+ HTML: 0,
90
+
91
+ /**
92
+ * A sequence of code units that can appear between quotes (either kind) in a
93
+ * JS program without causing a parse error, and without causing any side
94
+ * effects.
95
+ * <p>
96
+ * The content should not contain unescaped quotes, newlines, or anything else
97
+ * that would cause parsing to fail or to cause a JS parser to finish the
98
+ * string its parsing inside the content.
99
+ * <p>
100
+ * The content must also not end inside an escape sequence ; no partial octal
101
+ * escape sequences or odd number of '{@code \}'s at the end.
102
+ */
103
+ JS_STR_CHARS: 1,
104
+
105
+ /** A properly encoded portion of a URI. */
106
+ URI: 2,
107
+
108
+ /** An attribute name and value such as {@code dir="ltr"}. */
109
+ HTML_ATTRIBUTE: 3
110
+ };
111
+
112
+
113
+ /**
114
+ * A string-like object that carries a content-type.
115
+ * @param {string} content
116
+ * @constructor
117
+ * @private
118
+ */
119
+ soydata.SanitizedContent = function(content) {
120
+ /**
121
+ * The textual content.
122
+ * @type {string}
123
+ */
124
+ this.content = content;
125
+ };
126
+
127
+ /** @type {soydata.SanitizedContentKind} */
128
+ soydata.SanitizedContent.prototype.contentKind;
129
+
130
+ /** @override */
131
+ soydata.SanitizedContent.prototype.toString = function() {
132
+ return this.content;
133
+ };
134
+
135
+
136
+ /**
137
+ * Content of type {@link soydata.SanitizedContentKind.HTML}.
138
+ * @param {string} content A string of HTML that can safely be embedded in
139
+ * a PCDATA context in your app. If you would be surprised to find that an
140
+ * HTML sanitizer produced {@code s} (e.g. it runs code or fetches bad URLs)
141
+ * and you wouldn't write a template that produces {@code s} on security or
142
+ * privacy grounds, then don't pass {@code s} here.
143
+ * @constructor
144
+ * @extends {soydata.SanitizedContent}
145
+ */
146
+ soydata.SanitizedHtml = function(content) {
147
+ soydata.SanitizedContent.call(this, content);
148
+ };
149
+ goog.inherits(soydata.SanitizedHtml, soydata.SanitizedContent);
150
+
151
+ /** @override */
152
+ soydata.SanitizedHtml.prototype.contentKind = soydata.SanitizedContentKind.HTML;
153
+
154
+
155
+ /**
156
+ * Content of type {@link soydata.SanitizedContentKind.JS_STR_CHARS}.
157
+ * @param {string} content A string of JS that when evaled, produces a
158
+ * value that does not depend on any sensitive data and has no side effects
159
+ * <b>OR</b> a string of JS that does not reference any variables or have
160
+ * any side effects not known statically to the app authors.
161
+ * @constructor
162
+ * @extends {soydata.SanitizedContent}
163
+ */
164
+ soydata.SanitizedJsStrChars = function(content) {
165
+ soydata.SanitizedContent.call(this, content);
166
+ };
167
+ goog.inherits(soydata.SanitizedJsStrChars, soydata.SanitizedContent);
168
+
169
+ /** @override */
170
+ soydata.SanitizedJsStrChars.prototype.contentKind =
171
+ soydata.SanitizedContentKind.JS_STR_CHARS;
172
+
173
+
174
+ /**
175
+ * Content of type {@link soydata.SanitizedContentKind.URI}.
176
+ * @param {string} content A chunk of URI that the caller knows is safe to
177
+ * emit in a template.
178
+ * @constructor
179
+ * @extends {soydata.SanitizedContent}
180
+ */
181
+ soydata.SanitizedUri = function(content) {
182
+ soydata.SanitizedContent.call(this, content);
183
+ };
184
+ goog.inherits(soydata.SanitizedUri, soydata.SanitizedContent);
185
+
186
+ /** @override */
187
+ soydata.SanitizedUri.prototype.contentKind = soydata.SanitizedContentKind.URI;
188
+
189
+
190
+ /**
191
+ * Content of type {@link soydata.SanitizedContentKind.HTML_ATTRIBUTE}.
192
+ * @param {string} content An attribute name and value, such as
193
+ * {@code dir="ltr"}.
194
+ * @constructor
195
+ * @extends {soydata.SanitizedContent}
196
+ */
197
+ soydata.SanitizedHtmlAttribute = function(content) {
198
+ soydata.SanitizedContent.call(this, content);
199
+ };
200
+ goog.inherits(soydata.SanitizedHtmlAttribute, soydata.SanitizedContent);
201
+
202
+ /** @override */
203
+ soydata.SanitizedHtmlAttribute.prototype.contentKind =
204
+ soydata.SanitizedContentKind.HTML_ATTRIBUTE;
205
+
206
+
207
+ // -----------------------------------------------------------------------------
208
+ // Public utilities.
209
+
210
+
211
+ /**
212
+ * Helper function to render a Soy template and then set the output string as
213
+ * the innerHTML of an element. It is recommended to use this helper function
214
+ * instead of directly setting innerHTML in your hand-written code, so that it
215
+ * will be easier to audit the code for cross-site scripting vulnerabilities.
216
+ *
217
+ * NOTE: New code should consider using goog.soy.renderElement instead.
218
+ *
219
+ * @param {Element} element The element whose content we are rendering.
220
+ * @param {Function} template The Soy template defining the element's content.
221
+ * @param {Object=} opt_templateData The data for the template.
222
+ * @param {Object=} opt_injectedData The injected data for the template.
223
+ */
224
+ soy.renderElement = goog.soy.renderElement;
225
+
226
+
227
+ /**
228
+ * Helper function to render a Soy template into a single node or a document
229
+ * fragment. If the rendered HTML string represents a single node, then that
230
+ * node is returned (note that this is *not* a fragment, despite them name of
231
+ * the method). Otherwise a document fragment is returned containing the
232
+ * rendered nodes.
233
+ *
234
+ * NOTE: New code should consider using goog.soy.renderAsFragment
235
+ * instead (note that the arguments are different).
236
+ *
237
+ * @param {Function} template The Soy template defining the element's content.
238
+ * @param {Object=} opt_templateData The data for the template.
239
+ * @param {Document=} opt_document The document used to create DOM nodes. If not
240
+ * specified, global document object is used.
241
+ * @param {Object=} opt_injectedData The injected data for the template.
242
+ * @return {!Node} The resulting node or document fragment.
243
+ */
244
+ soy.renderAsFragment = function(
245
+ template, opt_templateData, opt_document, opt_injectedData) {
246
+ return goog.soy.renderAsFragment(
247
+ template, opt_templateData, opt_injectedData,
248
+ new goog.dom.DomHelper(opt_document));
249
+ };
250
+
251
+
252
+ /**
253
+ * Helper function to render a Soy template into a single node. If the rendered
254
+ * HTML string represents a single node, then that node is returned. Otherwise,
255
+ * a DIV element is returned containing the rendered nodes.
256
+ *
257
+ * NOTE: New code should consider using goog.soy.renderAsElement
258
+ * instead (note that the arguments are different).
259
+ *
260
+ * @param {Function} template The Soy template defining the element's content.
261
+ * @param {Object=} opt_templateData The data for the template.
262
+ * @param {Document=} opt_document The document used to create DOM nodes. If not
263
+ * specified, global document object is used.
264
+ * @param {Object=} opt_injectedData The injected data for the template.
265
+ * @return {!Element} Rendered template contents, wrapped in a parent DIV
266
+ * element if necessary.
267
+ */
268
+ soy.renderAsElement = function(
269
+ template, opt_templateData, opt_document, opt_injectedData) {
270
+ return goog.soy.renderAsElement(
271
+ template, opt_templateData, opt_injectedData,
272
+ new goog.dom.DomHelper(opt_document));
273
+ };
274
+
275
+
276
+ // -----------------------------------------------------------------------------
277
+ // Below are private utilities to be used by Soy-generated code only.
278
+
279
+
280
+ /**
281
+ * Builds an augmented data object to be passed when a template calls another,
282
+ * and needs to pass both original data and additional params. The returned
283
+ * object will contain both the original data and the additional params. If the
284
+ * same key appears in both, then the value from the additional params will be
285
+ * visible, while the value from the original data will be hidden. The original
286
+ * data object will be used, but not modified.
287
+ *
288
+ * @param {!Object} origData The original data to pass.
289
+ * @param {Object} additionalParams The additional params to pass.
290
+ * @return {Object} An augmented data object containing both the original data
291
+ * and the additional params.
292
+ */
293
+ soy.$$augmentData = function(origData, additionalParams) {
294
+
295
+ // Create a new object whose '__proto__' field is set to origData.
296
+ /** @constructor */
297
+ function TempCtor() {}
298
+ TempCtor.prototype = origData;
299
+ var newData = new TempCtor();
300
+
301
+ // Add the additional params to the new object.
302
+ for (var key in additionalParams) {
303
+ newData[key] = additionalParams[key];
304
+ }
305
+
306
+ return newData;
307
+ };
308
+
309
+
310
+ /**
311
+ * Gets the keys in a map as an array. There are no guarantees on the order.
312
+ * @param {Object} map The map to get the keys of.
313
+ * @return {Array.<string>} The array of keys in the given map.
314
+ */
315
+ soy.$$getMapKeys = function(map) {
316
+ var mapKeys = [];
317
+ for (var key in map) {
318
+ mapKeys.push(key);
319
+ }
320
+ return mapKeys;
321
+ };
322
+
323
+
324
+ /**
325
+ * Gets a consistent unique id for the given delegate template name. Two calls
326
+ * to this function will return the same id if and only if the input names are
327
+ * the same.
328
+ *
329
+ * <p> Important: This function must always be called with a string constant.
330
+ *
331
+ * <p> If Closure Compiler is not being used, then this is just this identity
332
+ * function. If Closure Compiler is being used, then each call to this function
333
+ * will be replaced with a short string constant, which will be consistent per
334
+ * input name.
335
+ *
336
+ * @param {string} delTemplateName The delegate template name for which to get a
337
+ * consistent unique id.
338
+ * @return {string} A unique id that is consistent per input name.
339
+ *
340
+ * @consistentIdGenerator
341
+ */
342
+ soy.$$getDelegateId = function(delTemplateName) {
343
+ return delTemplateName;
344
+ };
345
+
346
+
347
+ /**
348
+ * Map from registered delegate template id/name to the priority of the
349
+ * implementation.
350
+ * @type {Object}
351
+ * @private
352
+ */
353
+ soy.$$DELEGATE_REGISTRY_PRIORITIES_ = {};
354
+
355
+ /**
356
+ * Map from registered delegate template id/name to the implementation function.
357
+ * @type {Object}
358
+ * @private
359
+ */
360
+ soy.$$DELEGATE_REGISTRY_FUNCTIONS_ = {};
361
+
362
+
363
+ /**
364
+ * Registers a delegate implementation. If the same delegate template id/name
365
+ * has been registered previously, then priority values are compared and only
366
+ * the higher priority implementation is stored (if priorities are equal, an
367
+ * error is thrown).
368
+ *
369
+ * @param {string} delTemplateId The delegate template id/name to register.
370
+ * @param {number} delPriority The implementation's priority value.
371
+ * @param {Function} delFn The implementation function.
372
+ */
373
+ soy.$$registerDelegateFn = function(delTemplateId, delPriority, delFn) {
374
+ var mapKey = 'key_' + delTemplateId;
375
+ var currPriority = soy.$$DELEGATE_REGISTRY_PRIORITIES_[mapKey];
376
+ if (currPriority === undefined || delPriority > currPriority) {
377
+ // Registering new or higher-priority function: replace registry entry.
378
+ soy.$$DELEGATE_REGISTRY_PRIORITIES_[mapKey] = delPriority;
379
+ soy.$$DELEGATE_REGISTRY_FUNCTIONS_[mapKey] = delFn;
380
+ } else if (delPriority == currPriority) {
381
+ // Registering same-priority function: error.
382
+ throw Error(
383
+ 'Encountered two active delegates with same priority (id/name "' +
384
+ delTemplateId + '").');
385
+ } else {
386
+ // Registering lower-priority function: do nothing.
387
+ }
388
+ };
389
+
390
+
391
+ /**
392
+ * Retrieves the (highest-priority) implementation that has been registered for
393
+ * a given delegate template id/name. If no implementation has been registered
394
+ * for the id/name, then returns an implementation that is equivalent to an
395
+ * empty template (i.e. rendered output would be empty string).
396
+ *
397
+ * @param {string} delTemplateId The delegate template id/name to get.
398
+ * @return {Function} The retrieved implementation function.
399
+ */
400
+ soy.$$getDelegateFn = function(delTemplateId) {
401
+ var delFn = soy.$$DELEGATE_REGISTRY_FUNCTIONS_['key_' + delTemplateId];
402
+ return delFn ? delFn : soy.$$EMPTY_TEMPLATE_FN_;
403
+ };
404
+
405
+
406
+ /**
407
+ * Private helper soy.$$getDelegateFn(). This is the empty template function
408
+ * that is returned whenever there's no delegate implementation found.
409
+ *
410
+ * @param {Object.<string, *>=} opt_data
411
+ * @param {soy.StringBuilder=} opt_sb
412
+ * @param {Object.<string, *>=} opt_ijData
413
+ * @return {string}
414
+ * @private
415
+ */
416
+ soy.$$EMPTY_TEMPLATE_FN_ = function(opt_data, opt_sb, opt_ijData) {
417
+ return '';
418
+ };
419
+
420
+
421
+ // -----------------------------------------------------------------------------
422
+ // Escape/filter/normalize.
423
+
424
+
425
+ /**
426
+ * Escapes HTML special characters in a string. Escapes double quote '"' in
427
+ * addition to '&', '<', and '>' so that a string can be included in an HTML
428
+ * tag attribute value within double quotes.
429
+ * Will emit known safe HTML as-is.
430
+ *
431
+ * @param {*} value The string-like value to be escaped. May not be a string,
432
+ * but the value will be coerced to a string.
433
+ * @return {string} An escaped version of value.
434
+ */
435
+ soy.$$escapeHtml = function(value) {
436
+ if (typeof value === 'object' && value &&
437
+ value.contentKind === soydata.SanitizedContentKind.HTML) {
438
+ return value.content;
439
+ }
440
+ return soy.esc.$$escapeHtmlHelper(value);
441
+ };
442
+
443
+
444
+ /**
445
+ * Escapes HTML special characters in a string so that it can be embedded in
446
+ * RCDATA.
447
+ * <p>
448
+ * Escapes HTML special characters so that the value will not prematurely end
449
+ * the body of a tag like {@code <textarea>} or {@code <title>}. RCDATA tags
450
+ * cannot contain other HTML entities, so it is not strictly necessary to escape
451
+ * HTML special characters except when part of that text looks like an HTML
452
+ * entity or like a close tag : {@code </textarea>}.
453
+ * <p>
454
+ * Will normalize known safe HTML to make sure that sanitized HTML (which could
455
+ * contain an innocuous {@code </textarea>} don't prematurely end an RCDATA
456
+ * element.
457
+ *
458
+ * @param {*} value The string-like value to be escaped. May not be a string,
459
+ * but the value will be coerced to a string.
460
+ * @return {string} An escaped version of value.
461
+ */
462
+ soy.$$escapeHtmlRcdata = function(value) {
463
+ if (typeof value === 'object' && value &&
464
+ value.contentKind === soydata.SanitizedContentKind.HTML) {
465
+ return soy.esc.$$normalizeHtmlHelper(value.content);
466
+ }
467
+ return soy.esc.$$escapeHtmlHelper(value);
468
+ };
469
+
470
+
471
+ /**
472
+ * Removes HTML tags from a string of known safe HTML so it can be used as an
473
+ * attribute value.
474
+ *
475
+ * @param {*} value The HTML to be escaped. May not be a string, but the
476
+ * value will be coerced to a string.
477
+ * @return {string} A representation of value without tags, HTML comments, or
478
+ * other content.
479
+ */
480
+ soy.$$stripHtmlTags = function(value) {
481
+ return String(value).replace(soy.esc.$$HTML_TAG_REGEX_, '');
482
+ };
483
+
484
+
485
+ /**
486
+ * Escapes HTML special characters in an HTML attribute value.
487
+ *
488
+ * @param {*} value The HTML to be escaped. May not be a string, but the
489
+ * value will be coerced to a string.
490
+ * @return {string} An escaped version of value.
491
+ */
492
+ soy.$$escapeHtmlAttribute = function(value) {
493
+ if (typeof value === 'object' && value &&
494
+ value.contentKind === soydata.SanitizedContentKind.HTML) {
495
+ return soy.esc.$$normalizeHtmlHelper(soy.$$stripHtmlTags(value.content));
496
+ }
497
+ return soy.esc.$$escapeHtmlHelper(value);
498
+ };
499
+
500
+
501
+ /**
502
+ * Escapes HTML special characters in a string including space and other
503
+ * characters that can end an unquoted HTML attribute value.
504
+ *
505
+ * @param {*} value The HTML to be escaped. May not be a string, but the
506
+ * value will be coerced to a string.
507
+ * @return {string} An escaped version of value.
508
+ */
509
+ soy.$$escapeHtmlAttributeNospace = function(value) {
510
+ if (typeof value === 'object' && value &&
511
+ value.contentKind === soydata.SanitizedContentKind.HTML) {
512
+ return soy.esc.$$normalizeHtmlNospaceHelper(
513
+ soy.$$stripHtmlTags(value.content));
514
+ }
515
+ return soy.esc.$$escapeHtmlNospaceHelper(value);
516
+ };
517
+
518
+
519
+ /**
520
+ * Filters out strings that cannot be a substring of a valid HTML attribute.
521
+ *
522
+ * @param {*} value The value to escape. May not be a string, but the value
523
+ * will be coerced to a string.
524
+ * @return {string} A valid HTML attribute name part or name/value pair.
525
+ * {@code "zSoyz"} if the input is invalid.
526
+ */
527
+ soy.$$filterHtmlAttribute = function(value) {
528
+ if (typeof value === 'object' && value &&
529
+ value.contentKind === soydata.SanitizedContentKind.HTML_ATTRIBUTE) {
530
+ return value.content.replace(/=([^"']*)$/, '="$1"');
531
+ }
532
+ return soy.esc.$$filterHtmlAttributeHelper(value);
533
+ };
534
+
535
+
536
+ /**
537
+ * Filters out strings that cannot be a substring of a valid HTML element name.
538
+ *
539
+ * @param {*} value The value to escape. May not be a string, but the value
540
+ * will be coerced to a string.
541
+ * @return {string} A valid HTML element name part.
542
+ * {@code "zSoyz"} if the input is invalid.
543
+ */
544
+ soy.$$filterHtmlElementName = function(value) {
545
+ return soy.esc.$$filterHtmlElementNameHelper(value);
546
+ };
547
+
548
+
549
+ /**
550
+ * Escapes characters in the value to make it valid content for a JS string
551
+ * literal.
552
+ *
553
+ * @param {*} value The value to escape. May not be a string, but the value
554
+ * will be coerced to a string.
555
+ * @return {string} An escaped version of value.
556
+ * @deprecated
557
+ */
558
+ soy.$$escapeJs = function(value) {
559
+ return soy.$$escapeJsString(value);
560
+ };
561
+
562
+
563
+ /**
564
+ * Escapes characters in the value to make it valid content for a JS string
565
+ * literal.
566
+ *
567
+ * @param {*} value The value to escape. May not be a string, but the value
568
+ * will be coerced to a string.
569
+ * @return {string} An escaped version of value.
570
+ */
571
+ soy.$$escapeJsString = function(value) {
572
+ if (typeof value === 'object' &&
573
+ value.contentKind === soydata.SanitizedContentKind.JS_STR_CHARS) {
574
+ return value.content;
575
+ }
576
+ return soy.esc.$$escapeJsStringHelper(value);
577
+ };
578
+
579
+
580
+ /**
581
+ * Encodes a value as a JavaScript literal.
582
+ *
583
+ * @param {*} value The value to escape. May not be a string, but the value
584
+ * will be coerced to a string.
585
+ * @return {string} A JavaScript code representation of the input.
586
+ */
587
+ soy.$$escapeJsValue = function(value) {
588
+ // We surround values with spaces so that they can't be interpolated into
589
+ // identifiers by accident.
590
+ // We could use parentheses but those might be interpreted as a function call.
591
+ if (value == null) { // Intentionally matches undefined.
592
+ // Java returns null from maps where there is no corresponding key while
593
+ // JS returns undefined.
594
+ // We always output null for compatibility with Java which does not have a
595
+ // distinct undefined value.
596
+ return ' null ';
597
+ }
598
+ switch (typeof value) {
599
+ case 'boolean': case 'number':
600
+ return ' ' + value + ' ';
601
+ default:
602
+ return "'" + soy.esc.$$escapeJsStringHelper(String(value)) + "'";
603
+ }
604
+ };
605
+
606
+
607
+ /**
608
+ * Escapes characters in the string to make it valid content for a JS regular
609
+ * expression literal.
610
+ *
611
+ * @param {*} value The value to escape. May not be a string, but the value
612
+ * will be coerced to a string.
613
+ * @return {string} An escaped version of value.
614
+ */
615
+ soy.$$escapeJsRegex = function(value) {
616
+ return soy.esc.$$escapeJsRegexHelper(value);
617
+ };
618
+
619
+
620
+ /**
621
+ * Matches all URI mark characters that conflict with HTML attribute delimiters
622
+ * or that cannot appear in a CSS uri.
623
+ * From <a href="http://www.w3.org/TR/CSS2/grammar.html">G.2: CSS grammar</a>
624
+ * <pre>
625
+ * url ([!#$%&*-~]|{nonascii}|{escape})*
626
+ * </pre>
627
+ *
628
+ * @type {RegExp}
629
+ * @private
630
+ */
631
+ soy.$$problematicUriMarks_ = /['()]/g;
632
+
633
+ /**
634
+ * @param {string} ch A single character in {@link soy.$$problematicUriMarks_}.
635
+ * @return {string}
636
+ * @private
637
+ */
638
+ soy.$$pctEncode_ = function(ch) {
639
+ return '%' + ch.charCodeAt(0).toString(16);
640
+ };
641
+
642
+ /**
643
+ * Escapes a string so that it can be safely included in a URI.
644
+ *
645
+ * @param {*} value The value to escape. May not be a string, but the value
646
+ * will be coerced to a string.
647
+ * @return {string} An escaped version of value.
648
+ */
649
+ soy.$$escapeUri = function(value) {
650
+ if (typeof value === 'object' &&
651
+ value.contentKind === soydata.SanitizedContentKind.URI) {
652
+ return soy.$$normalizeUri(value);
653
+ }
654
+ // Apostophes and parentheses are not matched by encodeURIComponent.
655
+ // They are technically special in URIs, but only appear in the obsolete mark
656
+ // production in Appendix D.2 of RFC 3986, so can be encoded without changing
657
+ // semantics.
658
+ var encoded = soy.esc.$$escapeUriHelper(value);
659
+ soy.$$problematicUriMarks_.lastIndex = 0;
660
+ if (soy.$$problematicUriMarks_.test(encoded)) {
661
+ return encoded.replace(soy.$$problematicUriMarks_, soy.$$pctEncode_);
662
+ }
663
+ return encoded;
664
+ };
665
+
666
+
667
+ /**
668
+ * Removes rough edges from a URI by escaping any raw HTML/JS string delimiters.
669
+ *
670
+ * @param {*} value The value to escape. May not be a string, but the value
671
+ * will be coerced to a string.
672
+ * @return {string} An escaped version of value.
673
+ */
674
+ soy.$$normalizeUri = function(value) {
675
+ return soy.esc.$$normalizeUriHelper(value);
676
+ };
677
+
678
+
679
+ /**
680
+ * Vets a URI's protocol and removes rough edges from a URI by escaping
681
+ * any raw HTML/JS string delimiters.
682
+ *
683
+ * @param {*} value The value to escape. May not be a string, but the value
684
+ * will be coerced to a string.
685
+ * @return {string} An escaped version of value.
686
+ */
687
+ soy.$$filterNormalizeUri = function(value) {
688
+ return soy.esc.$$filterNormalizeUriHelper(value);
689
+ };
690
+
691
+
692
+ /**
693
+ * Escapes a string so it can safely be included inside a quoted CSS string.
694
+ *
695
+ * @param {*} value The value to escape. May not be a string, but the value
696
+ * will be coerced to a string.
697
+ * @return {string} An escaped version of value.
698
+ */
699
+ soy.$$escapeCssString = function(value) {
700
+ return soy.esc.$$escapeCssStringHelper(value);
701
+ };
702
+
703
+
704
+ /**
705
+ * Encodes a value as a CSS identifier part, keyword, or quantity.
706
+ *
707
+ * @param {*} value The value to escape. May not be a string, but the value
708
+ * will be coerced to a string.
709
+ * @return {string} A safe CSS identifier part, keyword, or quanitity.
710
+ */
711
+ soy.$$filterCssValue = function(value) {
712
+ // Uses == to intentionally match null and undefined for Java compatibility.
713
+ if (value == null) {
714
+ return '';
715
+ }
716
+ return soy.esc.$$filterCssValueHelper(value);
717
+ };
718
+
719
+
720
+ // -----------------------------------------------------------------------------
721
+ // Basic directives/functions.
722
+
723
+
724
+ /**
725
+ * Converts \r\n, \r, and \n to <br>s
726
+ * @param {*} str The string in which to convert newlines.
727
+ * @return {string} A copy of {@code str} with converted newlines.
728
+ */
729
+ soy.$$changeNewlineToBr = function(str) {
730
+ return goog.string.newLineToBr(String(str), false);
731
+ };
732
+
733
+
734
+ /**
735
+ * Inserts word breaks ('wbr' tags) into a HTML string at a given interval. The
736
+ * counter is reset if a space is encountered. Word breaks aren't inserted into
737
+ * HTML tags or entities. Entites count towards the character count; HTML tags
738
+ * do not.
739
+ *
740
+ * @param {*} str The HTML string to insert word breaks into. Can be other
741
+ * types, but the value will be coerced to a string.
742
+ * @param {number} maxCharsBetweenWordBreaks Maximum number of non-space
743
+ * characters to allow before adding a word break.
744
+ * @return {string} The string including word breaks.
745
+ */
746
+ soy.$$insertWordBreaks = function(str, maxCharsBetweenWordBreaks) {
747
+ return goog.format.insertWordBreaks(String(str), maxCharsBetweenWordBreaks);
748
+ };
749
+
750
+
751
+ /**
752
+ * Truncates a string to a given max length (if it's currently longer),
753
+ * optionally adding ellipsis at the end.
754
+ *
755
+ * @param {*} str The string to truncate. Can be other types, but the value will
756
+ * be coerced to a string.
757
+ * @param {number} maxLen The maximum length of the string after truncation
758
+ * (including ellipsis, if applicable).
759
+ * @param {boolean} doAddEllipsis Whether to add ellipsis if the string needs
760
+ * truncation.
761
+ * @return {string} The string after truncation.
762
+ */
763
+ soy.$$truncate = function(str, maxLen, doAddEllipsis) {
764
+
765
+ str = String(str);
766
+ if (str.length <= maxLen) {
767
+ return str; // no need to truncate
768
+ }
769
+
770
+ // If doAddEllipsis, either reduce maxLen to compensate, or else if maxLen is
771
+ // too small, just turn off doAddEllipsis.
772
+ if (doAddEllipsis) {
773
+ if (maxLen > 3) {
774
+ maxLen -= 3;
775
+ } else {
776
+ doAddEllipsis = false;
777
+ }
778
+ }
779
+
780
+ // Make sure truncating at maxLen doesn't cut up a unicode surrogate pair.
781
+ if (soy.$$isHighSurrogate_(str.charAt(maxLen - 1)) &&
782
+ soy.$$isLowSurrogate_(str.charAt(maxLen))) {
783
+ maxLen -= 1;
784
+ }
785
+
786
+ // Truncate.
787
+ str = str.substring(0, maxLen);
788
+
789
+ // Add ellipsis.
790
+ if (doAddEllipsis) {
791
+ str += '...';
792
+ }
793
+
794
+ return str;
795
+ };
796
+
797
+ /**
798
+ * Private helper for $$truncate() to check whether a char is a high surrogate.
799
+ * @param {string} ch The char to check.
800
+ * @return {boolean} Whether the given char is a unicode high surrogate.
801
+ * @private
802
+ */
803
+ soy.$$isHighSurrogate_ = function(ch) {
804
+ return 0xD800 <= ch && ch <= 0xDBFF;
805
+ };
806
+
807
+ /**
808
+ * Private helper for $$truncate() to check whether a char is a low surrogate.
809
+ * @param {string} ch The char to check.
810
+ * @return {boolean} Whether the given char is a unicode low surrogate.
811
+ * @private
812
+ */
813
+ soy.$$isLowSurrogate_ = function(ch) {
814
+ return 0xDC00 <= ch && ch <= 0xDFFF;
815
+ };
816
+
817
+
818
+ // -----------------------------------------------------------------------------
819
+ // Bidi directives/functions.
820
+
821
+
822
+ /**
823
+ * Cache of bidi formatter by context directionality, so we don't keep on
824
+ * creating new objects.
825
+ * @type {!Object.<!goog.i18n.BidiFormatter>}
826
+ * @private
827
+ */
828
+ soy.$$bidiFormatterCache_ = {};
829
+
830
+
831
+ /**
832
+ * Returns cached bidi formatter for bidiGlobalDir, or creates a new one.
833
+ * @param {number} bidiGlobalDir The global directionality context: 1 if ltr, -1
834
+ * if rtl, 0 if unknown.
835
+ * @return {goog.i18n.BidiFormatter} A formatter for bidiGlobalDir.
836
+ * @private
837
+ */
838
+ soy.$$getBidiFormatterInstance_ = function(bidiGlobalDir) {
839
+ return soy.$$bidiFormatterCache_[bidiGlobalDir] ||
840
+ (soy.$$bidiFormatterCache_[bidiGlobalDir] =
841
+ new goog.i18n.BidiFormatter(bidiGlobalDir));
842
+ };
843
+
844
+
845
+ /**
846
+ * Estimate the overall directionality of text. If opt_isHtml, makes sure to
847
+ * ignore the LTR nature of the mark-up and escapes in text, making the logic
848
+ * suitable for HTML and HTML-escaped text.
849
+ * @param {string} text The text whose directionality is to be estimated.
850
+ * @param {boolean=} opt_isHtml Whether text is HTML/HTML-escaped.
851
+ * Default: false.
852
+ * @return {number} 1 if text is LTR, -1 if it is RTL, and 0 if it is neutral.
853
+ */
854
+ soy.$$bidiTextDir = function(text, opt_isHtml) {
855
+ if (!text) {
856
+ return 0;
857
+ }
858
+ return goog.i18n.bidi.detectRtlDirectionality(text, opt_isHtml) ? -1 : 1;
859
+ };
860
+
861
+
862
+ /**
863
+ * Returns "dir=ltr" or "dir=rtl", depending on text's estimated
864
+ * directionality, if it is not the same as bidiGlobalDir.
865
+ * Otherwise, returns the empty string.
866
+ * If opt_isHtml, makes sure to ignore the LTR nature of the mark-up and escapes
867
+ * in text, making the logic suitable for HTML and HTML-escaped text.
868
+ * @param {number} bidiGlobalDir The global directionality context: 1 if ltr, -1
869
+ * if rtl, 0 if unknown.
870
+ * @param {string} text The text whose directionality is to be estimated.
871
+ * @param {boolean=} opt_isHtml Whether text is HTML/HTML-escaped.
872
+ * Default: false.
873
+ * @return {soydata.SanitizedHtmlAttribute} "dir=rtl" for RTL text in non-RTL
874
+ * context; "dir=ltr" for LTR text in non-LTR context;
875
+ * else, the empty string.
876
+ */
877
+ soy.$$bidiDirAttr = function(bidiGlobalDir, text, opt_isHtml) {
878
+ return new soydata.SanitizedHtmlAttribute(
879
+ soy.$$getBidiFormatterInstance_(bidiGlobalDir).dirAttr(text, opt_isHtml));
880
+ };
881
+
882
+
883
+ /**
884
+ * Returns a Unicode BiDi mark matching bidiGlobalDir (LRM or RLM) if the
885
+ * directionality or the exit directionality of text are opposite to
886
+ * bidiGlobalDir. Otherwise returns the empty string.
887
+ * If opt_isHtml, makes sure to ignore the LTR nature of the mark-up and escapes
888
+ * in text, making the logic suitable for HTML and HTML-escaped text.
889
+ * @param {number} bidiGlobalDir The global directionality context: 1 if ltr, -1
890
+ * if rtl, 0 if unknown.
891
+ * @param {string} text The text whose directionality is to be estimated.
892
+ * @param {boolean=} opt_isHtml Whether text is HTML/HTML-escaped.
893
+ * Default: false.
894
+ * @return {string} A Unicode bidi mark matching bidiGlobalDir, or the empty
895
+ * string when text's overall and exit directionalities both match
896
+ * bidiGlobalDir, or bidiGlobalDir is 0 (unknown).
897
+ */
898
+ soy.$$bidiMarkAfter = function(bidiGlobalDir, text, opt_isHtml) {
899
+ var formatter = soy.$$getBidiFormatterInstance_(bidiGlobalDir);
900
+ return formatter.markAfter(text, opt_isHtml);
901
+ };
902
+
903
+
904
+ /**
905
+ * Returns str wrapped in a <span dir=ltr|rtl> according to its directionality -
906
+ * but only if that is neither neutral nor the same as the global context.
907
+ * Otherwise, returns str unchanged.
908
+ * Always treats str as HTML/HTML-escaped, i.e. ignores mark-up and escapes when
909
+ * estimating str's directionality.
910
+ * @param {number} bidiGlobalDir The global directionality context: 1 if ltr, -1
911
+ * if rtl, 0 if unknown.
912
+ * @param {*} str The string to be wrapped. Can be other types, but the value
913
+ * will be coerced to a string.
914
+ * @return {string} The wrapped string.
915
+ */
916
+ soy.$$bidiSpanWrap = function(bidiGlobalDir, str) {
917
+ var formatter = soy.$$getBidiFormatterInstance_(bidiGlobalDir);
918
+ return formatter.spanWrap(str + '', true);
919
+ };
920
+
921
+
922
+ /**
923
+ * Returns str wrapped in Unicode BiDi formatting characters according to its
924
+ * directionality, i.e. either LRE or RLE at the beginning and PDF at the end -
925
+ * but only if str's directionality is neither neutral nor the same as the
926
+ * global context. Otherwise, returns str unchanged.
927
+ * Always treats str as HTML/HTML-escaped, i.e. ignores mark-up and escapes when
928
+ * estimating str's directionality.
929
+ * @param {number} bidiGlobalDir The global directionality context: 1 if ltr, -1
930
+ * if rtl, 0 if unknown.
931
+ * @param {*} str The string to be wrapped. Can be other types, but the value
932
+ * will be coerced to a string.
933
+ * @return {string} The wrapped string.
934
+ */
935
+ soy.$$bidiUnicodeWrap = function(bidiGlobalDir, str) {
936
+ var formatter = soy.$$getBidiFormatterInstance_(bidiGlobalDir);
937
+ return formatter.unicodeWrap(str + '', true);
938
+ };
939
+
940
+
941
+ // -----------------------------------------------------------------------------
942
+ // Generated code.
943
+
944
+
945
+
946
+
947
+ // START GENERATED CODE FOR ESCAPERS.
948
+
949
+ /**
950
+ * @type {function (*) : string}
951
+ */
952
+ soy.esc.$$escapeUriHelper = function(v) {
953
+ return goog.string.urlEncode(String(v));
954
+ };
955
+
956
+ /**
957
+ * Maps charcters to the escaped versions for the named escape directives.
958
+ * @type {Object.<string, string>}
959
+ * @private
960
+ */
961
+ soy.esc.$$ESCAPE_MAP_FOR_ESCAPE_HTML__AND__NORMALIZE_HTML__AND__ESCAPE_HTML_NOSPACE__AND__NORMALIZE_HTML_NOSPACE_ = {
962
+ '\x00': '\x26#0;',
963
+ '\x22': '\x26quot;',
964
+ '\x26': '\x26amp;',
965
+ '\x27': '\x26#39;',
966
+ '\x3c': '\x26lt;',
967
+ '\x3e': '\x26gt;',
968
+ '\x09': '\x26#9;',
969
+ '\x0a': '\x26#10;',
970
+ '\x0b': '\x26#11;',
971
+ '\x0c': '\x26#12;',
972
+ '\x0d': '\x26#13;',
973
+ ' ': '\x26#32;',
974
+ '-': '\x26#45;',
975
+ '\/': '\x26#47;',
976
+ '\x3d': '\x26#61;',
977
+ '`': '\x26#96;',
978
+ '\x85': '\x26#133;',
979
+ '\xa0': '\x26#160;',
980
+ '\u2028': '\x26#8232;',
981
+ '\u2029': '\x26#8233;'
982
+ };
983
+
984
+ /**
985
+ * A function that can be used with String.replace..
986
+ * @param {string} ch A single character matched by a compatible matcher.
987
+ * @return {string} A token in the output language.
988
+ * @private
989
+ */
990
+ soy.esc.$$REPLACER_FOR_ESCAPE_HTML__AND__NORMALIZE_HTML__AND__ESCAPE_HTML_NOSPACE__AND__NORMALIZE_HTML_NOSPACE_ = function(ch) {
991
+ return soy.esc.$$ESCAPE_MAP_FOR_ESCAPE_HTML__AND__NORMALIZE_HTML__AND__ESCAPE_HTML_NOSPACE__AND__NORMALIZE_HTML_NOSPACE_[ch];
992
+ };
993
+
994
+ /**
995
+ * Maps charcters to the escaped versions for the named escape directives.
996
+ * @type {Object.<string, string>}
997
+ * @private
998
+ */
999
+ soy.esc.$$ESCAPE_MAP_FOR_ESCAPE_JS_STRING__AND__ESCAPE_JS_REGEX_ = {
1000
+ '\x00': '\\x00',
1001
+ '\x08': '\\x08',
1002
+ '\x09': '\\t',
1003
+ '\x0a': '\\n',
1004
+ '\x0b': '\\x0b',
1005
+ '\x0c': '\\f',
1006
+ '\x0d': '\\r',
1007
+ '\x22': '\\x22',
1008
+ '\x26': '\\x26',
1009
+ '\x27': '\\x27',
1010
+ '\/': '\\\/',
1011
+ '\x3c': '\\x3c',
1012
+ '\x3d': '\\x3d',
1013
+ '\x3e': '\\x3e',
1014
+ '\\': '\\\\',
1015
+ '\x85': '\\x85',
1016
+ '\u2028': '\\u2028',
1017
+ '\u2029': '\\u2029',
1018
+ '$': '\\x24',
1019
+ '(': '\\x28',
1020
+ ')': '\\x29',
1021
+ '*': '\\x2a',
1022
+ '+': '\\x2b',
1023
+ ',': '\\x2c',
1024
+ '-': '\\x2d',
1025
+ '.': '\\x2e',
1026
+ ':': '\\x3a',
1027
+ '?': '\\x3f',
1028
+ '[': '\\x5b',
1029
+ ']': '\\x5d',
1030
+ '^': '\\x5e',
1031
+ '{': '\\x7b',
1032
+ '|': '\\x7c',
1033
+ '}': '\\x7d'
1034
+ };
1035
+
1036
+ /**
1037
+ * A function that can be used with String.replace..
1038
+ * @param {string} ch A single character matched by a compatible matcher.
1039
+ * @return {string} A token in the output language.
1040
+ * @private
1041
+ */
1042
+ soy.esc.$$REPLACER_FOR_ESCAPE_JS_STRING__AND__ESCAPE_JS_REGEX_ = function(ch) {
1043
+ return soy.esc.$$ESCAPE_MAP_FOR_ESCAPE_JS_STRING__AND__ESCAPE_JS_REGEX_[ch];
1044
+ };
1045
+
1046
+ /**
1047
+ * Maps charcters to the escaped versions for the named escape directives.
1048
+ * @type {Object.<string, string>}
1049
+ * @private
1050
+ */
1051
+ soy.esc.$$ESCAPE_MAP_FOR_ESCAPE_CSS_STRING_ = {
1052
+ '\x00': '\\0 ',
1053
+ '\x08': '\\8 ',
1054
+ '\x09': '\\9 ',
1055
+ '\x0a': '\\a ',
1056
+ '\x0b': '\\b ',
1057
+ '\x0c': '\\c ',
1058
+ '\x0d': '\\d ',
1059
+ '\x22': '\\22 ',
1060
+ '\x26': '\\26 ',
1061
+ '\x27': '\\27 ',
1062
+ '(': '\\28 ',
1063
+ ')': '\\29 ',
1064
+ '*': '\\2a ',
1065
+ '\/': '\\2f ',
1066
+ ':': '\\3a ',
1067
+ ';': '\\3b ',
1068
+ '\x3c': '\\3c ',
1069
+ '\x3d': '\\3d ',
1070
+ '\x3e': '\\3e ',
1071
+ '@': '\\40 ',
1072
+ '\\': '\\5c ',
1073
+ '{': '\\7b ',
1074
+ '}': '\\7d ',
1075
+ '\x85': '\\85 ',
1076
+ '\xa0': '\\a0 ',
1077
+ '\u2028': '\\2028 ',
1078
+ '\u2029': '\\2029 '
1079
+ };
1080
+
1081
+ /**
1082
+ * A function that can be used with String.replace..
1083
+ * @param {string} ch A single character matched by a compatible matcher.
1084
+ * @return {string} A token in the output language.
1085
+ * @private
1086
+ */
1087
+ soy.esc.$$REPLACER_FOR_ESCAPE_CSS_STRING_ = function(ch) {
1088
+ return soy.esc.$$ESCAPE_MAP_FOR_ESCAPE_CSS_STRING_[ch];
1089
+ };
1090
+
1091
+ /**
1092
+ * Maps charcters to the escaped versions for the named escape directives.
1093
+ * @type {Object.<string, string>}
1094
+ * @private
1095
+ */
1096
+ soy.esc.$$ESCAPE_MAP_FOR_NORMALIZE_URI__AND__FILTER_NORMALIZE_URI_ = {
1097
+ '\x00': '%00',
1098
+ '\x01': '%01',
1099
+ '\x02': '%02',
1100
+ '\x03': '%03',
1101
+ '\x04': '%04',
1102
+ '\x05': '%05',
1103
+ '\x06': '%06',
1104
+ '\x07': '%07',
1105
+ '\x08': '%08',
1106
+ '\x09': '%09',
1107
+ '\x0a': '%0A',
1108
+ '\x0b': '%0B',
1109
+ '\x0c': '%0C',
1110
+ '\x0d': '%0D',
1111
+ '\x0e': '%0E',
1112
+ '\x0f': '%0F',
1113
+ '\x10': '%10',
1114
+ '\x11': '%11',
1115
+ '\x12': '%12',
1116
+ '\x13': '%13',
1117
+ '\x14': '%14',
1118
+ '\x15': '%15',
1119
+ '\x16': '%16',
1120
+ '\x17': '%17',
1121
+ '\x18': '%18',
1122
+ '\x19': '%19',
1123
+ '\x1a': '%1A',
1124
+ '\x1b': '%1B',
1125
+ '\x1c': '%1C',
1126
+ '\x1d': '%1D',
1127
+ '\x1e': '%1E',
1128
+ '\x1f': '%1F',
1129
+ ' ': '%20',
1130
+ '\x22': '%22',
1131
+ '\x27': '%27',
1132
+ '(': '%28',
1133
+ ')': '%29',
1134
+ '\x3c': '%3C',
1135
+ '\x3e': '%3E',
1136
+ '\\': '%5C',
1137
+ '{': '%7B',
1138
+ '}': '%7D',
1139
+ '\x7f': '%7F',
1140
+ '\x85': '%C2%85',
1141
+ '\xa0': '%C2%A0',
1142
+ '\u2028': '%E2%80%A8',
1143
+ '\u2029': '%E2%80%A9',
1144
+ '\uff01': '%EF%BC%81',
1145
+ '\uff03': '%EF%BC%83',
1146
+ '\uff04': '%EF%BC%84',
1147
+ '\uff06': '%EF%BC%86',
1148
+ '\uff07': '%EF%BC%87',
1149
+ '\uff08': '%EF%BC%88',
1150
+ '\uff09': '%EF%BC%89',
1151
+ '\uff0a': '%EF%BC%8A',
1152
+ '\uff0b': '%EF%BC%8B',
1153
+ '\uff0c': '%EF%BC%8C',
1154
+ '\uff0f': '%EF%BC%8F',
1155
+ '\uff1a': '%EF%BC%9A',
1156
+ '\uff1b': '%EF%BC%9B',
1157
+ '\uff1d': '%EF%BC%9D',
1158
+ '\uff1f': '%EF%BC%9F',
1159
+ '\uff20': '%EF%BC%A0',
1160
+ '\uff3b': '%EF%BC%BB',
1161
+ '\uff3d': '%EF%BC%BD'
1162
+ };
1163
+
1164
+ /**
1165
+ * A function that can be used with String.replace..
1166
+ * @param {string} ch A single character matched by a compatible matcher.
1167
+ * @return {string} A token in the output language.
1168
+ * @private
1169
+ */
1170
+ soy.esc.$$REPLACER_FOR_NORMALIZE_URI__AND__FILTER_NORMALIZE_URI_ = function(ch) {
1171
+ return soy.esc.$$ESCAPE_MAP_FOR_NORMALIZE_URI__AND__FILTER_NORMALIZE_URI_[ch];
1172
+ };
1173
+
1174
+ /**
1175
+ * Matches characters that need to be escaped for the named directives.
1176
+ * @type RegExp
1177
+ * @private
1178
+ */
1179
+ soy.esc.$$MATCHER_FOR_ESCAPE_HTML_ = /[\x00\x22\x26\x27\x3c\x3e]/g;
1180
+
1181
+ /**
1182
+ * Matches characters that need to be escaped for the named directives.
1183
+ * @type RegExp
1184
+ * @private
1185
+ */
1186
+ soy.esc.$$MATCHER_FOR_NORMALIZE_HTML_ = /[\x00\x22\x27\x3c\x3e]/g;
1187
+
1188
+ /**
1189
+ * Matches characters that need to be escaped for the named directives.
1190
+ * @type RegExp
1191
+ * @private
1192
+ */
1193
+ soy.esc.$$MATCHER_FOR_ESCAPE_HTML_NOSPACE_ = /[\x00\x09-\x0d \x22\x26\x27\x2d\/\x3c-\x3e`\x85\xa0\u2028\u2029]/g;
1194
+
1195
+ /**
1196
+ * Matches characters that need to be escaped for the named directives.
1197
+ * @type RegExp
1198
+ * @private
1199
+ */
1200
+ soy.esc.$$MATCHER_FOR_NORMALIZE_HTML_NOSPACE_ = /[\x00\x09-\x0d \x22\x27\x2d\/\x3c-\x3e`\x85\xa0\u2028\u2029]/g;
1201
+
1202
+ /**
1203
+ * Matches characters that need to be escaped for the named directives.
1204
+ * @type RegExp
1205
+ * @private
1206
+ */
1207
+ soy.esc.$$MATCHER_FOR_ESCAPE_JS_STRING_ = /[\x00\x08-\x0d\x22\x26\x27\/\x3c-\x3e\\\x85\u2028\u2029]/g;
1208
+
1209
+ /**
1210
+ * Matches characters that need to be escaped for the named directives.
1211
+ * @type RegExp
1212
+ * @private
1213
+ */
1214
+ soy.esc.$$MATCHER_FOR_ESCAPE_JS_REGEX_ = /[\x00\x08-\x0d\x22\x24\x26-\/\x3a\x3c-\x3f\x5b-\x5e\x7b-\x7d\x85\u2028\u2029]/g;
1215
+
1216
+ /**
1217
+ * Matches characters that need to be escaped for the named directives.
1218
+ * @type RegExp
1219
+ * @private
1220
+ */
1221
+ soy.esc.$$MATCHER_FOR_ESCAPE_CSS_STRING_ = /[\x00\x08-\x0d\x22\x26-\x2a\/\x3a-\x3e@\\\x7b\x7d\x85\xa0\u2028\u2029]/g;
1222
+
1223
+ /**
1224
+ * Matches characters that need to be escaped for the named directives.
1225
+ * @type RegExp
1226
+ * @private
1227
+ */
1228
+ soy.esc.$$MATCHER_FOR_NORMALIZE_URI__AND__FILTER_NORMALIZE_URI_ = /[\x00- \x22\x27-\x29\x3c\x3e\\\x7b\x7d\x7f\x85\xa0\u2028\u2029\uff01\uff03\uff04\uff06-\uff0c\uff0f\uff1a\uff1b\uff1d\uff1f\uff20\uff3b\uff3d]/g;
1229
+
1230
+ /**
1231
+ * A pattern that vets values produced by the named directives.
1232
+ * @type RegExp
1233
+ * @private
1234
+ */
1235
+ soy.esc.$$FILTER_FOR_FILTER_CSS_VALUE_ = /^(?!-*(?:expression|(?:moz-)?binding))(?:[.#]?-?(?:[_a-z0-9-]+)(?:-[_a-z0-9-]+)*-?|-?(?:[0-9]+(?:\.[0-9]*)?|\.[0-9]+)(?:[a-z]{1,2}|%)?|!important|)$/i;
1236
+
1237
+ /**
1238
+ * A pattern that vets values produced by the named directives.
1239
+ * @type RegExp
1240
+ * @private
1241
+ */
1242
+ soy.esc.$$FILTER_FOR_FILTER_NORMALIZE_URI_ = /^(?:(?:https?|mailto):|[^&:\/?#]*(?:[\/?#]|$))/i;
1243
+
1244
+ /**
1245
+ * A pattern that vets values produced by the named directives.
1246
+ * @type RegExp
1247
+ * @private
1248
+ */
1249
+ soy.esc.$$FILTER_FOR_FILTER_HTML_ATTRIBUTE_ = /^(?!style|on|action|archive|background|cite|classid|codebase|data|dsync|href|longdesc|src|usemap)(?:[a-z0-9_$:-]*)$/i;
1250
+
1251
+ /**
1252
+ * A pattern that vets values produced by the named directives.
1253
+ * @type RegExp
1254
+ * @private
1255
+ */
1256
+ soy.esc.$$FILTER_FOR_FILTER_HTML_ELEMENT_NAME_ = /^(?!script|style|title|textarea|xmp|no)[a-z0-9_$:-]*$/i;
1257
+
1258
+ /**
1259
+ * A helper for the Soy directive |escapeHtml
1260
+ * @param {*} value Can be of any type but will be coerced to a string.
1261
+ * @return {string} The escaped text.
1262
+ */
1263
+ soy.esc.$$escapeHtmlHelper = function(value) {
1264
+ var str = String(value);
1265
+ return str.replace(
1266
+ soy.esc.$$MATCHER_FOR_ESCAPE_HTML_,
1267
+ soy.esc.$$REPLACER_FOR_ESCAPE_HTML__AND__NORMALIZE_HTML__AND__ESCAPE_HTML_NOSPACE__AND__NORMALIZE_HTML_NOSPACE_);
1268
+ };
1269
+
1270
+ /**
1271
+ * A helper for the Soy directive |normalizeHtml
1272
+ * @param {*} value Can be of any type but will be coerced to a string.
1273
+ * @return {string} The escaped text.
1274
+ */
1275
+ soy.esc.$$normalizeHtmlHelper = function(value) {
1276
+ var str = String(value);
1277
+ return str.replace(
1278
+ soy.esc.$$MATCHER_FOR_NORMALIZE_HTML_,
1279
+ soy.esc.$$REPLACER_FOR_ESCAPE_HTML__AND__NORMALIZE_HTML__AND__ESCAPE_HTML_NOSPACE__AND__NORMALIZE_HTML_NOSPACE_);
1280
+ };
1281
+
1282
+ /**
1283
+ * A helper for the Soy directive |escapeHtmlNospace
1284
+ * @param {*} value Can be of any type but will be coerced to a string.
1285
+ * @return {string} The escaped text.
1286
+ */
1287
+ soy.esc.$$escapeHtmlNospaceHelper = function(value) {
1288
+ var str = String(value);
1289
+ return str.replace(
1290
+ soy.esc.$$MATCHER_FOR_ESCAPE_HTML_NOSPACE_,
1291
+ soy.esc.$$REPLACER_FOR_ESCAPE_HTML__AND__NORMALIZE_HTML__AND__ESCAPE_HTML_NOSPACE__AND__NORMALIZE_HTML_NOSPACE_);
1292
+ };
1293
+
1294
+ /**
1295
+ * A helper for the Soy directive |normalizeHtmlNospace
1296
+ * @param {*} value Can be of any type but will be coerced to a string.
1297
+ * @return {string} The escaped text.
1298
+ */
1299
+ soy.esc.$$normalizeHtmlNospaceHelper = function(value) {
1300
+ var str = String(value);
1301
+ return str.replace(
1302
+ soy.esc.$$MATCHER_FOR_NORMALIZE_HTML_NOSPACE_,
1303
+ soy.esc.$$REPLACER_FOR_ESCAPE_HTML__AND__NORMALIZE_HTML__AND__ESCAPE_HTML_NOSPACE__AND__NORMALIZE_HTML_NOSPACE_);
1304
+ };
1305
+
1306
+ /**
1307
+ * A helper for the Soy directive |escapeJsString
1308
+ * @param {*} value Can be of any type but will be coerced to a string.
1309
+ * @return {string} The escaped text.
1310
+ */
1311
+ soy.esc.$$escapeJsStringHelper = function(value) {
1312
+ var str = String(value);
1313
+ return str.replace(
1314
+ soy.esc.$$MATCHER_FOR_ESCAPE_JS_STRING_,
1315
+ soy.esc.$$REPLACER_FOR_ESCAPE_JS_STRING__AND__ESCAPE_JS_REGEX_);
1316
+ };
1317
+
1318
+ /**
1319
+ * A helper for the Soy directive |escapeJsRegex
1320
+ * @param {*} value Can be of any type but will be coerced to a string.
1321
+ * @return {string} The escaped text.
1322
+ */
1323
+ soy.esc.$$escapeJsRegexHelper = function(value) {
1324
+ var str = String(value);
1325
+ return str.replace(
1326
+ soy.esc.$$MATCHER_FOR_ESCAPE_JS_REGEX_,
1327
+ soy.esc.$$REPLACER_FOR_ESCAPE_JS_STRING__AND__ESCAPE_JS_REGEX_);
1328
+ };
1329
+
1330
+ /**
1331
+ * A helper for the Soy directive |escapeCssString
1332
+ * @param {*} value Can be of any type but will be coerced to a string.
1333
+ * @return {string} The escaped text.
1334
+ */
1335
+ soy.esc.$$escapeCssStringHelper = function(value) {
1336
+ var str = String(value);
1337
+ return str.replace(
1338
+ soy.esc.$$MATCHER_FOR_ESCAPE_CSS_STRING_,
1339
+ soy.esc.$$REPLACER_FOR_ESCAPE_CSS_STRING_);
1340
+ };
1341
+
1342
+ /**
1343
+ * A helper for the Soy directive |filterCssValue
1344
+ * @param {*} value Can be of any type but will be coerced to a string.
1345
+ * @return {string} The escaped text.
1346
+ */
1347
+ soy.esc.$$filterCssValueHelper = function(value) {
1348
+ var str = String(value);
1349
+ if (!soy.esc.$$FILTER_FOR_FILTER_CSS_VALUE_.test(str)) {
1350
+ goog.asserts.fail('Bad value `%s` for |filterCssValue', [str]);
1351
+ return 'zSoyz';
1352
+ }
1353
+ return str;
1354
+ };
1355
+
1356
+ /**
1357
+ * A helper for the Soy directive |normalizeUri
1358
+ * @param {*} value Can be of any type but will be coerced to a string.
1359
+ * @return {string} The escaped text.
1360
+ */
1361
+ soy.esc.$$normalizeUriHelper = function(value) {
1362
+ var str = String(value);
1363
+ return str.replace(
1364
+ soy.esc.$$MATCHER_FOR_NORMALIZE_URI__AND__FILTER_NORMALIZE_URI_,
1365
+ soy.esc.$$REPLACER_FOR_NORMALIZE_URI__AND__FILTER_NORMALIZE_URI_);
1366
+ };
1367
+
1368
+ /**
1369
+ * A helper for the Soy directive |filterNormalizeUri
1370
+ * @param {*} value Can be of any type but will be coerced to a string.
1371
+ * @return {string} The escaped text.
1372
+ */
1373
+ soy.esc.$$filterNormalizeUriHelper = function(value) {
1374
+ var str = String(value);
1375
+ if (!soy.esc.$$FILTER_FOR_FILTER_NORMALIZE_URI_.test(str)) {
1376
+ goog.asserts.fail('Bad value `%s` for |filterNormalizeUri', [str]);
1377
+ return 'zSoyz';
1378
+ }
1379
+ return str.replace(
1380
+ soy.esc.$$MATCHER_FOR_NORMALIZE_URI__AND__FILTER_NORMALIZE_URI_,
1381
+ soy.esc.$$REPLACER_FOR_NORMALIZE_URI__AND__FILTER_NORMALIZE_URI_);
1382
+ };
1383
+
1384
+ /**
1385
+ * A helper for the Soy directive |filterHtmlAttribute
1386
+ * @param {*} value Can be of any type but will be coerced to a string.
1387
+ * @return {string} The escaped text.
1388
+ */
1389
+ soy.esc.$$filterHtmlAttributeHelper = function(value) {
1390
+ var str = String(value);
1391
+ if (!soy.esc.$$FILTER_FOR_FILTER_HTML_ATTRIBUTE_.test(str)) {
1392
+ goog.asserts.fail('Bad value `%s` for |filterHtmlAttribute', [str]);
1393
+ return 'zSoyz';
1394
+ }
1395
+ return str;
1396
+ };
1397
+
1398
+ /**
1399
+ * A helper for the Soy directive |filterHtmlElementName
1400
+ * @param {*} value Can be of any type but will be coerced to a string.
1401
+ * @return {string} The escaped text.
1402
+ */
1403
+ soy.esc.$$filterHtmlElementNameHelper = function(value) {
1404
+ var str = String(value);
1405
+ if (!soy.esc.$$FILTER_FOR_FILTER_HTML_ELEMENT_NAME_.test(str)) {
1406
+ goog.asserts.fail('Bad value `%s` for |filterHtmlElementName', [str]);
1407
+ return 'zSoyz';
1408
+ }
1409
+ return str;
1410
+ };
1411
+
1412
+ /**
1413
+ * Matches all tags, HTML comments, and DOCTYPEs in tag soup HTML.
1414
+ *
1415
+ * @type {RegExp}
1416
+ * @private
1417
+ */
1418
+ soy.esc.$$HTML_TAG_REGEX_ = /<(?:!|\/?[a-zA-Z])(?:[^>'"]|"[^"]*"|'[^']*')*>/g;
1419
+
1420
+ // END GENERATED CODE
1421
+ ;
1422
+ ;
1423
+ FI"
1424
+ F"%7fe743736f18e8992b98ea31b17617b3