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 | ||
| 3 | class DeploymentStrategy extends ViewableData { | ||
| 4 | |||
| 5 | const SUCCESS_CODE = 'success'; | ||
| 6 | |||
| 7 | const WARNING_CODE = 'warning'; | ||
| 8 | |||
| 9 | const ERROR_CODE = 'error'; | ||
| 10 | |||
| 11 | /** | ||
| 12 | * @var DNEnvironment | ||
| 13 | */ | ||
| 14 | protected $environment; | ||
| 15 | |||
| 16 | /** | ||
| 17 | * @var string | ||
| 18 | */ | ||
| 19 | protected $actionTitle = 'Deploy'; | ||
| 20 | |||
| 21 | /** | ||
| 22 | * @var string | ||
| 23 | */ | ||
| 24 | protected $actionCode = 'default'; | ||
| 25 | |||
| 26 | /** | ||
| 27 | * @var int | ||
| 28 | */ | ||
| 29 | protected $estimatedTime = 0; | ||
| 30 | |||
| 31 | /** | ||
| 32 | * @var array | ||
| 33 | */ | ||
| 34 | protected $changes = []; | ||
| 35 | |||
| 36 | /** | ||
| 37 | * @var array | ||
| 38 | */ | ||
| 39 | protected $options; | ||
| 40 | |||
| 41 | /** | ||
| 42 | * Validation code | ||
| 43 | * | ||
| 44 | * @var string | ||
| 45 | */ | ||
| 46 | protected $validationCode = DeploymentStrategy::SUCCESS_CODE; | ||
| 47 | |||
| 48 | /** | ||
| 49 | * @var array | ||
| 50 | */ | ||
| 51 | protected $messages = []; | ||
| 52 | |||
| 53 | |||
| 54 | /** | ||
| 55 | * @param DNEnvironment $environment | ||
| 56 | * @param array $options | ||
| 57 | */ | ||
| 58 | 	public function __construct(DNEnvironment $environment, $options = array()) { | ||
| 62 | |||
| 63 | /** | ||
| 64 | * @param string $title | ||
| 65 | */ | ||
| 66 | 	public function setActionTitle($title) { | ||
| 69 | |||
| 70 | /** | ||
| 71 | * @return string | ||
| 72 | */ | ||
| 73 | 	public function getActionTitle() { | ||
| 76 | |||
| 77 | /** | ||
| 78 | */ | ||
| 79 | 	public function setActionCode($code) { | ||
| 82 | |||
| 83 | /** | ||
| 84 | * @return string | ||
| 85 | */ | ||
| 86 | 	public function getActionCode() { | ||
| 89 | |||
| 90 | /** | ||
| 91 | * @param int | ||
| 92 | */ | ||
| 93 | 	public function setEstimatedTime($seconds) { | ||
| 96 | |||
| 97 | /** | ||
| 98 | * @return int Time in minutes | ||
| 99 | */ | ||
| 100 | 	public function getEstimatedTime() { | ||
| 103 | |||
| 104 | /** | ||
| 105 | * @param string $title | ||
| 106 | * @param string $from | ||
| 107 | * @param string $to | ||
| 108 | */ | ||
| 109 | 	public function setChange($title, $from, $to) { | ||
| 121 | |||
| 122 | /** | ||
| 123 | * @param string $title | ||
| 124 | * @param string $desc | ||
| 125 | */ | ||
| 126 | 	public function setChangeDescriptionOnly($title, $desc) { | ||
| 131 | |||
| 132 | /** | ||
| 133 | * Filter the changeset where modification was not required. | ||
| 134 | * | ||
| 135 | * @return array | ||
| 136 | */ | ||
| 137 | 	public function getChangesModificationNeeded() { | ||
| 152 | |||
| 153 | /** | ||
| 154 | * @return array Associative array of changes, e.g. | ||
| 155 | * array( | ||
| 156 | * 'SHA' => array( | ||
| 157 | * 'from' => 'abc', | ||
| 158 | * 'to' => 'def' | ||
| 159 | * ) | ||
| 160 | * ) | ||
| 161 | */ | ||
| 162 | 	public function getChanges() { | ||
| 165 | |||
| 166 | /** | ||
| 167 | * Returns a change or a given key. | ||
| 168 | * | ||
| 169 | * @return ArrayData|null | ||
| 170 | */ | ||
| 171 | 	public function getChange($key) { | ||
| 178 | |||
| 179 | /** | ||
| 180 | * @param string $option | ||
| 181 | * @param string $value | ||
| 182 | */ | ||
| 183 | 	public function setOption($option, $value) { | ||
| 186 | |||
| 187 | /** | ||
| 188 | * @param string $option | ||
| 189 | * @return string|null | ||
| 190 | */ | ||
| 191 | 	public function getOption($option) { | ||
| 196 | |||
| 197 | /** | ||
| 198 | * @return string | ||
| 199 | */ | ||
| 200 | 	public function getOptions() { | ||
| 203 | |||
| 204 | /** | ||
| 205 | * @param string $code | ||
| 206 | */ | ||
| 207 | 	public function setValidationCode($code) { | ||
| 210 | |||
| 211 | /** | ||
| 212 | * @return string | ||
| 213 | */ | ||
| 214 | 	public function getValidationCode() { | ||
| 217 | |||
| 218 | /** | ||
| 219 | * @param string $msg | ||
| 220 | */ | ||
| 221 | 	public function setMessage($msg, $code = self::ERROR_CODE) { | ||
| 237 | |||
| 238 | /** | ||
| 239 | * @return array | ||
| 240 | */ | ||
| 241 | 	public function getMessages() { | ||
| 244 | |||
| 245 | /** | ||
| 246 | * Transform the deployment strategy to an array. | ||
| 247 | * | ||
| 248 | * @return array | ||
| 249 | */ | ||
| 250 | View Code Duplication | 	public function toArray() { | |
| 267 | |||
| 268 | /** | ||
| 269 | * @return string | ||
| 270 | */ | ||
| 271 | 	public function toJSON() { | ||
| 274 | |||
| 275 | /** | ||
| 276 | * Load from JSON associative array. | ||
| 277 | * Environment must be set by the callee when creating this object. | ||
| 278 | * | ||
| 279 | * @param string $json | ||
| 280 | */ | ||
| 281 | 	public function fromJSON($json) { | ||
| 285 | |||
| 286 | /** | ||
| 287 | * Load from array. | ||
| 288 | * Environment must be set by the callee when creating this object. | ||
| 289 | * | ||
| 290 | * @param string $data | ||
| 291 | */ | ||
| 292 | View Code Duplication | 	public function fromArray($data) { | |
| 309 | |||
| 310 | /** | ||
| 311 | * @return DNDeployment | ||
| 312 | */ | ||
| 313 | 	public function createDeployment() { | ||
| 323 | |||
| 324 | } | ||
| 325 | |||
| 326 | 
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.