Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.
Common duplication problems, and corresponding solutions are:
| 1 | <?php | ||
| 44 | class BrowscapCache implements BrowscapCacheInterface | ||
| 45 | { | ||
| 46 | /** | ||
| 47 | * Path to the cache directory | ||
| 48 | * | ||
| 49 | * @var \WurflCache\Adapter\AdapterInterface | ||
| 50 | */ | ||
| 51 | private $cache = null; | ||
| 52 | |||
| 53 | /** | ||
| 54 | * Detected browscap version (read from INI file) | ||
| 55 | * | ||
| 56 | * @var int | ||
| 57 | */ | ||
| 58 | private $version = null; | ||
| 59 | |||
| 60 | /** | ||
| 61 | * Release date of the Browscap data (read from INI file) | ||
| 62 | * | ||
| 63 | * @var string | ||
| 64 | */ | ||
| 65 | private $releaseDate; | ||
| 66 | |||
| 67 | /** | ||
| 68 | * Type of the Browscap data (read from INI file) | ||
| 69 | * | ||
| 70 | * @var string | ||
| 71 | */ | ||
| 72 | private $type; | ||
| 73 | |||
| 74 | /** | ||
| 75 | * Constructor class, checks for the existence of (and loads) the cache and | ||
| 76 | * if needed updated the definitions | ||
| 77 | * | ||
| 78 | * @param \WurflCache\Adapter\AdapterInterface $adapter | ||
| 79 | * @param int $updateInterval | ||
| 80 | */ | ||
| 81 | 17 | public function __construct(AdapterInterface $adapter, $updateInterval = BrowscapCacheInterface::CACHE_LIVETIME) | |
| 86 | |||
| 87 | /** | ||
| 88 | * Gets the version of the Browscap data | ||
| 89 | * | ||
| 90 | * @return int | ||
| 91 | */ | ||
| 92 | 6 | View Code Duplication | public function getVersion() | 
| 106 | |||
| 107 | /** | ||
| 108 | * Gets the release date of the Browscap data | ||
| 109 | * | ||
| 110 | * @return string | ||
| 111 | */ | ||
| 112 | 1 | public function getReleaseDate() | |
| 126 | |||
| 127 | /** | ||
| 128 | * Gets the type of the Browscap data | ||
| 129 | * | ||
| 130 | * @return string | ||
| 131 | */ | ||
| 132 | 2 | View Code Duplication | public function getType() | 
| 146 | |||
| 147 | /** | ||
| 148 | * Get an item. | ||
| 149 | * | ||
| 150 | * @param string $cacheId | ||
| 151 | * @param bool $withVersion | ||
| 152 | * @param bool $success | ||
| 153 | * | ||
| 154 | * @return mixed Data on success, null on failure | ||
| 155 | */ | ||
| 156 | 7 | public function getItem($cacheId, $withVersion = true, & $success = null) | |
| 187 | |||
| 188 | /** | ||
| 189 | * save the content into an php file | ||
| 190 | * | ||
| 191 | * @param string $cacheId The cache id | ||
| 192 | * @param mixed $content The content to store | ||
| 193 | * @param bool $withVersion | ||
| 194 | * | ||
| 195 | * @return bool whether the file was correctly written to the disk | ||
| 196 | */ | ||
| 197 | 6 | public function setItem($cacheId, $content, $withVersion = true) | |
| 211 | |||
| 212 | /** | ||
| 213 | * Test if an item exists. | ||
| 214 | * | ||
| 215 | * @param string $cacheId | ||
| 216 | * @param bool $withVersion | ||
| 217 | * | ||
| 218 | * @return bool | ||
| 219 | */ | ||
| 220 | public function hasItem($cacheId, $withVersion = true) | ||
| 228 | |||
| 229 | /** | ||
| 230 | * Remove an item. | ||
| 231 | * | ||
| 232 | * @param string $cacheId | ||
| 233 | * @param bool $withVersion | ||
| 234 | * | ||
| 235 | * @return bool | ||
| 236 | */ | ||
| 237 | public function removeItem($cacheId, $withVersion = true) | ||
| 245 | |||
| 246 | /** | ||
| 247 | * Flush the whole storage | ||
| 248 | * | ||
| 249 | * @return bool | ||
| 250 | */ | ||
| 251 | public function flush() | ||
| 255 | } | ||
| 256 | 
Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.
You can also find more detailed suggestions in the “Code” section of your repository.