瀏覽代碼

Merge pull request #1293 from hamiltont/fix-symfony2

PHP: Fix symfony2
Hamilton Turner 10 年之前
父節點
當前提交
4f9ba9fba0
共有 100 個文件被更改,包括 177 次插入4229 次删除
  1. 49 0
      .mailmap
  2. 3 9
      .travis.yml
  3. 0 0
      frameworks/C++/ULib/__init__.py
  4. 0 0
      frameworks/C++/cpoll_cppsp/__init__.py
  5. 0 0
      frameworks/C++/treefrog/__init__.py
  6. 0 0
      frameworks/C++/wt/__init__.py
  7. 0 0
      frameworks/C/duda/__init__.py
  8. 0 0
      frameworks/C/onion/__init__.py
  9. 0 0
      frameworks/CSharp/HttpListener/__init__.py
  10. 0 0
      frameworks/CSharp/aspnet-stripped/__init__.py
  11. 0 0
      frameworks/CSharp/aspnet/__init__.py
  12. 0 0
      frameworks/CSharp/evhttp-sharp/__init__.py
  13. 0 0
      frameworks/CSharp/nancy/__init__.py
  14. 0 0
      frameworks/CSharp/servicestack/__init__.py
  15. 0 0
      frameworks/Clojure/compojure/__init__.py
  16. 0 0
      frameworks/Clojure/http-kit/__init__.py
  17. 0 0
      frameworks/Clojure/luminus/__init__.py
  18. 0 0
      frameworks/Dart/dart-redstone/__init__.py
  19. 0 0
      frameworks/Dart/dart-start/__init__.py
  20. 0 0
      frameworks/Dart/dart-stream/__init__.py
  21. 0 0
      frameworks/Dart/dart/__init__.py
  22. 0 0
      frameworks/Elixir/WeberFramework/__init__.py
  23. 0 0
      frameworks/Go/beego/__init__.py
  24. 0 0
      frameworks/Go/falcore/__init__.py
  25. 0 0
      frameworks/Go/gin/__init__.py
  26. 0 0
      frameworks/Go/go/__init__.py
  27. 0 0
      frameworks/Go/gorail/__init__.py
  28. 0 0
      frameworks/Go/revel-jet/__init__.py
  29. 0 0
      frameworks/Go/revel-qbs/__init__.py
  30. 0 0
      frameworks/Go/revel/__init__.py
  31. 0 0
      frameworks/Go/webgo/__init__.py
  32. 0 0
      frameworks/Groovy/grails/__init__.py
  33. 0 0
      frameworks/Haskell/snap/__init__.py
  34. 0 0
      frameworks/Haskell/wai/__init__.py
  35. 0 0
      frameworks/Haskell/yesod/__init__.py
  36. 0 0
      frameworks/Java/activeweb/__init__.py
  37. 0 0
      frameworks/Java/curacao/__init__.py
  38. 0 0
      frameworks/Java/dropwizard-mongodb/__init__.py
  39. 0 0
      frameworks/Java/dropwizard/__init__.py
  40. 0 0
      frameworks/Java/gemini/__init__.py
  41. 0 0
      frameworks/Java/grizzly-bm/__init__.py
  42. 0 0
      frameworks/Java/grizzly-jersey/__init__.py
  43. 0 0
      frameworks/Java/jetty-servlet/__init__.py
  44. 0 0
      frameworks/Java/netty/__init__.py
  45. 0 0
      frameworks/Java/ninja-standalone/__init__.py
  46. 0 0
      frameworks/Java/play1/__init__.py
  47. 0 0
      frameworks/Java/play1siena/__init__.py
  48. 0 0
      frameworks/Java/play2-java/__init__.py
  49. 0 0
      frameworks/Java/restexpress/__init__.py
  50. 0 0
      frameworks/Java/servlet/__init__.py
  51. 0 0
      frameworks/Java/servlet3-cass/__init__.py
  52. 0 0
      frameworks/Java/spark/__init__.py
  53. 0 0
      frameworks/Java/spring/__init__.py
  54. 0 0
      frameworks/Java/tapestry/__init__.py
  55. 0 0
      frameworks/Java/undertow-edge/__init__.py
  56. 0 0
      frameworks/Java/undertow/__init__.py
  57. 0 0
      frameworks/Java/vertx/__init__.py
  58. 0 0
      frameworks/Java/wicket/__init__.py
  59. 0 0
      frameworks/Java/wildfly-ee7/__init__.py
  60. 0 0
      frameworks/JavaScript/express/__init__.py
  61. 0 0
      frameworks/JavaScript/hapi/__init__.py
  62. 0 0
      frameworks/JavaScript/nodejs/__init__.py
  63. 0 0
      frameworks/JavaScript/ringojs-convenient/__init__.py
  64. 0 0
      frameworks/JavaScript/ringojs/__init__.py
  65. 0 0
      frameworks/Lua/lapis/__init__.py
  66. 0 0
      frameworks/Lua/openresty/__init__.py
  67. 0 0
      frameworks/Nimrod/jester/__init__.py
  68. 0 0
      frameworks/Nimrod/nawak/__init__.py
  69. 125 48
      frameworks/PHP/README.md
  70. 0 0
      frameworks/PHP/Yii2/__init__.py
  71. 0 0
      frameworks/PHP/cakephp/__init__.py
  72. 0 0
      frameworks/PHP/codeigniter/__init__.py
  73. 0 0
      frameworks/PHP/hhvm/__init__.py
  74. 0 0
      frameworks/PHP/kohana/__init__.py
  75. 0 0
      frameworks/PHP/lithium/__init__.py
  76. 0 0
      frameworks/PHP/php-fatfree/__init__.py
  77. 0 0
      frameworks/PHP/php-laravel/__init__.py
  78. 0 0
      frameworks/PHP/php-micromvc/__init__.py
  79. 0 0
      frameworks/PHP/php-phalcon-micro/__init__.py
  80. 0 0
      frameworks/PHP/php-phalcon/__init__.py
  81. 0 0
      frameworks/PHP/php-phpixie/__init__.py
  82. 0 0
      frameworks/PHP/php-pimf/__init__.py
  83. 0 0
      frameworks/PHP/php-silex-orm/__init__.py
  84. 0 0
      frameworks/PHP/php-silex/__init__.py
  85. 0 0
      frameworks/PHP/php-silica/__init__.py
  86. 0 0
      frameworks/PHP/php-slim/__init__.py
  87. 0 10
      frameworks/PHP/php-symfony2-stripped/.travis.yml
  88. 0 0
      frameworks/PHP/php-symfony2-stripped/__init__.py
  89. 0 2961
      frameworks/PHP/php-symfony2-stripped/app/bootstrap.php.cache
  90. 0 9
      frameworks/PHP/php-symfony2-stripped/bash_profile.sh
  91. 0 24
      frameworks/PHP/php-symfony2-stripped/composer.json
  92. 0 3
      frameworks/PHP/php-symfony2-stripped/install.sh
  93. 0 7
      frameworks/PHP/php-symfony2-stripped/src/Skamander/BenchmarkBundle/Resources/views/Bench/raw/content.php
  94. 0 9
      frameworks/PHP/php-symfony2-stripped/src/Skamander/BenchmarkBundle/Resources/views/layout.html.php
  95. 0 10
      frameworks/PHP/php-symfony2/.travis.yml
  96. 0 0
      frameworks/PHP/php-symfony2/__init__.py
  97. 0 1136
      frameworks/PHP/php-symfony2/app/bootstrap.php.cache
  98. 0 3
      frameworks/PHP/php-symfony2/install.sh
  99. 0 0
      frameworks/PHP/php-yaf/__init__.py
  100. 0 0
      frameworks/PHP/php-zend-framework/__init__.py

+ 49 - 0
.mailmap

@@ -0,0 +1,49 @@
+Adam Chlipala <[email protected]> <[email protected]>
+
+Alex Schneider <[email protected]> <aschneider@techempower> Alexander Schneider
+Alex Schneider <[email protected]> Alexander Schneider <[email protected]>
+
+Christian Knuth <[email protected]> <[email protected]>
+
+Donovan Muller <[email protected]> donovanmuller <[email protected]>
+
+Eduardo Silva <[email protected]> <[email protected]>
+
+Gerard Roche <[email protected]> <[email protected]>
+
+Gjero Krsteski <[email protected]> gjerokrsteski <[email protected]> 
+Gjero Krsteski <[email protected]> g.krsteski <[email protected]>
+
+INADA Naoki <[email protected]> <[email protected]> 
+INADA Naoki <[email protected]> <[email protected]>
+
+James Yen <[email protected]> jyentechempower <[email protected]>
+
+Karol Buček <[email protected]> kares <[email protected]> 
+
+Lari Hotari <[email protected]> <[email protected]>
+
+Leandro Pereira <[email protected]> <[email protected]>
+
+Luis Neves <[email protected]> Luis Filipe dos Santos Neves <[email protected]>
+Luis Neves <[email protected]> luis.neves <[email protected]>
+
+Luiz Mineo <[email protected]> <[email protected]>
+
+Marko Asplund <[email protected]> marko asplund <[email protected]>
+Marko Asplund <[email protected]> marko asplund <[email protected]>
+
+Matic Žgur <[email protected]> <[email protected]>
+
+mcocciaTE <[email protected]> mcoccia <[email protected]>
+
+Raphael Andre Bauer <[email protected]> reyez <[email protected]>
+
+Stefan Geneshky <[email protected]> Stefan G <[email protected]>
+
+Stefano Casazza <[email protected]> stefanocasazza <[email protected]>
+
+Skamander <[email protected]> sksamuel <[email protected]>
+
+Tim Fox <[email protected]> purplefox <[email protected]>
+

+ 3 - 9
.travis.yml

@@ -107,8 +107,8 @@ env:
     - "TESTDIR=PHP/php-silex-orm"
     - "TESTDIR=PHP/php-silica"
     - "TESTDIR=PHP/php-slim"
-    - "TESTDIR=PHP/php-symfony2"
-    - "TESTDIR=PHP/php-symfony2-stripped"
+    - "TESTDIR=PHP/symfony2"
+    - "TESTDIR=PHP/symfony2-stripped"
     - "TESTDIR=PHP/php-yaf"
     - "TESTDIR=PHP/Yii2"
     - "TESTDIR=PHP/php-zend-framework"
@@ -163,10 +163,4 @@ install:
 script: 
   # Pick one test in this directory and verify
   - time ./toolset/run-ci.py verify "$TESTDIR"
-
-cache:
-  directories:
-    - installs/mono-3.2.8
-    - installs/py2
-    - installs/py3
-    - installs/perl-5.18
+  

+ 0 - 0
frameworks/C++/ULib/__init__.py


+ 0 - 0
frameworks/C++/cpoll_cppsp/__init__.py


+ 0 - 0
frameworks/C++/treefrog/__init__.py


+ 0 - 0
frameworks/C++/wt/__init__.py


+ 0 - 0
frameworks/C/duda/__init__.py


+ 0 - 0
frameworks/C/onion/__init__.py


+ 0 - 0
frameworks/CSharp/HttpListener/__init__.py


+ 0 - 0
frameworks/CSharp/aspnet-stripped/__init__.py


+ 0 - 0
frameworks/CSharp/aspnet/__init__.py


+ 0 - 0
frameworks/CSharp/evhttp-sharp/__init__.py


+ 0 - 0
frameworks/CSharp/nancy/__init__.py


+ 0 - 0
frameworks/CSharp/servicestack/__init__.py


+ 0 - 0
frameworks/Clojure/compojure/__init__.py


+ 0 - 0
frameworks/Clojure/http-kit/__init__.py


+ 0 - 0
frameworks/Clojure/luminus/__init__.py


+ 0 - 0
frameworks/Dart/dart-redstone/__init__.py


+ 0 - 0
frameworks/Dart/dart-start/__init__.py


+ 0 - 0
frameworks/Dart/dart-stream/__init__.py


+ 0 - 0
frameworks/Dart/dart/__init__.py


+ 0 - 0
frameworks/Elixir/WeberFramework/__init__.py


+ 0 - 0
frameworks/Go/beego/__init__.py


+ 0 - 0
frameworks/Go/falcore/__init__.py


+ 0 - 0
frameworks/Go/gin/__init__.py


+ 0 - 0
frameworks/Go/go/__init__.py


+ 0 - 0
frameworks/Go/gorail/__init__.py


+ 0 - 0
frameworks/Go/revel-jet/__init__.py


+ 0 - 0
frameworks/Go/revel-qbs/__init__.py


+ 0 - 0
frameworks/Go/revel/__init__.py


+ 0 - 0
frameworks/Go/webgo/__init__.py


+ 0 - 0
frameworks/Groovy/grails/__init__.py


+ 0 - 0
frameworks/Haskell/snap/__init__.py


+ 0 - 0
frameworks/Haskell/wai/__init__.py


+ 0 - 0
frameworks/Haskell/yesod/__init__.py


+ 0 - 0
frameworks/Java/activeweb/__init__.py


+ 0 - 0
frameworks/Java/curacao/__init__.py


+ 0 - 0
frameworks/Java/dropwizard-mongodb/__init__.py


+ 0 - 0
frameworks/Java/dropwizard/__init__.py


+ 0 - 0
frameworks/Java/gemini/__init__.py


+ 0 - 0
frameworks/Java/grizzly-bm/__init__.py


+ 0 - 0
frameworks/Java/grizzly-jersey/__init__.py


+ 0 - 0
frameworks/Java/jetty-servlet/__init__.py


+ 0 - 0
frameworks/Java/netty/__init__.py


+ 0 - 0
frameworks/Java/ninja-standalone/__init__.py


+ 0 - 0
frameworks/Java/play1/__init__.py


+ 0 - 0
frameworks/Java/play1siena/__init__.py


+ 0 - 0
frameworks/Java/play2-java/__init__.py


+ 0 - 0
frameworks/Java/restexpress/__init__.py


+ 0 - 0
frameworks/Java/servlet/__init__.py


+ 0 - 0
frameworks/Java/servlet3-cass/__init__.py


+ 0 - 0
frameworks/Java/spark/__init__.py


+ 0 - 0
frameworks/Java/spring/__init__.py


+ 0 - 0
frameworks/Java/tapestry/__init__.py


+ 0 - 0
frameworks/Java/undertow-edge/__init__.py


+ 0 - 0
frameworks/Java/undertow/__init__.py


+ 0 - 0
frameworks/Java/vertx/__init__.py


+ 0 - 0
frameworks/Java/wicket/__init__.py


+ 0 - 0
frameworks/Java/wildfly-ee7/__init__.py


+ 0 - 0
frameworks/JavaScript/express/__init__.py


+ 0 - 0
frameworks/JavaScript/hapi/__init__.py


+ 0 - 0
frameworks/JavaScript/nodejs/__init__.py


+ 0 - 0
frameworks/JavaScript/ringojs-convenient/__init__.py


+ 0 - 0
frameworks/JavaScript/ringojs/__init__.py


+ 0 - 0
frameworks/Lua/lapis/__init__.py


+ 0 - 0
frameworks/Lua/openresty/__init__.py


+ 0 - 0
frameworks/Nimrod/jester/__init__.py


+ 0 - 0
frameworks/Nimrod/nawak/__init__.py


+ 125 - 48
frameworks/PHP/README.md

