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:
Complex classes like HtmlMin often do a lot of different things. To break such a class down, we need to identify a cohesive component within that class. A common approach to find such a component is to look for fields/methods that share the same prefixes, or suffixes. You can also have a look at the cohesion graph to spot any un-connected, or weakly-connected components.
Once you have determined the fields that belong together, you can apply the Extract Class refactoring. If the component makes sense as a sub-class, Extract Subclass is also a candidate, and is often faster.
While breaking up the class, it is a good idea to analyze how other classes use HtmlMin, and based on these observations, apply Extract Interface, too.
| 1 | <?php | ||
| 21 | class HtmlMin implements HtmlMinInterface | ||
| 22 | { | ||
| 23 | /** | ||
| 24 | * @var string | ||
| 25 | */ | ||
| 26 |     private static $regExSpace = "/[[:space:]]{2,}|[\r\n]/u"; | ||
| 27 | |||
| 28 | /** | ||
| 29 | * @var string[] | ||
| 30 | * | ||
| 31 | * @psalm-var list<string> | ||
| 32 | */ | ||
| 33 | private static $optional_end_tags = [ | ||
| 34 | 'html', | ||
| 35 | 'head', | ||
| 36 | 'body', | ||
| 37 | ]; | ||
| 38 | |||
| 39 | /** | ||
| 40 | * @var string[] | ||
| 41 | * | ||
| 42 | * @psalm-var list<string> | ||
| 43 | */ | ||
| 44 | private static $selfClosingTags = [ | ||
| 45 | 'area', | ||
| 46 | 'base', | ||
| 47 | 'basefont', | ||
| 48 | 'br', | ||
| 49 | 'col', | ||
| 50 | 'command', | ||
| 51 | 'embed', | ||
| 52 | 'frame', | ||
| 53 | 'hr', | ||
| 54 | 'img', | ||
| 55 | 'input', | ||
| 56 | 'isindex', | ||
| 57 | 'keygen', | ||
| 58 | 'link', | ||
| 59 | 'meta', | ||
| 60 | 'param', | ||
| 61 | 'source', | ||
| 62 | 'track', | ||
| 63 | 'wbr', | ||
| 64 | ]; | ||
| 65 | |||
| 66 | /** | ||
| 67 | * @var string[] | ||
| 68 | * | ||
| 69 | * @psalm-var array<string, string> | ||
| 70 | */ | ||
| 71 | private static $trimWhitespaceFromTags = [ | ||
| 72 | 'article' => '', | ||
| 73 | 'br' => '', | ||
| 74 | 'div' => '', | ||
| 75 | 'footer' => '', | ||
| 76 | 'hr' => '', | ||
| 77 | 'nav' => '', | ||
| 78 | 'p' => '', | ||
| 79 | 'script' => '', | ||
| 80 | ]; | ||
| 81 | |||
| 82 | /** | ||
| 83 | * @var array | ||
| 84 | */ | ||
| 85 | private static $booleanAttributes = [ | ||
| 86 | 'allowfullscreen' => '', | ||
| 87 | 'async' => '', | ||
| 88 | 'autofocus' => '', | ||
| 89 | 'autoplay' => '', | ||
| 90 | 'checked' => '', | ||
| 91 | 'compact' => '', | ||
| 92 | 'controls' => '', | ||
| 93 | 'declare' => '', | ||
| 94 | 'default' => '', | ||
| 95 | 'defaultchecked' => '', | ||
| 96 | 'defaultmuted' => '', | ||
| 97 | 'defaultselected' => '', | ||
| 98 | 'defer' => '', | ||
| 99 | 'disabled' => '', | ||
| 100 | 'enabled' => '', | ||
| 101 | 'formnovalidate' => '', | ||
| 102 | 'hidden' => '', | ||
| 103 | 'indeterminate' => '', | ||
| 104 | 'inert' => '', | ||
| 105 | 'ismap' => '', | ||
| 106 | 'itemscope' => '', | ||
| 107 | 'loop' => '', | ||
| 108 | 'multiple' => '', | ||
| 109 | 'muted' => '', | ||
| 110 | 'nohref' => '', | ||
| 111 | 'noresize' => '', | ||
| 112 | 'noshade' => '', | ||
| 113 | 'novalidate' => '', | ||
| 114 | 'nowrap' => '', | ||
| 115 | 'open' => '', | ||
| 116 | 'pauseonexit' => '', | ||
| 117 | 'readonly' => '', | ||
| 118 | 'required' => '', | ||
| 119 | 'reversed' => '', | ||
| 120 | 'scoped' => '', | ||
| 121 | 'seamless' => '', | ||
| 122 | 'selected' => '', | ||
| 123 | 'sortable' => '', | ||
| 124 | 'truespeed' => '', | ||
| 125 | 'typemustmatch' => '', | ||
| 126 | 'visible' => '', | ||
| 127 | ]; | ||
| 128 | |||
| 129 | /** | ||
| 130 | * @var array | ||
| 131 | */ | ||
| 132 | private static $skipTagsForRemoveWhitespace = [ | ||
| 133 | 'code', | ||
| 134 | 'pre', | ||
| 135 | 'script', | ||
| 136 | 'style', | ||
| 137 | 'textarea', | ||
| 138 | ]; | ||
| 139 | |||
| 140 | /** | ||
| 141 | * @var array | ||
| 142 | */ | ||
| 143 | private $protectedChildNodes = []; | ||
| 144 | |||
| 145 | /** | ||
| 146 | * @var string | ||
| 147 | */ | ||
| 148 | private $protectedChildNodesHelper = 'html-min--voku--saved-content'; | ||
| 149 | |||
| 150 | /** | ||
| 151 | * @var bool | ||
| 152 | */ | ||
| 153 | private $doOptimizeViaHtmlDomParser = true; | ||
| 154 | |||
| 155 | /** | ||
| 156 | * @var bool | ||
| 157 | */ | ||
| 158 | private $doOptimizeAttributes = true; | ||
| 159 | |||
| 160 | /** | ||
| 161 | * @var bool | ||
| 162 | */ | ||
| 163 | private $doRemoveComments = true; | ||
| 164 | |||
| 165 | /** | ||
| 166 | * @var bool | ||
| 167 | */ | ||
| 168 | private $doRemoveWhitespaceAroundTags = false; | ||
| 169 | |||
| 170 | /** | ||
| 171 | * @var bool | ||
| 172 | */ | ||
| 173 | private $doRemoveOmittedQuotes = true; | ||
| 174 | |||
| 175 | /** | ||
| 176 | * @var bool | ||
| 177 | */ | ||
| 178 | private $doRemoveOmittedHtmlTags = true; | ||
| 179 | |||
| 180 | /** | ||
| 181 | * @var bool | ||
| 182 | */ | ||
| 183 | private $doRemoveHttpPrefixFromAttributes = false; | ||
| 184 | |||
| 185 | /** | ||
| 186 | * @var bool | ||
| 187 | */ | ||
| 188 | private $doRemoveHttpsPrefixFromAttributes = false; | ||
| 189 | |||
| 190 | /** | ||
| 191 | * @var bool | ||
| 192 | */ | ||
| 193 | private $doKeepHttpAndHttpsPrefixOnExternalAttributes = false; | ||
| 194 | |||
| 195 | /** | ||
| 196 | * @var bool | ||
| 197 | */ | ||
| 198 | private $doMakeSameDomainsLinksRelative = false; | ||
| 199 | |||
| 200 | /** | ||
| 201 | * @var string[] | ||
| 202 | */ | ||
| 203 | private $localDomains = []; | ||
| 204 | |||
| 205 | /** | ||
| 206 | * @var array | ||
| 207 | */ | ||
| 208 | private $domainsToRemoveHttpPrefixFromAttributes = [ | ||
| 209 | 'google.com', | ||
| 210 | 'google.de', | ||
| 211 | ]; | ||
| 212 | |||
| 213 | /** | ||
| 214 | * @var bool | ||
| 215 | */ | ||
| 216 | private $doSortCssClassNames = true; | ||
| 217 | |||
| 218 | /** | ||
| 219 | * @var bool | ||
| 220 | */ | ||
| 221 | private $doSortHtmlAttributes = true; | ||
| 222 | |||
| 223 | /** | ||
| 224 | * @var bool | ||
| 225 | */ | ||
| 226 | private $doRemoveDeprecatedScriptCharsetAttribute = true; | ||
| 227 | |||
| 228 | /** | ||
| 229 | * @var bool | ||
| 230 | */ | ||
| 231 | private $doRemoveDefaultAttributes = false; | ||
| 232 | |||
| 233 | /** | ||
| 234 | * @var bool | ||
| 235 | */ | ||
| 236 | private $doRemoveDeprecatedAnchorName = true; | ||
| 237 | |||
| 238 | /** | ||
| 239 | * @var bool | ||
| 240 | */ | ||
| 241 | private $doRemoveDeprecatedTypeFromStylesheetLink = true; | ||
| 242 | |||
| 243 | /** | ||
| 244 | * @var bool | ||
| 245 | */ | ||
| 246 | private $doRemoveDeprecatedTypeFromStyleAndLinkTag = true; | ||
| 247 | |||
| 248 | /** | ||
| 249 | * @var bool | ||
| 250 | */ | ||
| 251 | private $doRemoveDefaultMediaTypeFromStyleAndLinkTag = true; | ||
| 252 | |||
| 253 | /** | ||
| 254 | * @var bool | ||
| 255 | */ | ||
| 256 | private $doRemoveDefaultTypeFromButton = false; | ||
| 257 | |||
| 258 | /** | ||
| 259 | * @var bool | ||
| 260 | */ | ||
| 261 | private $doRemoveDeprecatedTypeFromScriptTag = true; | ||
| 262 | |||
| 263 | /** | ||
| 264 | * @var bool | ||
| 265 | */ | ||
| 266 | private $doRemoveValueFromEmptyInput = true; | ||
| 267 | |||
| 268 | /** | ||
| 269 | * @var bool | ||
| 270 | */ | ||
| 271 | private $doRemoveEmptyAttributes = true; | ||
| 272 | |||
| 273 | /** | ||
| 274 | * @var bool | ||
| 275 | */ | ||
| 276 | private $doSumUpWhitespace = true; | ||
| 277 | |||
| 278 | /** | ||
| 279 | * @var bool | ||
| 280 | */ | ||
| 281 | private $doRemoveSpacesBetweenTags = false; | ||
| 282 | |||
| 283 | /** | ||
| 284 | * @var bool | ||
| 285 | */ | ||
| 286 | private $keepBrokenHtml = false; | ||
| 287 | |||
| 288 | /** | ||
| 289 | * @var bool | ||
| 290 | */ | ||
| 291 | private $withDocType = false; | ||
| 292 | |||
| 293 | /** | ||
| 294 | * @var HtmlMinDomObserverInterface[]|\SplObjectStorage | ||
| 295 | * | ||
| 296 | * @psalm-var \SplObjectStorage<HtmlMinDomObserverInterface> | ||
| 297 | */ | ||
| 298 | private $domLoopObservers; | ||
| 299 | |||
| 300 | /** | ||
| 301 | * @var int | ||
| 302 | */ | ||
| 303 | private $protected_tags_counter = 0; | ||
| 304 | |||
| 305 | /** | ||
| 306 | * @var bool | ||
| 307 | */ | ||
| 308 | private $isHTML4 = false; | ||
| 309 | |||
| 310 | /** | ||
| 311 | * @var bool | ||
| 312 | */ | ||
| 313 | private $isXHTML = false; | ||
| 314 | |||
| 315 | /** | ||
| 316 | * @var string[]|null | ||
| 317 | */ | ||
| 318 | private $templateLogicSyntaxInSpecialScriptTags; | ||
| 319 | |||
| 320 | /** | ||
| 321 | * HtmlMin constructor. | ||
| 322 | */ | ||
| 323 | 60 | public function __construct() | |
| 329 | |||
| 330 | /** | ||
| 331 | * @param HtmlMinDomObserverInterface $observer | ||
| 332 | * | ||
| 333 | * @return void | ||
| 334 | */ | ||
| 335 | 60 | public function attachObserverToTheDomLoop(HtmlMinDomObserverInterface $observer) | |
| 339 | |||
| 340 | /** | ||
| 341 | * @param bool $doOptimizeAttributes | ||
| 342 | * | ||
| 343 | * @return $this | ||
| 344 | */ | ||
| 345 | 2 | public function doOptimizeAttributes(bool $doOptimizeAttributes = true): self | |
| 351 | |||
| 352 | /** | ||
| 353 | * @param bool $doOptimizeViaHtmlDomParser | ||
| 354 | * | ||
| 355 | * @return $this | ||
| 356 | */ | ||
| 357 | 2 | public function doOptimizeViaHtmlDomParser(bool $doOptimizeViaHtmlDomParser = true): self | |
| 363 | |||
| 364 | /** | ||
| 365 | * @param bool $doRemoveComments | ||
| 366 | * | ||
| 367 | * @return $this | ||
| 368 | */ | ||
| 369 | 3 | public function doRemoveComments(bool $doRemoveComments = true): self | |
| 375 | |||
| 376 | /** | ||
| 377 | * @param bool $doRemoveDefaultAttributes | ||
| 378 | * | ||
| 379 | * @return $this | ||
| 380 | */ | ||
| 381 | 2 | public function doRemoveDefaultAttributes(bool $doRemoveDefaultAttributes = true): self | |
| 387 | |||
| 388 | /** | ||
| 389 | * @param bool $doRemoveDeprecatedAnchorName | ||
| 390 | * | ||
| 391 | * @return $this | ||
| 392 | */ | ||
| 393 | 2 | public function doRemoveDeprecatedAnchorName(bool $doRemoveDeprecatedAnchorName = true): self | |
| 399 | |||
| 400 | /** | ||
| 401 | * @param bool $doRemoveDeprecatedScriptCharsetAttribute | ||
| 402 | * | ||
| 403 | * @return $this | ||
| 404 | */ | ||
| 405 | 2 | public function doRemoveDeprecatedScriptCharsetAttribute(bool $doRemoveDeprecatedScriptCharsetAttribute = true): self | |
| 411 | |||
| 412 | /** | ||
| 413 | * @param bool $doRemoveDeprecatedTypeFromScriptTag | ||
| 414 | * | ||
| 415 | * @return $this | ||
| 416 | */ | ||
| 417 | 3 | public function doRemoveDeprecatedTypeFromScriptTag(bool $doRemoveDeprecatedTypeFromScriptTag = true): self | |
| 423 | |||
| 424 | /** | ||
| 425 | * @param bool $doRemoveDeprecatedTypeFromStylesheetLink | ||
| 426 | * | ||
| 427 | * @return $this | ||
| 428 | */ | ||
| 429 | 2 | public function doRemoveDeprecatedTypeFromStylesheetLink(bool $doRemoveDeprecatedTypeFromStylesheetLink = true): self | |
| 435 | |||
| 436 | /** | ||
| 437 | * @param bool $doRemoveDeprecatedTypeFromStyleAndLinkTag | ||
| 438 | * | ||
| 439 | * @return $this | ||
| 440 | */ | ||
| 441 | 1 | public function doRemoveDeprecatedTypeFromStyleAndLinkTag(bool $doRemoveDeprecatedTypeFromStyleAndLinkTag = true): self | |
| 447 | |||
| 448 | /** | ||
| 449 | * @param bool $doRemoveDefaultMediaTypeFromStyleAndLinkTag | ||
| 450 | * | ||
| 451 | * @return $this | ||
| 452 | */ | ||
| 453 | 1 | public function doRemoveDefaultMediaTypeFromStyleAndLinkTag(bool $doRemoveDefaultMediaTypeFromStyleAndLinkTag = true): self | |
| 459 | |||
| 460 | /** | ||
| 461 | * @param bool $doRemoveDefaultTypeFromButton | ||
| 462 | * | ||
| 463 | * @return $this | ||
| 464 | */ | ||
| 465 | 1 | public function doRemoveDefaultTypeFromButton(bool $doRemoveDefaultTypeFromButton = true): self | |
| 471 | |||
| 472 | /** | ||
| 473 | * @param bool $doRemoveEmptyAttributes | ||
| 474 | * | ||
| 475 | * @return $this | ||
| 476 | */ | ||
| 477 | 2 | public function doRemoveEmptyAttributes(bool $doRemoveEmptyAttributes = true): self | |
| 483 | |||
| 484 | /** | ||
| 485 | * @param bool $doRemoveHttpPrefixFromAttributes | ||
| 486 | * | ||
| 487 | * @return $this | ||
| 488 | */ | ||
| 489 | 6 | public function doRemoveHttpPrefixFromAttributes(bool $doRemoveHttpPrefixFromAttributes = true): self | |
| 495 | |||
| 496 | /** | ||
| 497 | * @param bool $doRemoveHttpsPrefixFromAttributes | ||
| 498 | * | ||
| 499 | * @return $this | ||
| 500 | */ | ||
| 501 | 1 | public function doRemoveHttpsPrefixFromAttributes(bool $doRemoveHttpsPrefixFromAttributes = true): self | |
| 507 | |||
| 508 | /** | ||
| 509 | * @param bool $doKeepHttpAndHttpsPrefixOnExternalAttributes | ||
| 510 | * | ||
| 511 | * @return $this | ||
| 512 | */ | ||
| 513 | 1 | public function doKeepHttpAndHttpsPrefixOnExternalAttributes(bool $doKeepHttpAndHttpsPrefixOnExternalAttributes = true): self | |
| 519 | |||
| 520 | /** | ||
| 521 | * @param string[] $localDomains | ||
| 522 | * | ||
| 523 | * @return $this | ||
| 524 | */ | ||
| 525 | 1 | public function doMakeSameDomainsLinksRelative(array $localDomains): self | |
| 537 | |||
| 538 | /** | ||
| 539 | * @return string[] | ||
| 540 | */ | ||
| 541 | 1 | public function getLocalDomains(): array | |
| 545 | |||
| 546 | /** | ||
| 547 | * @param bool $doRemoveOmittedHtmlTags | ||
| 548 | * | ||
| 549 | * @return $this | ||
| 550 | */ | ||
| 551 | 1 | public function doRemoveOmittedHtmlTags(bool $doRemoveOmittedHtmlTags = true): self | |
| 557 | |||
| 558 | /** | ||
| 559 | * @param bool $doRemoveOmittedQuotes | ||
| 560 | * | ||
| 561 | * @return $this | ||
| 562 | */ | ||
| 563 | 1 | public function doRemoveOmittedQuotes(bool $doRemoveOmittedQuotes = true): self | |
| 569 | |||
| 570 | /** | ||
| 571 | * @param bool $doRemoveSpacesBetweenTags | ||
| 572 | * | ||
| 573 | * @return $this | ||
| 574 | */ | ||
| 575 | 1 | public function doRemoveSpacesBetweenTags(bool $doRemoveSpacesBetweenTags = true): self | |
| 581 | |||
| 582 | /** | ||
| 583 | * @param bool $doRemoveValueFromEmptyInput | ||
| 584 | * | ||
| 585 | * @return $this | ||
| 586 | */ | ||
| 587 | 2 | public function doRemoveValueFromEmptyInput(bool $doRemoveValueFromEmptyInput = true): self | |
| 593 | |||
| 594 | /** | ||
| 595 | * @param bool $doRemoveWhitespaceAroundTags | ||
| 596 | * | ||
| 597 | * @return $this | ||
| 598 | */ | ||
| 599 | 5 | public function doRemoveWhitespaceAroundTags(bool $doRemoveWhitespaceAroundTags = true): self | |
| 605 | |||
| 606 | /** | ||
| 607 | * @param bool $doSortCssClassNames | ||
| 608 | * | ||
| 609 | * @return $this | ||
| 610 | */ | ||
| 611 | 2 | public function doSortCssClassNames(bool $doSortCssClassNames = true): self | |
| 617 | |||
| 618 | /** | ||
| 619 | * @param bool $doSortHtmlAttributes | ||
| 620 | * | ||
| 621 | * @return $this | ||
| 622 | */ | ||
| 623 | 2 | public function doSortHtmlAttributes(bool $doSortHtmlAttributes = true): self | |
| 629 | |||
| 630 | /** | ||
| 631 | * @param bool $doSumUpWhitespace | ||
| 632 | * | ||
| 633 | * @return $this | ||
| 634 | */ | ||
| 635 | 2 | public function doSumUpWhitespace(bool $doSumUpWhitespace = true): self | |
| 641 | |||
| 642 | 56 | private function domNodeAttributesToString(\DOMNode $node): string | |
| 703 | |||
| 704 | /** | ||
| 705 | * @param \DOMNode $node | ||
| 706 | * | ||
| 707 | * @return bool | ||
| 708 | */ | ||
| 709 | 55 | private function domNodeClosingTagOptional(\DOMNode $node): bool | |
| 973 | |||
| 974 | 56 | protected function domNodeToString(\DOMNode $node): string | |
| 1072 | |||
| 1073 | /** | ||
| 1074 | * @param \DOMNode $node | ||
| 1075 | * | ||
| 1076 | * @return string | ||
| 1077 | */ | ||
| 1078 | 56 | private function getDoctype(\DOMNode $node): string | |
| 1108 | |||
| 1109 | /** | ||
| 1110 | * @return array | ||
| 1111 | */ | ||
| 1112 | public function getDomainsToRemoveHttpPrefixFromAttributes(): array | ||
| 1116 | |||
| 1117 | /** | ||
| 1118 | * @return bool | ||
| 1119 | */ | ||
| 1120 | public function isDoOptimizeAttributes(): bool | ||
| 1124 | |||
| 1125 | /** | ||
| 1126 | * @return bool | ||
| 1127 | */ | ||
| 1128 | public function isDoOptimizeViaHtmlDomParser(): bool | ||
| 1132 | |||
| 1133 | /** | ||
| 1134 | * @return bool | ||
| 1135 | */ | ||
| 1136 | public function isDoRemoveComments(): bool | ||
| 1140 | |||
| 1141 | /** | ||
| 1142 | * @return bool | ||
| 1143 | */ | ||
| 1144 | 38 | public function isDoRemoveDefaultAttributes(): bool | |
| 1148 | |||
| 1149 | /** | ||
| 1150 | * @return bool | ||
| 1151 | */ | ||
| 1152 | 38 | public function isDoRemoveDeprecatedAnchorName(): bool | |
| 1156 | |||
| 1157 | /** | ||
| 1158 | * @return bool | ||
| 1159 | */ | ||
| 1160 | 38 | public function isDoRemoveDeprecatedScriptCharsetAttribute(): bool | |
| 1164 | |||
| 1165 | /** | ||
| 1166 | * @return bool | ||
| 1167 | */ | ||
| 1168 | 38 | public function isDoRemoveDeprecatedTypeFromScriptTag(): bool | |
| 1172 | |||
| 1173 | /** | ||
| 1174 | * @return bool | ||
| 1175 | */ | ||
| 1176 | 38 | public function isDoRemoveDeprecatedTypeFromStylesheetLink(): bool | |
| 1180 | |||
| 1181 | /** | ||
| 1182 | * @return bool | ||
| 1183 | */ | ||
| 1184 | 38 | public function isDoRemoveDeprecatedTypeFromStyleAndLinkTag(): bool | |
| 1188 | |||
| 1189 | /** | ||
| 1190 | * @return bool | ||
| 1191 | */ | ||
| 1192 | 38 | public function isDoRemoveDefaultMediaTypeFromStyleAndLinkTag(): bool | |
| 1196 | |||
| 1197 | /** | ||
| 1198 | * @return bool | ||
| 1199 | */ | ||
| 1200 | 37 | public function isDoRemoveDefaultTypeFromButton(): bool | |
| 1204 | |||
| 1205 | /** | ||
| 1206 | * @return bool | ||
| 1207 | */ | ||
| 1208 | 37 | public function isDoRemoveEmptyAttributes(): bool | |
| 1212 | |||
| 1213 | /** | ||
| 1214 | * @return bool | ||
| 1215 | */ | ||
| 1216 | 38 | public function isDoRemoveHttpPrefixFromAttributes(): bool | |
| 1220 | |||
| 1221 | /** | ||
| 1222 | * @return bool | ||
| 1223 | */ | ||
| 1224 | 38 | public function isDoRemoveHttpsPrefixFromAttributes(): bool | |
| 1228 | |||
| 1229 | /** | ||
| 1230 | * @return bool | ||
| 1231 | */ | ||
| 1232 | 4 | public function isdoKeepHttpAndHttpsPrefixOnExternalAttributes(): bool | |
| 1236 | |||
| 1237 | /** | ||
| 1238 | * @return bool | ||
| 1239 | */ | ||
| 1240 | 38 | public function isDoMakeSameDomainsLinksRelative(): bool | |
| 1244 | |||
| 1245 | /** | ||
| 1246 | * @return bool | ||
| 1247 | */ | ||
| 1248 | public function isDoRemoveOmittedHtmlTags(): bool | ||
| 1252 | |||
| 1253 | /** | ||
| 1254 | * @return bool | ||
| 1255 | */ | ||
| 1256 | public function isDoRemoveOmittedQuotes(): bool | ||
| 1260 | |||
| 1261 | /** | ||
| 1262 | * @return bool | ||
| 1263 | */ | ||
| 1264 | public function isDoRemoveSpacesBetweenTags(): bool | ||
| 1268 | |||
| 1269 | /** | ||
| 1270 | * @return bool | ||
| 1271 | */ | ||
| 1272 | 37 | public function isDoRemoveValueFromEmptyInput(): bool | |
| 1276 | |||
| 1277 | /** | ||
| 1278 | * @return bool | ||
| 1279 | */ | ||
| 1280 | public function isDoRemoveWhitespaceAroundTags(): bool | ||
| 1284 | |||
| 1285 | /** | ||
| 1286 | * @return bool | ||
| 1287 | */ | ||
| 1288 | 37 | public function isDoSortCssClassNames(): bool | |
| 1292 | |||
| 1293 | /** | ||
| 1294 | * @return bool | ||
| 1295 | */ | ||
| 1296 | 38 | public function isDoSortHtmlAttributes(): bool | |
| 1300 | |||
| 1301 | /** | ||
| 1302 | * @return bool | ||
| 1303 | */ | ||
| 1304 | public function isDoSumUpWhitespace(): bool | ||
| 1308 | |||
| 1309 | /** | ||
| 1310 | * @return bool | ||
| 1311 | */ | ||
| 1312 | 5 | public function isHTML4(): bool | |
| 1316 | |||
| 1317 | /** | ||
| 1318 | * @return bool | ||
| 1319 | */ | ||
| 1320 | 5 | public function isXHTML(): bool | |
| 1324 | |||
| 1325 | /** | ||
| 1326 | * @param string $html | ||
| 1327 | * @param bool $multiDecodeNewHtmlEntity | ||
| 1328 | * | ||
| 1329 | * @return string | ||
| 1330 | */ | ||
| 1331 | 60 | public function minify($html, $multiDecodeNewHtmlEntity = false): string | |
| 1456 | |||
| 1457 | /** | ||
| 1458 | * @param \DOMNode $node | ||
| 1459 | * | ||
| 1460 | * @return \DOMNode|null | ||
| 1461 | */ | ||
| 1462 | 55 | protected function getNextSiblingOfTypeDOMElement(\DOMNode $node) | |
| 1485 | |||
| 1486 | /** | ||
| 1487 | * Check if the current string is an conditional comment. | ||
| 1488 | * | ||
| 1489 | * INFO: since IE >= 10 conditional comment are not working anymore | ||
| 1490 | * | ||
| 1491 | * <!--[if expression]> HTML <![endif]--> | ||
| 1492 | * <![if expression]> HTML <![endif]> | ||
| 1493 | * | ||
| 1494 | * @param string $comment | ||
| 1495 | * | ||
| 1496 | * @return bool | ||
| 1497 | */ | ||
| 1498 | 4 | private function isConditionalComment($comment): bool | |
| 1518 | |||
| 1519 | /** | ||
| 1520 | * @param string $html | ||
| 1521 | * @param bool $multiDecodeNewHtmlEntity | ||
| 1522 | * | ||
| 1523 | * @return string | ||
| 1524 | */ | ||
| 1525 | 56 | private function minifyHtmlDom($html, $multiDecodeNewHtmlEntity): string | |
| 1613 | |||
| 1614 | /** | ||
| 1615 | * @param SimpleHtmlDomInterface $domElement | ||
| 1616 | * | ||
| 1617 | * @return void | ||
| 1618 | */ | ||
| 1619 | 56 | private function notifyObserversAboutDomElementAfterMinification(SimpleHtmlDomInterface $domElement) | |
| 1625 | |||
| 1626 | /** | ||
| 1627 | * @param SimpleHtmlDomInterface $domElement | ||
| 1628 | * | ||
| 1629 | * @return void | ||
| 1630 | */ | ||
| 1631 | 56 | private function notifyObserversAboutDomElementBeforeMinification(SimpleHtmlDomInterface $domElement) | |
| 1637 | |||
| 1638 | /** | ||
| 1639 | * @param HtmlDomParser $dom | ||
| 1640 | * @param string $selector | ||
| 1641 | * | ||
| 1642 | * @return HtmlDomParser | ||
| 1643 | */ | ||
| 1644 | 56 | private function protectTagHelper(HtmlDomParser $dom, string $selector): HtmlDomParser | |
| 1662 | |||
| 1663 | /** | ||
| 1664 | * Prevent changes of inline "styles" and "scripts". | ||
| 1665 | * | ||
| 1666 | * @param HtmlDomParser $dom | ||
| 1667 | * | ||
| 1668 | * @return HtmlDomParser | ||
| 1669 | */ | ||
| 1670 | 56 | private function protectTags(HtmlDomParser $dom): HtmlDomParser | |
| 1720 | |||
| 1721 | /** | ||
| 1722 | * Remove comments in the dom. | ||
| 1723 | * | ||
| 1724 | * @param HtmlDomParser $dom | ||
| 1725 | * | ||
| 1726 | * @return HtmlDomParser | ||
| 1727 | */ | ||
| 1728 | 54 | private function removeComments(HtmlDomParser $dom): HtmlDomParser | |
| 1745 | |||
| 1746 | /** | ||
| 1747 | * Trim tags in the dom. | ||
| 1748 | * | ||
| 1749 | * @param SimpleHtmlDomInterface $element | ||
| 1750 | * | ||
| 1751 | * @return void | ||
| 1752 | */ | ||
| 1753 | 3 | private function removeWhitespaceAroundTags(SimpleHtmlDomInterface $element) | |
| 1782 | |||
| 1783 | /** | ||
| 1784 | * Callback function for preg_replace_callback use. | ||
| 1785 | * | ||
| 1786 | * @param array $matches PREG matches | ||
| 1787 | * | ||
| 1788 | * @return string | ||
| 1789 | */ | ||
| 1790 | 12 | private function restoreProtectedHtml($matches): string | |
| 1796 | |||
| 1797 | /** | ||
| 1798 | * @param array $domainsToRemoveHttpPrefixFromAttributes | ||
| 1799 | * | ||
| 1800 | * @return $this | ||
| 1801 | */ | ||
| 1802 | 2 | public function setDomainsToRemoveHttpPrefixFromAttributes($domainsToRemoveHttpPrefixFromAttributes): self | |
| 1808 | |||
| 1809 | /** | ||
| 1810 | * Sum-up extra whitespace from dom-nodes. | ||
| 1811 | * | ||
| 1812 | * @param HtmlDomParser $dom | ||
| 1813 | * | ||
| 1814 | * @return HtmlDomParser | ||
| 1815 | */ | ||
| 1816 | 55 | private function sumUpWhitespace(HtmlDomParser $dom): HtmlDomParser | |
| 1849 | |||
| 1850 | /** | ||
| 1851 | * WARNING: maybe bad for performance ... | ||
| 1852 | * | ||
| 1853 | * @param bool $keepBrokenHtml | ||
| 1854 | * | ||
| 1855 | * @return HtmlMin | ||
| 1856 | */ | ||
| 1857 | 2 | public function useKeepBrokenHtml(bool $keepBrokenHtml): self | |
| 1863 | |||
| 1864 | /** | ||
| 1865 | * @param string[] $templateLogicSyntaxInSpecialScriptTags | ||
| 1866 | * | ||
| 1867 | * @return HtmlMin | ||
| 1868 | */ | ||
| 1869 | 1 | public function overwriteTemplateLogicSyntaxInSpecialScriptTags(array $templateLogicSyntaxInSpecialScriptTags): self | |
| 1881 | } | ||
| 1882 | 
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.