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 | ||
| 15 | class WC_Order_Refund extends WC_Abstract_Order { | ||
| 16 | |||
| 17 | /** | ||
| 18 | * Extend the abstract _data properties and then read the order object. | ||
| 19 | * | ||
| 20 | * @param int|object|WC_Order $order Order to init. | ||
| 21 | */ | ||
| 22 | 	public function __construct( $order = 0 ) { | ||
| 30 | |||
| 31 | /** | ||
| 32 | * Data stored in meta keys, but not considered "meta" for an order. | ||
| 33 | * @since 2.7.0 | ||
| 34 | * @var array | ||
| 35 | */ | ||
| 36 | protected $_internal_meta_keys = array( | ||
| 37 | '_order_currency', '_cart_discount', '_refund_amount', '_refunded_by', '_refund_reason', | ||
| 38 | '_cart_discount_tax', '_order_shipping', '_order_shipping_tax', | ||
| 39 | '_order_tax', '_order_total', '_order_version', '_prices_include_tax', | ||
| 40 | '_payment_tokens', | ||
| 41 | ); | ||
| 42 | |||
| 43 | /** | ||
| 44 | * Insert data into the database. | ||
| 45 | * @since 2.7.0 | ||
| 46 | */ | ||
| 47 | View Code Duplication | 	public function create() { | |
| 57 | |||
| 58 | /** | ||
| 59 | * Read from the database. | ||
| 60 | * @since 2.7.0 | ||
| 61 | * @param int $id ID of object to read. | ||
| 62 | */ | ||
| 63 | 	public function read( $id ) { | ||
| 78 | |||
| 79 | /** | ||
| 80 | * Update data in the database. | ||
| 81 | * @since 2.7.0 | ||
| 82 | */ | ||
| 83 | View Code Duplication | 	public function update() { | |
| 91 | |||
| 92 | /** | ||
| 93 | * Get internal type (post type.) | ||
| 94 | * @return string | ||
| 95 | */ | ||
| 96 | 	public function get_type() { | ||
| 99 | |||
| 100 | /** | ||
| 101 | * Get status - always completed for refunds. | ||
| 102 | * @return string | ||
| 103 | */ | ||
| 104 | 	public function get_status() { | ||
| 107 | |||
| 108 | /** | ||
| 109 | * Get a title for the new post type. | ||
| 110 | */ | ||
| 111 | 	protected function get_post_title() { | ||
| 114 | |||
| 115 | /** | ||
| 116 | * Set refunded amount. | ||
| 117 | * @param string $value | ||
| 118 | */ | ||
| 119 | 	public function set_amount( $value ) { | ||
| 122 | |||
| 123 | /** | ||
| 124 | * Get refunded amount. | ||
| 125 | * @return int|float | ||
| 126 | */ | ||
| 127 | 	public function get_amount() { | ||
| 130 | |||
| 131 | /** | ||
| 132 | * Get formatted refunded amount. | ||
| 133 | * @since 2.4 | ||
| 134 | * @return string | ||
| 135 | */ | ||
| 136 | 	public function get_formatted_refund_amount() { | ||
| 139 | |||
| 140 | /** | ||
| 141 | * Set refund reason. | ||
| 142 | * @param string $value | ||
| 143 | */ | ||
| 144 | 	public function set_reason( $value ) { | ||
| 147 | |||
| 148 | /** | ||
| 149 | * Get refund reason. | ||
| 150 | * @since 2.2 | ||
| 151 | * @return int|float | ||
| 152 | */ | ||
| 153 | 	public function get_reason() { | ||
| 156 | |||
| 157 | /** | ||
| 158 | * Set refunded by. | ||
| 159 | * @param int $value | ||
| 160 | */ | ||
| 161 | 	public function set_refunded_by( $value ) { | ||
| 164 | |||
| 165 | /** | ||
| 166 | * Get ID of user who did the refund. | ||
| 167 | * @since 2.7 | ||
| 168 | * @return int | ||
| 169 | */ | ||
| 170 | 	public function get_refunded_by() { | ||
| 173 | |||
| 174 | /** | ||
| 175 | * Magic __get method for backwards compatibility. | ||
| 176 | * @param string $key | ||
| 177 | * @return mixed | ||
| 178 | */ | ||
| 179 | 	public function __get( $key ) { | ||
| 191 | |||
| 192 | /** | ||
| 193 | * Gets an refund from the database. | ||
| 194 | * @deprecated 2.7 | ||
| 195 | * @param int $id (default: 0). | ||
| 196 | * @return bool | ||
| 197 | */ | ||
| 198 | View Code Duplication | 	public function get_refund( $id = 0 ) { | |
| 209 | |||
| 210 | /** | ||
| 211 | * Get refund amount. | ||
| 212 | * @deprecated 2.7 | ||
| 213 | * @return int|float | ||
| 214 | */ | ||
| 215 | 	public function get_refund_amount() { | ||
| 219 | |||
| 220 | /** | ||
| 221 | * Get refund reason. | ||
| 222 | * @deprecated 2.7 | ||
| 223 | * @return int|float | ||
| 224 | */ | ||
| 225 | 	public function get_refund_reason() { | ||
| 229 | } | ||
| 230 | 
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.