@@ -1,19 +1,100 @@
-# Tricks to writing PHP-based Frameworks
-
-Many servers use the `php`, `php-fpm`, or other binaries. If your
-server launches with `sudo` (e.g. `sudo php-fpm`) then you should be 
-aware that using sudo resets the `$PATH` environment variable, and your 
-specific binary may not be the one being used. The solution is to 
-always use `sudo <full-path-to-my-binary>`. For example, `cakephp`'s
-`bash_profile.sh` sets the variable `$PHP_FPM` to be the full path 
-to the `php-fpm` binary that `cakephp` wants, and then uses `sudo $PHP_FPM`
-to ensure that the `php-fpm` binary used by sudo is the exact binary 
-desired. 
+# PHP Version
+
+[Currently this toolset runs PHP 5.5.17](https://github.com/TechEmpower/FrameworkBenchmarks/blob/master/toolset/setup/linux/languages/php.sh). At the moment all PHP-based frameworks use the 
+same PHP version, but we are open to receiving a pull request
+that enables supporting multiple versions. 
+
+# PHP Acceleration and Caching
+
+Caching the output of the PHP bytecode compiler is expressly 
+allowed by this benchmark. As we use PHP 5.5, which comes 
+with opcache built in, we recommend you use this. However, 
+some frameworks utilize APC instead as switching can be 
+problematic (e.g. APC allows arbitrary data caching, while 
+opcache). 
+
+Caching the output of parsing your configuration files is 
+also expressly allowed (e.g. file caching, metadata caching).
+Some frameworks use APCu or memcached to achieve this. 
+
+Caching of the classloader (often referred to as optimizing
+the classloader) is also allowed. Most frameworks have their 
+own methods of doing this. 
+
+*Caching of any data fetched from the database is not allowed*. 
+Specifically, things such as [Doctrine's Result Cache](http://doctrine-orm.readthedocs.org/en/latest/reference/caching.html#result-cache) are inadmissible. 
+
+However, if you are using an ORM that prepares SQL 
+statements in some way, such as how 
+[Doctrine](http://doctrine-orm.readthedocs.org/en/latest/reference/caching.html#query-cache) 
+translates DQL into SQL, this translated form can be 
+cached, as long as you are dynamically accepting 
+query parameters. 
+
+Caching any data using databases (Redis, MongoDB, etc) 
+is discouraged, as 1) our databases run on a separate 
+computer across the network, so you won't see much 
+benefit 2) your usage of the DB *may* impact other 
+framework's tests, which we cannot allow. You may launch 
+a DB locally on the application server as part of your 
+`setup.sh` scripts and utilize it for caching the allowable
+cache items, if you so desire, but it's normally much 
+easier to use systems such as APCu.
+
+Ask if you are not certain.
+
+# Adding New PHP-based Frameworks
+
+Most PHP frameworks use `fw_depends php nginx composer` in their `install.sh` file, 
+which installs PHP, Nginx, and Composer automatically. They then create a `setup.sh`
+containing these lines (comments added to clarify what's happening)
+
+    # Explanation of variables provided by toolset:
+    #   FWROOT - absolute path to framework toolset, normally 
+    #            something like /home/username/FrameworkBenchmarks
+    #   TROOT  - absolute path to this framework's folder, normally
+    #            something like /home/username/FrameworkBenchmarks/frameworks/PHP/cakephp
+    #   IROOT  - absolute path to the location where the toolset has installed software, 
+    #            something like /home/username/FrameworkBenchmarks/installs
+    #
+    # As of writing fw_depends installs 5.5.17 into the installer root
+    export PHP_HOME=${IROOT}/php-5.5.17
+    export PHP_FPM=$PHP_HOME/sbin/php-fpm
+    export NGINX_HOME=${IROOT}/nginx
+    
+    # Uses the full path to php-fpm
+    #   - php-fpm configuration is located in the config folder found in the 
+    #     root of this project
+    #   - We tell PHP-FPM to place it's PID file into the deploy folder
+    $PHP_FPM --fpm-config $FWROOT/config/php-fpm.conf -g $TROOT/deploy/php-fpm.pid
+    # Turn on nginx using the configuration file found in this framework's deploy
+    # folder
+    $NGINX_HOME/sbin/nginx -c $TROOT/deploy/nginx.conf
+
+When using `php`, `php-fpm`, or other binaries, always use the full path 
+to the binary, e.g. instead of `php <command>`, 
+use `/home/foo/FrameworkBenchmarks/installs/php-5.5.17/bin/php <your command>`. 
 
 # Dependency Management Using Composer
 
-Many PHP apps use [Composer](https://getcomposer.org/) for dependency management.
-To support this, setup your `install.sh` with these two commands
+Many PHP apps use [Composer](https://getcomposer.org/) for dependency management, 
+which greatly simplifies downloading the framework, loading the framework, and 
+upgrading the framework version in the future. 
+
+There are two main guidelines for PHP frameworks: 
+
+* **Never include the source code for your framework into this repository.** Download it 
+using Composer, wget, or some other tool
+* **When using Composer, always add a `composer.lock` file in addition to the `composer.json` file**. 
+The lock file is a fully-defined file generated by composer 1) reading your JSON file 2) finding all 
+dependencies 3) downloading a lot of data from Github. Without this lock file, composer takes 2-3x 
+longer to run, and it can even halt and require user input
+
+## Setting up Composer
+
+Add a `composer.json` file to your framework's root folder, e.g. `php-fuel/composer.json`. 
+Ensure your `install.sh` lists composer as a dependency, and uses `composer.phar` to 
+install the dependencies required by your project. 
 
     # Note the order! Composer depends on PHP so it has to come second
     fw_depends php composer 
@@ -23,29 +104,29 @@ To support this, setup your `install.sh` with these two commands
     --no-interaction --working-dir $TROOT --no-progress \
     --optimize-autoloader 
 
-Add your `composer.json` file to your framework's folder, e.g. `php-fuel/composer.json`. 
 After installation runs, your framework folder will have a new `vendor` folder, 
-e.g. `php-fuel/vendor` that contains all dependencies. 
-
-## One-time Composer Setup
-
-Composer uses Github *a lot*, enough so that it is common 
-for it to exceed the API limit and cause infinite hangs or 
-installation failures. To avoid this, it is necessary to 
-generate a `composer.lock` file by manually running the 
-installation one time - this file will list the exact 
-github URLs that are needed for this project, which is then
-used by subsequent composer commands to avoid Github's 
-rate limits. More on this [here](https://getcomposer.org/doc/03-cli.md#install) and [here](https://circleci.com/docs/composer-api-rate-limit)
-
-You need to generate `composer.lock` manually, and then add it 
-to your framework's folder. This must be done manually because
-it will require you to provide input. Use these steps
-
-    # Run one installation to ensure PHP is installed
-    cd FrameworkBenchmarks
-    toolset/run-tests.py --install server --install-only --test <your test>
-     
+e.g. `php-fuel/vendor` that contains all dependencies. Update your PHP scripts
+to either directly reference files inside of vendor, or use the `vendor/autoload.php`
+file. 
+
+## Generating composer.lock file
+
+Composer uses Github *a lot*, enough so that it is common for it to exceed the 
+API limit and cause infinite hangs or installation failures. To avoid this, it 
+is necessary to generate a `composer.lock` file. If you're lucky, you can run 
+`toolset/run-tests.py --install server --test <your framework> --install-only`,
+which will run your `install.sh` file and leave the `composer.lock` file right
+next to your `composer.json` file. If this works, just add the lock file to 
+the repository and you're done. There is more info on this [here](https://getcomposer.org/doc/03-cli.md#install)
+and [here](https://circleci.com/docs/composer-api-rate-limit)
+
+*Note:* You may have to force-add the lock file (e.g. `git add -f composer.lock`), 
+because some gitignore files in this repo contain `*.lock` to avoid Ruby's lock files. 
+
+If you are prompted for input during the `run-tests.py` script above, then you
+need to generate your lock file manually so that you may answer the input 
+queries as they are shown. Use these steps
+
     # Switch to the user that runs tests
     sudo su testrunner
     
@@ -56,28 +137,24 @@ it will require you to provide input. Use these steps
     # Run the installation shown above
     #
     # This will manually prompt you for your Github credentials 
-    # to avoid the Github rate limit, and when this command
-    # finishes running you will have a new file composer.lock
+    # to avoid the Github rate limit
+    # When this command completes, you will have a lock file 
     ${IROOT}/php-5.5.17/bin/php $IROOT/composer.phar install \
       --working-dir $TROOT
     
-    # Add the lock file to this repository so it's used for all 
-    # future installations
+    # Add the lock file to this repository
     git add -f composer.lock
 
-**NOTE:** You should run this process manually once to generate the `composer.lock` file
-
 ## Updating Composer setup
 
-If you update `composer.json`, you need to re-run the above 
-process to generate a new `composer.lock` file. If you forget
-to do this, you will see this error message when running the 
-framework:
+If you update `composer.json`, you need to regenerate the lock
+file. If you forget to do this, you will see this error message 
+when running:
 
     Warning: The lock file is not up to date with the latest changes in composer.json. You may be getting outdated dependencies. Run update to update them.
 
 # Debugging PHP Frameworks
 
-The first stop for HTTP 500 errors is to enable stack 
-traces. Update `config/php-fpm.conf` to 
-include `php_flag[display_errors] = on`. 
+The first stop for HTTP 500 errors is to enable stack traces. 
+Update `config/php-fpm.conf` to include `php_flag[display_errors] = on`. 
+If you don't use php-fpm, update the `config/php.ini`

+ 0 - 0
frameworks/PHP/Yii2/__init__.py


+ 0 - 0
frameworks/PHP/cakephp/__init__.py


+ 0 - 0
frameworks/PHP/codeigniter/__init__.py


+ 0 - 0
frameworks/PHP/hhvm/__init__.py


+ 0 - 0
frameworks/PHP/kohana/__init__.py


+ 0 - 0
frameworks/PHP/lithium/__init__.py


+ 0 - 0
frameworks/PHP/php-fatfree/__init__.py


+ 0 - 0
frameworks/PHP/php-laravel/__init__.py


+ 0 - 0
frameworks/PHP/php-micromvc/__init__.py


+ 0 - 0
frameworks/PHP/php-phalcon-micro/__init__.py


+ 0 - 0
frameworks/PHP/php-phalcon/__init__.py


+ 0 - 0
frameworks/PHP/php-phpixie/__init__.py


+ 0 - 0
frameworks/PHP/php-pimf/__init__.py


+ 0 - 0
frameworks/PHP/php-silex-orm/__init__.py


+ 0 - 0
frameworks/PHP/php-silex/__init__.py


+ 0 - 0
frameworks/PHP/php-silica/__init__.py


+ 0 - 0
frameworks/PHP/php-slim/__init__.py


+ 0 - 10
frameworks/PHP/php-symfony2-stripped/.travis.yml

@@ -1,10 +0,0 @@
-language: php
-
-php:
-  - 5.3.3
-  - 5.3
-  - 5.4
-
-before_script: composer install
-
-script: phpunit -c app

+ 0 - 0
frameworks/PHP/php-symfony2-stripped/__init__.py


+ 0 - 2961
frameworks/PHP/php-symfony2-stripped/app/bootstrap.php.cache

@@ -1,2961 +0,0 @@
-<?php
-
-namespace { $loader = require_once __DIR__.'/autoload.php'; }
-
- 
-namespace Symfony\Component\HttpFoundation
-{
-class ParameterBag implements \IteratorAggregate, \Countable
-{
-protected $parameters;
-public function __construct(array $parameters = array())
-{
-$this->parameters = $parameters;
-}
-public function all()
-{
-return $this->parameters;
-}
-public function keys()
-{
-return array_keys($this->parameters);
-}
-public function replace(array $parameters = array())
-{
-$this->parameters = $parameters;
-}
-public function add(array $parameters = array())
-{
-$this->parameters = array_replace($this->parameters, $parameters);
-}
-public function get($path, $default = null, $deep = false)
-{
-if (!$deep || false === $pos = strpos($path,'[')) {
-return array_key_exists($path, $this->parameters) ? $this->parameters[$path] : $default;
-}
-$root = substr($path, 0, $pos);
-if (!array_key_exists($root, $this->parameters)) {
-return $default;
-}
-$value = $this->parameters[$root];
-$currentKey = null;
-for ($i = $pos, $c = strlen($path); $i < $c; $i++) {
-$char = $path[$i];
-if ('['=== $char) {
-if (null !== $currentKey) {
-throw new \InvalidArgumentException(sprintf('Malformed path. Unexpected "[" at position %d.', $i));
-}
-$currentKey ='';
-} elseif (']'=== $char) {
-if (null === $currentKey) {
-throw new \InvalidArgumentException(sprintf('Malformed path. Unexpected "]" at position %d.', $i));
-}
-if (!is_array($value) || !array_key_exists($currentKey, $value)) {
-return $default;
-}
-$value = $value[$currentKey];
-$currentKey = null;
-} else {
-if (null === $currentKey) {
-throw new \InvalidArgumentException(sprintf('Malformed path. Unexpected "%s" at position %d.', $char, $i));
-}
-$currentKey .= $char;
-}
-}
-if (null !== $currentKey) {
-throw new \InvalidArgumentException(sprintf('Malformed path. Path must end with "]".'));
-}
-return $value;
-}
-public function set($key, $value)
-{
-$this->parameters[$key] = $value;
-}
-public function has($key)
-{
-return array_key_exists($key, $this->parameters);
-}
-public function remove($key)
-{
-unset($this->parameters[$key]);
-}
-public function getAlpha($key, $default ='', $deep = false)
-{
-return preg_replace('/[^[:alpha:]]/','', $this->get($key, $default, $deep));
-}
-public function getAlnum($key, $default ='', $deep = false)
-{
-return preg_replace('/[^[:alnum:]]/','', $this->get($key, $default, $deep));
-}
-public function getDigits($key, $default ='', $deep = false)
-{
-return str_replace(array('-','+'),'', $this->filter($key, $default, $deep, FILTER_SANITIZE_NUMBER_INT));
-}
-public function getInt($key, $default = 0, $deep = false)
-{
-return (int) $this->get($key, $default, $deep);
-}
-public function filter($key, $default = null, $deep = false, $filter=FILTER_DEFAULT, $options=array())
-{
-$value = $this->get($key, $default, $deep);
-if (!is_array($options) && $options) {
-$options = array('flags'=> $options);
-}
-if (is_array($value) && !isset($options['flags'])) {
-$options['flags'] = FILTER_REQUIRE_ARRAY;
-}
-return filter_var($value, $filter, $options);
-}
-public function getIterator()
-{
-return new \ArrayIterator($this->parameters);
-}
-public function count()
-{
-return count($this->parameters);
-}
-}
-}
-namespace Symfony\Component\HttpFoundation
-{
-class HeaderBag implements \IteratorAggregate, \Countable
-{
-protected $headers;
-protected $cacheControl;
-public function __construct(array $headers = array())
-{
-$this->cacheControl = array();
-$this->headers = array();
-foreach ($headers as $key => $values) {
-$this->set($key, $values);
-}
-}
-public function __toString()
-{
-if (!$this->headers) {
-return'';
-}
-$max = max(array_map('strlen', array_keys($this->headers))) + 1;
-$content ='';
-ksort($this->headers);
-foreach ($this->headers as $name => $values) {
-$name = implode('-', array_map('ucfirst', explode('-', $name)));
-foreach ($values as $value) {
-$content .= sprintf("%-{$max}s %s\r\n", $name.':', $value);
-}
-}
-return $content;
-}
-public function all()
-{
-return $this->headers;
-}
-public function keys()
-{
-return array_keys($this->headers);
-}
-public function replace(array $headers = array())
-{
-$this->headers = array();
-$this->add($headers);
-}
-public function add(array $headers)
-{
-foreach ($headers as $key => $values) {
-$this->set($key, $values);
-}
-}
-public function get($key, $default = null, $first = true)
-{
-$key = strtr(strtolower($key),'_','-');
-if (!array_key_exists($key, $this->headers)) {
-if (null === $default) {
-return $first ? null : array();
-}
-return $first ? $default : array($default);
-}
-if ($first) {
-return count($this->headers[$key]) ? $this->headers[$key][0] : $default;
-}
-return $this->headers[$key];
-}
-public function set($key, $values, $replace = true)
-{
-$key = strtr(strtolower($key),'_','-');
-$values = array_values((array) $values);
-if (true === $replace || !isset($this->headers[$key])) {
-$this->headers[$key] = $values;
-} else {
-$this->headers[$key] = array_merge($this->headers[$key], $values);
-}
-if ('cache-control'=== $key) {
-$this->cacheControl = $this->parseCacheControl($values[0]);
-}
-}
-public function has($key)
-{
-return array_key_exists(strtr(strtolower($key),'_','-'), $this->headers);
-}
-public function contains($key, $value)
-{
-return in_array($value, $this->get($key, null, false));
-}
-public function remove($key)
-{
-$key = strtr(strtolower($key),'_','-');
-unset($this->headers[$key]);
-if ('cache-control'=== $key) {
-$this->cacheControl = array();
-}
-}
-public function getDate($key, \DateTime $default = null)
-{
-if (null === $value = $this->get($key)) {
-return $default;
-}
-if (false === $date = \DateTime::createFromFormat(DATE_RFC2822, $value)) {
-throw new \RuntimeException(sprintf('The %s HTTP header is not parseable (%s).', $key, $value));
-}
-return $date;
-}
-public function addCacheControlDirective($key, $value = true)
-{
-$this->cacheControl[$key] = $value;
-$this->set('Cache-Control', $this->getCacheControlHeader());
-}
-public function hasCacheControlDirective($key)
-{
-return array_key_exists($key, $this->cacheControl);
-}
-public function getCacheControlDirective($key)
-{
-return array_key_exists($key, $this->cacheControl) ? $this->cacheControl[$key] : null;
-}
-public function removeCacheControlDirective($key)
-{
-unset($this->cacheControl[$key]);
-$this->set('Cache-Control', $this->getCacheControlHeader());
-}
-public function getIterator()
-{
-return new \ArrayIterator($this->headers);
-}
-public function count()
-{
-return count($this->headers);
-}
-protected function getCacheControlHeader()
-{
-$parts = array();
-ksort($this->cacheControl);
-foreach ($this->cacheControl as $key => $value) {
-if (true === $value) {
-$parts[] = $key;
-} else {
-if (preg_match('#[^a-zA-Z0-9._-]#', $value)) {
-$value ='"'.$value.'"';
-}
-$parts[] = "$key=$value";
-}
-}
-return implode(', ', $parts);
-}
-protected function parseCacheControl($header)
-{
-$cacheControl = array();
-preg_match_all('#([a-zA-Z][a-zA-Z_-]*)\s*(?:=(?:"([^"]*)"|([^ \t",;]*)))?#', $header, $matches, PREG_SET_ORDER);
-foreach ($matches as $match) {
-$cacheControl[strtolower($match[1])] = isset($match[3]) ? $match[3] : (isset($match[2]) ? $match[2] : true);
-}
-return $cacheControl;
-}
-}
-}
-namespace Symfony\Component\HttpFoundation
-{
-use Symfony\Component\HttpFoundation\File\UploadedFile;
-class FileBag extends ParameterBag
-{
-private static $fileKeys = array('error','name','size','tmp_name','type');
-public function __construct(array $parameters = array())
-{
-$this->replace($parameters);
-}
-public function replace(array $files = array())
-{
-$this->parameters = array();
-$this->add($files);
-}
-public function set($key, $value)
-{
-if (!is_array($value) && !$value instanceof UploadedFile) {
-throw new \InvalidArgumentException('An uploaded file must be an array or an instance of UploadedFile.');
-}
-parent::set($key, $this->convertFileInformation($value));
-}
-public function add(array $files = array())
-{
-foreach ($files as $key => $file) {
-$this->set($key, $file);
-}
-}
-protected function convertFileInformation($file)
-{
-if ($file instanceof UploadedFile) {
-return $file;
-}
-$file = $this->fixPhpFilesArray($file);
-if (is_array($file)) {
-$keys = array_keys($file);
-sort($keys);
-if ($keys == self::$fileKeys) {
-if (UPLOAD_ERR_NO_FILE == $file['error']) {
-$file = null;
-} else {
-$file = new UploadedFile($file['tmp_name'], $file['name'], $file['type'], $file['size'], $file['error']);
-}
-} else {
-$file = array_map(array($this,'convertFileInformation'), $file);
-}
-}
-return $file;
-}
-protected function fixPhpFilesArray($data)
-{
-if (!is_array($data)) {
-return $data;
-}
-$keys = array_keys($data);
-sort($keys);
-if (self::$fileKeys != $keys || !isset($data['name']) || !is_array($data['name'])) {
-return $data;
-}
-$files = $data;
-foreach (self::$fileKeys as $k) {
-unset($files[$k]);
-}
-foreach (array_keys($data['name']) as $key) {
-$files[$key] = $this->fixPhpFilesArray(array('error'=> $data['error'][$key],'name'=> $data['name'][$key],'type'=> $data['type'][$key],'tmp_name'=> $data['tmp_name'][$key],'size'=> $data['size'][$key]
-));
-}
-return $files;
-}
-}
-}
-namespace Symfony\Component\HttpFoundation
-{
-class ServerBag extends ParameterBag
-{
-public function getHeaders()
-{
-$headers = array();
-$contentHeaders = array('CONTENT_LENGTH'=> true,'CONTENT_MD5'=> true,'CONTENT_TYPE'=> true);
-foreach ($this->parameters as $key => $value) {
-if (0 === strpos($key,'HTTP_')) {
-$headers[substr($key, 5)] = $value;
-}
-elseif (isset($contentHeaders[$key])) {
-$headers[$key] = $value;
-}
-}
-if (isset($this->parameters['PHP_AUTH_USER'])) {
-$headers['PHP_AUTH_USER'] = $this->parameters['PHP_AUTH_USER'];
-$headers['PHP_AUTH_PW'] = isset($this->parameters['PHP_AUTH_PW']) ? $this->parameters['PHP_AUTH_PW'] :'';
-} else {
-$authorizationHeader = null;
-if (isset($this->parameters['HTTP_AUTHORIZATION'])) {
-$authorizationHeader = $this->parameters['HTTP_AUTHORIZATION'];
-} elseif (isset($this->parameters['REDIRECT_HTTP_AUTHORIZATION'])) {
-$authorizationHeader = $this->parameters['REDIRECT_HTTP_AUTHORIZATION'];
-}
-if (null !== $authorizationHeader) {
-if (0 === stripos($authorizationHeader,'basic')) {
-$exploded = explode(':', base64_decode(substr($authorizationHeader, 6)));
-if (count($exploded) == 2) {
-list($headers['PHP_AUTH_USER'], $headers['PHP_AUTH_PW']) = $exploded;
-}
-} elseif (empty($this->parameters['PHP_AUTH_DIGEST']) && (0 === stripos($authorizationHeader,'digest'))) {
-$headers['PHP_AUTH_DIGEST'] = $authorizationHeader;
-$this->parameters['PHP_AUTH_DIGEST'] = $authorizationHeader;
-}
-}
-}
-if (isset($headers['PHP_AUTH_USER'])) {
-$headers['AUTHORIZATION'] ='Basic '.base64_encode($headers['PHP_AUTH_USER'].':'.$headers['PHP_AUTH_PW']);
-} elseif (isset($headers['PHP_AUTH_DIGEST'])) {
-$headers['AUTHORIZATION'] = $headers['PHP_AUTH_DIGEST'];
-}
-return $headers;
-}
-}
-}
-namespace Symfony\Component\HttpFoundation
-{
-use Symfony\Component\HttpFoundation\Session\SessionInterface;
-class Request
-{
-const HEADER_CLIENT_IP ='client_ip';
-const HEADER_CLIENT_HOST ='client_host';
-const HEADER_CLIENT_PROTO ='client_proto';
-const HEADER_CLIENT_PORT ='client_port';
-protected static $trustedProxies = array();
-protected static $trustedHostPatterns = array();
-protected static $trustedHosts = array();
-protected static $trustedHeaders = array(
-self::HEADER_CLIENT_IP =>'X_FORWARDED_FOR',
-self::HEADER_CLIENT_HOST =>'X_FORWARDED_HOST',
-self::HEADER_CLIENT_PROTO =>'X_FORWARDED_PROTO',
-self::HEADER_CLIENT_PORT =>'X_FORWARDED_PORT',
-);
-protected static $httpMethodParameterOverride = false;
-public $attributes;
-public $request;
-public $query;
-public $server;
-public $files;
-public $cookies;
-public $headers;
-protected $content;
-protected $languages;
-protected $charsets;
-protected $acceptableContentTypes;
-protected $pathInfo;
-protected $requestUri;
-protected $baseUrl;
-protected $basePath;
-protected $method;
-protected $format;
-protected $session;
-protected $locale;
-protected $defaultLocale ='en';
-protected static $formats;
-public function __construct(array $query = array(), array $request = array(), array $attributes = array(), array $cookies = array(), array $files = array(), array $server = array(), $content = null)
-{
-$this->initialize($query, $request, $attributes, $cookies, $files, $server, $content);
-}
-public function initialize(array $query = array(), array $request = array(), array $attributes = array(), array $cookies = array(), array $files = array(), array $server = array(), $content = null)
-{
-$this->request = new ParameterBag($request);
-$this->query = new ParameterBag($query);
-$this->attributes = new ParameterBag($attributes);
-$this->cookies = new ParameterBag($cookies);
-$this->files = new FileBag($files);
-$this->server = new ServerBag($server);
-$this->headers = new HeaderBag($this->server->getHeaders());
-$this->content = $content;
-$this->languages = null;
-$this->charsets = null;
-$this->acceptableContentTypes = null;
-$this->pathInfo = null;
-$this->requestUri = null;
-$this->baseUrl = null;
-$this->basePath = null;
-$this->method = null;
-$this->format = null;
-}
-public static function createFromGlobals()
-{
-$request = new static($_GET, $_POST, array(), $_COOKIE, $_FILES, $_SERVER);
-if (0 === strpos($request->headers->get('CONTENT_TYPE'),'application/x-www-form-urlencoded')
-&& in_array(strtoupper($request->server->get('REQUEST_METHOD','GET')), array('PUT','DELETE','PATCH'))
-) {
-parse_str($request->getContent(), $data);
-$request->request = new ParameterBag($data);
-}
-return $request;
-}
-public static function create($uri, $method ='GET', $parameters = array(), $cookies = array(), $files = array(), $server = array(), $content = null)
-{
-$server = array_replace(array('SERVER_NAME'=>'localhost','SERVER_PORT'=> 80,'HTTP_HOST'=>'localhost','HTTP_USER_AGENT'=>'Symfony/2.X','HTTP_ACCEPT'=>'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8','HTTP_ACCEPT_LANGUAGE'=>'en-us,en;q=0.5','HTTP_ACCEPT_CHARSET'=>'ISO-8859-1,utf-8;q=0.7,*;q=0.7','REMOTE_ADDR'=>'127.0.0.1','SCRIPT_NAME'=>'','SCRIPT_FILENAME'=>'','SERVER_PROTOCOL'=>'HTTP/1.1','REQUEST_TIME'=> time(),
-), $server);
-$server['PATH_INFO'] ='';
-$server['REQUEST_METHOD'] = strtoupper($method);
-$components = parse_url($uri);
-if (isset($components['host'])) {
-$server['SERVER_NAME'] = $components['host'];
-$server['HTTP_HOST'] = $components['host'];
-}
-if (isset($components['scheme'])) {
-if ('https'=== $components['scheme']) {
-$server['HTTPS'] ='on';
-$server['SERVER_PORT'] = 443;
-} else {
-unset($server['HTTPS']);
-$server['SERVER_PORT'] = 80;
-}
-}
-if (isset($components['port'])) {
-$server['SERVER_PORT'] = $components['port'];
-$server['HTTP_HOST'] = $server['HTTP_HOST'].':'.$components['port'];
-}
-if (isset($components['user'])) {
-$server['PHP_AUTH_USER'] = $components['user'];
-}
-if (isset($components['pass'])) {
-$server['PHP_AUTH_PW'] = $components['pass'];
-}
-if (!isset($components['path'])) {
-$components['path'] ='/';
-}
-switch (strtoupper($method)) {
-case'POST':
-case'PUT':
-case'DELETE':
-if (!isset($server['CONTENT_TYPE'])) {
-$server['CONTENT_TYPE'] ='application/x-www-form-urlencoded';
-}
-case'PATCH':
-$request = $parameters;
-$query = array();
-break;
-default:
-$request = array();
-$query = $parameters;
-break;
-}
-$queryString ='';
-if (isset($components['query'])) {
-parse_str(html_entity_decode($components['query']), $qs);
-if ($query) {
-$query = array_replace($qs, $query);
-$queryString = http_build_query($query,'','&');
-} else {
-$query = $qs;
-$queryString = $components['query'];
-}
-} elseif ($query) {
-$queryString = http_build_query($query,'','&');
-}
-$server['REQUEST_URI'] = $components['path'].(''!== $queryString ?'?'.$queryString :'');
-$server['QUERY_STRING'] = $queryString;
-return new static($query, $request, array(), $cookies, $files, $server, $content);
-}
-public function duplicate(array $query = null, array $request = null, array $attributes = null, array $cookies = null, array $files = null, array $server = null)
-{
-$dup = clone $this;
-if ($query !== null) {
-$dup->query = new ParameterBag($query);
-}
-if ($request !== null) {
-$dup->request = new ParameterBag($request);
-}
-if ($attributes !== null) {
-$dup->attributes = new ParameterBag($attributes);
-}
-if ($cookies !== null) {
-$dup->cookies = new ParameterBag($cookies);
-}
-if ($files !== null) {
-$dup->files = new FileBag($files);
-}
-if ($server !== null) {
-$dup->server = new ServerBag($server);
-$dup->headers = new HeaderBag($dup->server->getHeaders());
-}
-$dup->languages = null;
-$dup->charsets = null;
-$dup->acceptableContentTypes = null;
-$dup->pathInfo = null;
-$dup->requestUri = null;
-$dup->baseUrl = null;
-$dup->basePath = null;
-$dup->method = null;
-$dup->format = null;
-if (!$dup->get('_format') && $this->get('_format')) {
-$dup->attributes->set('_format', $this->get('_format'));
-}
-if (!$dup->getRequestFormat(null)) {
-$dup->setRequestFormat($format = $this->getRequestFormat(null));
-}
-return $dup;
-}
-public function __clone()
-{
-$this->query = clone $this->query;
-$this->request = clone $this->request;
-$this->attributes = clone $this->attributes;
-$this->cookies = clone $this->cookies;
-$this->files = clone $this->files;
-$this->server = clone $this->server;
-$this->headers = clone $this->headers;
-}
-public function __toString()
-{
-return
-sprintf('%s %s %s', $this->getMethod(), $this->getRequestUri(), $this->server->get('SERVER_PROTOCOL'))."\r\n".
-$this->headers."\r\n".
-$this->getContent();
-}
-public function overrideGlobals()
-{
-$_GET = $this->query->all();
-$_POST = $this->request->all();
-$_SERVER = $this->server->all();
-$_COOKIE = $this->cookies->all();
-foreach ($this->headers->all() as $key => $value) {
-$key = strtoupper(str_replace('-','_', $key));
-if (in_array($key, array('CONTENT_TYPE','CONTENT_LENGTH'))) {
-$_SERVER[$key] = implode(', ', $value);
-} else {
-$_SERVER['HTTP_'.$key] = implode(', ', $value);
-}
-}
-$request = array('g'=> $_GET,'p'=> $_POST,'c'=> $_COOKIE);
-$requestOrder = ini_get('request_order') ?: ini_get('variable_order');
-$requestOrder = preg_replace('#[^cgp]#','', strtolower($requestOrder)) ?:'gp';
-$_REQUEST = array();
-foreach (str_split($requestOrder) as $order) {
-$_REQUEST = array_merge($_REQUEST, $request[$order]);
-}
-}
-public static function setTrustedProxies(array $proxies)
-{
-self::$trustedProxies = $proxies;
-}
-public static function getTrustedProxies()
-{
-return self::$trustedProxies;
-}
-public static function setTrustedHosts(array $hostPatterns)
-{
-self::$trustedHostPatterns = array_map(function ($hostPattern) {
-return sprintf('{%s}i', str_replace('}','\\}', $hostPattern));
-}, $hostPatterns);
-self::$trustedHosts = array();
-}
-public static function getTrustedHosts()
-{
-return self::$trustedHostPatterns;
-}
-public static function setTrustedHeaderName($key, $value)
-{
-if (!array_key_exists($key, self::$trustedHeaders)) {
-throw new \InvalidArgumentException(sprintf('Unable to set the trusted header name for key "%s".', $key));
-}
-self::$trustedHeaders[$key] = $value;
-}
-public static function getTrustedHeaderName($key)
-{
-if (!array_key_exists($key, self::$trustedHeaders)) {
-throw new \InvalidArgumentException(sprintf('Unable to get the trusted header name for key "%s".', $key));
-}
-return self::$trustedHeaders[$key];
-}
-public static function normalizeQueryString($qs)
-{
-if (''== $qs) {
-return'';
-}
-$parts = array();
-$order = array();
-foreach (explode('&', $qs) as $param) {
-if (''=== $param ||'='=== $param[0]) {
-continue;
-}
-$keyValuePair = explode('=', $param, 2);
-$parts[] = isset($keyValuePair[1]) ?
-rawurlencode(urldecode($keyValuePair[0])).'='.rawurlencode(urldecode($keyValuePair[1])) :
-rawurlencode(urldecode($keyValuePair[0]));
-$order[] = urldecode($keyValuePair[0]);
-}
-array_multisort($order, SORT_ASC, $parts);
-return implode('&', $parts);
-}
-public static function enableHttpMethodParameterOverride()
-{
-self::$httpMethodParameterOverride = true;
-}
-public static function getHttpMethodParameterOverride()
-{
-return self::$httpMethodParameterOverride;
-}
-public function get($key, $default = null, $deep = false)
-{
-return $this->query->get($key, $this->attributes->get($key, $this->request->get($key, $default, $deep), $deep), $deep);
-}
-public function getSession()
-{
-return $this->session;
-}
-public function hasPreviousSession()
-{
-return $this->hasSession() && $this->cookies->has($this->session->getName());
-}
-public function hasSession()
-{
-return null !== $this->session;
-}
-public function setSession(SessionInterface $session)
-{
-$this->session = $session;
-}
-public function getClientIps()
-{
-$ip = $this->server->get('REMOTE_ADDR');
-if (!self::$trustedProxies) {
-return array($ip);
-}
-if (!self::$trustedHeaders[self::HEADER_CLIENT_IP] || !$this->headers->has(self::$trustedHeaders[self::HEADER_CLIENT_IP])) {
-return array($ip);
-}
-$clientIps = array_map('trim', explode(',', $this->headers->get(self::$trustedHeaders[self::HEADER_CLIENT_IP])));
-$clientIps[] = $ip;
-$trustedProxies = !self::$trustedProxies ? array($ip) : self::$trustedProxies;
-$ip = $clientIps[0];
-foreach ($clientIps as $key => $clientIp) {
-if (IpUtils::checkIp($clientIp, $trustedProxies)) {
-unset($clientIps[$key]);
-continue;
-}
-}
-return $clientIps ? array_reverse($clientIps) : array($ip);
-}
-public function getClientIp()
-{
-$ipAddresses = $this->getClientIps();
-return $ipAddresses[0];
-}
-public function getScriptName()
-{
-return $this->server->get('SCRIPT_NAME', $this->server->get('ORIG_SCRIPT_NAME',''));
-}
-public function getPathInfo()
-{
-if (null === $this->pathInfo) {
-$this->pathInfo = $this->preparePathInfo();
-}
-return $this->pathInfo;
-}
-public function getBasePath()
-{
-if (null === $this->basePath) {
-$this->basePath = $this->prepareBasePath();
-}
-return $this->basePath;
-}
-public function getBaseUrl()
-{
-if (null === $this->baseUrl) {
-$this->baseUrl = $this->prepareBaseUrl();
-}
-return $this->baseUrl;
-}
-public function getScheme()
-{
-return $this->isSecure() ?'https':'http';
-}
-public function getPort()
-{
-if (self::$trustedProxies) {
-if (self::$trustedHeaders[self::HEADER_CLIENT_PORT] && $port = $this->headers->get(self::$trustedHeaders[self::HEADER_CLIENT_PORT])) {
-return $port;
-}
-if (self::$trustedHeaders[self::HEADER_CLIENT_PROTO] &&'https'=== $this->headers->get(self::$trustedHeaders[self::HEADER_CLIENT_PROTO],'http')) {
-return 443;
-}
-}
-if ($host = $this->headers->get('HOST')) {
-if (false !== $pos = strrpos($host,':')) {
-return intval(substr($host, $pos + 1));
-}
-return'https'=== $this->getScheme() ? 443 : 80;
-}
-return $this->server->get('SERVER_PORT');
-}
-public function getUser()
-{
-return $this->server->get('PHP_AUTH_USER');
-}
-public function getPassword()
-{
-return $this->server->get('PHP_AUTH_PW');
-}
-public function getUserInfo()
-{
-$userinfo = $this->getUser();
-$pass = $this->getPassword();
-if (''!= $pass) {
-$userinfo .= ":$pass";
-}
-return $userinfo;
-}
-public function getHttpHost()
-{
-$scheme = $this->getScheme();
-$port = $this->getPort();
-if (('http'== $scheme && $port == 80) || ('https'== $scheme && $port == 443)) {
-return $this->getHost();
-}
-return $this->getHost().':'.$port;
-}
-public function getRequestUri()
-{
-if (null === $this->requestUri) {
-$this->requestUri = $this->prepareRequestUri();
-}
-return $this->requestUri;
-}
-public function getSchemeAndHttpHost()
-{
-return $this->getScheme().'://'.$this->getHttpHost();
-}
-public function getUri()
-{
-if (null !== $qs = $this->getQueryString()) {
-$qs ='?'.$qs;
-}
-return $this->getSchemeAndHttpHost().$this->getBaseUrl().$this->getPathInfo().$qs;
-}
-public function getUriForPath($path)
-{
-return $this->getSchemeAndHttpHost().$this->getBaseUrl().$path;
-}
-public function getQueryString()
-{
-$qs = static::normalizeQueryString($this->server->get('QUERY_STRING'));
-return''=== $qs ? null : $qs;
-}
-public function isSecure()
-{
-if (self::$trustedProxies && self::$trustedHeaders[self::HEADER_CLIENT_PROTO] && $proto = $this->headers->get(self::$trustedHeaders[self::HEADER_CLIENT_PROTO])) {
-return in_array(strtolower($proto), array('https','on','1'));
-}
-return'on'== strtolower($this->server->get('HTTPS')) || 1 == $this->server->get('HTTPS');
-}
-public function getHost()
-{
-if (self::$trustedProxies && self::$trustedHeaders[self::HEADER_CLIENT_HOST] && $host = $this->headers->get(self::$trustedHeaders[self::HEADER_CLIENT_HOST])) {
-$elements = explode(',', $host);
-$host = $elements[count($elements) - 1];
-} elseif (!$host = $this->headers->get('HOST')) {
-if (!$host = $this->server->get('SERVER_NAME')) {
-$host = $this->server->get('SERVER_ADDR','');
-}
-}
-$host = strtolower(preg_replace('/:\d+$/','', trim($host)));
-if ($host && !preg_match('/^\[?(?:[a-zA-Z0-9-:\]_]+\.?)+$/', $host)) {
-throw new \UnexpectedValueException('Invalid Host "'.$host.'"');
-}
-if (count(self::$trustedHostPatterns) > 0) {
-if (in_array($host, self::$trustedHosts)) {
-return $host;
-}
-foreach (self::$trustedHostPatterns as $pattern) {
-if (preg_match($pattern, $host)) {
-self::$trustedHosts[] = $host;
-return $host;
-}
-}
-throw new \UnexpectedValueException('Untrusted Host "'.$host.'"');
-}
-return $host;
-}
-public function setMethod($method)
-{
-$this->method = null;
-$this->server->set('REQUEST_METHOD', $method);
-}
-public function getMethod()
-{
-if (null === $this->method) {
-$this->method = strtoupper($this->server->get('REQUEST_METHOD','GET'));
-if ('POST'=== $this->method) {
-if ($method = $this->headers->get('X-HTTP-METHOD-OVERRIDE')) {
-$this->method = strtoupper($method);
-} elseif (self::$httpMethodParameterOverride) {
-$this->method = strtoupper($this->request->get('_method', $this->query->get('_method','POST')));
-}
-}
-}
-return $this->method;
-}
-public function getRealMethod()
-{
-return strtoupper($this->server->get('REQUEST_METHOD','GET'));
-}
-public function getMimeType($format)
-{
-if (null === static::$formats) {
-static::initializeFormats();
-}
-return isset(static::$formats[$format]) ? static::$formats[$format][0] : null;
-}
-public function getFormat($mimeType)
-{
-if (false !== $pos = strpos($mimeType,';')) {
-$mimeType = substr($mimeType, 0, $pos);
-}
-if (null === static::$formats) {
-static::initializeFormats();
-}
-foreach (static::$formats as $format => $mimeTypes) {
-if (in_array($mimeType, (array) $mimeTypes)) {
-return $format;
-}
-}
-return null;
-}
-public function setFormat($format, $mimeTypes)
-{
-if (null === static::$formats) {
-static::initializeFormats();
-}
-static::$formats[$format] = is_array($mimeTypes) ? $mimeTypes : array($mimeTypes);
-}
-public function getRequestFormat($default ='html')
-{
-if (null === $this->format) {
-$this->format = $this->get('_format', $default);
-}
-return $this->format;
-}
-public function setRequestFormat($format)
-{
-$this->format = $format;
-}
-public function getContentType()
-{
-return $this->getFormat($this->headers->get('CONTENT_TYPE'));
-}
-public function setDefaultLocale($locale)
-{
-$this->defaultLocale = $locale;
-if (null === $this->locale) {
-$this->setPhpDefaultLocale($locale);
-}
-}
-public function setLocale($locale)
-{
-$this->setPhpDefaultLocale($this->locale = $locale);
-}
-public function getLocale()
-{
-return null === $this->locale ? $this->defaultLocale : $this->locale;
-}
-public function isMethod($method)
-{
-return $this->getMethod() === strtoupper($method);
-}
-public function isMethodSafe()
-{
-return in_array($this->getMethod(), array('GET','HEAD'));
-}
-public function getContent($asResource = false)
-{
-if (false === $this->content || (true === $asResource && null !== $this->content)) {
-throw new \LogicException('getContent() can only be called once when using the resource return type.');
-}
-if (true === $asResource) {
-$this->content = false;
-return fopen('php://input','rb');
-}
-if (null === $this->content) {
-$this->content = file_get_contents('php://input');
-}
-return $this->content;
-}
-public function getETags()
-{
-return preg_split('/\s*,\s*/', $this->headers->get('if_none_match'), null, PREG_SPLIT_NO_EMPTY);
-}
-public function isNoCache()
-{
-return $this->headers->hasCacheControlDirective('no-cache') ||'no-cache'== $this->headers->get('Pragma');
-}
-public function getPreferredLanguage(array $locales = null)
-{
-$preferredLanguages = $this->getLanguages();
-if (empty($locales)) {
-return isset($preferredLanguages[0]) ? $preferredLanguages[0] : null;
-}
-if (!$preferredLanguages) {
-return $locales[0];
-}
-$extendedPreferredLanguages = array();
-foreach ($preferredLanguages as $language) {
-$extendedPreferredLanguages[] = $language;
-if (false !== $position = strpos($language,'_')) {
-$superLanguage = substr($language, 0, $position);
-if (!in_array($superLanguage, $preferredLanguages)) {
-$extendedPreferredLanguages[] = $superLanguage;
-}
-}
-}
-$preferredLanguages = array_values(array_intersect($extendedPreferredLanguages, $locales));
-return isset($preferredLanguages[0]) ? $preferredLanguages[0] : $locales[0];
-}
-public function getLanguages()
-{
-if (null !== $this->languages) {
-return $this->languages;
-}
-$languages = AcceptHeader::fromString($this->headers->get('Accept-Language'))->all();
-$this->languages = array();
-foreach (array_keys($languages) as $lang) {
-if (strstr($lang,'-')) {
-$codes = explode('-', $lang);
-if ($codes[0] =='i') {
-if (count($codes) > 1) {
-$lang = $codes[1];
-}
-} else {
-for ($i = 0, $max = count($codes); $i < $max; $i++) {
-if ($i == 0) {
-$lang = strtolower($codes[0]);
-} else {
-$lang .='_'.strtoupper($codes[$i]);
-}
-}
-}
-}
-$this->languages[] = $lang;
-}
-return $this->languages;
-}
-public function getCharsets()
-{
-if (null !== $this->charsets) {
-return $this->charsets;
-}
-return $this->charsets = array_keys(AcceptHeader::fromString($this->headers->get('Accept-Charset'))->all());
-}
-public function getAcceptableContentTypes()
-{
-if (null !== $this->acceptableContentTypes) {
-return $this->acceptableContentTypes;
-}
-return $this->acceptableContentTypes = array_keys(AcceptHeader::fromString($this->headers->get('Accept'))->all());
-}
-public function isXmlHttpRequest()
-{
-return'XMLHttpRequest'== $this->headers->get('X-Requested-With');
-}
-protected function prepareRequestUri()
-{
-$requestUri ='';
-if ($this->headers->has('X_ORIGINAL_URL')) {
-$requestUri = $this->headers->get('X_ORIGINAL_URL');
-$this->headers->remove('X_ORIGINAL_URL');
-$this->server->remove('HTTP_X_ORIGINAL_URL');
-$this->server->remove('UNENCODED_URL');
-$this->server->remove('IIS_WasUrlRewritten');
-} elseif ($this->headers->has('X_REWRITE_URL')) {
-$requestUri = $this->headers->get('X_REWRITE_URL');
-$this->headers->remove('X_REWRITE_URL');
-} elseif ($this->server->get('IIS_WasUrlRewritten') =='1'&& $this->server->get('UNENCODED_URL') !='') {
-$requestUri = $this->server->get('UNENCODED_URL');
-$this->server->remove('UNENCODED_URL');
-$this->server->remove('IIS_WasUrlRewritten');
-} elseif ($this->server->has('REQUEST_URI')) {
-$requestUri = $this->server->get('REQUEST_URI');
-$schemeAndHttpHost = $this->getSchemeAndHttpHost();
-if (strpos($requestUri, $schemeAndHttpHost) === 0) {
-$requestUri = substr($requestUri, strlen($schemeAndHttpHost));
-}
-} elseif ($this->server->has('ORIG_PATH_INFO')) {
-$requestUri = $this->server->get('ORIG_PATH_INFO');
-if (''!= $this->server->get('QUERY_STRING')) {
-$requestUri .='?'.$this->server->get('QUERY_STRING');
-}
-$this->server->remove('ORIG_PATH_INFO');
-}
-$this->server->set('REQUEST_URI', $requestUri);
-return $requestUri;
-}
-protected function prepareBaseUrl()
-{
-$filename = basename($this->server->get('SCRIPT_FILENAME'));
-if (basename($this->server->get('SCRIPT_NAME')) === $filename) {
-$baseUrl = $this->server->get('SCRIPT_NAME');
-} elseif (basename($this->server->get('PHP_SELF')) === $filename) {
-$baseUrl = $this->server->get('PHP_SELF');
-} elseif (basename($this->server->get('ORIG_SCRIPT_NAME')) === $filename) {
-$baseUrl = $this->server->get('ORIG_SCRIPT_NAME'); } else {
-$path = $this->server->get('PHP_SELF','');
-$file = $this->server->get('SCRIPT_FILENAME','');
-$segs = explode('/', trim($file,'/'));
-$segs = array_reverse($segs);
-$index = 0;
-$last = count($segs);
-$baseUrl ='';
-do {
-$seg = $segs[$index];
-$baseUrl ='/'.$seg.$baseUrl;
-++$index;
-} while ($last > $index && (false !== $pos = strpos($path, $baseUrl)) && 0 != $pos);
-}
-$requestUri = $this->getRequestUri();
-if ($baseUrl && false !== $prefix = $this->getUrlencodedPrefix($requestUri, $baseUrl)) {
-return $prefix;
-}
-if ($baseUrl && false !== $prefix = $this->getUrlencodedPrefix($requestUri, dirname($baseUrl))) {
-return rtrim($prefix,'/');
-}
-$truncatedRequestUri = $requestUri;
-if (false !== $pos = strpos($requestUri,'?')) {
-$truncatedRequestUri = substr($requestUri, 0, $pos);
-}
-$basename = basename($baseUrl);
-if (empty($basename) || !strpos(rawurldecode($truncatedRequestUri), $basename)) {
-return'';
-}
-if (strlen($requestUri) >= strlen($baseUrl) && (false !== $pos = strpos($requestUri, $baseUrl)) && $pos !== 0) {
-$baseUrl = substr($requestUri, 0, $pos + strlen($baseUrl));
-}
-return rtrim($baseUrl,'/');
-}
-protected function prepareBasePath()
-{
-$filename = basename($this->server->get('SCRIPT_FILENAME'));
-$baseUrl = $this->getBaseUrl();
-if (empty($baseUrl)) {
-return'';
-}
-if (basename($baseUrl) === $filename) {
-$basePath = dirname($baseUrl);
-} else {
-$basePath = $baseUrl;
-}
-if ('\\'=== DIRECTORY_SEPARATOR) {
-$basePath = str_replace('\\','/', $basePath);
-}
-return rtrim($basePath,'/');
-}
-protected function preparePathInfo()
-{
-$baseUrl = $this->getBaseUrl();
-if (null === ($requestUri = $this->getRequestUri())) {
-return'/';
-}
-$pathInfo ='/';
-if ($pos = strpos($requestUri,'?')) {
-$requestUri = substr($requestUri, 0, $pos);
-}
-if (null !== $baseUrl && false === $pathInfo = substr($requestUri, strlen($baseUrl))) {
-return'/';
-} elseif (null === $baseUrl) {
-return $requestUri;
-}
-return (string) $pathInfo;
-}
-protected static function initializeFormats()
-{
-static::$formats = array('html'=> array('text/html','application/xhtml+xml'),'txt'=> array('text/plain'),'js'=> array('application/javascript','application/x-javascript','text/javascript'),'css'=> array('text/css'),'json'=> array('application/json','application/x-json'),'xml'=> array('text/xml','application/xml','application/x-xml'),'rdf'=> array('application/rdf+xml'),'atom'=> array('application/atom+xml'),'rss'=> array('application/rss+xml'),
-);
-}
-private function setPhpDefaultLocale($locale)
-{
-try {
-if (class_exists('Locale', false)) {
-\Locale::setDefault($locale);
-}
-} catch (\Exception $e) {
-}
-}
-private function getUrlencodedPrefix($string, $prefix)
-{
-if (0 !== strpos(rawurldecode($string), $prefix)) {
-return false;
-}
-$len = strlen($prefix);
-if (preg_match("#^(%[[:xdigit:]]{2}|.){{$len}}#", $string, $match)) {
-return $match[0];
-}
-return false;
-}
-}
-}
-namespace Symfony\Component\HttpFoundation
-{
-class Response
-{
-public $headers;
-protected $content;
-protected $version;
-protected $statusCode;
-protected $statusText;
-protected $charset;
-public static $statusTexts = array(
-100 =>'Continue',
-101 =>'Switching Protocols',
-102 =>'Processing', 200 =>'OK',
-201 =>'Created',
-202 =>'Accepted',
-203 =>'Non-Authoritative Information',
-204 =>'No Content',
-205 =>'Reset Content',
-206 =>'Partial Content',
-207 =>'Multi-Status', 208 =>'Already Reported', 226 =>'IM Used', 300 =>'Multiple Choices',
-301 =>'Moved Permanently',
-302 =>'Found',
-303 =>'See Other',
-304 =>'Not Modified',
-305 =>'Use Proxy',
-306 =>'Reserved',
-307 =>'Temporary Redirect',
-308 =>'Permanent Redirect', 400 =>'Bad Request',
-401 =>'Unauthorized',
-402 =>'Payment Required',
-403 =>'Forbidden',
-404 =>'Not Found',
-405 =>'Method Not Allowed',
-406 =>'Not Acceptable',
-407 =>'Proxy Authentication Required',
-408 =>'Request Timeout',
-409 =>'Conflict',
-410 =>'Gone',
-411 =>'Length Required',
-412 =>'Precondition Failed',
-413 =>'Request Entity Too Large',
-414 =>'Request-URI Too Long',
-415 =>'Unsupported Media Type',
-416 =>'Requested Range Not Satisfiable',
-417 =>'Expectation Failed',
-418 =>'I\'m a teapot', 422 =>'Unprocessable Entity', 423 =>'Locked', 424 =>'Failed Dependency', 425 =>'Reserved for WebDAV advanced collections expired proposal', 426 =>'Upgrade Required', 428 =>'Precondition Required', 429 =>'Too Many Requests', 431 =>'Request Header Fields Too Large', 500 =>'Internal Server Error',
-501 =>'Not Implemented',
-502 =>'Bad Gateway',
-503 =>'Service Unavailable',
-504 =>'Gateway Timeout',
-505 =>'HTTP Version Not Supported',
-506 =>'Variant Also Negotiates (Experimental)', 507 =>'Insufficient Storage', 508 =>'Loop Detected', 510 =>'Not Extended', 511 =>'Network Authentication Required', );
-public function __construct($content ='', $status = 200, $headers = array())
-{
-$this->headers = new ResponseHeaderBag($headers);
-$this->setContent($content);
-$this->setStatusCode($status);
-$this->setProtocolVersion('1.0');
-if (!$this->headers->has('Date')) {
-$this->setDate(new \DateTime(null, new \DateTimeZone('UTC')));
-}
-}
-public static function create($content ='', $status = 200, $headers = array())
-{
-return new static($content, $status, $headers);
-}
-public function __toString()
-{
-return
-sprintf('HTTP/%s %s %s', $this->version, $this->statusCode, $this->statusText)."\r\n".
-$this->headers."\r\n".
-$this->getContent();
-}
-public function __clone()
-{
-$this->headers = clone $this->headers;
-}
-public function prepare(Request $request)
-{
-$headers = $this->headers;
-if ($this->isInformational() || in_array($this->statusCode, array(204, 304))) {
-$this->setContent(null);
-}
-if (!$headers->has('Content-Type')) {
-$format = $request->getRequestFormat();
-if (null !== $format && $mimeType = $request->getMimeType($format)) {
-$headers->set('Content-Type', $mimeType);
-}
-}
-$charset = $this->charset ?:'UTF-8';
-if (!$headers->has('Content-Type')) {
-$headers->set('Content-Type','text/html; charset='.$charset);
-} elseif (0 === strpos($headers->get('Content-Type'),'text/') && false === strpos($headers->get('Content-Type'),'charset')) {
-$headers->set('Content-Type', $headers->get('Content-Type').'; charset='.$charset);
-}
-if ($headers->has('Transfer-Encoding')) {
-$headers->remove('Content-Length');
-}
-if ($request->isMethod('HEAD')) {
-$length = $headers->get('Content-Length');
-$this->setContent(null);
-if ($length) {
-$headers->set('Content-Length', $length);
-}
-}
-if ('HTTP/1.0'!= $request->server->get('SERVER_PROTOCOL')) {
-$this->setProtocolVersion('1.1');
-}
-if ('1.0'== $this->getProtocolVersion() &&'no-cache'== $this->headers->get('Cache-Control')) {
-$this->headers->set('pragma','no-cache');
-$this->headers->set('expires', -1);
-}
-$this->ensureIEOverSSLCompatibility($request);
-return $this;
-}
-public function sendHeaders()
-{
-if (headers_sent()) {
-return $this;
-}
-header(sprintf('HTTP/%s %s %s', $this->version, $this->statusCode, $this->statusText));
-foreach ($this->headers->allPreserveCase() as $name => $values) {
-foreach ($values as $value) {
-header($name.': '.$value, false);
-}
-}
-foreach ($this->headers->getCookies() as $cookie) {
-setcookie($cookie->getName(), $cookie->getValue(), $cookie->getExpiresTime(), $cookie->getPath(), $cookie->getDomain(), $cookie->isSecure(), $cookie->isHttpOnly());
-}
-return $this;
-}
-public function sendContent()
-{
-echo $this->content;
-return $this;
-}
-public function send()
-{
-$this->sendHeaders();
-$this->sendContent();
-if (function_exists('fastcgi_finish_request')) {
-fastcgi_finish_request();
-} elseif ('cli'!== PHP_SAPI) {
-$previous = null;
-$obStatus = ob_get_status(1);
-while (($level = ob_get_level()) > 0 && $level !== $previous) {
-$previous = $level;
-if ($obStatus[$level - 1]) {
-if (version_compare(PHP_VERSION,'5.4','>=')) {
-if (isset($obStatus[$level - 1]['flags']) && ($obStatus[$level - 1]['flags'] & PHP_OUTPUT_HANDLER_REMOVABLE)) {
-ob_end_flush();
-}
-} else {
-if (isset($obStatus[$level - 1]['del']) && $obStatus[$level - 1]['del']) {
-ob_end_flush();
-}
-}
-}
-}
-flush();
-}
-return $this;
-}
-public function setContent($content)
-{
-if (null !== $content && !is_string($content) && !is_numeric($content) && !is_callable(array($content,'__toString'))) {
-throw new \UnexpectedValueException(sprintf('The Response content must be a string or object implementing __toString(), "%s" given.', gettype($content)));
-}
-$this->content = (string) $content;
-return $this;
-}
-public function getContent()
-{
-return $this->content;
-}
-public function setProtocolVersion($version)
-{
-$this->version = $version;
-return $this;
-}
-public function getProtocolVersion()
-{
-return $this->version;
-}
-public function setStatusCode($code, $text = null)
-{
-$this->statusCode = $code = (int) $code;
-if ($this->isInvalid()) {
-throw new \InvalidArgumentException(sprintf('The HTTP status code "%s" is not valid.', $code));
-}
-if (null === $text) {
-$this->statusText = isset(self::$statusTexts[$code]) ? self::$statusTexts[$code] :'';
-return $this;
-}
-if (false === $text) {
-$this->statusText ='';
-return $this;
-}
-$this->statusText = $text;
-return $this;
-}
-public function getStatusCode()
-{
-return $this->statusCode;
-}
-public function setCharset($charset)
-{
-$this->charset = $charset;
-return $this;
-}
-public function getCharset()
-{
-return $this->charset;
-}
-public function isCacheable()
-{
-if (!in_array($this->statusCode, array(200, 203, 300, 301, 302, 404, 410))) {
-return false;
-}
-if ($this->headers->hasCacheControlDirective('no-store') || $this->headers->getCacheControlDirective('private')) {
-return false;
-}
-return $this->isValidateable() || $this->isFresh();
-}
-public function isFresh()
-{
-return $this->getTtl() > 0;
-}
-public function isValidateable()
-{
-return $this->headers->has('Last-Modified') || $this->headers->has('ETag');
-}
-public function setPrivate()
-{
-$this->headers->removeCacheControlDirective('public');
-$this->headers->addCacheControlDirective('private');
-return $this;
-}
-public function setPublic()
-{
-$this->headers->addCacheControlDirective('public');
-$this->headers->removeCacheControlDirective('private');
-return $this;
-}
-public function mustRevalidate()
-{
-return $this->headers->hasCacheControlDirective('must-revalidate') || $this->headers->has('proxy-revalidate');
-}
-public function getDate()
-{
-return $this->headers->getDate('Date', new \DateTime());
-}
-public function setDate(\DateTime $date)
-{
-$date->setTimezone(new \DateTimeZone('UTC'));
-$this->headers->set('Date', $date->format('D, d M Y H:i:s').' GMT');
-return $this;
-}
-public function getAge()
-{
-if (null !== $age = $this->headers->get('Age')) {
-return (int) $age;
-}
-return max(time() - $this->getDate()->format('U'), 0);
-}
-public function expire()
-{
-if ($this->isFresh()) {
-$this->headers->set('Age', $this->getMaxAge());
-}
-return $this;
-}
-public function getExpires()
-{
-try {
-return $this->headers->getDate('Expires');
-} catch (\RuntimeException $e) {
-return \DateTime::createFromFormat(DATE_RFC2822,'Sat, 01 Jan 00 00:00:00 +0000');
-}
-}
-public function setExpires(\DateTime $date = null)
-{
-if (null === $date) {
-$this->headers->remove('Expires');
-} else {
-$date = clone $date;
-$date->setTimezone(new \DateTimeZone('UTC'));
-$this->headers->set('Expires', $date->format('D, d M Y H:i:s').' GMT');
-}
-return $this;
-}
-public function getMaxAge()
-{
-if ($this->headers->hasCacheControlDirective('s-maxage')) {
-return (int) $this->headers->getCacheControlDirective('s-maxage');
-}
-if ($this->headers->hasCacheControlDirective('max-age')) {
-return (int) $this->headers->getCacheControlDirective('max-age');
-}
-if (null !== $this->getExpires()) {
-return $this->getExpires()->format('U') - $this->getDate()->format('U');
-}
-return null;
-}
-public function setMaxAge($value)
-{
-$this->headers->addCacheControlDirective('max-age', $value);
-return $this;
-}
-public function setSharedMaxAge($value)
-{
-$this->setPublic();
-$this->headers->addCacheControlDirective('s-maxage', $value);
-return $this;
-}
-public function getTtl()
-{
-if (null !== $maxAge = $this->getMaxAge()) {
-return $maxAge - $this->getAge();
-}
-return null;
-}
-public function setTtl($seconds)
-{
-$this->setSharedMaxAge($this->getAge() + $seconds);
-return $this;
-}
-public function setClientTtl($seconds)
-{
-$this->setMaxAge($this->getAge() + $seconds);
-return $this;
-}
-public function getLastModified()
-{
-return $this->headers->getDate('Last-Modified');
-}
-public function setLastModified(\DateTime $date = null)
-{
-if (null === $date) {
-$this->headers->remove('Last-Modified');
-} else {
-$date = clone $date;
-$date->setTimezone(new \DateTimeZone('UTC'));
-$this->headers->set('Last-Modified', $date->format('D, d M Y H:i:s').' GMT');
-}
-return $this;
-}
-public function getEtag()
-{
-return $this->headers->get('ETag');
-}
-public function setEtag($etag = null, $weak = false)
-{
-if (null === $etag) {
-$this->headers->remove('Etag');
-} else {
-if (0 !== strpos($etag,'"')) {
-$etag ='"'.$etag.'"';
-}
-$this->headers->set('ETag', (true === $weak ?'W/':'').$etag);
-}
-return $this;
-}
-public function setCache(array $options)
-{
-if ($diff = array_diff(array_keys($options), array('etag','last_modified','max_age','s_maxage','private','public'))) {
-throw new \InvalidArgumentException(sprintf('Response does not support the following options: "%s".', implode('", "', array_values($diff))));
-}
-if (isset($options['etag'])) {
-$this->setEtag($options['etag']);
-}
-if (isset($options['last_modified'])) {
-$this->setLastModified($options['last_modified']);
-}
-if (isset($options['max_age'])) {
-$this->setMaxAge($options['max_age']);
-}
-if (isset($options['s_maxage'])) {
-$this->setSharedMaxAge($options['s_maxage']);
-}
-if (isset($options['public'])) {
-if ($options['public']) {
-$this->setPublic();
-} else {
-$this->setPrivate();
-}
-}
-if (isset($options['private'])) {
-if ($options['private']) {
-$this->setPrivate();
-} else {
-$this->setPublic();
-}
-}
-return $this;
-}
-public function setNotModified()
-{
-$this->setStatusCode(304);
-$this->setContent(null);
-foreach (array('Allow','Content-Encoding','Content-Language','Content-Length','Content-MD5','Content-Type','Last-Modified') as $header) {
-$this->headers->remove($header);
-}
-return $this;
-}
-public function hasVary()
-{
-return null !== $this->headers->get('Vary');
-}
-public function getVary()
-{
-if (!$vary = $this->headers->get('Vary')) {
-return array();
-}
-return is_array($vary) ? $vary : preg_split('/[\s,]+/', $vary);
-}
-public function setVary($headers, $replace = true)
-{
-$this->headers->set('Vary', $headers, $replace);
-return $this;
-}
-public function isNotModified(Request $request)
-{
-if (!$request->isMethodSafe()) {
-return false;
-}
-$lastModified = $request->headers->get('If-Modified-Since');
-$notModified = false;
-if ($etags = $request->getEtags()) {
-$notModified = (in_array($this->getEtag(), $etags) || in_array('*', $etags)) && (!$lastModified || $this->headers->get('Last-Modified') == $lastModified);
-} elseif ($lastModified) {
-$notModified = $lastModified == $this->headers->get('Last-Modified');
-}
-if ($notModified) {
-$this->setNotModified();
-}
-return $notModified;
-}
-public function isInvalid()
-{
-return $this->statusCode < 100 || $this->statusCode >= 600;
-}
-public function isInformational()
-{
-return $this->statusCode >= 100 && $this->statusCode < 200;
-}
-public function isSuccessful()
-{
-return $this->statusCode >= 200 && $this->statusCode < 300;
-}
-public function isRedirection()
-{
-return $this->statusCode >= 300 && $this->statusCode < 400;
-}
-public function isClientError()
-{
-return $this->statusCode >= 400 && $this->statusCode < 500;
-}
-public function isServerError()
-{
-return $this->statusCode >= 500 && $this->statusCode < 600;
-}
-public function isOk()
-{
-return 200 === $this->statusCode;
-}
-public function isForbidden()
-{
-return 403 === $this->statusCode;
-}
-public function isNotFound()
-{
-return 404 === $this->statusCode;
-}
-public function isRedirect($location = null)
-{
-return in_array($this->statusCode, array(201, 301, 302, 303, 307, 308)) && (null === $location ?: $location == $this->headers->get('Location'));
-}
-public function isEmpty()
-{
-return in_array($this->statusCode, array(201, 204, 304));
-}
-protected function ensureIEOverSSLCompatibility(Request $request)
-{
-if (false !== stripos($this->headers->get('Content-Disposition'),'attachment') && preg_match('/MSIE (.*?);/i', $request->server->get('HTTP_USER_AGENT'), $match) == 1 && true === $request->isSecure()) {
-if (intval(preg_replace("/(MSIE )(.*?);/","$2", $match[0])) < 9) {
-$this->headers->remove('Cache-Control');
-}
-}
-}
-}
-}
-namespace Symfony\Component\HttpFoundation
-{
-class ResponseHeaderBag extends HeaderBag
-{
-const COOKIES_FLAT ='flat';
-const COOKIES_ARRAY ='array';
-const DISPOSITION_ATTACHMENT ='attachment';
-const DISPOSITION_INLINE ='inline';
-protected $computedCacheControl = array();
-protected $cookies = array();
-protected $headerNames = array();
-public function __construct(array $headers = array())
-{
-parent::__construct($headers);
-if (!isset($this->headers['cache-control'])) {
-$this->set('Cache-Control','');
-}
-}
-public function __toString()
-{
-$cookies ='';
-foreach ($this->getCookies() as $cookie) {
-$cookies .='Set-Cookie: '.$cookie."\r\n";
-}
-ksort($this->headerNames);
-return parent::__toString().$cookies;
-}
-public function allPreserveCase()
-{
-return array_combine($this->headerNames, $this->headers);
-}
-public function replace(array $headers = array())
-{
-$this->headerNames = array();
-parent::replace($headers);
-if (!isset($this->headers['cache-control'])) {
-$this->set('Cache-Control','');
-}
-}
-public function set($key, $values, $replace = true)
-{
-parent::set($key, $values, $replace);
-$uniqueKey = strtr(strtolower($key),'_','-');
-$this->headerNames[$uniqueKey] = $key;
-if (in_array($uniqueKey, array('cache-control','etag','last-modified','expires'))) {
-$computed = $this->computeCacheControlValue();
-$this->headers['cache-control'] = array($computed);
-$this->headerNames['cache-control'] ='Cache-Control';
-$this->computedCacheControl = $this->parseCacheControl($computed);
-}
-}
-public function remove($key)
-{
-parent::remove($key);
-$uniqueKey = strtr(strtolower($key),'_','-');
-unset($this->headerNames[$uniqueKey]);
-if ('cache-control'=== $uniqueKey) {
-$this->computedCacheControl = array();
-}
-}
-public function hasCacheControlDirective($key)
-{
-return array_key_exists($key, $this->computedCacheControl);
-}
-public function getCacheControlDirective($key)
-{
-return array_key_exists($key, $this->computedCacheControl) ? $this->computedCacheControl[$key] : null;
-}
-public function setCookie(Cookie $cookie)
-{
-$this->cookies[$cookie->getDomain()][$cookie->getPath()][$cookie->getName()] = $cookie;
-}
-public function removeCookie($name, $path ='/', $domain = null)
-{
-if (null === $path) {
-$path ='/';
-}
-unset($this->cookies[$domain][$path][$name]);
-if (empty($this->cookies[$domain][$path])) {
-unset($this->cookies[$domain][$path]);
-if (empty($this->cookies[$domain])) {
-unset($this->cookies[$domain]);
-}
-}
-}
-public function getCookies($format = self::COOKIES_FLAT)
-{
-if (!in_array($format, array(self::COOKIES_FLAT, self::COOKIES_ARRAY))) {
-throw new \InvalidArgumentException(sprintf('Format "%s" invalid (%s).', $format, implode(', ', array(self::COOKIES_FLAT, self::COOKIES_ARRAY))));
-}
-if (self::COOKIES_ARRAY === $format) {
-return $this->cookies;
-}
-$flattenedCookies = array();
-foreach ($this->cookies as $path) {
-foreach ($path as $cookies) {
-foreach ($cookies as $cookie) {
-$flattenedCookies[] = $cookie;
-}
-}
-}
-return $flattenedCookies;
-}
-public function clearCookie($name, $path ='/', $domain = null)
-{
-$this->setCookie(new Cookie($name, null, 1, $path, $domain));
-}
-public function makeDisposition($disposition, $filename, $filenameFallback ='')
-{
-if (!in_array($disposition, array(self::DISPOSITION_ATTACHMENT, self::DISPOSITION_INLINE))) {
-throw new \InvalidArgumentException(sprintf('The disposition must be either "%s" or "%s".', self::DISPOSITION_ATTACHMENT, self::DISPOSITION_INLINE));
-}
-if (''== $filenameFallback) {
-$filenameFallback = $filename;
-}
-if (!preg_match('/^[\x20-\x7e]*$/', $filenameFallback)) {
-throw new \InvalidArgumentException('The filename fallback must only contain ASCII characters.');
-}
-if (false !== strpos($filenameFallback,'%')) {
-throw new \InvalidArgumentException('The filename fallback cannot contain the "%" character.');
-}
-if (false !== strpos($filename,'/') || false !== strpos($filename,'\\') || false !== strpos($filenameFallback,'/') || false !== strpos($filenameFallback,'\\')) {
-throw new \InvalidArgumentException('The filename and the fallback cannot contain the "/" and "\\" characters.');
-}
-$output = sprintf('%s; filename="%s"', $disposition, str_replace('"','\\"', $filenameFallback));
-if ($filename !== $filenameFallback) {
-$output .= sprintf("; filename*=utf-8''%s", rawurlencode($filename));
-}
-return $output;
-}
-protected function computeCacheControlValue()
-{
-if (!$this->cacheControl && !$this->has('ETag') && !$this->has('Last-Modified') && !$this->has('Expires')) {
-return'no-cache';
-}
-if (!$this->cacheControl) {
-return'private, must-revalidate';
-}
-$header = $this->getCacheControlHeader();
-if (isset($this->cacheControl['public']) || isset($this->cacheControl['private'])) {
-return $header;
-}
-if (!isset($this->cacheControl['s-maxage'])) {
-return $header.', private';
-}
-return $header;
-}
-}
-}
-namespace Symfony\Component\DependencyInjection
-{
-interface ContainerAwareInterface
-{
-public function setContainer(ContainerInterface $container = null);
-}
-}
-namespace Symfony\Component\DependencyInjection
-{
-use Symfony\Component\DependencyInjection\Exception\InvalidArgumentException;
-use Symfony\Component\DependencyInjection\Exception\ServiceCircularReferenceException;
-use Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException;
-interface ContainerInterface
-{
-const EXCEPTION_ON_INVALID_REFERENCE = 1;
-const NULL_ON_INVALID_REFERENCE = 2;
-const IGNORE_ON_INVALID_REFERENCE = 3;
-const SCOPE_CONTAINER ='container';
-const SCOPE_PROTOTYPE ='prototype';
-public function set($id, $service, $scope = self::SCOPE_CONTAINER);
-public function get($id, $invalidBehavior = self::EXCEPTION_ON_INVALID_REFERENCE);
-public function has($id);
-public function getParameter($name);
-public function hasParameter($name);
-public function setParameter($name, $value);
-public function enterScope($name);
-public function leaveScope($name);
-public function addScope(ScopeInterface $scope);
-public function hasScope($name);
-public function isScopeActive($name);
-}
-}
-namespace Symfony\Component\DependencyInjection
-{
-interface IntrospectableContainerInterface extends ContainerInterface
-{
-public function initialized($id);
-}
-}
-namespace Symfony\Component\DependencyInjection
-{
-use Symfony\Component\DependencyInjection\Exception\InactiveScopeException;
-use Symfony\Component\DependencyInjection\Exception\InvalidArgumentException;
-use Symfony\Component\DependencyInjection\Exception\RuntimeException;
-use Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException;
-use Symfony\Component\DependencyInjection\Exception\ServiceCircularReferenceException;
-use Symfony\Component\DependencyInjection\ParameterBag\ParameterBagInterface;
-use Symfony\Component\DependencyInjection\ParameterBag\ParameterBag;
-use Symfony\Component\DependencyInjection\ParameterBag\FrozenParameterBag;
-class Container implements IntrospectableContainerInterface
-{
-protected $parameterBag;
-protected $services;
-protected $methodMap;
-protected $aliases;
-protected $scopes;
-protected $scopeChildren;
-protected $scopedServices;
-protected $scopeStacks;
-protected $loading = array();
-public function __construct(ParameterBagInterface $parameterBag = null)
-{
-$this->parameterBag = null === $parameterBag ? new ParameterBag() : $parameterBag;
-$this->services = array();
-$this->aliases = array();
-$this->scopes = array();
-$this->scopeChildren = array();
-$this->scopedServices = array();
-$this->scopeStacks = array();
-$this->set('service_container', $this);
-}
-public function compile()
-{
-$this->parameterBag->resolve();
-$this->parameterBag = new FrozenParameterBag($this->parameterBag->all());
-}
-public function isFrozen()
-{
-return $this->parameterBag instanceof FrozenParameterBag;
-}
-public function getParameterBag()
-{
-return $this->parameterBag;
-}
-public function getParameter($name)
-{
-return $this->parameterBag->get($name);
-}
-public function hasParameter($name)
-{
-return $this->parameterBag->has($name);
-}
-public function setParameter($name, $value)
-{
-$this->parameterBag->set($name, $value);
-}
-public function set($id, $service, $scope = self::SCOPE_CONTAINER)
-{
-if (self::SCOPE_PROTOTYPE === $scope) {
-throw new InvalidArgumentException(sprintf('You cannot set service "%s" of scope "prototype".', $id));
-}
-$id = strtolower($id);
-if (self::SCOPE_CONTAINER !== $scope) {
-if (!isset($this->scopedServices[$scope])) {
-throw new RuntimeException(sprintf('You cannot set service "%s" of inactive scope.', $id));
-}
-$this->scopedServices[$scope][$id] = $service;
-}
-$this->services[$id] = $service;
-if (method_exists($this, $method ='synchronize'.strtr($id, array('_'=>'','.'=>'_')).'Service')) {
-$this->$method();
-}
-if (self::SCOPE_CONTAINER !== $scope && null === $service) {
-unset($this->scopedServices[$scope][$id]);
-}
-if (null === $service) {
-unset($this->services[$id]);
-}
-}
-public function has($id)
-{
-$id = strtolower($id);
-return isset($this->services[$id])
-|| array_key_exists($id, $this->services)
-|| isset($this->aliases[$id])
-|| method_exists($this,'get'.strtr($id, array('_'=>'','.'=>'_')).'Service')
-;
-}
-public function get($id, $invalidBehavior = self::EXCEPTION_ON_INVALID_REFERENCE)
-{
-foreach (array(false, true) as $strtolower) {
-if ($strtolower) {
-$id = strtolower($id);
-}
-if (isset($this->aliases[$id])) {
-$id = $this->aliases[$id];
-}
-if (isset($this->services[$id]) || array_key_exists($id, $this->services)) {
-return $this->services[$id];
-}
-}
-if (isset($this->loading[$id])) {
-throw new ServiceCircularReferenceException($id, array_keys($this->loading));
-}
-if (isset($this->methodMap[$id])) {
-$method = $this->methodMap[$id];
-} elseif (method_exists($this, $method ='get'.strtr($id, array('_'=>'','.'=>'_')).'Service')) {
-} else {
-if (self::EXCEPTION_ON_INVALID_REFERENCE === $invalidBehavior) {
-if (!$id) {
-throw new ServiceNotFoundException($id);
-}
-$alternatives = array();
-foreach (array_keys($this->services) as $key) {
-$lev = levenshtein($id, $key);
-if ($lev <= strlen($id) / 3 || false !== strpos($key, $id)) {
-$alternatives[] = $key;
-}
-}
-throw new ServiceNotFoundException($id, null, null, $alternatives);
-}
-return null;
-}
-$this->loading[$id] = true;
-try {
-$service = $this->$method();
-} catch (\Exception $e) {
-unset($this->loading[$id]);
-if (array_key_exists($id, $this->services)) {
-unset($this->services[$id]);
-}
-if ($e instanceof InactiveScopeException && self::EXCEPTION_ON_INVALID_REFERENCE !== $invalidBehavior) {
-return null;
-}
-throw $e;
-}
-unset($this->loading[$id]);
-return $service;
-}
-public function initialized($id)
-{
-$id = strtolower($id);
-return isset($this->services[$id]) || array_key_exists($id, $this->services);
-}
-public function getServiceIds()
-{
-$ids = array();
-$r = new \ReflectionClass($this);
-foreach ($r->getMethods() as $method) {
-if (preg_match('/^get(.+)Service$/', $method->name, $match)) {
-$ids[] = self::underscore($match[1]);
-}
-}
-return array_unique(array_merge($ids, array_keys($this->services)));
-}
-public function enterScope($name)
-{
-if (!isset($this->scopes[$name])) {
-throw new InvalidArgumentException(sprintf('The scope "%s" does not exist.', $name));
-}
-if (self::SCOPE_CONTAINER !== $this->scopes[$name] && !isset($this->scopedServices[$this->scopes[$name]])) {
-throw new RuntimeException(sprintf('The parent scope "%s" must be active when entering this scope.', $this->scopes[$name]));
-}
-if (isset($this->scopedServices[$name])) {
-$services = array($this->services, $name => $this->scopedServices[$name]);
-unset($this->scopedServices[$name]);
-foreach ($this->scopeChildren[$name] as $child) {
-if (isset($this->scopedServices[$child])) {
-$services[$child] = $this->scopedServices[$child];
-unset($this->scopedServices[$child]);
-}
-}
-$this->services = call_user_func_array('array_diff_key', $services);
-array_shift($services);
-if (!isset($this->scopeStacks[$name])) {
-$this->scopeStacks[$name] = new \SplStack();
-}
-$this->scopeStacks[$name]->push($services);
-}
-$this->scopedServices[$name] = array();
-}
-public function leaveScope($name)
-{
-if (!isset($this->scopedServices[$name])) {
-throw new InvalidArgumentException(sprintf('The scope "%s" is not active.', $name));
-}
-$services = array($this->services, $this->scopedServices[$name]);
-unset($this->scopedServices[$name]);
-foreach ($this->scopeChildren[$name] as $child) {
-if (!isset($this->scopedServices[$child])) {
-continue;
-}
-$services[] = $this->scopedServices[$child];
-unset($this->scopedServices[$child]);
-}
-$this->services = call_user_func_array('array_diff_key', $services);
-if (isset($this->scopeStacks[$name]) && count($this->scopeStacks[$name]) > 0) {
-$services = $this->scopeStacks[$name]->pop();
-$this->scopedServices += $services;
-foreach ($services as $array) {
-foreach ($array as $id => $service) {
-$this->set($id, $service, $name);
-}
-}
-}
-}
-public function addScope(ScopeInterface $scope)
-{
-$name = $scope->getName();
-$parentScope = $scope->getParentName();
-if (self::SCOPE_CONTAINER === $name || self::SCOPE_PROTOTYPE === $name) {
-throw new InvalidArgumentException(sprintf('The scope "%s" is reserved.', $name));
-}
-if (isset($this->scopes[$name])) {
-throw new InvalidArgumentException(sprintf('A scope with name "%s" already exists.', $name));
-}
-if (self::SCOPE_CONTAINER !== $parentScope && !isset($this->scopes[$parentScope])) {
-throw new InvalidArgumentException(sprintf('The parent scope "%s" does not exist, or is invalid.', $parentScope));
-}
-$this->scopes[$name] = $parentScope;
-$this->scopeChildren[$name] = array();
-while ($parentScope !== self::SCOPE_CONTAINER) {
-$this->scopeChildren[$parentScope][] = $name;
-$parentScope = $this->scopes[$parentScope];
-}
-}
-public function hasScope($name)
-{
-return isset($this->scopes[$name]);
-}
-public function isScopeActive($name)
-{
-return isset($this->scopedServices[$name]);
-}
-public static function camelize($id)
-{
-return strtr(ucwords(strtr($id, array('_'=>' ','.'=>'_ '))), array(' '=>''));
-}
-public static function underscore($id)
-{
-return strtolower(preg_replace(array('/([A-Z]+)([A-Z][a-z])/','/([a-z\d])([A-Z])/'), array('\\1_\\2','\\1_\\2'), strtr($id,'_','.')));
-}
-}
-}
-namespace Symfony\Component\HttpKernel
-{
-use Symfony\Component\HttpFoundation\Request;
-use Symfony\Component\HttpFoundation\Response;
-interface HttpKernelInterface
-{
-const MASTER_REQUEST = 1;
-const SUB_REQUEST = 2;
-public function handle(Request $request, $type = self::MASTER_REQUEST, $catch = true);
-}
-}
-namespace Symfony\Component\HttpKernel
-{
-use Symfony\Component\DependencyInjection\ContainerInterface;
-use Symfony\Component\HttpKernel\HttpKernelInterface;
-use Symfony\Component\HttpKernel\Bundle\BundleInterface;
-use Symfony\Component\Config\Loader\LoaderInterface;
-interface KernelInterface extends HttpKernelInterface, \Serializable
-{
-public function registerBundles();
-public function registerContainerConfiguration(LoaderInterface $loader);
-public function boot();
-public function shutdown();
-public function getBundles();
-public function isClassInActiveBundle($class);
-public function getBundle($name, $first = true);
-public function locateResource($name, $dir = null, $first = true);
-public function getName();
-public function getEnvironment();
-public function isDebug();
-public function getRootDir();
-public function getContainer();
-public function getStartTime();
-public function getCacheDir();
-public function getLogDir();
-public function getCharset();
-}
-}
-namespace Symfony\Component\HttpKernel
-{
-use Symfony\Component\HttpFoundation\Request;
-use Symfony\Component\HttpFoundation\Response;
-interface TerminableInterface
-{
-public function terminate(Request $request, Response $response);
-}
-}
-namespace Symfony\Component\HttpKernel
-{
-use Symfony\Bridge\ProxyManager\LazyProxy\Instantiator\RuntimeInstantiator;
-use Symfony\Bridge\ProxyManager\LazyProxy\PhpDumper\ProxyDumper;
-use Symfony\Component\DependencyInjection\ContainerInterface;
-use Symfony\Component\DependencyInjection\ContainerBuilder;
-use Symfony\Component\DependencyInjection\Dumper\PhpDumper;
-use Symfony\Component\DependencyInjection\ParameterBag\ParameterBag;
-use Symfony\Component\DependencyInjection\Loader\XmlFileLoader;
-use Symfony\Component\DependencyInjection\Loader\YamlFileLoader;
-use Symfony\Component\DependencyInjection\Loader\IniFileLoader;
-use Symfony\Component\DependencyInjection\Loader\PhpFileLoader;
-use Symfony\Component\DependencyInjection\Loader\ClosureLoader;
-use Symfony\Component\HttpFoundation\Request;
-use Symfony\Component\HttpFoundation\Response;
-use Symfony\Component\HttpKernel\HttpKernelInterface;
-use Symfony\Component\HttpKernel\Bundle\BundleInterface;
-use Symfony\Component\HttpKernel\Config\FileLocator;
-use Symfony\Component\HttpKernel\DependencyInjection\MergeExtensionConfigurationPass;
-use Symfony\Component\HttpKernel\DependencyInjection\AddClassesToCachePass;
-use Symfony\Component\Config\Loader\LoaderResolver;
-use Symfony\Component\Config\Loader\DelegatingLoader;
-use Symfony\Component\Config\ConfigCache;
-use Symfony\Component\ClassLoader\ClassCollectionLoader;
-abstract class Kernel implements KernelInterface, TerminableInterface
-{
-protected $bundles;
-protected $bundleMap;
-protected $container;
-protected $rootDir;
-protected $environment;
-protected $debug;
-protected $booted;
-protected $name;
-protected $startTime;
-protected $loadClassCache;
-const VERSION ='2.3.5';
-const VERSION_ID ='20305';
-const MAJOR_VERSION ='2';
-const MINOR_VERSION ='3';
-const RELEASE_VERSION ='5';
-const EXTRA_VERSION ='';
-public function __construct($environment, $debug)
-{
-$this->environment = $environment;
-$this->debug = (Boolean) $debug;
-$this->booted = false;
-$this->rootDir = $this->getRootDir();
-$this->name = $this->getName();
-$this->bundles = array();
-if ($this->debug) {
-$this->startTime = microtime(true);
-}
-$this->init();
-}
-public function init()
-{
-}
-public function __clone()
-{
-if ($this->debug) {
-$this->startTime = microtime(true);
-}
-$this->booted = false;
-$this->container = null;
-}
-public function boot()
-{
-if (true === $this->booted) {
-return;
-}
-if ($this->loadClassCache) {
-$this->doLoadClassCache($this->loadClassCache[0], $this->loadClassCache[1]);
-}
-$this->initializeBundles();
-$this->initializeContainer();
-foreach ($this->getBundles() as $bundle) {
-$bundle->setContainer($this->container);
-$bundle->boot();
-}
-$this->booted = true;
-}
-public function terminate(Request $request, Response $response)
-{
-if (false === $this->booted) {
-return;
-}
-if ($this->getHttpKernel() instanceof TerminableInterface) {
-$this->getHttpKernel()->terminate($request, $response);
-}
-}
-public function shutdown()
-{
-if (false === $this->booted) {
-return;
-}
-$this->booted = false;
-foreach ($this->getBundles() as $bundle) {
-$bundle->shutdown();
-$bundle->setContainer(null);
-}
-$this->container = null;
-}
-public function handle(Request $request, $type = HttpKernelInterface::MASTER_REQUEST, $catch = true)
-{
-if (false === $this->booted) {
-$this->boot();
-}
-return $this->getHttpKernel()->handle($request, $type, $catch);
-}
-protected function getHttpKernel()
-{
-return $this->container->get('http_kernel');
-}
-public function getBundles()
-{
-return $this->bundles;
-}
-public function isClassInActiveBundle($class)
-{
-foreach ($this->getBundles() as $bundle) {
-if (0 === strpos($class, $bundle->getNamespace())) {
-return true;
-}
-}
-return false;
-}
-public function getBundle($name, $first = true)
-{
-if (!isset($this->bundleMap[$name])) {
-throw new \InvalidArgumentException(sprintf('Bundle "%s" does not exist or it is not enabled. Maybe you forgot to add it in the registerBundles() method of your %s.php file?', $name, get_class($this)));
-}
-if (true === $first) {
-return $this->bundleMap[$name][0];
-}
-return $this->bundleMap[$name];
-}
-public function locateResource($name, $dir = null, $first = true)
-{
-if ('@'!== $name[0]) {
-throw new \InvalidArgumentException(sprintf('A resource name must start with @ ("%s" given).', $name));
-}
-if (false !== strpos($name,'..')) {
-throw new \RuntimeException(sprintf('File name "%s" contains invalid characters (..).', $name));
-}
-$bundleName = substr($name, 1);
-$path ='';
-if (false !== strpos($bundleName,'/')) {
-list($bundleName, $path) = explode('/', $bundleName, 2);
-}
-$isResource = 0 === strpos($path,'Resources') && null !== $dir;
-$overridePath = substr($path, 9);
-$resourceBundle = null;
-$bundles = $this->getBundle($bundleName, false);
-$files = array();
-foreach ($bundles as $bundle) {
-if ($isResource && file_exists($file = $dir.'/'.$bundle->getName().$overridePath)) {
-if (null !== $resourceBundle) {
-throw new \RuntimeException(sprintf('"%s" resource is hidden by a resource from the "%s" derived bundle. Create a "%s" file to override the bundle resource.',
-$file,
-$resourceBundle,
-$dir.'/'.$bundles[0]->getName().$overridePath
-));
-}
-if ($first) {
-return $file;
-}
-$files[] = $file;
-}
-if (file_exists($file = $bundle->getPath().'/'.$path)) {
-if ($first && !$isResource) {
-return $file;
-}
-$files[] = $file;
-$resourceBundle = $bundle->getName();
-}
-}
-if (count($files) > 0) {
-return $first && $isResource ? $files[0] : $files;
-}
-throw new \InvalidArgumentException(sprintf('Unable to find file "%s".', $name));
-}
-public function getName()
-{
-if (null === $this->name) {
-$this->name = preg_replace('/[^a-zA-Z0-9_]+/','', basename($this->rootDir));
-}
-return $this->name;
-}
-public function getEnvironment()
-{
-return $this->environment;
-}
-public function isDebug()
-{
-return $this->debug;
-}
-public function getRootDir()
-{
-if (null === $this->rootDir) {
-$r = new \ReflectionObject($this);
-$this->rootDir = str_replace('\\','/', dirname($r->getFileName()));
-}
-return $this->rootDir;
-}
-public function getContainer()
-{
-return $this->container;
-}
-public function loadClassCache($name ='classes', $extension ='.php')
-{
-$this->loadClassCache = array($name, $extension);
-}
-public function setClassCache(array $classes)
-{
-file_put_contents($this->getCacheDir().'/classes.map', sprintf('<?php return %s;', var_export($classes, true)));
-}
-public function getStartTime()
-{
-return $this->debug ? $this->startTime : -INF;
-}
-public function getCacheDir()
-{
-return $this->rootDir.'/cache/'.$this->environment;
-}
-public function getLogDir()
-{
-return $this->rootDir.'/logs';
-}
-public function getCharset()
-{
-return'UTF-8';
-}
-protected function doLoadClassCache($name, $extension)
-{
-if (!$this->booted && is_file($this->getCacheDir().'/classes.map')) {
-ClassCollectionLoader::load(include($this->getCacheDir().'/classes.map'), $this->getCacheDir(), $name, $this->debug, false, $extension);
-}
-}
-protected function initializeBundles()
-{
-$this->bundles = array();
-$topMostBundles = array();
-$directChildren = array();
-foreach ($this->registerBundles() as $bundle) {
-$name = $bundle->getName();
-if (isset($this->bundles[$name])) {
-throw new \LogicException(sprintf('Trying to register two bundles with the same name "%s"', $name));
-}
-$this->bundles[$name] = $bundle;
-if ($parentName = $bundle->getParent()) {
-if (isset($directChildren[$parentName])) {
-throw new \LogicException(sprintf('Bundle "%s" is directly extended by two bundles "%s" and "%s".', $parentName, $name, $directChildren[$parentName]));
-}
-if ($parentName == $name) {
-throw new \LogicException(sprintf('Bundle "%s" can not extend itself.', $name));
-}
-$directChildren[$parentName] = $name;
-} else {
-$topMostBundles[$name] = $bundle;
-}
-}
-if (count($diff = array_values(array_diff(array_keys($directChildren), array_keys($this->bundles))))) {
-throw new \LogicException(sprintf('Bundle "%s" extends bundle "%s", which is not registered.', $directChildren[$diff[0]], $diff[0]));
-}
-$this->bundleMap = array();
-foreach ($topMostBundles as $name => $bundle) {
-$bundleMap = array($bundle);
-$hierarchy = array($name);
-while (isset($directChildren[$name])) {
-$name = $directChildren[$name];
-array_unshift($bundleMap, $this->bundles[$name]);
-$hierarchy[] = $name;
-}
-foreach ($hierarchy as $bundle) {
-$this->bundleMap[$bundle] = $bundleMap;
-array_pop($bundleMap);
-}
-}
-}
-protected function getContainerClass()
-{
-return $this->name.ucfirst($this->environment).($this->debug ?'Debug':'').'ProjectContainer';
-}
-protected function getContainerBaseClass()
-{
-return'Container';
-}
-protected function initializeContainer()
-{
-$class = $this->getContainerClass();
-$cache = new ConfigCache($this->getCacheDir().'/'.$class.'.php', $this->debug);
-$fresh = true;
-if (!$cache->isFresh()) {
-$container = $this->buildContainer();
-$container->compile();
-$this->dumpContainer($cache, $container, $class, $this->getContainerBaseClass());
-$fresh = false;
-}
-require_once $cache;
-$this->container = new $class();
-$this->container->set('kernel', $this);
-if (!$fresh && $this->container->has('cache_warmer')) {
-$this->container->get('cache_warmer')->warmUp($this->container->getParameter('kernel.cache_dir'));
-}
-}
-protected function getKernelParameters()
-{
-$bundles = array();
-foreach ($this->bundles as $name => $bundle) {
-$bundles[$name] = get_class($bundle);
-}
-return array_merge(
-array('kernel.root_dir'=> $this->rootDir,'kernel.environment'=> $this->environment,'kernel.debug'=> $this->debug,'kernel.name'=> $this->name,'kernel.cache_dir'=> $this->getCacheDir(),'kernel.logs_dir'=> $this->getLogDir(),'kernel.bundles'=> $bundles,'kernel.charset'=> $this->getCharset(),'kernel.container_class'=> $this->getContainerClass(),
-),
-$this->getEnvParameters()
-);
-}
-protected function getEnvParameters()
-{
-$parameters = array();
-foreach ($_SERVER as $key => $value) {
-if (0 === strpos($key,'SYMFONY__')) {
-$parameters[strtolower(str_replace('__','.', substr($key, 9)))] = $value;
-}
-}
-return $parameters;
-}
-protected function buildContainer()
-{
-foreach (array('cache'=> $this->getCacheDir(),'logs'=> $this->getLogDir()) as $name => $dir) {
-if (!is_dir($dir)) {
-if (false === @mkdir($dir, 0777, true)) {
-throw new \RuntimeException(sprintf("Unable to create the %s directory (%s)\n", $name, $dir));
-}
-} elseif (!is_writable($dir)) {
-throw new \RuntimeException(sprintf("Unable to write in the %s directory (%s)\n", $name, $dir));
-}
-}
-$container = $this->getContainerBuilder();
-$container->addObjectResource($this);
-$this->prepareContainer($container);
-if (null !== $cont = $this->registerContainerConfiguration($this->getContainerLoader($container))) {
-$container->merge($cont);
-}
-$container->addCompilerPass(new AddClassesToCachePass($this));
-return $container;
-}
-protected function prepareContainer(ContainerBuilder $container)
-{
-$extensions = array();
-foreach ($this->bundles as $bundle) {
-if ($extension = $bundle->getContainerExtension()) {
-$container->registerExtension($extension);
-$extensions[] = $extension->getAlias();
-}
-if ($this->debug) {
-$container->addObjectResource($bundle);
-}
-}
-foreach ($this->bundles as $bundle) {
-$bundle->build($container);
-}
-$container->getCompilerPassConfig()->setMergePass(new MergeExtensionConfigurationPass($extensions));
-}
-protected function getContainerBuilder()
-{
-$container = new ContainerBuilder(new ParameterBag($this->getKernelParameters()));
-if (class_exists('ProxyManager\Configuration')) {
-$container->setProxyInstantiator(new RuntimeInstantiator());
-}
-return $container;
-}
-protected function dumpContainer(ConfigCache $cache, ContainerBuilder $container, $class, $baseClass)
-{
-$dumper = new PhpDumper($container);
-if (class_exists('ProxyManager\Configuration')) {
-$dumper->setProxyDumper(new ProxyDumper());
-}
-$content = $dumper->dump(array('class'=> $class,'base_class'=> $baseClass));
-if (!$this->debug) {
-$content = self::stripComments($content);
-}
-$cache->write($content, $container->getResources());
-}
-protected function getContainerLoader(ContainerInterface $container)
-{
-$locator = new FileLocator($this);
-$resolver = new LoaderResolver(array(
-new XmlFileLoader($container, $locator),
-new YamlFileLoader($container, $locator),
-new IniFileLoader($container, $locator),
-new PhpFileLoader($container, $locator),
-new ClosureLoader($container),
-));
-return new DelegatingLoader($resolver);
-}
-public static function stripComments($source)
-{
-if (!function_exists('token_get_all')) {
-return $source;
-}
-$rawChunk ='';
-$output ='';
-$tokens = token_get_all($source);
-for (reset($tokens); false !== $token = current($tokens); next($tokens)) {
-if (is_string($token)) {
-$rawChunk .= $token;
-} elseif (T_START_HEREDOC === $token[0]) {
-$output .= preg_replace(array('/\s+$/Sm','/\n+/S'),"\n", $rawChunk).$token[1];
-do {
-$token = next($tokens);
-$output .= $token[1];
-} while ($token[0] !== T_END_HEREDOC);
-$rawChunk ='';
-} elseif (!in_array($token[0], array(T_COMMENT, T_DOC_COMMENT))) {
-$rawChunk .= $token[1];
-}
-}
-$output .= preg_replace(array('/\s+$/Sm','/\n+/S'),"\n", $rawChunk);
-return $output;
-}
-public function serialize()
-{
-return serialize(array($this->environment, $this->debug));
-}
-public function unserialize($data)
-{
-list($environment, $debug) = unserialize($data);
-$this->__construct($environment, $debug);
-}
-}
-}
-namespace Symfony\Component\ClassLoader
-{
-class ApcClassLoader
-{
-private $prefix;
-protected $decorated;
-public function __construct($prefix, $decorated)
-{
-if (!extension_loaded('apc')) {
-throw new \RuntimeException('Unable to use ApcClassLoader as APC is not enabled.');
-}
-if (!method_exists($decorated,'findFile')) {
-throw new \InvalidArgumentException('The class finder must implement a "findFile" method.');
-}
-$this->prefix = $prefix;
-$this->decorated = $decorated;
-}
-public function register($prepend = false)
-{
-spl_autoload_register(array($this,'loadClass'), true, $prepend);
-}
-public function unregister()
-{
-spl_autoload_unregister(array($this,'loadClass'));
-}
-public function loadClass($class)
-{
-if ($file = $this->findFile($class)) {
-require $file;
-return true;
-}
-}
-public function findFile($class)
-{
-if (false === $file = apc_fetch($this->prefix.$class)) {
-apc_store($this->prefix.$class, $file = $this->decorated->findFile($class));
-}
-return $file;
-}
-public function __call($method, $args)
-{
-return call_user_func_array(array($this->decorated, $method), $args);
-}
-}
-}
-namespace Symfony\Component\HttpKernel\Bundle
-{
-use Symfony\Component\DependencyInjection\ContainerAwareInterface;
-use Symfony\Component\DependencyInjection\ContainerBuilder;
-use Symfony\Component\DependencyInjection\Extension\ExtensionInterface;
-interface BundleInterface extends ContainerAwareInterface
-{
-public function boot();
-public function shutdown();
-public function build(ContainerBuilder $container);
-public function getContainerExtension();
-public function getParent();
-public function getName();
-public function getNamespace();
-public function getPath();
-}
-}
-namespace Symfony\Component\DependencyInjection
-{
-abstract class ContainerAware implements ContainerAwareInterface
-{
-protected $container;
-public function setContainer(ContainerInterface $container = null)
-{
-$this->container = $container;
-}
-}
-}
-namespace Symfony\Component\HttpKernel\Bundle
-{
-use Symfony\Component\DependencyInjection\ContainerAware;
-use Symfony\Component\DependencyInjection\ContainerBuilder;
-use Symfony\Component\DependencyInjection\Container;
-use Symfony\Component\Console\Application;
-use Symfony\Component\Finder\Finder;
-use Symfony\Component\DependencyInjection\Extension\ExtensionInterface;
-abstract class Bundle extends ContainerAware implements BundleInterface
-{
-protected $name;
-protected $reflected;
-protected $extension;
-public function boot()
-{
-}
-public function shutdown()
-{
-}
-public function build(ContainerBuilder $container)
-{
-}
-public function getContainerExtension()
-{
-if (null === $this->extension) {
-$basename = preg_replace('/Bundle$/','', $this->getName());
-$class = $this->getNamespace().'\\DependencyInjection\\'.$basename.'Extension';
-if (class_exists($class)) {
-$extension = new $class();
-$expectedAlias = Container::underscore($basename);
-if ($expectedAlias != $extension->getAlias()) {
-throw new \LogicException(sprintf('The extension alias for the default extension of a '.'bundle must be the underscored version of the '.'bundle name ("%s" instead of "%s")',
-$expectedAlias, $extension->getAlias()
-));
-}
-$this->extension = $extension;
-} else {
-$this->extension = false;
-}
-}
-if ($this->extension) {
-return $this->extension;
-}
-}
-public function getNamespace()
-{
-if (null === $this->reflected) {
-$this->reflected = new \ReflectionObject($this);
-}
-return $this->reflected->getNamespaceName();
-}
-public function getPath()
-{
-if (null === $this->reflected) {
-$this->reflected = new \ReflectionObject($this);
-}
-return dirname($this->reflected->getFileName());
-}
-public function getParent()
-{
-return null;
-}
-final public function getName()
-{
-if (null !== $this->name) {
-return $this->name;
-}
-$name = get_class($this);
-$pos = strrpos($name,'\\');
-return $this->name = false === $pos ? $name : substr($name, $pos + 1);
-}
-public function registerCommands(Application $application)
-{
-if (!is_dir($dir = $this->getPath().'/Command')) {
-return;
-}
-$finder = new Finder();
-$finder->files()->name('*Command.php')->in($dir);
-$prefix = $this->getNamespace().'\\Command';
-foreach ($finder as $file) {
-$ns = $prefix;
-if ($relativePath = $file->getRelativePath()) {
-$ns .='\\'.strtr($relativePath,'/','\\');
-}
-$r = new \ReflectionClass($ns.'\\'.$file->getBasename('.php'));
-if ($r->isSubclassOf('Symfony\\Component\\Console\\Command\\Command') && !$r->isAbstract() && !$r->getConstructor()->getNumberOfRequiredParameters()) {
-$application->add($r->newInstance());
-}
-}
-}
-}
-}
-namespace Symfony\Component\Config
-{
-use Symfony\Component\Config\Resource\ResourceInterface;
-use Symfony\Component\Filesystem\Filesystem;
-class ConfigCache
-{
-private $debug;
-private $file;
-public function __construct($file, $debug)
-{
-$this->file = $file;
-$this->debug = (Boolean) $debug;
-}
-public function __toString()
-{
-return $this->file;
-}
-public function isFresh()
-{
-if (!is_file($this->file)) {
-return false;
-}
-if (!$this->debug) {
-return true;
-}
-$metadata = $this->getMetaFile();
-if (!is_file($metadata)) {
-return false;
-}
-$time = filemtime($this->file);
-$meta = unserialize(file_get_contents($metadata));
-foreach ($meta as $resource) {
-if (!$resource->isFresh($time)) {
-return false;
-}
-}
-return true;
-}
-public function write($content, array $metadata = null)
-{
-$mode = 0666 & ~umask();
-$filesystem = new Filesystem();
-$filesystem->dumpFile($this->file, $content, $mode);
-if (null !== $metadata && true === $this->debug) {
-$filesystem->dumpFile($this->getMetaFile(), serialize($metadata), $mode);
-}
-}
-private function getMetaFile()
-{
-return $this->file.'.meta';
-}
-}
-}
-namespace Symfony\Component\HttpKernel
-{
-use Symfony\Component\HttpKernel\Controller\ControllerResolverInterface;
-use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
-use Symfony\Component\HttpKernel\Exception\HttpExceptionInterface;
-use Symfony\Component\HttpKernel\Event\FilterControllerEvent;
-use Symfony\Component\HttpKernel\Event\FilterResponseEvent;
-use Symfony\Component\HttpKernel\Event\GetResponseEvent;
-use Symfony\Component\HttpKernel\Event\GetResponseForControllerResultEvent;
-use Symfony\Component\HttpKernel\Event\GetResponseForExceptionEvent;
-use Symfony\Component\HttpKernel\Event\PostResponseEvent;
-use Symfony\Component\HttpFoundation\Request;
-use Symfony\Component\HttpFoundation\Response;
-use Symfony\Component\EventDispatcher\EventDispatcherInterface;
-class HttpKernel implements HttpKernelInterface, TerminableInterface
-{
-protected $dispatcher;
-protected $resolver;
-public function __construct(EventDispatcherInterface $dispatcher, ControllerResolverInterface $resolver)
-{
-$this->dispatcher = $dispatcher;
-$this->resolver = $resolver;
-}
-public function handle(Request $request, $type = HttpKernelInterface::MASTER_REQUEST, $catch = true)
-{
-try {
-return $this->handleRaw($request, $type);
-} catch (\Exception $e) {
-if (false === $catch) {
-throw $e;
-}
-return $this->handleException($e, $request, $type);
-}
-}
-public function terminate(Request $request, Response $response)
-{
-$this->dispatcher->dispatch(KernelEvents::TERMINATE, new PostResponseEvent($this, $request, $response));
-}
-private function handleRaw(Request $request, $type = self::MASTER_REQUEST)
-{
-$event = new GetResponseEvent($this, $request, $type);
-$this->dispatcher->dispatch(KernelEvents::REQUEST, $event);
-if ($event->hasResponse()) {
-return $this->filterResponse($event->getResponse(), $request, $type);
-}
-if (false === $controller = $this->resolver->getController($request)) {
-throw new NotFoundHttpException(sprintf('Unable to find the controller for path "%s". Maybe you forgot to add the matching route in your routing configuration?', $request->getPathInfo()));
-}
-$event = new FilterControllerEvent($this, $controller, $request, $type);
-$this->dispatcher->dispatch(KernelEvents::CONTROLLER, $event);
-$controller = $event->getController();
-$arguments = $this->resolver->getArguments($request, $controller);
-$response = call_user_func_array($controller, $arguments);
-if (!$response instanceof Response) {
-$event = new GetResponseForControllerResultEvent($this, $request, $type, $response);
-$this->dispatcher->dispatch(KernelEvents::VIEW, $event);
-if ($event->hasResponse()) {
-$response = $event->getResponse();
-}
-if (!$response instanceof Response) {
-$msg = sprintf('The controller must return a response (%s given).', $this->varToString($response));
-if (null === $response) {
-$msg .=' Did you forget to add a return statement somewhere in your controller?';
-}
-throw new \LogicException($msg);
-}
-}
-return $this->filterResponse($response, $request, $type);
-}
-private function filterResponse(Response $response, Request $request, $type)
-{
-$event = new FilterResponseEvent($this, $request, $type, $response);
-$this->dispatcher->dispatch(KernelEvents::RESPONSE, $event);
-return $event->getResponse();
-}
-private function handleException(\Exception $e, $request, $type)
-{
-$event = new GetResponseForExceptionEvent($this, $request, $type, $e);
-$this->dispatcher->dispatch(KernelEvents::EXCEPTION, $event);
-$e = $event->getException();
-if (!$event->hasResponse()) {
-throw $e;
-}
-$response = $event->getResponse();
-if ($response->headers->has('X-Status-Code')) {
-$response->setStatusCode($response->headers->get('X-Status-Code'));
-$response->headers->remove('X-Status-Code');
-} elseif (!$response->isClientError() && !$response->isServerError() && !$response->isRedirect()) {
-if ($e instanceof HttpExceptionInterface) {
-$response->setStatusCode($e->getStatusCode());
-$response->headers->add($e->getHeaders());
-} else {
-$response->setStatusCode(500);
-}
-}
-try {
-return $this->filterResponse($response, $request, $type);
-} catch (\Exception $e) {
-return $response;
-}
-}
-private function varToString($var)
-{
-if (is_object($var)) {
-return sprintf('Object(%s)', get_class($var));
-}
-if (is_array($var)) {
-$a = array();
-foreach ($var as $k => $v) {
-$a[] = sprintf('%s => %s', $k, $this->varToString($v));
-}
-return sprintf("Array(%s)", implode(', ', $a));
-}
-if (is_resource($var)) {
-return sprintf('Resource(%s)', get_resource_type($var));
-}
-if (null === $var) {
-return'null';
-}
-if (false === $var) {
-return'false';
-}
-if (true === $var) {
-return'true';
-}
-return (string) $var;
-}
-}
-}
-namespace Symfony\Component\HttpKernel\DependencyInjection
-{
-use Symfony\Component\HttpFoundation\Request;
-use Symfony\Component\HttpKernel\HttpKernelInterface;
-use Symfony\Component\HttpKernel\HttpKernel;
-use Symfony\Component\HttpKernel\Controller\ControllerResolverInterface;
-use Symfony\Component\EventDispatcher\EventDispatcherInterface;
-use Symfony\Component\DependencyInjection\ContainerInterface;
-use Symfony\Component\DependencyInjection\Scope;
-class ContainerAwareHttpKernel extends HttpKernel
-{
-protected $container;
-public function __construct(EventDispatcherInterface $dispatcher, ContainerInterface $container, ControllerResolverInterface $controllerResolver)
-{
-parent::__construct($dispatcher, $controllerResolver);
-$this->container = $container;
-if (!$container->hasScope('request')) {
-$container->addScope(new Scope('request'));
-}
-}
-public function handle(Request $request, $type = HttpKernelInterface::MASTER_REQUEST, $catch = true)
-{
-$request->headers->set('X-Php-Ob-Level', ob_get_level());
-$this->container->enterScope('request');
-$this->container->set('request', $request,'request');
-try {
-$response = parent::handle($request, $type, $catch);
-} catch (\Exception $e) {
-$this->container->set('request', null,'request');
-$this->container->leaveScope('request');
-throw $e;
-}
-$this->container->set('request', null,'request');
-$this->container->leaveScope('request');
-return $response;
-}
-}
-}
-
-namespace { return $loader; }
-            

+ 0 - 9
frameworks/PHP/php-symfony2-stripped/bash_profile.sh

@@ -1,9 +0,0 @@
-#!/bin/bash
-
-export PHP_HOME=${IROOT}/php-5.5.17
-
-export PHP_FPM=$PHP_HOME/sbin/php-fpm
-
-export COMPOSER_HOME=${IROOT}/php-composer
-
-export NGINX_HOME=${IROOT}/nginx

+ 0 - 24
frameworks/PHP/php-symfony2-stripped/composer.json

@@ -1,24 +0,0 @@
-{
-    "name": "symfony/framework-standard-edition",
-    "description": "The \"Symfony Standard Edition\" distribution",
-    "autoload": {
-        "psr-0": { "": "src/" }
-    },
-    "require": {
-        "php": ">=5.3.3",
-        "symfony/symfony": "2.3.*",
-        "doctrine/orm": ">=2.2.3,<2.4-dev",
-        "doctrine/doctrine-bundle": "1.2.*"
-    },
-   "config": {
-        "bin-dir": "bin"
-    },
-    "minimum-stability": "stable",
-    "extra": {
-        "symfony-app-dir": "app",
-        "symfony-web-dir": "web",
-        "branch-alias": {
-            "dev-master": "2.3-dev"
-        }
-    }
-}

+ 0 - 3
frameworks/PHP/php-symfony2-stripped/install.sh

@@ -1,3 +0,0 @@
-#!/bin/bash
-
-fw_depends php composer nginx

+ 0 - 7
frameworks/PHP/php-symfony2-stripped/src/Skamander/BenchmarkBundle/Resources/views/Bench/raw/content.php

@@ -1,7 +0,0 @@
-<?php include 'template_header.php'; ?>
-
-<div class="block">
-    <?php include 'fortunes.php'; ?>
-</div>
-
-<?php include 'template_footer.php'; ?>

+ 0 - 9
frameworks/PHP/php-symfony2-stripped/src/Skamander/BenchmarkBundle/Resources/views/layout.html.php

@@ -1,9 +0,0 @@
-<?php $view->extend('::base.html.php') ?>
-
-<?php $view['slots']->set('title', 'Benchmark Bundle') ?>
-
-<?php $view['slots']->start('body') ?>
-    <div class="block">
-        <?php $view['slots']->output('content') ?>
-    </div>
-<?php $view['slots']->stop() ?>

+ 0 - 10
frameworks/PHP/php-symfony2/.travis.yml

@@ -1,10 +0,0 @@
-language: php
-
-php:
-  - 5.3.3
-  - 5.3
-  - 5.4
-
-before_script: composer install
-
-script: phpunit -c app

+ 0 - 0
frameworks/PHP/php-symfony2/__init__.py


+ 0 - 1136
frameworks/PHP/php-symfony2/app/bootstrap.php.cache

@@ -1,1136 +0,0 @@
-<?php
-
-namespace { $loader = require_once __DIR__.'/autoload.php'; }
-
- 
-namespace Symfony\Component\DependencyInjection
-{
-interface ContainerAwareInterface
-{
-public function setContainer(ContainerInterface $container = null);
-}
-}
-namespace Symfony\Component\DependencyInjection
-{
-use Symfony\Component\DependencyInjection\Exception\InvalidArgumentException;
-use Symfony\Component\DependencyInjection\Exception\ServiceCircularReferenceException;
-use Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException;
-interface ContainerInterface
-{
-const EXCEPTION_ON_INVALID_REFERENCE = 1;
-const NULL_ON_INVALID_REFERENCE = 2;
-const IGNORE_ON_INVALID_REFERENCE = 3;
-const SCOPE_CONTAINER ='container';
-const SCOPE_PROTOTYPE ='prototype';
-public function set($id, $service, $scope = self::SCOPE_CONTAINER);
-public function get($id, $invalidBehavior = self::EXCEPTION_ON_INVALID_REFERENCE);
-public function has($id);
-public function getParameter($name);
-public function hasParameter($name);
-public function setParameter($name, $value);
-public function enterScope($name);
-public function leaveScope($name);
-public function addScope(ScopeInterface $scope);
-public function hasScope($name);
-public function isScopeActive($name);
-}
-}
-namespace Symfony\Component\DependencyInjection
-{
-interface IntrospectableContainerInterface extends ContainerInterface
-{
-public function initialized($id);
-}
-}
-namespace Symfony\Component\DependencyInjection
-{
-use Symfony\Component\DependencyInjection\Exception\InvalidArgumentException;
-use Symfony\Component\DependencyInjection\Exception\RuntimeException;
-use Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException;
-use Symfony\Component\DependencyInjection\Exception\ServiceCircularReferenceException;
-use Symfony\Component\DependencyInjection\ParameterBag\ParameterBagInterface;
-use Symfony\Component\DependencyInjection\ParameterBag\ParameterBag;
-use Symfony\Component\DependencyInjection\ParameterBag\FrozenParameterBag;
-class Container implements IntrospectableContainerInterface
-{
-protected $parameterBag;
-protected $services;
-protected $scopes;
-protected $scopeChildren;
-protected $scopedServices;
-protected $scopeStacks;
-protected $loading = array();
-public function __construct(ParameterBagInterface $parameterBag = null)
-{
-$this->parameterBag = null === $parameterBag ? new ParameterBag() : $parameterBag;
-$this->services = array();
-$this->scopes = array();
-$this->scopeChildren = array();
-$this->scopedServices = array();
-$this->scopeStacks = array();
-$this->set('service_container', $this);
-}
-public function compile()
-{
-$this->parameterBag->resolve();
-$this->parameterBag = new FrozenParameterBag($this->parameterBag->all());
-}
-public function isFrozen()
-{
-return $this->parameterBag instanceof FrozenParameterBag;
-}
-public function getParameterBag()
-{
-return $this->parameterBag;
-}
-public function getParameter($name)
-{
-return $this->parameterBag->get($name);
-}
-public function hasParameter($name)
-{
-return $this->parameterBag->has($name);
-}
-public function setParameter($name, $value)
-{
-$this->parameterBag->set($name, $value);
-}
-public function set($id, $service, $scope = self::SCOPE_CONTAINER)
-{
-if (self::SCOPE_PROTOTYPE === $scope) {
-throw new InvalidArgumentException(sprintf('You cannot set service "%s" of scope "prototype".', $id));
-}
-$id = strtolower($id);
-if (self::SCOPE_CONTAINER !== $scope) {
-if (!isset($this->scopedServices[$scope])) {
-throw new RuntimeException(sprintf('You cannot set service "%s" of inactive scope.', $id));
-}
-$this->scopedServices[$scope][$id] = $service;
-}
-$this->services[$id] = $service;
-}
-public function has($id)
-{
-$id = strtolower($id);
-return isset($this->services[$id]) || method_exists($this,'get'.strtr($id, array('_'=>'','.'=>'_')).'Service');
-}
-public function get($id, $invalidBehavior = self::EXCEPTION_ON_INVALID_REFERENCE)
-{
-$id = strtolower($id);
-if (isset($this->services[$id])) {
-return $this->services[$id];
-}
-if (isset($this->loading[$id])) {
-throw new ServiceCircularReferenceException($id, array_keys($this->loading));
-}
-if (method_exists($this, $method ='get'.strtr($id, array('_'=>'','.'=>'_')).'Service')) {
-$this->loading[$id] = true;
-try {
-$service = $this->$method();
-} catch (\Exception $e) {
-unset($this->loading[$id]);
-if (isset($this->services[$id])) {
-unset($this->services[$id]);
-}
-throw $e;
-}
-unset($this->loading[$id]);
-return $service;
-}
-if (self::EXCEPTION_ON_INVALID_REFERENCE === $invalidBehavior) {
-throw new ServiceNotFoundException($id);
-}
-}
-public function initialized($id)
-{
-return isset($this->services[strtolower($id)]);
-}
-public function getServiceIds()
-{
-$ids = array();
-$r = new \ReflectionClass($this);
-foreach ($r->getMethods() as $method) {
-if (preg_match('/^get(.+)Service$/', $method->name, $match)) {
-$ids[] = self::underscore($match[1]);
-}
-}
-return array_unique(array_merge($ids, array_keys($this->services)));
-}
-public function enterScope($name)
-{
-if (!isset($this->scopes[$name])) {
-throw new InvalidArgumentException(sprintf('The scope "%s" does not exist.', $name));
-}
-if (self::SCOPE_CONTAINER !== $this->scopes[$name] && !isset($this->scopedServices[$this->scopes[$name]])) {
-throw new RuntimeException(sprintf('The parent scope "%s" must be active when entering this scope.', $this->scopes[$name]));
-}
-if (isset($this->scopedServices[$name])) {
-$services = array($this->services, $name => $this->scopedServices[$name]);
-unset($this->scopedServices[$name]);
-foreach ($this->scopeChildren[$name] as $child) {
-if (isset($this->scopedServices[$child])) {
-$services[$child] = $this->scopedServices[$child];
-unset($this->scopedServices[$child]);
-}
-}
-$this->services = call_user_func_array('array_diff_key', $services);
-array_shift($services);
-if (!isset($this->scopeStacks[$name])) {
-$this->scopeStacks[$name] = new \SplStack();
-}
-$this->scopeStacks[$name]->push($services);
-}
-$this->scopedServices[$name] = array();
-}
-public function leaveScope($name)
-{
-if (!isset($this->scopedServices[$name])) {
-throw new InvalidArgumentException(sprintf('The scope "%s" is not active.', $name));
-}
-$services = array($this->services, $this->scopedServices[$name]);
-unset($this->scopedServices[$name]);
-foreach ($this->scopeChildren[$name] as $child) {
-if (!isset($this->scopedServices[$child])) {
-continue;
-}
-$services[] = $this->scopedServices[$child];
-unset($this->scopedServices[$child]);
-}
-$this->services = call_user_func_array('array_diff_key', $services);
-if (isset($this->scopeStacks[$name]) && count($this->scopeStacks[$name]) > 0) {
-$services = $this->scopeStacks[$name]->pop();
-$this->scopedServices += $services;
-array_unshift($services, $this->services);
-$this->services = call_user_func_array('array_merge', $services);
-}
-}
-public function addScope(ScopeInterface $scope)
-{
-$name = $scope->getName();
-$parentScope = $scope->getParentName();
-if (self::SCOPE_CONTAINER === $name || self::SCOPE_PROTOTYPE === $name) {
-throw new InvalidArgumentException(sprintf('The scope "%s" is reserved.', $name));
-}
-if (isset($this->scopes[$name])) {
-throw new InvalidArgumentException(sprintf('A scope with name "%s" already exists.', $name));
-}
-if (self::SCOPE_CONTAINER !== $parentScope && !isset($this->scopes[$parentScope])) {
-throw new InvalidArgumentException(sprintf('The parent scope "%s" does not exist, or is invalid.', $parentScope));
-}
-$this->scopes[$name] = $parentScope;
-$this->scopeChildren[$name] = array();
-while ($parentScope !== self::SCOPE_CONTAINER) {
-$this->scopeChildren[$parentScope][] = $name;
-$parentScope = $this->scopes[$parentScope];
-}
-}
-public function hasScope($name)
-{
-return isset($this->scopes[$name]);
-}
-public function isScopeActive($name)
-{
-return isset($this->scopedServices[$name]);
-}
-public static function camelize($id)
-{
-return strtr(ucwords(strtr($id, array('_'=>' ','.'=>'_ '))), array(' '=>''));
-}
-public static function underscore($id)
-{
-return strtolower(preg_replace(array('/([A-Z]+)([A-Z][a-z])/','/([a-z\d])([A-Z])/'), array('\\1_\\2','\\1_\\2'), strtr($id,'_','.')));
-}
-}
-}
-namespace Symfony\Component\HttpKernel
-{
-use Symfony\Component\HttpFoundation\Request;
-use Symfony\Component\HttpFoundation\Response;
-interface HttpKernelInterface
-{
-const MASTER_REQUEST = 1;
-const SUB_REQUEST = 2;
-public function handle(Request $request, $type = self::MASTER_REQUEST, $catch = true);
-}
-}
-namespace Symfony\Component\HttpKernel
-{
-use Symfony\Component\DependencyInjection\ContainerInterface;
-use Symfony\Component\HttpKernel\HttpKernelInterface;
-use Symfony\Component\HttpKernel\Bundle\BundleInterface;
-use Symfony\Component\Config\Loader\LoaderInterface;
-interface KernelInterface extends HttpKernelInterface, \Serializable
-{
-public function registerBundles();
-public function registerContainerConfiguration(LoaderInterface $loader);
-public function boot();
-public function shutdown();
-public function getBundles();
-public function isClassInActiveBundle($class);
-public function getBundle($name, $first = true);
-public function locateResource($name, $dir = null, $first = true);
-public function getName();
-public function getEnvironment();
-public function isDebug();
-public function getRootDir();
-public function getContainer();
-public function getStartTime();
-public function getCacheDir();
-public function getLogDir();
-public function getCharset();
-}
-}
-namespace Symfony\Component\HttpKernel
-{
-use Symfony\Component\HttpFoundation\Request;
-use Symfony\Component\HttpFoundation\Response;
-interface TerminableInterface
-{
-public function terminate(Request $request, Response $response);
-}
-}
-namespace Symfony\Component\HttpKernel
-{
-use Symfony\Component\DependencyInjection\ContainerInterface;
-use Symfony\Component\DependencyInjection\ContainerBuilder;
-use Symfony\Component\DependencyInjection\Dumper\PhpDumper;
-use Symfony\Component\DependencyInjection\ParameterBag\ParameterBag;
-use Symfony\Component\DependencyInjection\Loader\XmlFileLoader;
-use Symfony\Component\DependencyInjection\Loader\YamlFileLoader;
-use Symfony\Component\DependencyInjection\Loader\IniFileLoader;
-use Symfony\Component\DependencyInjection\Loader\PhpFileLoader;
-use Symfony\Component\DependencyInjection\Loader\ClosureLoader;
-use Symfony\Component\HttpFoundation\Request;
-use Symfony\Component\HttpFoundation\Response;
-use Symfony\Component\HttpKernel\HttpKernelInterface;
-use Symfony\Component\HttpKernel\Bundle\BundleInterface;
-use Symfony\Component\HttpKernel\Config\FileLocator;
-use Symfony\Component\HttpKernel\DependencyInjection\MergeExtensionConfigurationPass;
-use Symfony\Component\HttpKernel\DependencyInjection\AddClassesToCachePass;
-use Symfony\Component\HttpKernel\Debug\ErrorHandler;
-use Symfony\Component\HttpKernel\Debug\ExceptionHandler;
-use Symfony\Component\Config\Loader\LoaderResolver;
-use Symfony\Component\Config\Loader\DelegatingLoader;
-use Symfony\Component\Config\ConfigCache;
-use Symfony\Component\ClassLoader\ClassCollectionLoader;
-use Symfony\Component\ClassLoader\DebugClassLoader;
-abstract class Kernel implements KernelInterface, TerminableInterface
-{
-protected $bundles;
-protected $bundleMap;
-protected $container;
-protected $rootDir;
-protected $environment;
-protected $debug;
-protected $booted;
-protected $name;
-protected $startTime;
-protected $errorReportingLevel;
-const VERSION ='2.2.8';
-const VERSION_ID ='20208';
-const MAJOR_VERSION ='2';
-const MINOR_VERSION ='2';
-const RELEASE_VERSION ='8';
-const EXTRA_VERSION ='';
-public function __construct($environment, $debug)
-{
-$this->environment = $environment;
-$this->debug = (Boolean) $debug;
-$this->booted = false;
-$this->rootDir = $this->getRootDir();
-$this->name = $this->getName();
-$this->bundles = array();
-if ($this->debug) {
-$this->startTime = microtime(true);
-}
-$this->init();
-}
-public function init()
-{
-ini_set('display_errors', 0);
-if ($this->debug) {
-error_reporting(-1);
-if (class_exists('Symfony\Component\ClassLoader\DebugClassLoader')) {
-DebugClassLoader::enable();
-}
-ErrorHandler::register($this->errorReportingLevel);
-if ('cli'!== php_sapi_name()) {
-ExceptionHandler::register();
-} else {
-ini_set('display_errors', 1);
-}
-}
-}
-public function __clone()
-{
-if ($this->debug) {
-$this->startTime = microtime(true);
-}
-$this->booted = false;
-$this->container = null;
-}
-public function boot()
-{
-if (true === $this->booted) {
-return;
-}
-$this->initializeBundles();
-$this->initializeContainer();
-foreach ($this->getBundles() as $bundle) {
-$bundle->setContainer($this->container);
-$bundle->boot();
-}
-$this->booted = true;
-}
-public function terminate(Request $request, Response $response)
-{
-if (false === $this->booted) {
-return;
-}
-if ($this->getHttpKernel() instanceof TerminableInterface) {
-$this->getHttpKernel()->terminate($request, $response);
-}
-}
-public function shutdown()
-{
-if (false === $this->booted) {
-return;
-}
-$this->booted = false;
-foreach ($this->getBundles() as $bundle) {
-$bundle->shutdown();
-$bundle->setContainer(null);
-}
-$this->container = null;
-}
-public function handle(Request $request, $type = HttpKernelInterface::MASTER_REQUEST, $catch = true)
-{
-if (false === $this->booted) {
-$this->boot();
-}
-return $this->getHttpKernel()->handle($request, $type, $catch);
-}
-protected function getHttpKernel()
-{
-return $this->container->get('http_kernel');
-}
-public function getBundles()
-{
-return $this->bundles;
-}
-public function isClassInActiveBundle($class)
-{
-foreach ($this->getBundles() as $bundle) {
-if (0 === strpos($class, $bundle->getNamespace())) {
-return true;
-}
-}
-return false;
-}
-public function getBundle($name, $first = true)
-{
-if (!isset($this->bundleMap[$name])) {
-throw new \InvalidArgumentException(sprintf('Bundle "%s" does not exist or it is not enabled. Maybe you forgot to add it in the registerBundles() method of your %s.php file?', $name, get_class($this)));
-}
-if (true === $first) {
-return $this->bundleMap[$name][0];
-}
-return $this->bundleMap[$name];
-}
-public function locateResource($name, $dir = null, $first = true)
-{
-if ('@'!== $name[0]) {
-throw new \InvalidArgumentException(sprintf('A resource name must start with @ ("%s" given).', $name));
-}
-if (false !== strpos($name,'..')) {
-throw new \RuntimeException(sprintf('File name "%s" contains invalid characters (..).', $name));
-}
-$bundleName = substr($name, 1);
-$path ='';
-if (false !== strpos($bundleName,'/')) {
-list($bundleName, $path) = explode('/', $bundleName, 2);
-}
-$isResource = 0 === strpos($path,'Resources') && null !== $dir;
-$overridePath = substr($path, 9);
-$resourceBundle = null;
-$bundles = $this->getBundle($bundleName, false);
-$files = array();
-foreach ($bundles as $bundle) {
-if ($isResource && file_exists($file = $dir.'/'.$bundle->getName().$overridePath)) {
-if (null !== $resourceBundle) {
-throw new \RuntimeException(sprintf('"%s" resource is hidden by a resource from the "%s" derived bundle. Create a "%s" file to override the bundle resource.',
-$file,
-$resourceBundle,
-$dir.'/'.$bundles[0]->getName().$overridePath
-));
-}
-if ($first) {
-return $file;
-}
-$files[] = $file;
-}
-if (file_exists($file = $bundle->getPath().'/'.$path)) {
-if ($first && !$isResource) {
-return $file;
-}
-$files[] = $file;
-$resourceBundle = $bundle->getName();
-}
-}
-if (count($files) > 0) {
-return $first && $isResource ? $files[0] : $files;
-}
-throw new \InvalidArgumentException(sprintf('Unable to find file "%s".', $name));
-}
-public function getName()
-{
-if (null === $this->name) {
-$this->name = preg_replace('/[^a-zA-Z0-9_]+/','', basename($this->rootDir));
-}
-return $this->name;
-}
-public function getEnvironment()
-{
-return $this->environment;
-}
-public function isDebug()
-{
-return $this->debug;
-}
-public function getRootDir()
-{
-if (null === $this->rootDir) {
-$r = new \ReflectionObject($this);
-$this->rootDir = str_replace('\\','/', dirname($r->getFileName()));
-}
-return $this->rootDir;
-}
-public function getContainer()
-{
-return $this->container;
-}
-public function loadClassCache($name ='classes', $extension ='.php')
-{
-if (!$this->booted && is_file($this->getCacheDir().'/classes.map')) {
-ClassCollectionLoader::load(include($this->getCacheDir().'/classes.map'), $this->getCacheDir(), $name, $this->debug, false, $extension);
-}
-}
-public function setClassCache(array $classes)
-{
-file_put_contents($this->getCacheDir().'/classes.map', sprintf('<?php return %s;', var_export($classes, true)));
-}
-public function getStartTime()
-{
-return $this->debug ? $this->startTime : -INF;
-}
-public function getCacheDir()
-{
-return $this->rootDir.'/cache/'.$this->environment;
-}
-public function getLogDir()
-{
-return $this->rootDir.'/logs';
-}
-public function getCharset()
-{
-return'UTF-8';
-}
-protected function initializeBundles()
-{
-$this->bundles = array();
-$topMostBundles = array();
-$directChildren = array();
-foreach ($this->registerBundles() as $bundle) {
-$name = $bundle->getName();
-if (isset($this->bundles[$name])) {
-throw new \LogicException(sprintf('Trying to register two bundles with the same name "%s"', $name));
-}
-$this->bundles[$name] = $bundle;
-if ($parentName = $bundle->getParent()) {
-if (isset($directChildren[$parentName])) {
-throw new \LogicException(sprintf('Bundle "%s" is directly extended by two bundles "%s" and "%s".', $parentName, $name, $directChildren[$parentName]));
-}
-if ($parentName == $name) {
-throw new \LogicException(sprintf('Bundle "%s" can not extend itself.', $name));
-}
-$directChildren[$parentName] = $name;
-} else {
-$topMostBundles[$name] = $bundle;
-}
-}
-if (count($diff = array_values(array_diff(array_keys($directChildren), array_keys($this->bundles))))) {
-throw new \LogicException(sprintf('Bundle "%s" extends bundle "%s", which is not registered.', $directChildren[$diff[0]], $diff[0]));
-}
-$this->bundleMap = array();
-foreach ($topMostBundles as $name => $bundle) {
-$bundleMap = array($bundle);
-$hierarchy = array($name);
-while (isset($directChildren[$name])) {
-$name = $directChildren[$name];
-array_unshift($bundleMap, $this->bundles[$name]);
-$hierarchy[] = $name;
-}
-foreach ($hierarchy as $bundle) {
-$this->bundleMap[$bundle] = $bundleMap;
-array_pop($bundleMap);
-}
-}
-}
-protected function getContainerClass()
-{
-return $this->name.ucfirst($this->environment).($this->debug ?'Debug':'').'ProjectContainer';
-}
-protected function getContainerBaseClass()
-{
-return'Container';
-}
-protected function initializeContainer()
-{
-$class = $this->getContainerClass();
-$cache = new ConfigCache($this->getCacheDir().'/'.$class.'.php', $this->debug);
-$fresh = true;
-if (!$cache->isFresh()) {
-$container = $this->buildContainer();
-$this->dumpContainer($cache, $container, $class, $this->getContainerBaseClass());
-$fresh = false;
-}
-require_once $cache;
-$this->container = new $class();
-$this->container->set('kernel', $this);
-if (!$fresh && $this->container->has('cache_warmer')) {
-$this->container->get('cache_warmer')->warmUp($this->container->getParameter('kernel.cache_dir'));
-}
-}
-protected function getKernelParameters()
-{
-$bundles = array();
-foreach ($this->bundles as $name => $bundle) {
-$bundles[$name] = get_class($bundle);
-}
-return array_merge(
-array('kernel.root_dir'=> $this->rootDir,'kernel.environment'=> $this->environment,'kernel.debug'=> $this->debug,'kernel.name'=> $this->name,'kernel.cache_dir'=> $this->getCacheDir(),'kernel.logs_dir'=> $this->getLogDir(),'kernel.bundles'=> $bundles,'kernel.charset'=> $this->getCharset(),'kernel.container_class'=> $this->getContainerClass(),
-),
-$this->getEnvParameters()
-);
-}
-protected function getEnvParameters()
-{
-$parameters = array();
-foreach ($_SERVER as $key => $value) {
-if (0 === strpos($key,'SYMFONY__')) {
-$parameters[strtolower(str_replace('__','.', substr($key, 9)))] = $value;
-}
-}
-return $parameters;
-}
-protected function buildContainer()
-{
-foreach (array('cache'=> $this->getCacheDir(),'logs'=> $this->getLogDir()) as $name => $dir) {
-if (!is_dir($dir)) {
-if (false === @mkdir($dir, 0777, true)) {
-throw new \RuntimeException(sprintf("Unable to create the %s directory (%s)\n", $name, $dir));
-}
-} elseif (!is_writable($dir)) {
-throw new \RuntimeException(sprintf("Unable to write in the %s directory (%s)\n", $name, $dir));
-}
-}
-$container = $this->getContainerBuilder();
-$extensions = array();
-foreach ($this->bundles as $bundle) {
-if ($extension = $bundle->getContainerExtension()) {
-$container->registerExtension($extension);
-$extensions[] = $extension->getAlias();
-}
-if ($this->debug) {
-$container->addObjectResource($bundle);
-}
-}
-foreach ($this->bundles as $bundle) {
-$bundle->build($container);
-}
-$container->addObjectResource($this);
-$container->getCompilerPassConfig()->setMergePass(new MergeExtensionConfigurationPass($extensions));
-if (null !== $cont = $this->registerContainerConfiguration($this->getContainerLoader($container))) {
-$container->merge($cont);
-}
-$container->addCompilerPass(new AddClassesToCachePass($this));
-$container->compile();
-return $container;
-}
-protected function getContainerBuilder()
-{
-return new ContainerBuilder(new ParameterBag($this->getKernelParameters()));
-}
-protected function dumpContainer(ConfigCache $cache, ContainerBuilder $container, $class, $baseClass)
-{
-$dumper = new PhpDumper($container);
-$content = $dumper->dump(array('class'=> $class,'base_class'=> $baseClass));
-if (!$this->debug) {
-$content = self::stripComments($content);
-}
-$cache->write($content, $container->getResources());
-}
-protected function getContainerLoader(ContainerInterface $container)
-{
-$locator = new FileLocator($this);
-$resolver = new LoaderResolver(array(
-new XmlFileLoader($container, $locator),
-new YamlFileLoader($container, $locator),
-new IniFileLoader($container, $locator),
-new PhpFileLoader($container, $locator),
-new ClosureLoader($container),
-));
-return new DelegatingLoader($resolver);
-}
-public static function stripComments($source)
-{
-if (!function_exists('token_get_all')) {
-return $source;
-}
-$rawChunk ='';
-$output ='';
-$tokens = token_get_all($source);
-for (reset($tokens); false !== $token = current($tokens); next($tokens)) {
-if (is_string($token)) {
-$rawChunk .= $token;
-} elseif (T_START_HEREDOC === $token[0]) {
-$output .= preg_replace(array('/\s+$/Sm','/\n+/S'),"\n", $rawChunk) . $token[1];
-do {
-$token = next($tokens);
-$output .= $token[1];
-} while ($token[0] !== T_END_HEREDOC);
-$rawChunk ='';
-} elseif (!in_array($token[0], array(T_COMMENT, T_DOC_COMMENT))) {
-$rawChunk .= $token[1];
-}
-}
-$output .= preg_replace(array('/\s+$/Sm','/\n+/S'),"\n", $rawChunk);
-return $output;
-}
-public function serialize()
-{
-return serialize(array($this->environment, $this->debug));
-}
-public function unserialize($data)
-{
-list($environment, $debug) = unserialize($data);
-$this->__construct($environment, $debug);
-}
-}
-}
-namespace Symfony\Component\ClassLoader
-{
-class ApcClassLoader
-{
-private $prefix;
-protected $decorated;
-public function __construct($prefix, $decorated)
-{
-if (!extension_loaded('apc')) {
-throw new \RuntimeException('Unable to use ApcClassLoader as APC is not enabled.');
-}
-if (!method_exists($decorated,'findFile')) {
-throw new \InvalidArgumentException('The class finder must implement a "findFile" method.');
-}
-$this->prefix = $prefix;
-$this->decorated = $decorated;
-}
-public function register($prepend = false)
-{
-spl_autoload_register(array($this,'loadClass'), true, $prepend);
-}
-public function unregister()
-{
-spl_autoload_unregister(array($this,'loadClass'));
-}
-public function loadClass($class)
-{
-if ($file = $this->findFile($class)) {
-require $file;
-return true;
-}
-}
-public function findFile($class)
-{
-if (false === $file = apc_fetch($this->prefix.$class)) {
-apc_store($this->prefix.$class, $file = $this->decorated->findFile($class));
-}
-return $file;
-}
-public function __call($method, $args)
-{
-return call_user_func_array(array($this->decorated, $method), $args);
-}
-}
-}
-namespace Symfony\Component\HttpKernel\Bundle
-{
-use Symfony\Component\DependencyInjection\ContainerAwareInterface;
-use Symfony\Component\DependencyInjection\ContainerBuilder;
-use Symfony\Component\DependencyInjection\Extension\ExtensionInterface;
-interface BundleInterface extends ContainerAwareInterface
-{
-public function boot();
-public function shutdown();
-public function build(ContainerBuilder $container);
-public function getContainerExtension();
-public function getParent();
-public function getName();
-public function getNamespace();
-public function getPath();
-}
-}
-namespace Symfony\Component\DependencyInjection
-{
-abstract class ContainerAware implements ContainerAwareInterface
-{
-protected $container;
-public function setContainer(ContainerInterface $container = null)
-{
-$this->container = $container;
-}
-}
-}
-namespace Symfony\Component\HttpKernel\Bundle
-{
-use Symfony\Component\DependencyInjection\ContainerAware;
-use Symfony\Component\DependencyInjection\ContainerBuilder;
-use Symfony\Component\DependencyInjection\Container;
-use Symfony\Component\Console\Application;
-use Symfony\Component\Finder\Finder;
-use Symfony\Component\DependencyInjection\Extension\ExtensionInterface;
-abstract class Bundle extends ContainerAware implements BundleInterface
-{
-protected $name;
-protected $reflected;
-protected $extension;
-public function boot()
-{
-}
-public function shutdown()
-{
-}
-public function build(ContainerBuilder $container)
-{
-}
-public function getContainerExtension()
-{
-if (null === $this->extension) {
-$basename = preg_replace('/Bundle$/','', $this->getName());
-$class = $this->getNamespace().'\\DependencyInjection\\'.$basename.'Extension';
-if (class_exists($class)) {
-$extension = new $class();
-$expectedAlias = Container::underscore($basename);
-if ($expectedAlias != $extension->getAlias()) {
-throw new \LogicException(sprintf('The extension alias for the default extension of a '.'bundle must be the underscored version of the '.'bundle name ("%s" instead of "%s")',
-$expectedAlias, $extension->getAlias()
-));
-}
-$this->extension = $extension;
-} else {
-$this->extension = false;
-}
-}
-if ($this->extension) {
-return $this->extension;
-}
-}
-public function getNamespace()
-{
-if (null === $this->reflected) {
-$this->reflected = new \ReflectionObject($this);
-}
-return $this->reflected->getNamespaceName();
-}
-public function getPath()
-{
-if (null === $this->reflected) {
-$this->reflected = new \ReflectionObject($this);
-}
-return dirname($this->reflected->getFileName());
-}
-public function getParent()
-{
-return null;
-}
-final public function getName()
-{
-if (null !== $this->name) {
-return $this->name;
-}
-$name = get_class($this);
-$pos = strrpos($name,'\\');
-return $this->name = false === $pos ? $name : substr($name, $pos + 1);
-}
-public function registerCommands(Application $application)
-{
-if (!is_dir($dir = $this->getPath().'/Command')) {
-return;
-}
-$finder = new Finder();
-$finder->files()->name('*Command.php')->in($dir);
-$prefix = $this->getNamespace().'\\Command';
-foreach ($finder as $file) {
-$ns = $prefix;
-if ($relativePath = $file->getRelativePath()) {
-$ns .='\\'.strtr($relativePath,'/','\\');
-}
-$r = new \ReflectionClass($ns.'\\'.$file->getBasename('.php'));
-if ($r->isSubclassOf('Symfony\\Component\\Console\\Command\\Command') && !$r->isAbstract() && !$r->getConstructor()->getNumberOfRequiredParameters()) {
-$application->add($r->newInstance());
-}
-}
-}
-}
-}
-namespace Symfony\Component\Config
-{
-use Symfony\Component\Config\Resource\ResourceInterface;
-class ConfigCache
-{
-private $debug;
-private $file;
-public function __construct($file, $debug)
-{
-$this->file = $file;
-$this->debug = (Boolean) $debug;
-}
-public function __toString()
-{
-return $this->file;
-}
-public function isFresh()
-{
-if (!is_file($this->file)) {
-return false;
-}
-if (!$this->debug) {
-return true;
-}
-$metadata = $this->file.'.meta';
-if (!is_file($metadata)) {
-return false;
-}
-$time = filemtime($this->file);
-$meta = unserialize(file_get_contents($metadata));
-foreach ($meta as $resource) {
-if (!$resource->isFresh($time)) {
-return false;
-}
-}
-return true;
-}
-public function write($content, array $metadata = null)
-{
-$dir = dirname($this->file);
-if (!is_dir($dir)) {
-if (false === @mkdir($dir, 0777, true)) {
-throw new \RuntimeException(sprintf('Unable to create the %s directory', $dir));
-}
-} elseif (!is_writable($dir)) {
-throw new \RuntimeException(sprintf('Unable to write in the %s directory', $dir));
-}
-$tmpFile = tempnam($dir, basename($this->file));
-if (false !== @file_put_contents($tmpFile, $content) && @rename($tmpFile, $this->file)) {
-@chmod($this->file, 0666 & ~umask());
-} else {
-throw new \RuntimeException(sprintf('Failed to write cache file "%s".', $this->file));
-}
-if (null !== $metadata && true === $this->debug) {
-$file = $this->file.'.meta';
-$tmpFile = tempnam($dir, basename($file));
-if (false !== @file_put_contents($tmpFile, serialize($metadata)) && @rename($tmpFile, $file)) {
-@chmod($file, 0666 & ~umask());
-}
-}
-}
-}
-}
-namespace Symfony\Component\HttpKernel
-{
-use Symfony\Component\HttpKernel\Controller\ControllerResolverInterface;
-use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
-use Symfony\Component\HttpKernel\Exception\HttpExceptionInterface;
-use Symfony\Component\HttpKernel\Event\FilterControllerEvent;
-use Symfony\Component\HttpKernel\Event\FilterResponseEvent;
-use Symfony\Component\HttpKernel\Event\GetResponseEvent;
-use Symfony\Component\HttpKernel\Event\GetResponseForControllerResultEvent;
-use Symfony\Component\HttpKernel\Event\GetResponseForExceptionEvent;
-use Symfony\Component\HttpKernel\Event\PostResponseEvent;
-use Symfony\Component\HttpFoundation\Request;
-use Symfony\Component\HttpFoundation\Response;
-use Symfony\Component\EventDispatcher\EventDispatcherInterface;
-class HttpKernel implements HttpKernelInterface, TerminableInterface
-{
-protected $dispatcher;
-protected $resolver;
-public function __construct(EventDispatcherInterface $dispatcher, ControllerResolverInterface $resolver)
-{
-$this->dispatcher = $dispatcher;
-$this->resolver = $resolver;
-}
-public function handle(Request $request, $type = HttpKernelInterface::MASTER_REQUEST, $catch = true)
-{
-try {
-return $this->handleRaw($request, $type);
-} catch (\Exception $e) {
-if (false === $catch) {
-throw $e;
-}
-return $this->handleException($e, $request, $type);
-}
-}
-public function terminate(Request $request, Response $response)
-{
-$this->dispatcher->dispatch(KernelEvents::TERMINATE, new PostResponseEvent($this, $request, $response));
-}
-private function handleRaw(Request $request, $type = self::MASTER_REQUEST)
-{
-$event = new GetResponseEvent($this, $request, $type);
-$this->dispatcher->dispatch(KernelEvents::REQUEST, $event);
-if ($event->hasResponse()) {
-return $this->filterResponse($event->getResponse(), $request, $type);
-}
-if (false === $controller = $this->resolver->getController($request)) {
-throw new NotFoundHttpException(sprintf('Unable to find the controller for path "%s". Maybe you forgot to add the matching route in your routing configuration?', $request->getPathInfo()));
-}
-$event = new FilterControllerEvent($this, $controller, $request, $type);
-$this->dispatcher->dispatch(KernelEvents::CONTROLLER, $event);
-$controller = $event->getController();
-$arguments = $this->resolver->getArguments($request, $controller);
-$response = call_user_func_array($controller, $arguments);
-if (!$response instanceof Response) {
-$event = new GetResponseForControllerResultEvent($this, $request, $type, $response);
-$this->dispatcher->dispatch(KernelEvents::VIEW, $event);
-if ($event->hasResponse()) {
-$response = $event->getResponse();
-}
-if (!$response instanceof Response) {
-$msg = sprintf('The controller must return a response (%s given).', $this->varToString($response));
-if (null === $response) {
-$msg .=' Did you forget to add a return statement somewhere in your controller?';
-}
-throw new \LogicException($msg);
-}
-}
-return $this->filterResponse($response, $request, $type);
-}
-private function filterResponse(Response $response, Request $request, $type)
-{
-$event = new FilterResponseEvent($this, $request, $type, $response);
-$this->dispatcher->dispatch(KernelEvents::RESPONSE, $event);
-return $event->getResponse();
-}
-private function handleException(\Exception $e, $request, $type)
-{
-$event = new GetResponseForExceptionEvent($this, $request, $type, $e);
-$this->dispatcher->dispatch(KernelEvents::EXCEPTION, $event);
-$e = $event->getException();
-if (!$event->hasResponse()) {
-throw $e;
-}
-$response = $event->getResponse();
-if ($response->headers->has('X-Status-Code')) {
-$response->setStatusCode($response->headers->get('X-Status-Code'));
-$response->headers->remove('X-Status-Code');
-} elseif (!$response->isClientError() && !$response->isServerError() && !$response->isRedirect()) {
-if ($e instanceof HttpExceptionInterface) {
-$response->setStatusCode($e->getStatusCode());
-$response->headers->add($e->getHeaders());
-} else {
-$response->setStatusCode(500);
-}
-}
-try {
-return $this->filterResponse($response, $request, $type);
-} catch (\Exception $e) {
-return $response;
-}
-}
-private function varToString($var)
-{
-if (is_object($var)) {
-return sprintf('Object(%s)', get_class($var));
-}
-if (is_array($var)) {
-$a = array();
-foreach ($var as $k => $v) {
-$a[] = sprintf('%s => %s', $k, $this->varToString($v));
-}
-return sprintf("Array(%s)", implode(', ', $a));
-}
-if (is_resource($var)) {
-return sprintf('Resource(%s)', get_resource_type($var));
-}
-if (null === $var) {
-return'null';
-}
-if (false === $var) {
-return'false';
-}
-if (true === $var) {
-return'true';
-}
-return (string) $var;
-}
-}
-}
-namespace Symfony\Component\HttpKernel\DependencyInjection
-{
-use Symfony\Component\HttpFoundation\Request;
-use Symfony\Component\HttpKernel\HttpKernelInterface;
-use Symfony\Component\HttpKernel\HttpKernel;
-use Symfony\Component\HttpKernel\Controller\ControllerResolverInterface;
-use Symfony\Component\EventDispatcher\EventDispatcherInterface;
-use Symfony\Component\DependencyInjection\ContainerInterface;
-class ContainerAwareHttpKernel extends HttpKernel
-{
-protected $container;
-public function __construct(EventDispatcherInterface $dispatcher, ContainerInterface $container, ControllerResolverInterface $controllerResolver)
-{
-parent::__construct($dispatcher, $controllerResolver);
-$this->container = $container;
-}
-public function handle(Request $request, $type = HttpKernelInterface::MASTER_REQUEST, $catch = true)
-{
-$request->headers->set('X-Php-Ob-Level', ob_get_level());
-$this->container->enterScope('request');
-$this->container->set('request', $request,'request');
-try {
-$response = parent::handle($request, $type, $catch);
-} catch (\Exception $e) {
-$this->container->leaveScope('request');
-throw $e;
-}
-$this->container->leaveScope('request');
-return $response;
-}
-}
-}
-namespace Symfony\Bundle\FrameworkBundle
-{
-use Symfony\Component\HttpFoundation\Response;
-use Symfony\Component\HttpKernel\HttpKernelInterface;
-use Symfony\Component\HttpKernel\DependencyInjection\ContainerAwareHttpKernel;
-class HttpKernel extends ContainerAwareHttpKernel
-{
-public function forward($controller, array $attributes = array(), array $query = array())
-{
-trigger_error('forward() is deprecated since version 2.2 and will be removed in 2.3.', E_USER_DEPRECATED);
-$attributes['_controller'] = $controller;
-$subRequest = $this->container->get('request')->duplicate($query, null, $attributes);
-return $this->handle($subRequest, HttpKernelInterface::SUB_REQUEST);
-}
-public function render($uri, array $options = array())
-{
-trigger_error('render() is deprecated since version 2.2 and will be removed in 2.3. Use Symfony\Component\HttpKernel\Fragment\FragmentHandler::render() instead.', E_USER_DEPRECATED);
-$options = $this->renderer->fixOptions($options);
-$strategy = isset($options['strategy']) ? $options['strategy'] :'default';
-unset($options['strategy']);
-$this->container->get('fragment.handler')->render($uri, $strategy, $options);
-}
-}
-}
-
-namespace { return $loader; }
-            

+ 0 - 3
frameworks/PHP/php-symfony2/install.sh

@@ -1,3 +0,0 @@
-#!/bin/bash
-
-fw_depends php composer nginx

+ 0 - 0
frameworks/PHP/php-yaf/__init__.py


+ 0 - 0
frameworks/PHP/php-zend-framework/__init__.py


Some files were not shown because too many files changed in this diff