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,1105 @@
|
|
1
|
+
o: ActiveSupport::Cache::Entry :@compressedF:@expires_in0:@created_atf1325441615.693562:@value{I"
|
2
|
+
class:EFI"BundledAsset;
|
3
|
+
FI"id;
|
4
|
+
F"%59a326aca6895e0598635e27205b2d9dI"logical_path;
|
5
|
+
FI"closure/goog/net/xhrio.js;
|
6
|
+
TI"
|
7
|
+
F"k/Volumes/Development/dev-web/yellow-brick-road/vendor/assets/closure-library/closure/goog/net/xhrio.jsI"content_type;
|
8
|
+
FI"application/javascript;
|
9
|
+
FI"
|
10
|
+
mtime;
|
11
|
+
FI"2011-12-30T02:16:24+00:00;
|
12
|
+
FI" body;
|
13
|
+
FI"Z�// Copyright 2006 The Closure Library Authors. All Rights Reserved.
|
14
|
+
//
|
15
|
+
// Licensed under the Apache License, Version 2.0 (the "License");
|
16
|
+
// you may not use this file except in compliance with the License.
|
17
|
+
// You may obtain a copy of the License at
|
18
|
+
//
|
19
|
+
// http://www.apache.org/licenses/LICENSE-2.0
|
20
|
+
//
|
21
|
+
// Unless required by applicable law or agreed to in writing, software
|
22
|
+
// distributed under the License is distributed on an "AS-IS" BASIS,
|
23
|
+
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
24
|
+
// See the License for the specific language governing permissions and
|
25
|
+
// limitations under the License.
|
26
|
+
|
27
|
+
/**
|
28
|
+
* @fileoverview Wrapper class for handling XmlHttpRequests.
|
29
|
+
*
|
30
|
+
* One off requests can be sent through goog.net.XhrIo.send() or an
|
31
|
+
* instance can be created to send multiple requests. Each request uses its
|
32
|
+
* own XmlHttpRequest object and handles clearing of the event callback to
|
33
|
+
* ensure no leaks.
|
34
|
+
*
|
35
|
+
* XhrIo is event based, it dispatches events when a request finishes, fails or
|
36
|
+
* succeeds or when the ready-state changes. The ready-state or timeout event
|
37
|
+
* fires first, followed by a generic completed event. Then the abort, error,
|
38
|
+
* or success event is fired as appropriate. Lastly, the ready event will fire
|
39
|
+
* to indicate that the object may be used to make another request.
|
40
|
+
*
|
41
|
+
* The error event may also be called before completed and
|
42
|
+
* ready-state-change if the XmlHttpRequest.open() or .send() methods throw.
|
43
|
+
*
|
44
|
+
* This class does not support multiple requests, queuing, or prioritization.
|
45
|
+
*
|
46
|
+
* Tested = IE6, FF1.5, Safari, Opera 8.5
|
47
|
+
*
|
48
|
+
* TODO(user): Error cases aren't playing nicely in Safari.
|
49
|
+
*
|
50
|
+
*/
|
51
|
+
|
52
|
+
|
53
|
+
|
54
|
+
goog.provide('goog.net.XhrIo');
|
55
|
+
goog.provide('goog.net.XhrIo.ResponseType');
|
56
|
+
|
57
|
+
goog.require('goog.Timer');
|
58
|
+
goog.require('goog.debug.Logger');
|
59
|
+
goog.require('goog.debug.entryPointRegistry');
|
60
|
+
goog.require('goog.debug.errorHandlerWeakDep');
|
61
|
+
goog.require('goog.events.EventTarget');
|
62
|
+
goog.require('goog.json');
|
63
|
+
goog.require('goog.net.ErrorCode');
|
64
|
+
goog.require('goog.net.EventType');
|
65
|
+
goog.require('goog.net.HttpStatus');
|
66
|
+
goog.require('goog.net.XmlHttp');
|
67
|
+
goog.require('goog.object');
|
68
|
+
goog.require('goog.structs');
|
69
|
+
goog.require('goog.structs.Map');
|
70
|
+
goog.require('goog.uri.utils');
|
71
|
+
|
72
|
+
|
73
|
+
|
74
|
+
/**
|
75
|
+
* Basic class for handling XMLHttpRequests.
|
76
|
+
* @param {goog.net.XmlHttpFactory=} opt_xmlHttpFactory Factory to use when
|
77
|
+
* creating XMLHttpRequest objects.
|
78
|
+
* @constructor
|
79
|
+
* @extends {goog.events.EventTarget}
|
80
|
+
*/
|
81
|
+
goog.net.XhrIo = function(opt_xmlHttpFactory) {
|
82
|
+
goog.events.EventTarget.call(this);
|
83
|
+
|
84
|
+
/**
|
85
|
+
* Map of default headers to add to every request, use:
|
86
|
+
* XhrIo.headers.set(name, value)
|
87
|
+
* @type {goog.structs.Map}
|
88
|
+
*/
|
89
|
+
this.headers = new goog.structs.Map();
|
90
|
+
|
91
|
+
/**
|
92
|
+
* Optional XmlHttpFactory
|
93
|
+
* @type {goog.net.XmlHttpFactory}
|
94
|
+
* @private
|
95
|
+
*/
|
96
|
+
this.xmlHttpFactory_ = opt_xmlHttpFactory || null;
|
97
|
+
};
|
98
|
+
goog.inherits(goog.net.XhrIo, goog.events.EventTarget);
|
99
|
+
|
100
|
+
|
101
|
+
/**
|
102
|
+
* Response types that may be requested for XMLHttpRequests.
|
103
|
+
* @enum {string}
|
104
|
+
* @see http://dev.w3.org/2006/webapi/XMLHttpRequest-2/#the-responsetype-attribute
|
105
|
+
*/
|
106
|
+
goog.net.XhrIo.ResponseType = {
|
107
|
+
DEFAULT: '',
|
108
|
+
TEXT: 'text',
|
109
|
+
DOCUMENT: 'document',
|
110
|
+
// Not supported as of Chrome 10.0.612.1 dev
|
111
|
+
BLOB: 'blob',
|
112
|
+
ARRAY_BUFFER: 'arraybuffer'
|
113
|
+
};
|
114
|
+
|
115
|
+
|
116
|
+
/**
|
117
|
+
* A reference to the XhrIo logger
|
118
|
+
* @type {goog.debug.Logger}
|
119
|
+
* @private
|
120
|
+
*/
|
121
|
+
goog.net.XhrIo.prototype.logger_ =
|
122
|
+
goog.debug.Logger.getLogger('goog.net.XhrIo');
|
123
|
+
|
124
|
+
|
125
|
+
/**
|
126
|
+
* The Content-Type HTTP header name
|
127
|
+
* @type {string}
|
128
|
+
*/
|
129
|
+
goog.net.XhrIo.CONTENT_TYPE_HEADER = 'Content-Type';
|
130
|
+
|
131
|
+
|
132
|
+
/**
|
133
|
+
* The pattern matching the 'http' and 'https' URI schemes
|
134
|
+
* @type {!RegExp}
|
135
|
+
*/
|
136
|
+
goog.net.XhrIo.HTTP_SCHEME_PATTERN = /^https?$/i;
|
137
|
+
|
138
|
+
|
139
|
+
/**
|
140
|
+
* The Content-Type HTTP header value for a url-encoded form
|
141
|
+
* @type {string}
|
142
|
+
*/
|
143
|
+
goog.net.XhrIo.FORM_CONTENT_TYPE =
|
144
|
+
'application/x-www-form-urlencoded;charset=utf-8';
|
145
|
+
|
146
|
+
|
147
|
+
/**
|
148
|
+
* All non-disposed instances of goog.net.XhrIo created
|
149
|
+
* by {@link goog.net.XhrIo.send} are in this Array.
|
150
|
+
* @see goog.net.XhrIo.cleanup
|
151
|
+
* @type {Array.<goog.net.XhrIo>}
|
152
|
+
* @private
|
153
|
+
*/
|
154
|
+
goog.net.XhrIo.sendInstances_ = [];
|
155
|
+
|
156
|
+
|
157
|
+
/**
|
158
|
+
* Static send that creates a short lived instance of XhrIo to send the
|
159
|
+
* request.
|
160
|
+
* @see goog.net.XhrIo.cleanup
|
161
|
+
* @param {string|goog.Uri} url Uri to make request to.
|
162
|
+
* @param {Function=} opt_callback Callback function for when request is
|
163
|
+
* complete.
|
164
|
+
* @param {string=} opt_method Send method, default: GET.
|
165
|
+
* @param {string|GearsBlob=} opt_content Post data. This can be a Gears blob
|
166
|
+
* if the underlying HTTP request object is a Gears HTTP request.
|
167
|
+
* @param {Object|goog.structs.Map=} opt_headers Map of headers to add to the
|
168
|
+
* request.
|
169
|
+
* @param {number=} opt_timeoutInterval Number of milliseconds after which an
|
170
|
+
* incomplete request will be aborted; 0 means no timeout is set.
|
171
|
+
*/
|
172
|
+
goog.net.XhrIo.send = function(url, opt_callback, opt_method, opt_content,
|
173
|
+
opt_headers, opt_timeoutInterval) {
|
174
|
+
var x = new goog.net.XhrIo();
|
175
|
+
goog.net.XhrIo.sendInstances_.push(x);
|
176
|
+
if (opt_callback) {
|
177
|
+
goog.events.listen(x, goog.net.EventType.COMPLETE, opt_callback);
|
178
|
+
}
|
179
|
+
goog.events.listen(x,
|
180
|
+
goog.net.EventType.READY,
|
181
|
+
goog.partial(goog.net.XhrIo.cleanupSend_, x));
|
182
|
+
if (opt_timeoutInterval) {
|
183
|
+
x.setTimeoutInterval(opt_timeoutInterval);
|
184
|
+
}
|
185
|
+
x.send(url, opt_method, opt_content, opt_headers);
|
186
|
+
};
|
187
|
+
|
188
|
+
|
189
|
+
/**
|
190
|
+
* Disposes all non-disposed instances of goog.net.XhrIo created by
|
191
|
+
* {@link goog.net.XhrIo.send}.
|
192
|
+
* {@link goog.net.XhrIo.send} cleans up the goog.net.XhrIo instance
|
193
|
+
* it creates when the request completes or fails. However, if
|
194
|
+
* the request never completes, then the goog.net.XhrIo is not disposed.
|
195
|
+
* This can occur if the window is unloaded before the request completes.
|
196
|
+
* We could have {@link goog.net.XhrIo.send} return the goog.net.XhrIo
|
197
|
+
* it creates and make the client of {@link goog.net.XhrIo.send} be
|
198
|
+
* responsible for disposing it in this case. However, this makes things
|
199
|
+
* significantly more complicated for the client, and the whole point
|
200
|
+
* of {@link goog.net.XhrIo.send} is that it's simple and easy to use.
|
201
|
+
* Clients of {@link goog.net.XhrIo.send} should call
|
202
|
+
* {@link goog.net.XhrIo.cleanup} when doing final
|
203
|
+
* cleanup on window unload.
|
204
|
+
*/
|
205
|
+
goog.net.XhrIo.cleanup = function() {
|
206
|
+
var instances = goog.net.XhrIo.sendInstances_;
|
207
|
+
while (instances.length) {
|
208
|
+
instances.pop().dispose();
|
209
|
+
}
|
210
|
+
};
|
211
|
+
|
212
|
+
|
213
|
+
/**
|
214
|
+
* Installs exception protection for all entry point introduced by
|
215
|
+
* goog.net.XhrIo instances which are not protected by
|
216
|
+
* {@link goog.debug.ErrorHandler#protectWindowSetTimeout},
|
217
|
+
* {@link goog.debug.ErrorHandler#protectWindowSetInterval}, or
|
218
|
+
* {@link goog.events.protectBrowserEventEntryPoint}.
|
219
|
+
*
|
220
|
+
* @param {goog.debug.ErrorHandler} errorHandler Error handler with which to
|
221
|
+
* protect the entry point(s).
|
222
|
+
*/
|
223
|
+
goog.net.XhrIo.protectEntryPoints = function(errorHandler) {
|
224
|
+
goog.net.XhrIo.prototype.onReadyStateChangeEntryPoint_ =
|
225
|
+
errorHandler.protectEntryPoint(
|
226
|
+
goog.net.XhrIo.prototype.onReadyStateChangeEntryPoint_);
|
227
|
+
};
|
228
|
+
|
229
|
+
|
230
|
+
/**
|
231
|
+
* Disposes of the specified goog.net.XhrIo created by
|
232
|
+
* {@link goog.net.XhrIo.send} and removes it from
|
233
|
+
* {@link goog.net.XhrIo.pendingStaticSendInstances_}.
|
234
|
+
* @param {goog.net.XhrIo} XhrIo An XhrIo created by
|
235
|
+
* {@link goog.net.XhrIo.send}.
|
236
|
+
* @private
|
237
|
+
*/
|
238
|
+
goog.net.XhrIo.cleanupSend_ = function(XhrIo) {
|
239
|
+
XhrIo.dispose();
|
240
|
+
goog.array.remove(goog.net.XhrIo.sendInstances_, XhrIo);
|
241
|
+
};
|
242
|
+
|
243
|
+
|
244
|
+
/**
|
245
|
+
* Whether XMLHttpRequest is active. A request is active from the time send()
|
246
|
+
* is called until onReadyStateChange() is complete, or error() or abort()
|
247
|
+
* is called.
|
248
|
+
* @type {boolean}
|
249
|
+
* @private
|
250
|
+
*/
|
251
|
+
goog.net.XhrIo.prototype.active_ = false;
|
252
|
+
|
253
|
+
|
254
|
+
/**
|
255
|
+
* Reference to an XMLHttpRequest object that is being used for the transfer.
|
256
|
+
* @type {XMLHttpRequest|GearsHttpRequest}
|
257
|
+
* @private
|
258
|
+
*/
|
259
|
+
goog.net.XhrIo.prototype.xhr_ = null;
|
260
|
+
|
261
|
+
|
262
|
+
/**
|
263
|
+
* The options to use with the current XMLHttpRequest object.
|
264
|
+
* @type {Object}
|
265
|
+
* @private
|
266
|
+
*/
|
267
|
+
goog.net.XhrIo.prototype.xhrOptions_ = null;
|
268
|
+
|
269
|
+
|
270
|
+
/**
|
271
|
+
* Last URL that was requested.
|
272
|
+
* @type {string|goog.Uri}
|
273
|
+
* @private
|
274
|
+
*/
|
275
|
+
goog.net.XhrIo.prototype.lastUri_ = '';
|
276
|
+
|
277
|
+
|
278
|
+
/**
|
279
|
+
* Method for the last request.
|
280
|
+
* @type {string}
|
281
|
+
* @private
|
282
|
+
*/
|
283
|
+
goog.net.XhrIo.prototype.lastMethod_ = '';
|
284
|
+
|
285
|
+
|
286
|
+
/**
|
287
|
+
* Last error code.
|
288
|
+
* @type {goog.net.ErrorCode}
|
289
|
+
* @private
|
290
|
+
*/
|
291
|
+
goog.net.XhrIo.prototype.lastErrorCode_ = goog.net.ErrorCode.NO_ERROR;
|
292
|
+
|
293
|
+
|
294
|
+
/**
|
295
|
+
* Last error message.
|
296
|
+
* @type {Error|string}
|
297
|
+
* @private
|
298
|
+
*/
|
299
|
+
goog.net.XhrIo.prototype.lastError_ = '';
|
300
|
+
|
301
|
+
|
302
|
+
/**
|
303
|
+
* This is used to ensure that we don't dispatch an multiple ERROR events. This
|
304
|
+
* can happen in IE when it does a synchronous load and one error is handled in
|
305
|
+
* the ready statte change and one is handled due to send() throwing an
|
306
|
+
* exception.
|
307
|
+
* @type {boolean}
|
308
|
+
* @private
|
309
|
+
*/
|
310
|
+
goog.net.XhrIo.prototype.errorDispatched_ = false;
|
311
|
+
|
312
|
+
|
313
|
+
/**
|
314
|
+
* Used to make sure we don't fire the complete event from inside a send call.
|
315
|
+
* @type {boolean}
|
316
|
+
* @private
|
317
|
+
*/
|
318
|
+
goog.net.XhrIo.prototype.inSend_ = false;
|
319
|
+
|
320
|
+
|
321
|
+
/**
|
322
|
+
* Used in determining if a call to {@link #onReadyStateChange_} is from within
|
323
|
+
* a call to this.xhr_.open.
|
324
|
+
* @type {boolean}
|
325
|
+
* @private
|
326
|
+
*/
|
327
|
+
goog.net.XhrIo.prototype.inOpen_ = false;
|
328
|
+
|
329
|
+
|
330
|
+
/**
|
331
|
+
* Used in determining if a call to {@link #onReadyStateChange_} is from within
|
332
|
+
* a call to this.xhr_.abort.
|
333
|
+
* @type {boolean}
|
334
|
+
* @private
|
335
|
+
*/
|
336
|
+
goog.net.XhrIo.prototype.inAbort_ = false;
|
337
|
+
|
338
|
+
|
339
|
+
/**
|
340
|
+
* Number of milliseconds after which an incomplete request will be aborted and
|
341
|
+
* a {@link goog.net.EventType.TIMEOUT} event raised; 0 means no timeout is set.
|
342
|
+
* @type {number}
|
343
|
+
* @private
|
344
|
+
*/
|
345
|
+
goog.net.XhrIo.prototype.timeoutInterval_ = 0;
|
346
|
+
|
347
|
+
|
348
|
+
/**
|
349
|
+
* Window timeout ID used to cancel the timeout event handler if the request
|
350
|
+
* completes successfully.
|
351
|
+
* @type {Object}
|
352
|
+
* @private
|
353
|
+
*/
|
354
|
+
goog.net.XhrIo.prototype.timeoutId_ = null;
|
355
|
+
|
356
|
+
|
357
|
+
/**
|
358
|
+
* The requested type for the response. The empty string means use the default
|
359
|
+
* XHR behavior.
|
360
|
+
* @type {goog.net.XhrIo.ResponseType}
|
361
|
+
* @private
|
362
|
+
*/
|
363
|
+
goog.net.XhrIo.prototype.responseType_ = goog.net.XhrIo.ResponseType.DEFAULT;
|
364
|
+
|
365
|
+
|
366
|
+
/**
|
367
|
+
* Whether a "credentialed" request is to be sent (one that is aware of cookies
|
368
|
+
* and authentication) . This is applicable only for cross-domain requests and
|
369
|
+
* more recent browsers that support this part of the HTTP Access Control
|
370
|
+
* standard.
|
371
|
+
*
|
372
|
+
* @see http://dev.w3.org/2006/webapi/XMLHttpRequest-2/#withcredentials
|
373
|
+
*
|
374
|
+
* @type {boolean}
|
375
|
+
* @private
|
376
|
+
*/
|
377
|
+
goog.net.XhrIo.prototype.withCredentials_ = false;
|
378
|
+
|
379
|
+
|
380
|
+
/**
|
381
|
+
* Returns the number of milliseconds after which an incomplete request will be
|
382
|
+
* aborted, or 0 if no timeout is set.
|
383
|
+
* @return {number} Timeout interval in milliseconds.
|
384
|
+
*/
|
385
|
+
goog.net.XhrIo.prototype.getTimeoutInterval = function() {
|
386
|
+
return this.timeoutInterval_;
|
387
|
+
};
|
388
|
+
|
389
|
+
|
390
|
+
/**
|
391
|
+
* Sets the number of milliseconds after which an incomplete request will be
|
392
|
+
* aborted and a {@link goog.net.EventType.TIMEOUT} event raised; 0 means no
|
393
|
+
* timeout is set.
|
394
|
+
* @param {number} ms Timeout interval in milliseconds; 0 means none.
|
395
|
+
*/
|
396
|
+
goog.net.XhrIo.prototype.setTimeoutInterval = function(ms) {
|
397
|
+
this.timeoutInterval_ = Math.max(0, ms);
|
398
|
+
};
|
399
|
+
|
400
|
+
|
401
|
+
/**
|
402
|
+
* Sets the desired type for the response. At time of writing, this is only
|
403
|
+
* supported in very recent versions of WebKit (10.0.612.1 dev and later).
|
404
|
+
*
|
405
|
+
* If this is used, the response may only be accessed via {@link #getResponse}.
|
406
|
+
*
|
407
|
+
* @param {goog.net.XhrIo.ResponseType} type The desired type for the response.
|
408
|
+
*/
|
409
|
+
goog.net.XhrIo.prototype.setResponseType = function(type) {
|
410
|
+
this.responseType_ = type;
|
411
|
+
};
|
412
|
+
|
413
|
+
|
414
|
+
/**
|
415
|
+
* Gets the desired type for the response.
|
416
|
+
* @return {goog.net.XhrIo.ResponseType} The desired type for the response.
|
417
|
+
*/
|
418
|
+
goog.net.XhrIo.prototype.getResponseType = function() {
|
419
|
+
return this.responseType_;
|
420
|
+
};
|
421
|
+
|
422
|
+
|
423
|
+
/**
|
424
|
+
* Sets whether a "credentialed" request that is aware of cookie and
|
425
|
+
* authentication information should be made. This option is only supported by
|
426
|
+
* browsers that support HTTP Access Control. As of this writing, this option
|
427
|
+
* is not supported in IE.
|
428
|
+
*
|
429
|
+
* @param {boolean} withCredentials Whether this should be a "credentialed"
|
430
|
+
* request.
|
431
|
+
*/
|
432
|
+
goog.net.XhrIo.prototype.setWithCredentials = function(withCredentials) {
|
433
|
+
this.withCredentials_ = withCredentials;
|
434
|
+
};
|
435
|
+
|
436
|
+
|
437
|
+
/**
|
438
|
+
* Gets whether a "credentialed" request is to be sent.
|
439
|
+
* @return {boolean} The desired type for the response.
|
440
|
+
*/
|
441
|
+
goog.net.XhrIo.prototype.getWithCredentials = function() {
|
442
|
+
return this.withCredentials_;
|
443
|
+
};
|
444
|
+
|
445
|
+
|
446
|
+
/**
|
447
|
+
* Instance send that actually uses XMLHttpRequest to make a server call.
|
448
|
+
* @param {string|goog.Uri} url Uri to make request to.
|
449
|
+
* @param {string=} opt_method Send method, default: GET.
|
450
|
+
* @param {string|GearsBlob=} opt_content Post data. This can be a Gears blob
|
451
|
+
* if the underlying HTTP request object is a Gears HTTP request.
|
452
|
+
* @param {Object|goog.structs.Map=} opt_headers Map of headers to add to the
|
453
|
+
* request.
|
454
|
+
*/
|
455
|
+
goog.net.XhrIo.prototype.send = function(url, opt_method, opt_content,
|
456
|
+
opt_headers) {
|
457
|
+
if (this.xhr_) {
|
458
|
+
throw Error('[goog.net.XhrIo] Object is active with another request');
|
459
|
+
}
|
460
|
+
|
461
|
+
var method = opt_method ? opt_method.toUpperCase() : 'GET';
|
462
|
+
|
463
|
+
this.lastUri_ = url;
|
464
|
+
this.lastError_ = '';
|
465
|
+
this.lastErrorCode_ = goog.net.ErrorCode.NO_ERROR;
|
466
|
+
this.lastMethod_ = method;
|
467
|
+
this.errorDispatched_ = false;
|
468
|
+
this.active_ = true;
|
469
|
+
|
470
|
+
// Use the factory to create the XHR object and options
|
471
|
+
this.xhr_ = this.createXhr();
|
472
|
+
this.xhrOptions_ = this.xmlHttpFactory_ ?
|
473
|
+
this.xmlHttpFactory_.getOptions() : goog.net.XmlHttp.getOptions();
|
474
|
+
|
475
|
+
// Set up the onreadystatechange callback
|
476
|
+
this.xhr_.onreadystatechange = goog.bind(this.onReadyStateChange_, this);
|
477
|
+
|
478
|
+
/**
|
479
|
+
* Try to open the XMLHttpRequest (always async), if an error occurs here it
|
480
|
+
* is generally permission denied
|
481
|
+
* @preserveTry
|
482
|
+
*/
|
483
|
+
try {
|
484
|
+
this.logger_.fine(this.formatMsg_('Opening Xhr'));
|
485
|
+
this.inOpen_ = true;
|
486
|
+
this.xhr_.open(method, url, true); // Always async!
|
487
|
+
this.inOpen_ = false;
|
488
|
+
} catch (err) {
|
489
|
+
this.logger_.fine(this.formatMsg_('Error opening Xhr: ' + err.message));
|
490
|
+
this.error_(goog.net.ErrorCode.EXCEPTION, err);
|
491
|
+
return;
|
492
|
+
}
|
493
|
+
|
494
|
+
// We can't use null since this won't allow POSTs to have a content length
|
495
|
+
// specified which will cause some proxies to return a 411 error.
|
496
|
+
var content = opt_content || '';
|
497
|
+
|
498
|
+
var headers = this.headers.clone();
|
499
|
+
|
500
|
+
// Add headers specific to this request
|
501
|
+
if (opt_headers) {
|
502
|
+
goog.structs.forEach(opt_headers, function(value, key) {
|
503
|
+
headers.set(key, value);
|
504
|
+
});
|
505
|
+
}
|
506
|
+
|
507
|
+
if (method == 'POST' &&
|
508
|
+
!headers.containsKey(goog.net.XhrIo.CONTENT_TYPE_HEADER)) {
|
509
|
+
// For POST requests, default to the url-encoded form content type.
|
510
|
+
headers.set(goog.net.XhrIo.CONTENT_TYPE_HEADER,
|
511
|
+
goog.net.XhrIo.FORM_CONTENT_TYPE);
|
512
|
+
}
|
513
|
+
|
514
|
+
// Add the headers to the Xhr object
|
515
|
+
goog.structs.forEach(headers, function(value, key) {
|
516
|
+
this.xhr_.setRequestHeader(key, value);
|
517
|
+
}, this);
|
518
|
+
|
519
|
+
if (this.responseType_) {
|
520
|
+
this.xhr_.responseType = this.responseType_;
|
521
|
+
}
|
522
|
+
|
523
|
+
if (goog.object.containsKey(this.xhr_, 'withCredentials')) {
|
524
|
+
this.xhr_.withCredentials = this.withCredentials_;
|
525
|
+
}
|
526
|
+
|
527
|
+
/**
|
528
|
+
* Try to send the request, or other wise report an error (404 not found).
|
529
|
+
* @preserveTry
|
530
|
+
*/
|
531
|
+
try {
|
532
|
+
if (this.timeoutId_) {
|
533
|
+
// This should never happen, since the if (this.active_) above shouldn't
|
534
|
+
// let execution reach this point if there is a request in progress...
|
535
|
+
goog.Timer.defaultTimerObject.clearTimeout(this.timeoutId_);
|
536
|
+
this.timeoutId_ = null;
|
537
|
+
}
|
538
|
+
if (this.timeoutInterval_ > 0) {
|
539
|
+
this.logger_.fine(this.formatMsg_('Will abort after ' +
|
540
|
+
this.timeoutInterval_ + 'ms if incomplete'));
|
541
|
+
this.timeoutId_ = goog.Timer.defaultTimerObject.setTimeout(
|
542
|
+
goog.bind(this.timeout_, this), this.timeoutInterval_);
|
543
|
+
}
|
544
|
+
this.logger_.fine(this.formatMsg_('Sending request'));
|
545
|
+
this.inSend_ = true;
|
546
|
+
this.xhr_.send(content);
|
547
|
+
this.inSend_ = false;
|
548
|
+
|
549
|
+
} catch (err) {
|
550
|
+
this.logger_.fine(this.formatMsg_('Send error: ' + err.message));
|
551
|
+
this.error_(goog.net.ErrorCode.EXCEPTION, err);
|
552
|
+
}
|
553
|
+
};
|
554
|
+
|
555
|
+
|
556
|
+
/**
|
557
|
+
* Creates a new XHR object.
|
558
|
+
* @return {XMLHttpRequest|GearsHttpRequest} The newly created XHR object.
|
559
|
+
* @protected
|
560
|
+
*/
|
561
|
+
goog.net.XhrIo.prototype.createXhr = function() {
|
562
|
+
return this.xmlHttpFactory_ ?
|
563
|
+
this.xmlHttpFactory_.createInstance() : goog.net.XmlHttp();
|
564
|
+
};
|
565
|
+
|
566
|
+
|
567
|
+
/**
|
568
|
+
* The request didn't complete after {@link goog.net.XhrIo#timeoutInterval_}
|
569
|
+
* milliseconds; raises a {@link goog.net.EventType.TIMEOUT} event and aborts
|
570
|
+
* the request.
|
571
|
+
* @private
|
572
|
+
*/
|
573
|
+
goog.net.XhrIo.prototype.timeout_ = function() {
|
574
|
+
if (typeof goog == 'undefined') {
|
575
|
+
// If goog is undefined then the callback has occurred as the application
|
576
|
+
// is unloading and will error. Thus we let it silently fail.
|
577
|
+
} else if (this.xhr_) {
|
578
|
+
this.lastError_ = 'Timed out after ' + this.timeoutInterval_ +
|
579
|
+
'ms, aborting';
|
580
|
+
this.lastErrorCode_ = goog.net.ErrorCode.TIMEOUT;
|
581
|
+
this.logger_.fine(this.formatMsg_(this.lastError_));
|
582
|
+
this.dispatchEvent(goog.net.EventType.TIMEOUT);
|
583
|
+
this.abort(goog.net.ErrorCode.TIMEOUT);
|
584
|
+
}
|
585
|
+
};
|
586
|
+
|
587
|
+
|
588
|
+
/**
|
589
|
+
* Something errorred, so inactivate, fire error callback and clean up
|
590
|
+
* @param {goog.net.ErrorCode} errorCode The error code.
|
591
|
+
* @param {Error} err The error object.
|
592
|
+
* @private
|
593
|
+
*/
|
594
|
+
goog.net.XhrIo.prototype.error_ = function(errorCode, err) {
|
595
|
+
this.active_ = false;
|
596
|
+
if (this.xhr_) {
|
597
|
+
this.inAbort_ = true;
|
598
|
+
this.xhr_.abort(); // Ensures XHR isn't hung (FF)
|
599
|
+
this.inAbort_ = false;
|
600
|
+
}
|
601
|
+
this.lastError_ = err;
|
602
|
+
this.lastErrorCode_ = errorCode;
|
603
|
+
this.dispatchErrors_();
|
604
|
+
this.cleanUpXhr_();
|
605
|
+
};
|
606
|
+
|
607
|
+
|
608
|
+
/**
|
609
|
+
* Dispatches COMPLETE and ERROR in case of an error. This ensures that we do
|
610
|
+
* not dispatch multiple error events.
|
611
|
+
* @private
|
612
|
+
*/
|
613
|
+
goog.net.XhrIo.prototype.dispatchErrors_ = function() {
|
614
|
+
if (!this.errorDispatched_) {
|
615
|
+
this.errorDispatched_ = true;
|
616
|
+
this.dispatchEvent(goog.net.EventType.COMPLETE);
|
617
|
+
this.dispatchEvent(goog.net.EventType.ERROR);
|
618
|
+
}
|
619
|
+
};
|
620
|
+
|
621
|
+
|
622
|
+
/**
|
623
|
+
* Abort the current XMLHttpRequest
|
624
|
+
* @param {goog.net.ErrorCode=} opt_failureCode Optional error code to use -
|
625
|
+
* defaults to ABORT.
|
626
|
+
*/
|
627
|
+
goog.net.XhrIo.prototype.abort = function(opt_failureCode) {
|
628
|
+
if (this.xhr_ && this.active_) {
|
629
|
+
this.logger_.fine(this.formatMsg_('Aborting'));
|
630
|
+
this.active_ = false;
|
631
|
+
this.inAbort_ = true;
|
632
|
+
this.xhr_.abort();
|
633
|
+
this.inAbort_ = false;
|
634
|
+
this.lastErrorCode_ = opt_failureCode || goog.net.ErrorCode.ABORT;
|
635
|
+
this.dispatchEvent(goog.net.EventType.COMPLETE);
|
636
|
+
this.dispatchEvent(goog.net.EventType.ABORT);
|
637
|
+
this.cleanUpXhr_();
|
638
|
+
}
|
639
|
+
};
|
640
|
+
|
641
|
+
|
642
|
+
/**
|
643
|
+
* Nullifies all callbacks to reduce risks of leaks.
|
644
|
+
* @override
|
645
|
+
* @protected
|
646
|
+
*/
|
647
|
+
goog.net.XhrIo.prototype.disposeInternal = function() {
|
648
|
+
if (this.xhr_) {
|
649
|
+
// We explicitly do not call xhr_.abort() unless active_ is still true.
|
650
|
+
// This is to avoid unnecessarily aborting a successful request when
|
651
|
+
// dispose() is called in a callback triggered by a complete response, but
|
652
|
+
// in which browser cleanup has not yet finished.
|
653
|
+
// (See http://b/issue?id=1684217.)
|
654
|
+
if (this.active_) {
|
655
|
+
this.active_ = false;
|
656
|
+
this.inAbort_ = true;
|
657
|
+
this.xhr_.abort();
|
658
|
+
this.inAbort_ = false;
|
659
|
+
}
|
660
|
+
this.cleanUpXhr_(true);
|
661
|
+
}
|
662
|
+
|
663
|
+
goog.net.XhrIo.superClass_.disposeInternal.call(this);
|
664
|
+
};
|
665
|
+
|
666
|
+
|
667
|
+
/**
|
668
|
+
* Internal handler for the XHR object's readystatechange event. This method
|
669
|
+
* checks the status and the readystate and fires the correct callbacks.
|
670
|
+
* If the request has ended, the handlers are cleaned up and the XHR object is
|
671
|
+
* nullified.
|
672
|
+
* @private
|
673
|
+
*/
|
674
|
+
goog.net.XhrIo.prototype.onReadyStateChange_ = function() {
|
675
|
+
if (!this.inOpen_ && !this.inSend_ && !this.inAbort_) {
|
676
|
+
// Were not being called from within a call to this.xhr_.send
|
677
|
+
// this.xhr_.abort, or this.xhr_.open, so this is an entry point
|
678
|
+
this.onReadyStateChangeEntryPoint_();
|
679
|
+
} else {
|
680
|
+
this.onReadyStateChangeHelper_();
|
681
|
+
}
|
682
|
+
};
|
683
|
+
|
684
|
+
|
685
|
+
/**
|
686
|
+
* Used to protect the onreadystatechange handler entry point. Necessary
|
687
|
+
* as {#onReadyStateChange_} maybe called from within send or abort, this
|
688
|
+
* method is only called when {#onReadyStateChange_} is called as an
|
689
|
+
* entry point.
|
690
|
+
* {@see #protectEntryPoints}
|
691
|
+
* @private
|
692
|
+
*/
|
693
|
+
goog.net.XhrIo.prototype.onReadyStateChangeEntryPoint_ = function() {
|
694
|
+
this.onReadyStateChangeHelper_();
|
695
|
+
};
|
696
|
+
|
697
|
+
|
698
|
+
/**
|
699
|
+
* Helper for {@link #onReadyStateChange_}. This is used so that
|
700
|
+
* entry point calls to {@link #onReadyStateChange_} can be routed through
|
701
|
+
* {@link #onReadyStateChangeEntryPoint_}.
|
702
|
+
* @private
|
703
|
+
*/
|
704
|
+
goog.net.XhrIo.prototype.onReadyStateChangeHelper_ = function() {
|
705
|
+
if (!this.active_) {
|
706
|
+
// can get called inside abort call
|
707
|
+
return;
|
708
|
+
}
|
709
|
+
|
710
|
+
if (typeof goog == 'undefined') {
|
711
|
+
// NOTE(user): If goog is undefined then the callback has occurred as the
|
712
|
+
// application is unloading and will error. Thus we let it silently fail.
|
713
|
+
|
714
|
+
} else if (
|
715
|
+
this.xhrOptions_[goog.net.XmlHttp.OptionType.LOCAL_REQUEST_ERROR] &&
|
716
|
+
this.getReadyState() == goog.net.XmlHttp.ReadyState.COMPLETE &&
|
717
|
+
this.getStatus() == 2) {
|
718
|
+
// NOTE(user): In IE if send() errors on a *local* request the readystate
|
719
|
+
// is still changed to COMPLETE. We need to ignore it and allow the
|
720
|
+
// try/catch around send() to pick up the error.
|
721
|
+
this.logger_.fine(this.formatMsg_(
|
722
|
+
'Local request error detected and ignored'));
|
723
|
+
|
724
|
+
} else {
|
725
|
+
|
726
|
+
// In IE when the response has been cached we sometimes get the callback
|
727
|
+
// from inside the send call and this usually breaks code that assumes that
|
728
|
+
// XhrIo is asynchronous. If that is the case we delay the callback
|
729
|
+
// using a timer.
|
730
|
+
if (this.inSend_ &&
|
731
|
+
this.getReadyState() == goog.net.XmlHttp.ReadyState.COMPLETE) {
|
732
|
+
goog.Timer.defaultTimerObject.setTimeout(
|
733
|
+
goog.bind(this.onReadyStateChange_, this), 0);
|
734
|
+
return;
|
735
|
+
}
|
736
|
+
|
737
|
+
this.dispatchEvent(goog.net.EventType.READY_STATE_CHANGE);
|
738
|
+
|
739
|
+
// readyState indicates the transfer has finished
|
740
|
+
if (this.isComplete()) {
|
741
|
+
this.logger_.fine(this.formatMsg_('Request complete'));
|
742
|
+
|
743
|
+
this.active_ = false;
|
744
|
+
|
745
|
+
// Call the specific callbacks for success or failure. Only call the
|
746
|
+
// success if the status is 200 (HTTP_OK) or 304 (HTTP_CACHED)
|
747
|
+
if (this.isSuccess()) {
|
748
|
+
this.dispatchEvent(goog.net.EventType.COMPLETE);
|
749
|
+
this.dispatchEvent(goog.net.EventType.SUCCESS);
|
750
|
+
} else {
|
751
|
+
this.lastErrorCode_ = goog.net.ErrorCode.HTTP_ERROR;
|
752
|
+
this.lastError_ = this.getStatusText() + ' [' + this.getStatus() + ']';
|
753
|
+
this.dispatchErrors_();
|
754
|
+
}
|
755
|
+
|
756
|
+
this.cleanUpXhr_();
|
757
|
+
}
|
758
|
+
}
|
759
|
+
};
|
760
|
+
|
761
|
+
|
762
|
+
/**
|
763
|
+
* Remove the listener to protect against leaks, and nullify the XMLHttpRequest
|
764
|
+
* object.
|
765
|
+
* @param {boolean=} opt_fromDispose If this is from the dispose (don't want to
|
766
|
+
* fire any events).
|
767
|
+
* @private
|
768
|
+
*/
|
769
|
+
goog.net.XhrIo.prototype.cleanUpXhr_ = function(opt_fromDispose) {
|
770
|
+
if (this.xhr_) {
|
771
|
+
// Save reference so we can mark it as closed after the READY event. The
|
772
|
+
// READY event may trigger another request, thus we must nullify this.xhr_
|
773
|
+
var xhr = this.xhr_;
|
774
|
+
var clearedOnReadyStateChange =
|
775
|
+
this.xhrOptions_[goog.net.XmlHttp.OptionType.USE_NULL_FUNCTION] ?
|
776
|
+
goog.nullFunction : null;
|
777
|
+
this.xhr_ = null;
|
778
|
+
this.xhrOptions_ = null;
|
779
|
+
|
780
|
+
if (this.timeoutId_) {
|
781
|
+
// Cancel any pending timeout event handler.
|
782
|
+
goog.Timer.defaultTimerObject.clearTimeout(this.timeoutId_);
|
783
|
+
this.timeoutId_ = null;
|
784
|
+
}
|
785
|
+
|
786
|
+
if (!opt_fromDispose) {
|
787
|
+
this.dispatchEvent(goog.net.EventType.READY);
|
788
|
+
}
|
789
|
+
|
790
|
+
try {
|
791
|
+
// NOTE(user): Not nullifying in FireFox can still leak if the callbacks
|
792
|
+
// are defined in the same scope as the instance of XhrIo. But, IE doesn't
|
793
|
+
// allow you to set the onreadystatechange to NULL so nullFunction is
|
794
|
+
// used.
|
795
|
+
xhr.onreadystatechange = clearedOnReadyStateChange;
|
796
|
+
} catch (e) {
|
797
|
+
// This seems to occur with a Gears HTTP request. Delayed the setting of
|
798
|
+
// this onreadystatechange until after READY is sent out and catching the
|
799
|
+
// error to see if we can track down the problem.
|
800
|
+
this.logger_.severe('Problem encountered resetting onreadystatechange: ' +
|
801
|
+
e.message);
|
802
|
+
}
|
803
|
+
}
|
804
|
+
};
|
805
|
+
|
806
|
+
|
807
|
+
/**
|
808
|
+
* @return {boolean} Whether there is an active request.
|
809
|
+
*/
|
810
|
+
goog.net.XhrIo.prototype.isActive = function() {
|
811
|
+
return !!this.xhr_;
|
812
|
+
};
|
813
|
+
|
814
|
+
|
815
|
+
/**
|
816
|
+
* @return {boolean} Whether the request has completed.
|
817
|
+
*/
|
818
|
+
goog.net.XhrIo.prototype.isComplete = function() {
|
819
|
+
return this.getReadyState() == goog.net.XmlHttp.ReadyState.COMPLETE;
|
820
|
+
};
|
821
|
+
|
822
|
+
|
823
|
+
/**
|
824
|
+
* @return {boolean} Whether the request completed with a success.
|
825
|
+
*/
|
826
|
+
goog.net.XhrIo.prototype.isSuccess = function() {
|
827
|
+
var status = this.getStatus();
|
828
|
+
// A zero status code is considered successful for local files.
|
829
|
+
return goog.net.HttpStatus.isSuccess(status) ||
|
830
|
+
status === 0 && !this.isLastUriEffectiveSchemeHttp_();
|
831
|
+
};
|
832
|
+
|
833
|
+
|
834
|
+
/**
|
835
|
+
* @return {boolean} whether the effective scheme of the last URI that was
|
836
|
+
* fetched was 'http' or 'https'.
|
837
|
+
* @private
|
838
|
+
*/
|
839
|
+
goog.net.XhrIo.prototype.isLastUriEffectiveSchemeHttp_ = function() {
|
840
|
+
var scheme = goog.uri.utils.getEffectiveScheme(String(this.lastUri_));
|
841
|
+
return goog.net.XhrIo.HTTP_SCHEME_PATTERN.test(scheme);
|
842
|
+
};
|
843
|
+
|
844
|
+
|
845
|
+
/**
|
846
|
+
* Get the readystate from the Xhr object
|
847
|
+
* Will only return correct result when called from the context of a callback
|
848
|
+
* @return {goog.net.XmlHttp.ReadyState} goog.net.XmlHttp.ReadyState.*.
|
849
|
+
*/
|
850
|
+
goog.net.XhrIo.prototype.getReadyState = function() {
|
851
|
+
return this.xhr_ ?
|
852
|
+
/** @type {goog.net.XmlHttp.ReadyState} */ (this.xhr_.readyState) :
|
853
|
+
goog.net.XmlHttp.ReadyState.UNINITIALIZED;
|
854
|
+
};
|
855
|
+
|
856
|
+
|
857
|
+
/**
|
858
|
+
* Get the status from the Xhr object
|
859
|
+
* Will only return correct result when called from the context of a callback
|
860
|
+
* @return {number} Http status.
|
861
|
+
*/
|
862
|
+
goog.net.XhrIo.prototype.getStatus = function() {
|
863
|
+
/**
|
864
|
+
* IE doesn't like you checking status until the readystate is greater than 2
|
865
|
+
* (i.e. it is recieving or complete). The try/catch is used for when the
|
866
|
+
* page is unloading and an ERROR_NOT_AVAILABLE may occur when accessing xhr_.
|
867
|
+
* @preserveTry
|
868
|
+
*/
|
869
|
+
try {
|
870
|
+
return this.getReadyState() > goog.net.XmlHttp.ReadyState.LOADED ?
|
871
|
+
this.xhr_.status : -1;
|
872
|
+
} catch (e) {
|
873
|
+
this.logger_.warning('Can not get status: ' + e.message);
|
874
|
+
return -1;
|
875
|
+
}
|
876
|
+
};
|
877
|
+
|
878
|
+
|
879
|
+
/**
|
880
|
+
* Get the status text from the Xhr object
|
881
|
+
* Will only return correct result when called from the context of a callback
|
882
|
+
* @return {string} Status text.
|
883
|
+
*/
|
884
|
+
goog.net.XhrIo.prototype.getStatusText = function() {
|
885
|
+
/**
|
886
|
+
* IE doesn't like you checking status until the readystate is greater than 2
|
887
|
+
* (i.e. it is recieving or complete). The try/catch is used for when the
|
888
|
+
* page is unloading and an ERROR_NOT_AVAILABLE may occur when accessing xhr_.
|
889
|
+
* @preserveTry
|
890
|
+
*/
|
891
|
+
try {
|
892
|
+
return this.getReadyState() > goog.net.XmlHttp.ReadyState.LOADED ?
|
893
|
+
this.xhr_.statusText : '';
|
894
|
+
} catch (e) {
|
895
|
+
this.logger_.fine('Can not get status: ' + e.message);
|
896
|
+
return '';
|
897
|
+
}
|
898
|
+
};
|
899
|
+
|
900
|
+
|
901
|
+
/**
|
902
|
+
* Get the last Uri that was requested
|
903
|
+
* @return {string} Last Uri.
|
904
|
+
*/
|
905
|
+
goog.net.XhrIo.prototype.getLastUri = function() {
|
906
|
+
return String(this.lastUri_);
|
907
|
+
};
|
908
|
+
|
909
|
+
|
910
|
+
/**
|
911
|
+
* Get the response text from the Xhr object
|
912
|
+
* Will only return correct result when called from the context of a callback.
|
913
|
+
* @return {string} Result from the server, or '' if no result available.
|
914
|
+
*/
|
915
|
+
goog.net.XhrIo.prototype.getResponseText = function() {
|
916
|
+
/** @preserveTry */
|
917
|
+
try {
|
918
|
+
return this.xhr_ ? this.xhr_.responseText : '';
|
919
|
+
} catch (e) {
|
920
|
+
// http://www.w3.org/TR/XMLHttpRequest/#the-responsetext-attribute
|
921
|
+
// states that responseText should return '' (and responseXML null)
|
922
|
+
// when the state is not LOADING or DONE. Instead, IE and Gears can
|
923
|
+
// throw unexpected exceptions, eg, when a request is aborted or no
|
924
|
+
// data is available yet.
|
925
|
+
this.logger_.fine('Can not get responseText: ' + e.message);
|
926
|
+
return '';
|
927
|
+
}
|
928
|
+
};
|
929
|
+
|
930
|
+
|
931
|
+
/**
|
932
|
+
* Get the response XML from the Xhr object
|
933
|
+
* Will only return correct result when called from the context of a callback.
|
934
|
+
* @return {Document} The DOM Document representing the XML file, or null
|
935
|
+
* if no result available.
|
936
|
+
*/
|
937
|
+
goog.net.XhrIo.prototype.getResponseXml = function() {
|
938
|
+
/** @preserveTry */
|
939
|
+
try {
|
940
|
+
return this.xhr_ ? this.xhr_.responseXML : null;
|
941
|
+
} catch (e) {
|
942
|
+
this.logger_.fine('Can not get responseXML: ' + e.message);
|
943
|
+
return null;
|
944
|
+
}
|
945
|
+
};
|
946
|
+
|
947
|
+
|
948
|
+
/**
|
949
|
+
* Get the response and evaluates it as JSON from the Xhr object
|
950
|
+
* Will only return correct result when called from the context of a callback
|
951
|
+
* @param {string=} opt_xssiPrefix Optional XSSI prefix string to use for
|
952
|
+
* stripping of the response before parsing. This needs to be set only if
|
953
|
+
* your backend server prepends the same prefix string to the JSON response.
|
954
|
+
* @return {Object|undefined} JavaScript object.
|
955
|
+
*/
|
956
|
+
goog.net.XhrIo.prototype.getResponseJson = function(opt_xssiPrefix) {
|
957
|
+
if (!this.xhr_) {
|
958
|
+
return undefined;
|
959
|
+
}
|
960
|
+
|
961
|
+
var responseText = this.xhr_.responseText;
|
962
|
+
if (opt_xssiPrefix && responseText.indexOf(opt_xssiPrefix) == 0) {
|
963
|
+
responseText = responseText.substring(opt_xssiPrefix.length);
|
964
|
+
}
|
965
|
+
|
966
|
+
return goog.json.parse(responseText);
|
967
|
+
};
|
968
|
+
|
969
|
+
|
970
|
+
/**
|
971
|
+
* Get the response as the type specificed by {@link #setResponseType}. At time
|
972
|
+
* of writing, this is only directly supported in very recent versions of WebKit
|
973
|
+
* (10.0.612.1 dev and later). If the field is not supported directly, we will
|
974
|
+
* try to emulate it.
|
975
|
+
*
|
976
|
+
* Emulating the response means following the rules laid out at
|
977
|
+
* http://dev.w3.org/2006/webapi/XMLHttpRequest-2/#the-response-attribute.
|
978
|
+
*
|
979
|
+
* On browsers with no support for this (Chrome < 10, Firefox < 4, etc), only
|
980
|
+
* response types of DEFAULT or TEXT may be used, and the response returned will
|
981
|
+
* be the text response.
|
982
|
+
*
|
983
|
+
* On browsers with Mozilla's draft support for array buffers (Firefox 4, 5),
|
984
|
+
* only response types of DEFAULT, TEXT, and ARRAY_BUFFER may be used, and the
|
985
|
+
* response returned will be either the text response or the Mozilla
|
986
|
+
* implementation of the array buffer response.
|
987
|
+
*
|
988
|
+
* On browsers will full support, any valid response type supported by the
|
989
|
+
* browser may be used, and the response provided by the browser will be
|
990
|
+
* returned.
|
991
|
+
*
|
992
|
+
* @return {*} The response.
|
993
|
+
*/
|
994
|
+
goog.net.XhrIo.prototype.getResponse = function() {
|
995
|
+
/** @preserveTry */
|
996
|
+
try {
|
997
|
+
if (!this.xhr_) {
|
998
|
+
return null;
|
999
|
+
}
|
1000
|
+
if ('response' in this.xhr_) {
|
1001
|
+
return this.xhr_.response;
|
1002
|
+
}
|
1003
|
+
switch (this.responseType_) {
|
1004
|
+
case goog.net.XhrIo.ResponseType.DEFAULT:
|
1005
|
+
case goog.net.XhrIo.ResponseType.TEXT:
|
1006
|
+
return this.xhr_.responseText;
|
1007
|
+
// DOCUMENT and BLOB don't need to be handled here because they are
|
1008
|
+
// introduced in the same spec that adds the .response field, and would
|
1009
|
+
// have been caught above.
|
1010
|
+
// ARRAY_BUFFER needs an implementation for Firefox 4, where it was
|
1011
|
+
// implemented using a draft spec rather than the final spec.
|
1012
|
+
case goog.net.XhrIo.ResponseType.ARRAY_BUFFER:
|
1013
|
+
if ('mozResponseArrayBuffer' in this.xhr_) {
|
1014
|
+
return this.xhr_.mozResponseArrayBuffer;
|
1015
|
+
}
|
1016
|
+
}
|
1017
|
+
// Fell through to a response type that is not supported on this browser.
|
1018
|
+
this.logger_.severe('Response type ' + this.responseType_ + ' is not ' +
|
1019
|
+
'supported on this browser');
|
1020
|
+
return null;
|
1021
|
+
} catch (e) {
|
1022
|
+
this.logger_.fine('Can not get response: ' + e.message);
|
1023
|
+
return null;
|
1024
|
+
}
|
1025
|
+
};
|
1026
|
+
|
1027
|
+
|
1028
|
+
/**
|
1029
|
+
* Get the value of the response-header with the given name from the Xhr object
|
1030
|
+
* Will only return correct result when called from the context of a callback
|
1031
|
+
* and the request has completed
|
1032
|
+
* @param {string} key The name of the response-header to retrieve.
|
1033
|
+
* @return {string|undefined} The value of the response-header named key.
|
1034
|
+
*/
|
1035
|
+
goog.net.XhrIo.prototype.getResponseHeader = function(key) {
|
1036
|
+
return this.xhr_ && this.isComplete() ?
|
1037
|
+
this.xhr_.getResponseHeader(key) : undefined;
|
1038
|
+
};
|
1039
|
+
|
1040
|
+
|
1041
|
+
/**
|
1042
|
+
* Gets the text of all the headers in the response.
|
1043
|
+
* Will only return correct result when called from the context of a callback
|
1044
|
+
* and the request has completed.
|
1045
|
+
* @return {string} The value of the response headers or empty string.
|
1046
|
+
*/
|
1047
|
+
goog.net.XhrIo.prototype.getAllResponseHeaders = function() {
|
1048
|
+
return this.xhr_ && this.isComplete() ?
|
1049
|
+
this.xhr_.getAllResponseHeaders() : '';
|
1050
|
+
};
|
1051
|
+
|
1052
|
+
|
1053
|
+
/**
|
1054
|
+
* Get the last error message
|
1055
|
+
* @return {goog.net.ErrorCode} Last error code.
|
1056
|
+
*/
|
1057
|
+
goog.net.XhrIo.prototype.getLastErrorCode = function() {
|
1058
|
+
return this.lastErrorCode_;
|
1059
|
+
};
|
1060
|
+
|
1061
|
+
|
1062
|
+
/**
|
1063
|
+
* Get the last error message
|
1064
|
+
* @return {string} Last error message.
|
1065
|
+
*/
|
1066
|
+
goog.net.XhrIo.prototype.getLastError = function() {
|
1067
|
+
return goog.isString(this.lastError_) ? this.lastError_ :
|
1068
|
+
String(this.lastError_);
|
1069
|
+
};
|
1070
|
+
|
1071
|
+
|
1072
|
+
/**
|
1073
|
+
* Adds the last method, status and URI to the message. This is used to add
|
1074
|
+
* this information to the logging calls.
|
1075
|
+
* @param {string} msg The message text that we want to add the extra text to.
|
1076
|
+
* @return {string} The message with the extra text appended.
|
1077
|
+
* @private
|
1078
|
+
*/
|
1079
|
+
goog.net.XhrIo.prototype.formatMsg_ = function(msg) {
|
1080
|
+
return msg + ' [' + this.lastMethod_ + ' ' + this.lastUri_ + ' ' +
|
1081
|
+
this.getStatus() + ']';
|
1082
|
+
};
|
1083
|
+
|
1084
|
+
|
1085
|
+
// Register the xhr handler as an entry point, so that
|
1086
|
+
// it can be monitored for exception handling, etc.
|
1087
|
+
goog.debug.entryPointRegistry.register(
|
1088
|
+
/**
|
1089
|
+
* @param {function(!Function): !Function} transformer The transforming
|
1090
|
+
* function.
|
1091
|
+
*/
|
1092
|
+
function(transformer) {
|
1093
|
+
goog.net.XhrIo.prototype.onReadyStateChangeEntryPoint_ =
|
1094
|
+
transformer(goog.net.XhrIo.prototype.onReadyStateChangeEntryPoint_);
|
1095
|
+
});
|
1096
|
+
;
|
1097
|
+
FI"asset_paths;
|
1098
|
+
F["k/Volumes/Development/dev-web/yellow-brick-road/vendor/assets/closure-library/closure/goog/net/xhrio.jsI"dependency_paths;
|
1099
|
+
F[{I" path;
|
1100
|
+
F"k/Volumes/Development/dev-web/yellow-brick-road/vendor/assets/closure-library/closure/goog/net/xhrio.jsI"
|
1101
|
+
mtime;
|
1102
|
+
FIu: Time
|
1103
|
+
T:offsetiI"hexdigest;
|
1104
|
+
F"%bb57ef1eea28685ed28a6ab9d90f2cbaI"
|
1105
|
+
F"%46dde6621c301f4928e3b34efee9e3b5
|