Move into nested docroot
This commit is contained in:
		
							parent
							
								
									83a0d3a149
								
							
						
					
					
						commit
						c8b70abde9
					
				
					 13405 changed files with 0 additions and 0 deletions
				
			
		|  | @ -0,0 +1,31 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Component\FileCache; | ||||
| 
 | ||||
| /** | ||||
|  * APCu backend for the file cache. | ||||
|  */ | ||||
| class ApcuFileCacheBackend implements FileCacheBackendInterface { | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function fetch(array $cids) { | ||||
|     return apcu_fetch($cids); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function store($cid, $data) { | ||||
|     apcu_store($cid, $data); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function delete($cid) { | ||||
|     apcu_delete($cid); | ||||
|   } | ||||
| 
 | ||||
| } | ||||
							
								
								
									
										160
									
								
								web/core/lib/Drupal/Component/FileCache/FileCache.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										160
									
								
								web/core/lib/Drupal/Component/FileCache/FileCache.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,160 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Component\FileCache; | ||||
| 
 | ||||
| /** | ||||
|  * Allows to cache data based on file modification dates. | ||||
|  */ | ||||
| class FileCache implements FileCacheInterface { | ||||
| 
 | ||||
|   /** | ||||
|    * Prefix that is used for cache entries. | ||||
|    * | ||||
|    * @var string | ||||
|    */ | ||||
|   protected $prefix; | ||||
| 
 | ||||
|   /** | ||||
|    * Static cache that contains already loaded cache entries. | ||||
|    * | ||||
|    * @var array | ||||
|    */ | ||||
|   protected static $cached = []; | ||||
| 
 | ||||
|   /** | ||||
|    * The collection identifier of this cache. | ||||
|    * | ||||
|    * @var string | ||||
|    */ | ||||
|   protected $collection; | ||||
| 
 | ||||
|   /** | ||||
|    * The cache backend backing this FileCache object. | ||||
|    * | ||||
|    * @var \Drupal\Component\FileCache\FileCacheBackendInterface | ||||
|    */ | ||||
|   protected $cache; | ||||
| 
 | ||||
|   /** | ||||
|    * Constructs a FileCache object. | ||||
|    * | ||||
|    * @param string $prefix | ||||
|    *   The cache prefix. | ||||
|    * @param string $collection | ||||
|    *   A collection identifier to ensure that the same files could be cached for | ||||
|    *   different purposes without clashing. | ||||
|    * @param string|null $cache_backend_class | ||||
|    *   (optional) The class that should be used as cache backend. | ||||
|    * @param array $cache_backend_configuration | ||||
|    *   (optional) The configuration for the backend class. | ||||
|    */ | ||||
|   public function __construct($prefix, $collection, $cache_backend_class = NULL, array $cache_backend_configuration = []) { | ||||
| 
 | ||||
|     if (empty($prefix)) { | ||||
|       throw new \InvalidArgumentException('Required prefix configuration is missing'); | ||||
|     } | ||||
| 
 | ||||
|     $this->prefix = $prefix; | ||||
|     $this->collection = $collection; | ||||
| 
 | ||||
|     if (isset($cache_backend_class)) { | ||||
|       $this->cache = new $cache_backend_class($cache_backend_configuration); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function get($filepath) { | ||||
|     $filepaths = [$filepath]; | ||||
|     $cached = $this->getMultiple($filepaths); | ||||
|     return isset($cached[$filepath]) ? $cached[$filepath] : NULL; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function getMultiple(array $filepaths) { | ||||
|     $file_data = []; | ||||
|     $remaining_cids = []; | ||||
| 
 | ||||
|     // First load from the static cache what we can.
 | ||||
|     foreach ($filepaths as $filepath) { | ||||
|       if (!file_exists($filepath)) { | ||||
|         continue; | ||||
|       } | ||||
| 
 | ||||
|       $realpath = realpath($filepath); | ||||
|       // If the file exists but realpath returns nothing, it is using a stream
 | ||||
|       // wrapper, those are not supported.
 | ||||
|       if (empty($realpath)) { | ||||
|         continue; | ||||
|       } | ||||
| 
 | ||||
|       $cid = $this->prefix . ':' . $this->collection . ':' . $realpath; | ||||
|       if (isset(static::$cached[$cid]) && static::$cached[$cid]['mtime'] == filemtime($filepath)) { | ||||
|         $file_data[$filepath] = static::$cached[$cid]['data']; | ||||
|       } | ||||
|       else { | ||||
|         // Collect a list of cache IDs that we still need to fetch from cache
 | ||||
|         // backend.
 | ||||
|         $remaining_cids[$cid] = $filepath; | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|     // If there are any cache IDs left to fetch from the cache backend.
 | ||||
|     if ($remaining_cids && $this->cache) { | ||||
|       $cache_results = $this->cache->fetch(array_keys($remaining_cids)) ?: []; | ||||
|       foreach ($cache_results as $cid => $cached) { | ||||
|         $filepath = $remaining_cids[$cid]; | ||||
|         if ($cached['mtime'] == filemtime($filepath)) { | ||||
|           $file_data[$cached['filepath']] = $cached['data']; | ||||
|           static::$cached[$cid] = $cached; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|     return $file_data; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function set($filepath, $data) { | ||||
|     $realpath = realpath($filepath); | ||||
|     $cached = [ | ||||
|       'mtime' => filemtime($filepath), | ||||
|       'filepath' => $filepath, | ||||
|       'data' => $data, | ||||
|     ]; | ||||
| 
 | ||||
|     $cid = $this->prefix . ':' . $this->collection . ':' . $realpath; | ||||
|     static::$cached[$cid] = $cached; | ||||
|     if ($this->cache) { | ||||
|       $this->cache->store($cid, $cached); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function delete($filepath) { | ||||
|     $realpath = realpath($filepath); | ||||
|     $cid = $this->prefix . ':' . $this->collection . ':' . $realpath; | ||||
| 
 | ||||
|     unset(static::$cached[$cid]); | ||||
|     if ($this->cache) { | ||||
|       $this->cache->delete($cid); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Resets the static cache. | ||||
|    * | ||||
|    * @todo Replace this once https://www.drupal.org/node/2260187 is in. | ||||
|    */ | ||||
|   public static function reset() { | ||||
|     static::$cached = []; | ||||
|   } | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,39 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Component\FileCache; | ||||
| 
 | ||||
| /** | ||||
|  * Defines an interface inspired by APCu for FileCache backends. | ||||
|  */ | ||||
| interface FileCacheBackendInterface { | ||||
| 
 | ||||
|   /** | ||||
|    * Fetches data from the cache backend. | ||||
|    * | ||||
|    * @param array $cids | ||||
|    *   The cache IDs to fetch. | ||||
|    * | ||||
|    * @return array | ||||
|    *   An array containing cache entries keyed by cache ID. | ||||
|    */ | ||||
|   public function fetch(array $cids); | ||||
| 
 | ||||
|   /** | ||||
|    * Stores data into a cache backend. | ||||
|    * | ||||
|    * @param string $cid | ||||
|    *   The cache ID to store data to. | ||||
|    * @param mixed $data | ||||
|    *   The data to store. | ||||
|    */ | ||||
|   public function store($cid, $data); | ||||
| 
 | ||||
|   /** | ||||
|    * Deletes data from a cache backend. | ||||
|    * | ||||
|    * @param string $cid | ||||
|    *   The cache ID to delete. | ||||
|    */ | ||||
|   public function delete($cid); | ||||
| 
 | ||||
| } | ||||
							
								
								
									
										119
									
								
								web/core/lib/Drupal/Component/FileCache/FileCacheFactory.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										119
									
								
								web/core/lib/Drupal/Component/FileCache/FileCacheFactory.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,119 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Component\FileCache; | ||||
| 
 | ||||
| /** | ||||
|  * Creates a FileCache object. | ||||
|  */ | ||||
| class FileCacheFactory { | ||||
| 
 | ||||
|   /** | ||||
|    * The configuration key to disable FileCache completely. | ||||
|    */ | ||||
|   const DISABLE_CACHE = 'file_cache_disable'; | ||||
| 
 | ||||
|   /** | ||||
|    * The configuration used to create FileCache objects. | ||||
|    * | ||||
|    * @var array $configuration | ||||
|    */ | ||||
|   protected static $configuration; | ||||
| 
 | ||||
|   /** | ||||
|    * The cache prefix. | ||||
|    * | ||||
|    * @var string | ||||
|    */ | ||||
|   protected static $prefix; | ||||
| 
 | ||||
|   /** | ||||
|    * Instantiates a FileCache object for a given collection identifier. | ||||
|    * | ||||
|    * @param string $collection | ||||
|    *   The collection identifier for this FileCache. | ||||
|    * @param array $default_configuration | ||||
|    *   (optional) The default configuration for this FileCache collection. This | ||||
|    *   can be used to e.g. specify default usage of a FileCache class. | ||||
|    * | ||||
|    * @return \Drupal\Component\FileCache\FileCacheInterface | ||||
|    *   The initialized FileCache object. | ||||
|    */ | ||||
|   public static function get($collection, $default_configuration = []) { | ||||
|     // If there is a special key in the configuration, disable FileCache completely.
 | ||||
|     if (!empty(static::$configuration[static::DISABLE_CACHE])) { | ||||
|       return new NullFileCache('', ''); | ||||
|     } | ||||
| 
 | ||||
|     $configuration = []; | ||||
| 
 | ||||
|     // Check for a collection specific setting first.
 | ||||
|     if (isset(static::$configuration[$collection])) { | ||||
|       $configuration += static::$configuration[$collection]; | ||||
|     } | ||||
|     // Then check if a default configuration has been provided.
 | ||||
|     if (!empty($default_configuration)) { | ||||
|       $configuration += $default_configuration; | ||||
|     } | ||||
|     // Last check if a default setting has been provided.
 | ||||
|     if (isset(static::$configuration['default'])) { | ||||
|       $configuration += static::$configuration['default']; | ||||
|     } | ||||
| 
 | ||||
|     // Ensure that all properties are set.
 | ||||
|     $fallback_configuration = [ | ||||
|       'class' => '\Drupal\Component\FileCache\FileCache', | ||||
|       'collection' => $collection, | ||||
|       'cache_backend_class' => NULL, | ||||
|       'cache_backend_configuration' => [], | ||||
|     ]; | ||||
| 
 | ||||
|     $configuration = $configuration + $fallback_configuration; | ||||
| 
 | ||||
|     $class = $configuration['class']; | ||||
|     return new $class(static::getPrefix(), $configuration['collection'], $configuration['cache_backend_class'], $configuration['cache_backend_configuration']); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Gets the configuration used for constructing future file cache objects. | ||||
|    * | ||||
|    * @return array | ||||
|    *   The configuration that is used. | ||||
|    */ | ||||
|   public static function getConfiguration() { | ||||
|     return static::$configuration; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Sets the configuration to use for constructing future file cache objects. | ||||
|    * | ||||
|    * @param array $configuration | ||||
|    *   The configuration to use. | ||||
|    */ | ||||
|   public static function setConfiguration($configuration) { | ||||
|     static::$configuration = $configuration; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Returns the cache prefix. | ||||
|    * | ||||
|    * @return string | ||||
|    *   The cache prefix. | ||||
|    */ | ||||
|   public static function getPrefix() { | ||||
|     return static::$prefix; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Sets the cache prefix that should be used. | ||||
|    * | ||||
|    * Should be set to a secure, unique key to prevent cache pollution by a | ||||
|    * third party. | ||||
|    * | ||||
|    * @param string $prefix | ||||
|    *   The cache prefix. | ||||
|    */ | ||||
|   public static function setPrefix($prefix) { | ||||
|     static::$prefix = $prefix; | ||||
|   } | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,59 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Component\FileCache; | ||||
| 
 | ||||
| /** | ||||
|  * Interface for objects that allow caching file data. | ||||
|  * | ||||
|  * Parsing YAML, annotations or similar data out of files can be a | ||||
|  * time-consuming process, especially since those files usually don't change | ||||
|  * and identical data is parsed over and over again. | ||||
|  * | ||||
|  * File cache is a self-contained caching layer for such processing, that relies | ||||
|  * on the file modification to ensure that cached data is still up to date and | ||||
|  * does not need to be invalidated externally. | ||||
|  */ | ||||
| interface FileCacheInterface { | ||||
| 
 | ||||
|   /** | ||||
|    * Gets data based on a filename. | ||||
|    * | ||||
|    * @param string $filepath | ||||
|    *   Path of the file that the cached data is based on. | ||||
|    * | ||||
|    * @return mixed|null | ||||
|    *   The data that was persisted with set() or NULL if there is no data | ||||
|    *   or the file has been modified. | ||||
|    */ | ||||
|   public function get($filepath); | ||||
| 
 | ||||
|   /** | ||||
|    * Gets data based on filenames. | ||||
|    * | ||||
|    * @param string[] $filepaths | ||||
|    *   List of file paths used as cache identifiers. | ||||
|    * | ||||
|    * @return array | ||||
|    *   List of cached data keyed by the passed in file paths. | ||||
|    */ | ||||
|   public function getMultiple(array $filepaths); | ||||
| 
 | ||||
|   /** | ||||
|    * Stores data based on a filename. | ||||
|    * | ||||
|    * @param string $filepath | ||||
|    *   Path of the file that the cached data is based on. | ||||
|    * @param mixed $data | ||||
|    *   The data that should be cached. | ||||
|    */ | ||||
|   public function set($filepath, $data); | ||||
| 
 | ||||
|   /** | ||||
|    * Deletes data from the cache. | ||||
|    * | ||||
|    * @param string $filepath | ||||
|    *   Path of the file that the cached data is based on. | ||||
|    */ | ||||
|   public function delete($filepath); | ||||
| 
 | ||||
| } | ||||
							
								
								
									
										339
									
								
								web/core/lib/Drupal/Component/FileCache/LICENSE.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										339
									
								
								web/core/lib/Drupal/Component/FileCache/LICENSE.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,339 @@ | |||
|         GNU GENERAL PUBLIC LICENSE | ||||
|            Version 2, June 1991 | ||||
| 
 | ||||
|  Copyright (C) 1989, 1991 Free Software Foundation, Inc., | ||||
|  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | ||||
|  Everyone is permitted to copy and distribute verbatim copies | ||||
|  of this license document, but changing it is not allowed. | ||||
| 
 | ||||
|           Preamble | ||||
| 
 | ||||
|   The licenses for most software are designed to take away your | ||||
| freedom to share and change it.  By contrast, the GNU General Public | ||||
| License is intended to guarantee your freedom to share and change free | ||||
| software--to make sure the software is free for all its users.  This | ||||
| General Public License applies to most of the Free Software | ||||
| Foundation's software and to any other program whose authors commit to | ||||
| using it.  (Some other Free Software Foundation software is covered by | ||||
| the GNU Lesser General Public License instead.)  You can apply it to | ||||
| your programs, too. | ||||
| 
 | ||||
|   When we speak of free software, we are referring to freedom, not | ||||
| price.  Our General Public Licenses are designed to make sure that you | ||||
| have the freedom to distribute copies of free software (and charge for | ||||
| this service if you wish), that you receive source code or can get it | ||||
| if you want it, that you can change the software or use pieces of it | ||||
| in new free programs; and that you know you can do these things. | ||||
| 
 | ||||
|   To protect your rights, we need to make restrictions that forbid | ||||
| anyone to deny you these rights or to ask you to surrender the rights. | ||||
| These restrictions translate to certain responsibilities for you if you | ||||
| distribute copies of the software, or if you modify it. | ||||
| 
 | ||||
|   For example, if you distribute copies of such a program, whether | ||||
| gratis or for a fee, you must give the recipients all the rights that | ||||
| you have.  You must make sure that they, too, receive or can get the | ||||
| source code.  And you must show them these terms so they know their | ||||
| rights. | ||||
| 
 | ||||
|   We protect your rights with two steps: (1) copyright the software, and | ||||
| (2) offer you this license which gives you legal permission to copy, | ||||
| distribute and/or modify the software. | ||||
| 
 | ||||
|   Also, for each author's protection and ours, we want to make certain | ||||
| that everyone understands that there is no warranty for this free | ||||
| software.  If the software is modified by someone else and passed on, we | ||||
| want its recipients to know that what they have is not the original, so | ||||
| that any problems introduced by others will not reflect on the original | ||||
| authors' reputations. | ||||
| 
 | ||||
|   Finally, any free program is threatened constantly by software | ||||
| patents.  We wish to avoid the danger that redistributors of a free | ||||
| program will individually obtain patent licenses, in effect making the | ||||
| program proprietary.  To prevent this, we have made it clear that any | ||||
| patent must be licensed for everyone's free use or not licensed at all. | ||||
| 
 | ||||
|   The precise terms and conditions for copying, distribution and | ||||
| modification follow. | ||||
| 
 | ||||
|         GNU GENERAL PUBLIC LICENSE | ||||
|    TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION | ||||
| 
 | ||||
|   0. This License applies to any program or other work which contains | ||||
| a notice placed by the copyright holder saying it may be distributed | ||||
| under the terms of this General Public License.  The "Program", below, | ||||
| refers to any such program or work, and a "work based on the Program" | ||||
| means either the Program or any derivative work under copyright law: | ||||
| that is to say, a work containing the Program or a portion of it, | ||||
| either verbatim or with modifications and/or translated into another | ||||
| language.  (Hereinafter, translation is included without limitation in | ||||
| the term "modification".)  Each licensee is addressed as "you". | ||||
| 
 | ||||
| Activities other than copying, distribution and modification are not | ||||
| covered by this License; they are outside its scope.  The act of | ||||
| running the Program is not restricted, and the output from the Program | ||||
| is covered only if its contents constitute a work based on the | ||||
| Program (independent of having been made by running the Program). | ||||
| Whether that is true depends on what the Program does. | ||||
| 
 | ||||
|   1. You may copy and distribute verbatim copies of the Program's | ||||
| source code as you receive it, in any medium, provided that you | ||||
| conspicuously and appropriately publish on each copy an appropriate | ||||
| copyright notice and disclaimer of warranty; keep intact all the | ||||
| notices that refer to this License and to the absence of any warranty; | ||||
| and give any other recipients of the Program a copy of this License | ||||
| along with the Program. | ||||
| 
 | ||||
| You may charge a fee for the physical act of transferring a copy, and | ||||
| you may at your option offer warranty protection in exchange for a fee. | ||||
| 
 | ||||
|   2. You may modify your copy or copies of the Program or any portion | ||||
| of it, thus forming a work based on the Program, and copy and | ||||
| distribute such modifications or work under the terms of Section 1 | ||||
| above, provided that you also meet all of these conditions: | ||||
| 
 | ||||
|     a) You must cause the modified files to carry prominent notices | ||||
|     stating that you changed the files and the date of any change. | ||||
| 
 | ||||
|     b) You must cause any work that you distribute or publish, that in | ||||
|     whole or in part contains or is derived from the Program or any | ||||
|     part thereof, to be licensed as a whole at no charge to all third | ||||
|     parties under the terms of this License. | ||||
| 
 | ||||
|     c) If the modified program normally reads commands interactively | ||||
|     when run, you must cause it, when started running for such | ||||
|     interactive use in the most ordinary way, to print or display an | ||||
|     announcement including an appropriate copyright notice and a | ||||
|     notice that there is no warranty (or else, saying that you provide | ||||
|     a warranty) and that users may redistribute the program under | ||||
|     these conditions, and telling the user how to view a copy of this | ||||
|     License.  (Exception: if the Program itself is interactive but | ||||
|     does not normally print such an announcement, your work based on | ||||
|     the Program is not required to print an announcement.) | ||||
| 
 | ||||
| These requirements apply to the modified work as a whole.  If | ||||
| identifiable sections of that work are not derived from the Program, | ||||
| and can be reasonably considered independent and separate works in | ||||
| themselves, then this License, and its terms, do not apply to those | ||||
| sections when you distribute them as separate works.  But when you | ||||
| distribute the same sections as part of a whole which is a work based | ||||
| on the Program, the distribution of the whole must be on the terms of | ||||
| this License, whose permissions for other licensees extend to the | ||||
| entire whole, and thus to each and every part regardless of who wrote it. | ||||
| 
 | ||||
| Thus, it is not the intent of this section to claim rights or contest | ||||
| your rights to work written entirely by you; rather, the intent is to | ||||
| exercise the right to control the distribution of derivative or | ||||
| collective works based on the Program. | ||||
| 
 | ||||
| In addition, mere aggregation of another work not based on the Program | ||||
| with the Program (or with a work based on the Program) on a volume of | ||||
| a storage or distribution medium does not bring the other work under | ||||
| the scope of this License. | ||||
| 
 | ||||
|   3. You may copy and distribute the Program (or a work based on it, | ||||
| under Section 2) in object code or executable form under the terms of | ||||
| Sections 1 and 2 above provided that you also do one of the following: | ||||
| 
 | ||||
|     a) Accompany it with the complete corresponding machine-readable | ||||
|     source code, which must be distributed under the terms of Sections | ||||
|     1 and 2 above on a medium customarily used for software interchange; or, | ||||
| 
 | ||||
|     b) Accompany it with a written offer, valid for at least three | ||||
|     years, to give any third party, for a charge no more than your | ||||
|     cost of physically performing source distribution, a complete | ||||
|     machine-readable copy of the corresponding source code, to be | ||||
|     distributed under the terms of Sections 1 and 2 above on a medium | ||||
|     customarily used for software interchange; or, | ||||
| 
 | ||||
|     c) Accompany it with the information you received as to the offer | ||||
|     to distribute corresponding source code.  (This alternative is | ||||
|     allowed only for noncommercial distribution and only if you | ||||
|     received the program in object code or executable form with such | ||||
|     an offer, in accord with Subsection b above.) | ||||
| 
 | ||||
| The source code for a work means the preferred form of the work for | ||||
| making modifications to it.  For an executable work, complete source | ||||
| code means all the source code for all modules it contains, plus any | ||||
| associated interface definition files, plus the scripts used to | ||||
| control compilation and installation of the executable.  However, as a | ||||
| special exception, the source code distributed need not include | ||||
| anything that is normally distributed (in either source or binary | ||||
| form) with the major components (compiler, kernel, and so on) of the | ||||
| operating system on which the executable runs, unless that component | ||||
| itself accompanies the executable. | ||||
| 
 | ||||
| If distribution of executable or object code is made by offering | ||||
| access to copy from a designated place, then offering equivalent | ||||
| access to copy the source code from the same place counts as | ||||
| distribution of the source code, even though third parties are not | ||||
| compelled to copy the source along with the object code. | ||||
| 
 | ||||
|   4. You may not copy, modify, sublicense, or distribute the Program | ||||
| except as expressly provided under this License.  Any attempt | ||||
| otherwise to copy, modify, sublicense or distribute the Program is | ||||
| void, and will automatically terminate your rights under this License. | ||||
| However, parties who have received copies, or rights, from you under | ||||
| this License will not have their licenses terminated so long as such | ||||
| parties remain in full compliance. | ||||
| 
 | ||||
|   5. You are not required to accept this License, since you have not | ||||
| signed it.  However, nothing else grants you permission to modify or | ||||
| distribute the Program or its derivative works.  These actions are | ||||
| prohibited by law if you do not accept this License.  Therefore, by | ||||
| modifying or distributing the Program (or any work based on the | ||||
| Program), you indicate your acceptance of this License to do so, and | ||||
| all its terms and conditions for copying, distributing or modifying | ||||
| the Program or works based on it. | ||||
| 
 | ||||
|   6. Each time you redistribute the Program (or any work based on the | ||||
| Program), the recipient automatically receives a license from the | ||||
| original licensor to copy, distribute or modify the Program subject to | ||||
| these terms and conditions.  You may not impose any further | ||||
| restrictions on the recipients' exercise of the rights granted herein. | ||||
| You are not responsible for enforcing compliance by third parties to | ||||
| this License. | ||||
| 
 | ||||
|   7. If, as a consequence of a court judgment or allegation of patent | ||||
| infringement or for any other reason (not limited to patent issues), | ||||
| conditions are imposed on you (whether by court order, agreement or | ||||
| otherwise) that contradict the conditions of this License, they do not | ||||
| excuse you from the conditions of this License.  If you cannot | ||||
| distribute so as to satisfy simultaneously your obligations under this | ||||
| License and any other pertinent obligations, then as a consequence you | ||||
| may not distribute the Program at all.  For example, if a patent | ||||
| license would not permit royalty-free redistribution of the Program by | ||||
| all those who receive copies directly or indirectly through you, then | ||||
| the only way you could satisfy both it and this License would be to | ||||
| refrain entirely from distribution of the Program. | ||||
| 
 | ||||
| If any portion of this section is held invalid or unenforceable under | ||||
| any particular circumstance, the balance of the section is intended to | ||||
| apply and the section as a whole is intended to apply in other | ||||
| circumstances. | ||||
| 
 | ||||
| It is not the purpose of this section to induce you to infringe any | ||||
| patents or other property right claims or to contest validity of any | ||||
| such claims; this section has the sole purpose of protecting the | ||||
| integrity of the free software distribution system, which is | ||||
| implemented by public license practices.  Many people have made | ||||
| generous contributions to the wide range of software distributed | ||||
| through that system in reliance on consistent application of that | ||||
| system; it is up to the author/donor to decide if he or she is willing | ||||
| to distribute software through any other system and a licensee cannot | ||||
| impose that choice. | ||||
| 
 | ||||
| This section is intended to make thoroughly clear what is believed to | ||||
| be a consequence of the rest of this License. | ||||
| 
 | ||||
|   8. If the distribution and/or use of the Program is restricted in | ||||
| certain countries either by patents or by copyrighted interfaces, the | ||||
| original copyright holder who places the Program under this License | ||||
| may add an explicit geographical distribution limitation excluding | ||||
| those countries, so that distribution is permitted only in or among | ||||
| countries not thus excluded.  In such case, this License incorporates | ||||
| the limitation as if written in the body of this License. | ||||
| 
 | ||||
|   9. The Free Software Foundation may publish revised and/or new versions | ||||
| of the General Public License from time to time.  Such new versions will | ||||
| be similar in spirit to the present version, but may differ in detail to | ||||
| address new problems or concerns. | ||||
| 
 | ||||
| Each version is given a distinguishing version number.  If the Program | ||||
| specifies a version number of this License which applies to it and "any | ||||
| later version", you have the option of following the terms and conditions | ||||
| either of that version or of any later version published by the Free | ||||
| Software Foundation.  If the Program does not specify a version number of | ||||
| this License, you may choose any version ever published by the Free Software | ||||
| Foundation. | ||||
| 
 | ||||
|   10. If you wish to incorporate parts of the Program into other free | ||||
| programs whose distribution conditions are different, write to the author | ||||
| to ask for permission.  For software which is copyrighted by the Free | ||||
| Software Foundation, write to the Free Software Foundation; we sometimes | ||||
| make exceptions for this.  Our decision will be guided by the two goals | ||||
| of preserving the free status of all derivatives of our free software and | ||||
| of promoting the sharing and reuse of software generally. | ||||
| 
 | ||||
|           NO WARRANTY | ||||
| 
 | ||||
|   11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY | ||||
| FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW.  EXCEPT WHEN | ||||
| OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES | ||||
| PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED | ||||
| OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | ||||
| MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.  THE ENTIRE RISK AS | ||||
| TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.  SHOULD THE | ||||
| PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, | ||||
| REPAIR OR CORRECTION. | ||||
| 
 | ||||
|   12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING | ||||
| WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR | ||||
| REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, | ||||
| INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING | ||||
| OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED | ||||
| TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY | ||||
| YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER | ||||
| PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE | ||||
| POSSIBILITY OF SUCH DAMAGES. | ||||
| 
 | ||||
|          END OF TERMS AND CONDITIONS | ||||
| 
 | ||||
|       How to Apply These Terms to Your New Programs | ||||
| 
 | ||||
|   If you develop a new program, and you want it to be of the greatest | ||||
| possible use to the public, the best way to achieve this is to make it | ||||
| free software which everyone can redistribute and change under these terms. | ||||
| 
 | ||||
|   To do so, attach the following notices to the program.  It is safest | ||||
| to attach them to the start of each source file to most effectively | ||||
| convey the exclusion of warranty; and each file should have at least | ||||
| the "copyright" line and a pointer to where the full notice is found. | ||||
| 
 | ||||
|     <one line to give the program's name and a brief idea of what it does.> | ||||
|     Copyright (C) <year>  <name of author> | ||||
| 
 | ||||
|     This program is free software; you can redistribute it and/or modify | ||||
|     it under the terms of the GNU General Public License as published by | ||||
|     the Free Software Foundation; either version 2 of the License, or | ||||
|     (at your option) any later version. | ||||
| 
 | ||||
|     This program is distributed in the hope that it will be useful, | ||||
|     but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|     GNU General Public License for more details. | ||||
| 
 | ||||
|     You should have received a copy of the GNU General Public License along | ||||
|     with this program; if not, write to the Free Software Foundation, Inc., | ||||
|     51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||||
| 
 | ||||
| Also add information on how to contact you by electronic and paper mail. | ||||
| 
 | ||||
| If the program is interactive, make it output a short notice like this | ||||
| when it starts in an interactive mode: | ||||
| 
 | ||||
|     Gnomovision version 69, Copyright (C) year name of author | ||||
|     Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. | ||||
|     This is free software, and you are welcome to redistribute it | ||||
|     under certain conditions; type `show c' for details. | ||||
| 
 | ||||
| The hypothetical commands `show w' and `show c' should show the appropriate | ||||
| parts of the General Public License.  Of course, the commands you use may | ||||
| be called something other than `show w' and `show c'; they could even be | ||||
| mouse-clicks or menu items--whatever suits your program. | ||||
| 
 | ||||
| You should also get your employer (if you work as a programmer) or your | ||||
| school, if any, to sign a "copyright disclaimer" for the program, if | ||||
| necessary.  Here is a sample; alter the names: | ||||
| 
 | ||||
|   Yoyodyne, Inc., hereby disclaims all copyright interest in the program | ||||
|   `Gnomovision' (which makes passes at compilers) written by James Hacker. | ||||
| 
 | ||||
|   <signature of Ty Coon>, 1 April 1989 | ||||
|   Ty Coon, President of Vice | ||||
| 
 | ||||
| This General Public License does not permit incorporating your program into | ||||
| proprietary programs.  If your program is a subroutine library, you may | ||||
| consider it more useful to permit linking proprietary applications with the | ||||
| library.  If this is what you want to do, use the GNU Lesser General | ||||
| Public License instead of this License. | ||||
							
								
								
									
										53
									
								
								web/core/lib/Drupal/Component/FileCache/NullFileCache.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								web/core/lib/Drupal/Component/FileCache/NullFileCache.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,53 @@ | |||
| <?php | ||||
| 
 | ||||
| namespace Drupal\Component\FileCache; | ||||
| 
 | ||||
| /** | ||||
|  * Null implementation for the file cache. | ||||
|  */ | ||||
| class NullFileCache implements FileCacheInterface { | ||||
| 
 | ||||
|   /** | ||||
|    * Constructs a FileCache object. | ||||
|    * | ||||
|    * @param string $prefix | ||||
|    *   A prefix that is used as a prefix, should be set to a secure, unique key | ||||
|    *   to prevent cache pollution by a third party. | ||||
|    * @param string $collection | ||||
|    *   A collection identifier to ensure that the same files could be cached for | ||||
|    *   different purposes without clashing. | ||||
|    * @param string|null $cache_backend_class | ||||
|    *   (optional) The class that should be used as cache backend. | ||||
|    * @param array $cache_backend_configuration | ||||
|    *   (optional) The configuration for the backend class. | ||||
|    */ | ||||
|   public function __construct($prefix, $collection, $cache_backend_class = NULL, array $cache_backend_configuration = []) { | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function get($filepath) { | ||||
|     return NULL; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function getMultiple(array $filepaths) { | ||||
|     return []; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function set($filepath, $data) { | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function delete($filepath) { | ||||
|   } | ||||
| 
 | ||||
| } | ||||
							
								
								
									
										12
									
								
								web/core/lib/Drupal/Component/FileCache/README.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								web/core/lib/Drupal/Component/FileCache/README.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,12 @@ | |||
| The Drupal FileCache Component | ||||
| 
 | ||||
| Thanks for using this Drupal component. | ||||
| 
 | ||||
| You can participate in its development on Drupal.org, through our issue system: | ||||
| https://www.drupal.org/project/issues/drupal | ||||
| 
 | ||||
| You can get the full Drupal repo here: | ||||
| https://www.drupal.org/project/drupal/git-instructions | ||||
| 
 | ||||
| You can browse the full Drupal repo here: | ||||
| http://cgit.drupalcode.org/drupal | ||||
							
								
								
									
										18
									
								
								web/core/lib/Drupal/Component/FileCache/TESTING.txt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								web/core/lib/Drupal/Component/FileCache/TESTING.txt
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,18 @@ | |||
| HOW-TO: Test this Drupal component | ||||
| 
 | ||||
| In order to test this component, you'll need to get the entire Drupal repo and | ||||
| run the tests there. | ||||
| 
 | ||||
| You'll find the tests under core/tests/Drupal/Tests/Component. | ||||
| 
 | ||||
| You can get the full Drupal repo here: | ||||
| https://www.drupal.org/project/drupal/git-instructions | ||||
| 
 | ||||
| You can find more information about running PHPUnit tests with Drupal here: | ||||
| https://www.drupal.org/node/2116263 | ||||
| 
 | ||||
| Each component in the Drupal\Component namespace has its own annotated test | ||||
| group. You can use this group to run only the tests for this component. Like | ||||
| this: | ||||
| 
 | ||||
| $ ./vendor/bin/phpunit -c core --group FileCache | ||||
							
								
								
									
										15
									
								
								web/core/lib/Drupal/Component/FileCache/composer.json
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								web/core/lib/Drupal/Component/FileCache/composer.json
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,15 @@ | |||
| { | ||||
|   "name": "drupal/core-file-cache", | ||||
|   "description": "FileCache.", | ||||
|   "keywords": ["drupal"], | ||||
|   "homepage": "https://www.drupal.org/project/drupal", | ||||
|   "license": "GPL-2.0+", | ||||
|   "require": { | ||||
|     "php": ">=5.5.9" | ||||
|   }, | ||||
|   "autoload": { | ||||
|     "psr-4": { | ||||
|       "Drupal\\Component\\FileCache\\": "" | ||||
|     } | ||||
|   } | ||||
| } | ||||
		Reference in a new issue
	
	 Rob Davies
						Rob Davies