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.
- data/README.rst +148 -0
- data/Rakefile +37 -0
- data/lib/tasks/yellow-brick-road_tasks.rake +4 -0
- data/lib/yellow-brick-road.rb +6 -0
- data/lib/yellow-brick-road/config.rb +15 -0
- data/lib/yellow-brick-road/directive_processor.rb +68 -0
- data/lib/yellow-brick-road/engine.rb +22 -0
- data/lib/yellow-brick-road/soy_processor.rb +56 -0
- data/lib/yellow-brick-road/utils.rb +38 -0
- data/lib/yellow-brick-road/version.rb +3 -0
- data/test/dummy/Rakefile +7 -0
- data/test/dummy/app/assets/javascripts/application.js +12 -0
- data/test/dummy/app/assets/javascripts/closure-deps.js +4 -0
- data/test/dummy/app/assets/javascripts/my-closure/simple.js.soy +14 -0
- data/test/dummy/app/assets/javascripts/my-closure/start.js +25 -0
- data/test/dummy/app/assets/stylesheets/application.css +7 -0
- data/test/dummy/app/controllers/application_controller.rb +7 -0
- data/test/dummy/app/helpers/application_helper.rb +2 -0
- data/test/dummy/app/views/application/index.html.erb +0 -0
- data/test/dummy/app/views/layouts/application.html.erb +18 -0
- data/test/dummy/config.ru +4 -0
- data/test/dummy/config/application.rb +51 -0
- data/test/dummy/config/boot.rb +10 -0
- data/test/dummy/config/environment.rb +5 -0
- data/test/dummy/config/environments/development.rb +30 -0
- data/test/dummy/config/environments/production.rb +60 -0
- data/test/dummy/config/environments/test.rb +39 -0
- data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/test/dummy/config/initializers/inflections.rb +10 -0
- data/test/dummy/config/initializers/mime_types.rb +5 -0
- data/test/dummy/config/initializers/secret_token.rb +7 -0
- data/test/dummy/config/initializers/session_store.rb +8 -0
- data/test/dummy/config/initializers/wrap_parameters.rb +10 -0
- data/test/dummy/config/initializers/yellow_brick_road.rb +2 -0
- data/test/dummy/config/locales/en.yml +5 -0
- data/test/dummy/config/routes.rb +58 -0
- data/test/dummy/log/development.log +13924 -0
- data/test/dummy/log/test.log +0 -0
- data/test/dummy/public/404.html +26 -0
- data/test/dummy/public/422.html +26 -0
- data/test/dummy/public/500.html +26 -0
- data/test/dummy/public/favicon.ico +0 -0
- data/test/dummy/script/rails +6 -0
- data/test/dummy/tmp/cache/assets/BE0/120/sprockets%2F751842b8c6750008c7310d182600d173 +142 -0
- data/test/dummy/tmp/cache/assets/C19/950/sprockets%2F142437f1d8d9424007b4a882a5429333 +1372 -0
- data/test/dummy/tmp/cache/assets/C4B/D00/sprockets%2F400f22c081529179ce3d079457de3009 +806 -0
- data/test/dummy/tmp/cache/assets/C5A/EE0/sprockets%2Fb711429ed948c503b718d077037780f8 +0 -0
- data/test/dummy/tmp/cache/assets/C5B/A80/sprockets%2F508569b474262724c61a461f7777dab7 +1118 -0
- data/test/dummy/tmp/cache/assets/C6C/660/sprockets%2F2c298b3b02232a21527680685a3efc30 +9289 -0
- data/test/dummy/tmp/cache/assets/C72/8A0/sprockets%2F167b265129e30d87d253c406db305c60 +293 -0
- data/test/dummy/tmp/cache/assets/C7E/9F0/sprockets%2F89862076204c62c4593ac20de32da909 +9 -0
- data/test/dummy/tmp/cache/assets/C8B/5F0/sprockets%2Fc6a4470b5c21e285e829a99365839b24 +0 -0
- data/test/dummy/tmp/cache/assets/C92/D20/sprockets%2F2e618f7805f445889aec94885a500f03 +457 -0
- data/test/dummy/tmp/cache/assets/C98/FD0/sprockets%2Fb11442af041f96e87a43a1dc11231745 +283 -0
- data/test/dummy/tmp/cache/assets/CA3/520/sprockets%2F5379d7143c6c52b11b88dc0ab5436133 +277 -0
- data/test/dummy/tmp/cache/assets/CA5/450/sprockets%2F6bb727c9312a749134ad67323a317f0d +73 -0
- data/test/dummy/tmp/cache/assets/CA5/4F0/sprockets%2Feeb7de7771527700af194c0441d29101 +709 -0
- data/test/dummy/tmp/cache/assets/CA6/E90/sprockets%2F611f68180f43c4181f06ae5c5f8201e2 +1546 -0
- data/test/dummy/tmp/cache/assets/CA7/310/sprockets%2F45664cf816315200b574e029fde6f10a +0 -0
- data/test/dummy/tmp/cache/assets/CA9/9D0/sprockets%2F2672e32464cf7267c4ba3d028f54b153 +224 -0
- data/test/dummy/tmp/cache/assets/CAB/5A0/sprockets%2F7f50e0289f150c8636ac9253129bc13c +2556 -0
- data/test/dummy/tmp/cache/assets/CB5/7E0/sprockets%2F42ff6672683b2029233a800e7539eeee +474 -0
- data/test/dummy/tmp/cache/assets/CB6/DC0/sprockets%2F2f9882155bb2d4d3ab5d708951857c60 +494 -0
- data/test/dummy/tmp/cache/assets/CBB/680/sprockets%2F1dc336d96fb52df34b458185559922b5 +1018 -0
- data/test/dummy/tmp/cache/assets/CBC/640/sprockets%2F67d2e0d9e5129d237e575d2780c64b47 +1260 -0
- data/test/dummy/tmp/cache/assets/CBE/550/sprockets%2Fd680cac830e0b3408ba910f0b0421147 +25 -0
- data/test/dummy/tmp/cache/assets/CC7/790/sprockets%2F69941f32a12e4f99d4a57f65386d870d +608 -0
- data/test/dummy/tmp/cache/assets/CCB/F80/sprockets%2Fa865701ef2ec41155e524772c31a1a2b +1088 -0
- data/test/dummy/tmp/cache/assets/CCE/580/sprockets%2F879411ed27ed1c557d57853d8f579b56 +0 -0
- data/test/dummy/tmp/cache/assets/CD0/070/sprockets%2F6748fe8481965f260d9c56b7f9f508a2 +1530 -0
- data/test/dummy/tmp/cache/assets/CD4/750/sprockets%2Faf3505141ecb3169ce41ce519d136924 +0 -0
- data/test/dummy/tmp/cache/assets/CD6/A90/sprockets%2F3f55ac75b9fb8426312116bcb940a580 +2539 -0
- data/test/dummy/tmp/cache/assets/CD9/6C0/sprockets%2F5e2458bc52da90ba349a66035e3b6752 +0 -0
- data/test/dummy/tmp/cache/assets/CD9/F50/sprockets%2F9008bf696500cfae1d61f045f209181e +256 -0
- data/test/dummy/tmp/cache/assets/CDB/B40/sprockets%2F53529a22c994570a0df4742c0bfe61f4 +0 -0
- data/test/dummy/tmp/cache/assets/CDC/D10/sprockets%2F1e775b4ff06b4401c07503ce95a839b5 +75 -0
- data/test/dummy/tmp/cache/assets/CDE/CD0/sprockets%2F141066798b4acf07053f7e3a6cb4e555 +1613 -0
- data/test/dummy/tmp/cache/assets/CE1/760/sprockets%2F245fe11803630fe30d0cf8a869886ab5 +357 -0
- data/test/dummy/tmp/cache/assets/CE1/FA0/sprockets%2F863d1650ef066e4a2168bc57c7c0e096 +0 -0
- data/test/dummy/tmp/cache/assets/CE2/310/sprockets%2Fd38075d5592ecaf82e43526c03b467c4 +1545 -0
- data/test/dummy/tmp/cache/assets/CE2/420/sprockets%2F30f2e8f30477e80cf6416dfe27307c07 +204 -0
- data/test/dummy/tmp/cache/assets/CE2/D70/sprockets%2F467c44b63644e0f44dd06a585f36f1a6 +522 -0
- data/test/dummy/tmp/cache/assets/CE3/670/sprockets%2Fddd11860b444cd0f9996be0c46762318 +796 -0
- data/test/dummy/tmp/cache/assets/CE4/0B0/sprockets%2Ff11535d785c0d34349c64d673bd4b28f +1105 -0
- data/test/dummy/tmp/cache/assets/CE4/590/sprockets%2Fd68edcc87a4ae302794093081b45b819 +10 -0
- data/test/dummy/tmp/cache/assets/CE4/D60/sprockets%2F61772e4a60b616f74da91b838a2f4f82 +0 -0
- data/test/dummy/tmp/cache/assets/CE6/DD0/sprockets%2F2fe073024a2bf26bd98458388b57af37 +1355 -0
- data/test/dummy/tmp/cache/assets/CE7/160/sprockets%2Fba1f9939f031b4356ec1869d40fc2747 +1261 -0
- data/test/dummy/tmp/cache/assets/CE8/C70/sprockets%2Fc6c9ba3c677b5e2af8520395192c9445 +173 -0
- data/test/dummy/tmp/cache/assets/CEA/8B0/sprockets%2Ff77e549cb6d37604105f35d4e67d8c21 +511 -0
- data/test/dummy/tmp/cache/assets/CEA/AA0/sprockets%2F5f816982c86d2e6b72b2f5f65c51d070 +1529 -0
- data/test/dummy/tmp/cache/assets/CEA/C10/sprockets%2F9dcd541e67c299ab076a44a2183872f8 +0 -0
- data/test/dummy/tmp/cache/assets/CF1/5A0/sprockets%2F1a697695edf2bb7b49a2896904218bc7 +115 -0
- data/test/dummy/tmp/cache/assets/CF4/480/sprockets%2F5e99c77e93f4a522c84357e62b25e0f7 +43 -0
- data/test/dummy/tmp/cache/assets/CF7/460/sprockets%2Fd12ea9733fe3c92456f57f9145569b9c +0 -0
- data/test/dummy/tmp/cache/assets/CF7/470/sprockets%2F2897897a166ca3369fecb88f83f211b5 +435 -0
- data/test/dummy/tmp/cache/assets/CFA/760/sprockets%2Fa9024adba14091e0635c6874d1db4e22 +0 -0
- data/test/dummy/tmp/cache/assets/D01/F30/sprockets%2Fe639a15b6e0cca37d12443b408e1166f +25 -0
- data/test/dummy/tmp/cache/assets/D02/9F0/sprockets%2Fb99eae308897fe88cb9414b96824098b +0 -0
- data/test/dummy/tmp/cache/assets/D03/330/sprockets%2F1e003cdb3e7dcc9307e84090ad457127 +454 -0
- data/test/dummy/tmp/cache/assets/D03/8B0/sprockets%2Ff74632bddf2c0b2018ca7b736309380e +365 -0
- data/test/dummy/tmp/cache/assets/D05/0A0/sprockets%2Fe57658220260db13eb5577aef42cb61b +257 -0
- data/test/dummy/tmp/cache/assets/D05/920/sprockets%2F909507434dcc270db4853e4c147f0aac +31 -0
- data/test/dummy/tmp/cache/assets/D08/510/sprockets%2Fa567be6cb6d7310096f1739b25a5a3f0 +50 -0
- data/test/dummy/tmp/cache/assets/D08/9F0/sprockets%2F1d61d2c89ca50957066bacc5b69011f5 +1424 -0
- data/test/dummy/tmp/cache/assets/D0A/790/sprockets%2Feb16913e6504c9b0d3be431de39e4751 +300 -0
- data/test/dummy/tmp/cache/assets/D0C/C50/sprockets%2Fd6613bee8b40d50459af6b52a7084f34 +796 -0
- data/test/dummy/tmp/cache/assets/D0D/030/sprockets%2Fba3f13b4a444679e8bc2549226ec743b +21 -0
- data/test/dummy/tmp/cache/assets/D0D/350/sprockets%2F2670bce036d485e15d059c0f1e98f24a +207 -0
- data/test/dummy/tmp/cache/assets/D13/270/sprockets%2F497cb163e6317e3fc1565d832f406cfb +348 -0
- data/test/dummy/tmp/cache/assets/D13/380/sprockets%2F786d003c9c7fb759dd26c1030c087cf6 +813 -0
- data/test/dummy/tmp/cache/assets/D13/7C0/sprockets%2F528d22310a9ab8e6fba08d82844ce795 +0 -0
- data/test/dummy/tmp/cache/assets/D15/F60/sprockets%2Fa28394e3f80365b5bc86794dd46daa22 +0 -0
- data/test/dummy/tmp/cache/assets/D18/500/sprockets%2Fd22c2d97d1db2154f2f7592906e957ea +1001 -0
- data/test/dummy/tmp/cache/assets/D1B/C70/sprockets%2F1c04848b1e1d6e8e33b8581f8c8128ff +223 -0
- data/test/dummy/tmp/cache/assets/D1C/600/sprockets%2Fa0601f99147f59ddd6266e6aff077e14 +0 -0
- data/test/dummy/tmp/cache/assets/D1E/470/sprockets%2Fb3933e694547b78bf6fb15f44a4623fe +53 -0
- data/test/dummy/tmp/cache/assets/D1F/480/sprockets%2F545164168becf42b289efc8708f1db68 +1278 -0
- data/test/dummy/tmp/cache/assets/D21/630/sprockets%2F0a14114729c14637f2e8f122acabd1ab +823 -0
- data/test/dummy/tmp/cache/assets/D24/A90/sprockets%2F21c8a0d48c51b8585ba03bc112ecd153 +692 -0
- data/test/dummy/tmp/cache/assets/D25/D30/sprockets%2F3b937f4c16d2aa0a28fc02a0e922712b +1441 -0
- data/test/dummy/tmp/cache/assets/D25/F30/sprockets%2Fe251527c0c018f4b4ad44b2ad7064fb0 +2255 -0
- data/test/dummy/tmp/cache/assets/D26/DE0/sprockets%2F761ac1bdb0739cc56fa0c1224b137b09 +0 -0
- data/test/dummy/tmp/cache/assets/D2A/C30/sprockets%2F978fe7268754f451c59b9ccb323ffa56 +0 -0
- data/test/dummy/tmp/cache/assets/D2B/0F0/sprockets%2Fbf223af03335cfc08a71e549e10c0e27 +2539 -0
- data/test/dummy/tmp/cache/assets/D2E/6D0/sprockets%2F9e7fda3affb389313cc50223f01c0324 +0 -0
- data/test/dummy/tmp/cache/assets/D2F/110/sprockets%2F3730ffe2ed34c1219d580bd1615ea7b0 +2239 -0
- data/test/dummy/tmp/cache/assets/D2F/F10/sprockets%2F9cac242f0bf5ec00079ea3a463e26552 +153 -0
- data/test/dummy/tmp/cache/assets/D30/1D0/sprockets%2Fd690a26a0b0ae138c1c48d257a7674bc +589 -0
- data/test/dummy/tmp/cache/assets/D32/A10/sprockets%2F13fe41fee1fe35b49d145bcc06610705 +0 -0
- data/test/dummy/tmp/cache/assets/D36/940/sprockets%2Fb4ba462ac9f4aac561c36e60367c1378 +572 -0
- data/test/dummy/tmp/cache/assets/D37/090/sprockets%2F2f2e71ebbc240014ebf648f0917e854a +798 -0
- data/test/dummy/tmp/cache/assets/D3A/440/sprockets%2F6d332243647c841dea36ed822cdfc23e +165 -0
- data/test/dummy/tmp/cache/assets/D3B/5A0/sprockets%2F82e05cf8c88ba8cb1c87e50d51372a03 +0 -0
- data/test/dummy/tmp/cache/assets/D41/B30/sprockets%2Fba1b93913dd01d83ac9a96df334456f8 +0 -0
- data/test/dummy/tmp/cache/assets/D43/D90/sprockets%2F04f3a5926d5a7672456dc7afa73d0c7f +38 -0
- data/test/dummy/tmp/cache/assets/D45/1F0/sprockets%2F1bfa855d9c10ff2431a9a548958cc5e4 +83 -0
- data/test/dummy/tmp/cache/assets/D45/B10/sprockets%2F643f3d9b216e48df952b7f150a46a7ec +60 -0
- data/test/dummy/tmp/cache/assets/D46/040/sprockets%2F199546844e5939721a5afcbcce4ea43a +143 -0
- data/test/dummy/tmp/cache/assets/D49/320/sprockets%2Fd8123eb229e34c9f507f7b1876f1c4ee +506 -0
- data/test/dummy/tmp/cache/assets/D49/750/sprockets%2Ff41ef1c0832b7294fb15588ff5c783cb +0 -0
- data/test/dummy/tmp/cache/assets/D49/930/sprockets%2F1071926698fa55abc71e1b6fd966dfe1 +72 -0
- data/test/dummy/tmp/cache/assets/D49/D10/sprockets%2Fb67b8d7cc7579352a91694f9ae10cdb0 +127 -0
- data/test/dummy/tmp/cache/assets/D4A/160/sprockets%2Fcbd8988b5e18d153eff6230d72e9046a +516 -0
- data/test/dummy/tmp/cache/assets/D4A/2B0/sprockets%2Ffcdf002d38fd938bf7226b46b76706c8 +1101 -0
- data/test/dummy/tmp/cache/assets/D4E/2F0/sprockets%2F77cb87ae57f0d8c25cdaa74181a64997 +1441 -0
- data/test/dummy/tmp/cache/assets/D4F/060/sprockets%2Fa9e66b39ada7394a29bf44f3a682f665 +511 -0
- data/test/dummy/tmp/cache/assets/D50/BD0/sprockets%2F88650dd57ef64075462e6dae757dbe2c +0 -0
- data/test/dummy/tmp/cache/assets/D53/CA0/sprockets%2Fa85032e82709a043fbb2ec00e04f2bbd +0 -0
- data/test/dummy/tmp/cache/assets/D54/BF0/sprockets%2F91970514ff528e8d2bfd81f1ec83c9c8 +240 -0
- data/test/dummy/tmp/cache/assets/D54/ED0/sprockets%2F71c9fa01091d432b131da3bb73faf3d4 +10 -0
- data/test/dummy/tmp/cache/assets/D56/500/sprockets%2F75ebadd035f1324b194034af92eac3a0 +0 -0
- data/test/dummy/tmp/cache/assets/D5A/900/sprockets%2F5729f77d97fdee53b1942cf17f6f05e4 +474 -0
- data/test/dummy/tmp/cache/assets/D5A/D50/sprockets%2F81bace3db2c2f1241175ff3c5009d08c +0 -0
- data/test/dummy/tmp/cache/assets/D5B/C70/sprockets%2Fe64119a9db7017b7ab3b0da1b6076f0d +44 -0
- data/test/dummy/tmp/cache/assets/D5E/4D0/sprockets%2F756f25e4ad861a050cdc41bb8414e4ab +126 -0
- data/test/dummy/tmp/cache/assets/D5E/730/sprockets%2Fd30caf70b387c4604326bdda32aeb549 +0 -0
- data/test/dummy/tmp/cache/assets/D5E/AA0/sprockets%2F790dd07caaaacb30ceb0174664e90817 +136 -0
- data/test/dummy/tmp/cache/assets/D64/D30/sprockets%2Fe4bd8f60a3a446274c3cb2f5d16563ac +590 -0
- data/test/dummy/tmp/cache/assets/D66/400/sprockets%2Fecb7401d20daf25605a7afad3a793778 +0 -0
- data/test/dummy/tmp/cache/assets/D67/250/sprockets%2F8422eb26855ca9c953a3bf1aeade8004 +0 -0
- data/test/dummy/tmp/cache/assets/D69/900/sprockets%2F28ae64f52cb18f77b1a1bd9c51293da4 +0 -0
- data/test/dummy/tmp/cache/assets/D6A/870/sprockets%2F1ece6a51b42f9280f4cee9020c94b72e +197 -0
- data/test/dummy/tmp/cache/assets/D6B/DD0/sprockets%2F9a0abc735e27fc61dab019788518eba4 +164 -0
- data/test/dummy/tmp/cache/assets/D6E/CC0/sprockets%2F8b4fbcec2475e7203b8859baf8e310a3 +0 -0
- data/test/dummy/tmp/cache/assets/D72/470/sprockets%2Fbc0c6d850e7c769e83d58eb3e6061b2a +2556 -0
- data/test/dummy/tmp/cache/assets/D72/9D0/sprockets%2F9402daf6da6f7eed331a9d78216cb761 +0 -0
- data/test/dummy/tmp/cache/assets/D74/070/sprockets%2F91ae68f698a39bd7d0d11150fc46e4cd +418 -0
- data/test/dummy/tmp/cache/assets/D74/7F0/sprockets%2F22dad1069ea6a8f29ae757c44e18ec83 +0 -0
- data/test/dummy/tmp/cache/assets/D75/3C0/sprockets%2F44e2ae51b97853d8ecda7b264a267c7d +1630 -0
- data/test/dummy/tmp/cache/assets/D77/780/sprockets%2Ffa2abdfb0b62867c346f79187b8e42d5 +823 -0
- data/test/dummy/tmp/cache/assets/D79/850/sprockets%2F4d540586ed379fd9a70fa0b7ce4f5b27 +306 -0
- data/test/dummy/tmp/cache/assets/D7A/B60/sprockets%2F5925c92f48caff053d08853dc69e5bba +0 -0
- data/test/dummy/tmp/cache/assets/D81/C90/sprockets%2F19aca5c835efce74878c23e581e2a89e +2239 -0
- data/test/dummy/tmp/cache/assets/D84/210/sprockets%2Fabd0103ccec2b428ac62c94e4c40b384 +11228 -0
- data/test/dummy/tmp/cache/assets/D8B/B10/sprockets%2Fbb7a2305a8f2832631863bbababb67be +301 -0
- data/test/dummy/tmp/cache/assets/D92/3B0/sprockets%2F93dc71f411faf72ec8ef0b5d217b51a0 +505 -0
- data/test/dummy/tmp/cache/assets/D92/EE0/sprockets%2Ffd051ea0abf6be6970754aa732e40c8b +289 -0
- data/test/dummy/tmp/cache/assets/D93/810/sprockets%2F7dc1ac5e1b83ba5144e34cf156d48a8a +471 -0
- data/test/dummy/tmp/cache/assets/D94/020/sprockets%2F35cb4ce22488fb5bdd260508ca47a3fb +239 -0
- data/test/dummy/tmp/cache/assets/D94/EC0/sprockets%2F8b900fba18f8e046f5f12e6d1f0ac15b +74 -0
- data/test/dummy/tmp/cache/assets/D95/470/sprockets%2F5be5d361a52575c433831b5e8cccbace +9273 -0
- data/test/dummy/tmp/cache/assets/D97/9D0/sprockets%2F524a2a94a88c1d392dabcba654e365fc +103 -0
- data/test/dummy/tmp/cache/assets/D9D/800/sprockets%2Ff8387220eb4dda9b29a37b5deb9f2a40 +54 -0
- data/test/dummy/tmp/cache/assets/D9E/DD0/sprockets%2Fb6b4ffad6485eda046b327a196e8c44a +0 -0
- data/test/dummy/tmp/cache/assets/DA1/0A0/sprockets%2F359c94aee6ba2e15fc9666aa4de311c8 +166 -0
- data/test/dummy/tmp/cache/assets/DA1/0D0/sprockets%2F798de3c28452e164a7fc1a3a6e8cdb4b +652 -0
- data/test/dummy/tmp/cache/assets/DA3/CB0/sprockets%2Fdfad6bb1857a8af91f98ba137c18504e +815 -0
- data/test/dummy/tmp/cache/assets/DA4/E10/sprockets%2Fbda7705734ace95f12a7d79df9c14af2 +1354 -0
- data/test/dummy/tmp/cache/assets/DA5/E30/sprockets%2F2e6707a119e94a784efbadca18d7e8d1 +129 -0
- data/test/dummy/tmp/cache/assets/DA6/4B0/sprockets%2F4f7a708b6aa2d42eb577493dea7cef55 +115 -0
- data/test/dummy/tmp/cache/assets/DA8/A10/sprockets%2F0ae5bbb4ca200e74db3b64d72c2be120 +0 -0
- data/test/dummy/tmp/cache/assets/DA9/3F0/sprockets%2Fdd0af9cfd65fb7d02fe778c8f6015361 +499 -0
- data/test/dummy/tmp/cache/assets/DA9/780/sprockets%2Fe3559a635e8f92dec7727a3db2ae7b4c +813 -0
- data/test/dummy/tmp/cache/assets/DAC/0E0/sprockets%2F04cef8243a9ef7321846debc977ea8db +607 -0
- data/test/dummy/tmp/cache/assets/DB1/260/sprockets%2Fb879ff7530bf8cc175e0c7e70dc4e79b +0 -0
- data/test/dummy/tmp/cache/assets/DB4/4C0/sprockets%2F30a76cbd98dedb56742cd8ecaf858757 +0 -0
- data/test/dummy/tmp/cache/assets/DBD/7E0/sprockets%2F236fb1ac5ed9f2e3fe32203acc3a842d +0 -0
- data/test/dummy/tmp/cache/assets/DC2/DF0/sprockets%2Fe233bcaba8beff15626c35cb5e0e0936 +845 -0
- data/test/dummy/tmp/cache/assets/DC4/600/sprockets%2F59c96aa6c1cbebc61bff6c050a5351d7 +225 -0
- data/test/dummy/tmp/cache/assets/DC5/030/sprockets%2Fcb2fe864a0177eec19017c43ce9aa4ad +187 -0
- data/test/dummy/tmp/cache/assets/DC8/A60/sprockets%2F9fcb9f5c3f679ce749ee4c3f93869ba6 +74 -0
- data/test/dummy/tmp/cache/assets/DCB/D40/sprockets%2Ffd5542bfb7660a8d8cac3a2e46fb01f8 +828 -0
- data/test/dummy/tmp/cache/assets/DCC/020/sprockets%2F0c129c5f2784c96fa1dc3da6c19c1efc +128 -0
- data/test/dummy/tmp/cache/assets/DCF/520/sprockets%2F975162fb97a3ec7033db5f2fdba4fcd3 +70 -0
- data/test/dummy/tmp/cache/assets/DD0/000/sprockets%2F0d5d631cce6f0b078bb29cf98b3d78bb +276 -0
- data/test/dummy/tmp/cache/assets/DD0/C90/sprockets%2F84eeca4ef8f5eb29b13f7e1ea3c71324 +591 -0
- data/test/dummy/tmp/cache/assets/DD6/710/sprockets%2F9e83f2ebbe3e349efca2de390e15d635 +204 -0
- data/test/dummy/tmp/cache/assets/DE1/830/sprockets%2Fd23d3cafef2e2a9055bc103dffc1a023 +208 -0
- data/test/dummy/tmp/cache/assets/DEB/470/sprockets%2Fae2de0fcbc2214b71d3f2a875d2bc8c3 +2255 -0
- data/test/dummy/tmp/cache/assets/DEE/690/sprockets%2F5d824bcadef29060cc13eed71af4b4d0 +550 -0
- data/test/dummy/tmp/cache/assets/DF0/5D0/sprockets%2F25a875eb0a5d4c49bcc3fa39ea0adb26 +567 -0
- data/test/dummy/tmp/cache/assets/DF3/E20/sprockets%2Fada770c49a5d6b38d1cc43ed4d51c1fc +0 -0
- data/test/dummy/tmp/cache/assets/DF5/C80/sprockets%2F03ad7d7b3a8feba9ed9be82ae2083b20 +340 -0
- data/test/dummy/tmp/cache/assets/DF6/560/sprockets%2Fafceb2b55eb108efe4446dfb02b519b8 +0 -0
- data/test/dummy/tmp/cache/assets/DFC/030/sprockets%2Fcbdd3679eaba219b4e1ff20677af1c6f +1371 -0
- data/test/dummy/tmp/cache/assets/E00/970/sprockets%2F8bc6dde8d05c382dd07cbcec70f54e09 +378 -0
- data/test/dummy/tmp/cache/assets/E04/890/sprockets%2F2f5173deea6c795b8fdde723bb4b63af +0 -0
- data/test/dummy/tmp/cache/assets/E12/2F0/sprockets%2F5c45062ecfbe512dcba176ba6ddacc00 +523 -0
- data/test/dummy/tmp/cache/assets/E21/5D0/sprockets%2Fd4fe6d611bfb0e63c04de5dbfb128a8a +0 -0
- data/test/dummy/tmp/cache/assets/E22/770/sprockets%2F2ccebcabfbb9b59159e4b73b3b30a74d +208 -0
- data/test/dummy/tmp/cache/assets/E31/A90/sprockets%2F26b98bbbc15eee9b370c7dcde88d16aa +394 -0
- data/test/dummy/tmp/cache/assets/E31/E30/sprockets%2Ffbdafcc4e2f44bb9fc653bcf9625b750 +284 -0
- data/test/dummy/tmp/cache/assets/E37/1C0/sprockets%2Fa5eb45fc86dafe2bee4e4fa3f53c4785 +0 -0
- data/test/dummy/tmp/cache/assets/E4C/960/sprockets%2F13fd6e4bfdf031acb3dedca8d0f407b4 +1277 -0
- data/test/dummy/tmp/cache/assets/E88/330/sprockets%2Fe02d0adb5529ffafcea1b9e5ccf69a5b +669 -0
- data/test/dummy/tmp/pids/server.pid +1 -0
- data/test/dummy/tmp/simple.js.js +20 -0
- data/test/dummy/tmp/soy-1325274421.js +20 -0
- data/test/dummy/tmp/soy-1325286267.js +20 -0
- data/test/test_helper.rb +10 -0
- data/test/yellow-brick-road_test.rb +7 -0
- 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
|