@@ -54,45 +54,45 @@ discard block |
||
| 54 | 54 | const ERROR_INVALID_COMMANDS = 47801; |
| 55 | 55 | const ERROR_PLACEHOLDER_NOT_FOUND = 47804; |
| 56 | 56 | |
| 57 | - /** |
|
| 58 | - * @var Mailcode_Parser |
|
| 59 | - */ |
|
| 57 | + /** |
|
| 58 | + * @var Mailcode_Parser |
|
| 59 | + */ |
|
| 60 | 60 | protected $parser; |
| 61 | 61 | |
| 62 | - /** |
|
| 63 | - * @var Mailcode_Collection |
|
| 64 | - */ |
|
| 62 | + /** |
|
| 63 | + * @var Mailcode_Collection |
|
| 64 | + */ |
|
| 65 | 65 | protected $commands; |
| 66 | 66 | |
| 67 | - /** |
|
| 68 | - * @var string |
|
| 69 | - */ |
|
| 67 | + /** |
|
| 68 | + * @var string |
|
| 69 | + */ |
|
| 70 | 70 | protected $originalString; |
| 71 | 71 | |
| 72 | - /** |
|
| 73 | - * @var Mailcode_Collection |
|
| 74 | - */ |
|
| 72 | + /** |
|
| 73 | + * @var Mailcode_Collection |
|
| 74 | + */ |
|
| 75 | 75 | protected $collection; |
| 76 | 76 | |
| 77 | - /** |
|
| 78 | - * Counter for the placeholders, global for all placeholders. |
|
| 79 | - * @var integer |
|
| 80 | - */ |
|
| 77 | + /** |
|
| 78 | + * Counter for the placeholders, global for all placeholders. |
|
| 79 | + * @var integer |
|
| 80 | + */ |
|
| 81 | 81 | private static $counter = 0; |
| 82 | 82 | |
| 83 | - /** |
|
| 84 | - * @var Mailcode_Parser_Safeguard_Placeholder[] |
|
| 85 | - */ |
|
| 83 | + /** |
|
| 84 | + * @var Mailcode_Parser_Safeguard_Placeholder[] |
|
| 85 | + */ |
|
| 86 | 86 | protected $placeholders; |
| 87 | 87 | |
| 88 | - /** |
|
| 89 | - * @var string |
|
| 90 | - */ |
|
| 88 | + /** |
|
| 89 | + * @var string |
|
| 90 | + */ |
|
| 91 | 91 | protected $delimiter = '999'; |
| 92 | 92 | |
| 93 | - /** |
|
| 94 | - * @var string[]|NULL |
|
| 95 | - */ |
|
| 93 | + /** |
|
| 94 | + * @var string[]|NULL |
|
| 95 | + */ |
|
| 96 | 96 | protected $placeholderStrings; |
| 97 | 97 | |
| 98 | 98 | public function __construct(Mailcode_Parser $parser, string $subject) |
@@ -111,28 +111,28 @@ discard block |
||
| 111 | 111 | self::$counter = 0; |
| 112 | 112 | } |
| 113 | 113 | |
| 114 | - /** |
|
| 115 | - * Retrieves the string the safeguard was created for. |
|
| 116 | - * |
|
| 117 | - * @return string |
|
| 118 | - */ |
|
| 114 | + /** |
|
| 115 | + * Retrieves the string the safeguard was created for. |
|
| 116 | + * |
|
| 117 | + * @return string |
|
| 118 | + */ |
|
| 119 | 119 | public function getOriginalString() : string |
| 120 | 120 | { |
| 121 | 121 | return $this->originalString; |
| 122 | 122 | } |
| 123 | 123 | |
| 124 | - /** |
|
| 125 | - * Sets the delimiter character sequence used to prepend |
|
| 126 | - * and append to the placeholders. |
|
| 127 | - * |
|
| 128 | - * The delimiter's default is "999". |
|
| 129 | - * |
|
| 130 | - * Minimum characters: 2 |
|
| 131 | - * Invalid characters: Any characters that get URL encoded |
|
| 132 | - * |
|
| 133 | - * @param string $delimiter |
|
| 134 | - * @return Mailcode_Parser_Safeguard |
|
| 135 | - */ |
|
| 124 | + /** |
|
| 125 | + * Sets the delimiter character sequence used to prepend |
|
| 126 | + * and append to the placeholders. |
|
| 127 | + * |
|
| 128 | + * The delimiter's default is "999". |
|
| 129 | + * |
|
| 130 | + * Minimum characters: 2 |
|
| 131 | + * Invalid characters: Any characters that get URL encoded |
|
| 132 | + * |
|
| 133 | + * @param string $delimiter |
|
| 134 | + * @return Mailcode_Parser_Safeguard |
|
| 135 | + */ |
|
| 136 | 136 | public function setDelimiter(string $delimiter) : Mailcode_Parser_Safeguard |
| 137 | 137 | { |
| 138 | 138 | $validator = new Mailcode_Parser_Safeguard_DelimiterValidator($delimiter); |
@@ -148,15 +148,15 @@ discard block |
||
| 148 | 148 | return $this->delimiter; |
| 149 | 149 | } |
| 150 | 150 | |
| 151 | - /** |
|
| 152 | - * Retrieves the safe string in which all commands have been replaced |
|
| 153 | - * by placeholder strings. |
|
| 154 | - * |
|
| 155 | - * @return string |
|
| 156 | - * @throws Mailcode_Exception |
|
| 157 | - * |
|
| 158 | - * @see Mailcode_Parser_Safeguard::ERROR_INVALID_COMMANDS |
|
| 159 | - */ |
|
| 151 | + /** |
|
| 152 | + * Retrieves the safe string in which all commands have been replaced |
|
| 153 | + * by placeholder strings. |
|
| 154 | + * |
|
| 155 | + * @return string |
|
| 156 | + * @throws Mailcode_Exception |
|
| 157 | + * |
|
| 158 | + * @see Mailcode_Parser_Safeguard::ERROR_INVALID_COMMANDS |
|
| 159 | + */ |
|
| 160 | 160 | public function makeSafe() : string |
| 161 | 161 | { |
| 162 | 162 | $this->requireValidCollection(); |
@@ -164,16 +164,16 @@ discard block |
||
| 164 | 164 | return $this->makeSafePartial(); |
| 165 | 165 | } |
| 166 | 166 | |
| 167 | - /** |
|
| 168 | - * Like makeSafe(), but allows partial (invalid) commands: use this |
|
| 169 | - * if the subject string may contain only part of the whole set of |
|
| 170 | - * commands. |
|
| 171 | - * |
|
| 172 | - * Example: parsing a text with an opening if statement, without the |
|
| 173 | - * matching end statement. |
|
| 174 | - * |
|
| 175 | - * @return string |
|
| 176 | - */ |
|
| 167 | + /** |
|
| 168 | + * Like makeSafe(), but allows partial (invalid) commands: use this |
|
| 169 | + * if the subject string may contain only part of the whole set of |
|
| 170 | + * commands. |
|
| 171 | + * |
|
| 172 | + * Example: parsing a text with an opening if statement, without the |
|
| 173 | + * matching end statement. |
|
| 174 | + * |
|
| 175 | + * @return string |
|
| 176 | + */ |
|
| 177 | 177 | public function makeSafePartial() : string |
| 178 | 178 | { |
| 179 | 179 | $placeholders = $this->getPlaceholders(); |
@@ -257,13 +257,13 @@ discard block |
||
| 257 | 257 | $analyzer->analyze(); |
| 258 | 258 | } |
| 259 | 259 | |
| 260 | - /** |
|
| 261 | - * Creates a formatting handler, which can be used to specify |
|
| 262 | - * which formattings to use for the commands in the subject string. |
|
| 263 | - * |
|
| 264 | - * @param Mailcode_StringContainer|string $subject |
|
| 265 | - * @return Mailcode_Parser_Safeguard_Formatting |
|
| 266 | - */ |
|
| 260 | + /** |
|
| 261 | + * Creates a formatting handler, which can be used to specify |
|
| 262 | + * which formattings to use for the commands in the subject string. |
|
| 263 | + * |
|
| 264 | + * @param Mailcode_StringContainer|string $subject |
|
| 265 | + * @return Mailcode_Parser_Safeguard_Formatting |
|
| 266 | + */ |
|
| 267 | 267 | public function createFormatting($subject) : Mailcode_Parser_Safeguard_Formatting |
| 268 | 268 | { |
| 269 | 269 | if(is_string($subject)) |
@@ -274,12 +274,12 @@ discard block |
||
| 274 | 274 | return new Mailcode_Parser_Safeguard_Formatting($this, $subject); |
| 275 | 275 | } |
| 276 | 276 | |
| 277 | - /** |
|
| 278 | - * Retrieves all placeholders that have to be added to |
|
| 279 | - * the subject text. |
|
| 280 | - * |
|
| 281 | - * @return \Mailcode\Mailcode_Parser_Safeguard_Placeholder[] |
|
| 282 | - */ |
|
| 277 | + /** |
|
| 278 | + * Retrieves all placeholders that have to be added to |
|
| 279 | + * the subject text. |
|
| 280 | + * |
|
| 281 | + * @return \Mailcode\Mailcode_Parser_Safeguard_Placeholder[] |
|
| 282 | + */ |
|
| 283 | 283 | public function getPlaceholders() |
| 284 | 284 | { |
| 285 | 285 | if(isset($this->placeholders)) |
@@ -355,16 +355,16 @@ discard block |
||
| 355 | 355 | return $string; |
| 356 | 356 | } |
| 357 | 357 | |
| 358 | - /** |
|
| 359 | - * Makes the string whole again after transforming or filtering it, |
|
| 360 | - * by replacing the command placeholders with the original commands. |
|
| 361 | - * |
|
| 362 | - * @param string $string |
|
| 363 | - * @return string |
|
| 364 | - * @throws Mailcode_Exception |
|
| 365 | - * |
|
| 366 | - * @see Mailcode_Parser_Safeguard::ERROR_INVALID_COMMANDS |
|
| 367 | - */ |
|
| 358 | + /** |
|
| 359 | + * Makes the string whole again after transforming or filtering it, |
|
| 360 | + * by replacing the command placeholders with the original commands. |
|
| 361 | + * |
|
| 362 | + * @param string $string |
|
| 363 | + * @return string |
|
| 364 | + * @throws Mailcode_Exception |
|
| 365 | + * |
|
| 366 | + * @see Mailcode_Parser_Safeguard::ERROR_INVALID_COMMANDS |
|
| 367 | + */ |
|
| 368 | 368 | public function makeWhole(string $string) : string |
| 369 | 369 | { |
| 370 | 370 | return $this->restore( |
@@ -374,15 +374,15 @@ discard block |
||
| 374 | 374 | ); |
| 375 | 375 | } |
| 376 | 376 | |
| 377 | - /** |
|
| 378 | - * Like `makeWhole()`, but ignores missing command placeholders. |
|
| 379 | - * |
|
| 380 | - * @param string $string |
|
| 381 | - * @return string |
|
| 382 | - * @throws Mailcode_Exception |
|
| 383 | - * |
|
| 384 | - * @see Mailcode_Parser_Safeguard::ERROR_INVALID_COMMANDS |
|
| 385 | - */ |
|
| 377 | + /** |
|
| 378 | + * Like `makeWhole()`, but ignores missing command placeholders. |
|
| 379 | + * |
|
| 380 | + * @param string $string |
|
| 381 | + * @return string |
|
| 382 | + * @throws Mailcode_Exception |
|
| 383 | + * |
|
| 384 | + * @see Mailcode_Parser_Safeguard::ERROR_INVALID_COMMANDS |
|
| 385 | + */ |
|
| 386 | 386 | public function makeWholePartial(string $string) : string |
| 387 | 387 | { |
| 388 | 388 | return $this->restore( |
@@ -392,19 +392,19 @@ discard block |
||
| 392 | 392 | ); |
| 393 | 393 | } |
| 394 | 394 | |
| 395 | - /** |
|
| 396 | - * Like `makeWhole()`, but replaces the commands with a syntax |
|
| 397 | - * highlighted version, meant for human readable texts only. |
|
| 398 | - * |
|
| 399 | - * Note: the commands lose their functionality (They cannot be |
|
| 400 | - * parsed from that string again). |
|
| 401 | - * |
|
| 402 | - * @param string $string |
|
| 403 | - * @return string |
|
| 404 | - * @throws Mailcode_Exception |
|
| 405 | - * |
|
| 406 | - * @see Mailcode_Parser_Safeguard::ERROR_INVALID_COMMANDS |
|
| 407 | - */ |
|
| 395 | + /** |
|
| 396 | + * Like `makeWhole()`, but replaces the commands with a syntax |
|
| 397 | + * highlighted version, meant for human readable texts only. |
|
| 398 | + * |
|
| 399 | + * Note: the commands lose their functionality (They cannot be |
|
| 400 | + * parsed from that string again). |
|
| 401 | + * |
|
| 402 | + * @param string $string |
|
| 403 | + * @return string |
|
| 404 | + * @throws Mailcode_Exception |
|
| 405 | + * |
|
| 406 | + * @see Mailcode_Parser_Safeguard::ERROR_INVALID_COMMANDS |
|
| 407 | + */ |
|
| 408 | 408 | public function makeHighlighted(string $string) : string |
| 409 | 409 | { |
| 410 | 410 | return $this->restore( |
@@ -414,15 +414,15 @@ discard block |
||
| 414 | 414 | ); |
| 415 | 415 | } |
| 416 | 416 | |
| 417 | - /** |
|
| 418 | - * Like `makeHighlighted()`, but ignores missing command placeholders. |
|
| 419 | - * |
|
| 420 | - * @param string $string |
|
| 421 | - * @return string |
|
| 422 | - * @throws Mailcode_Exception |
|
| 423 | - * |
|
| 424 | - * @see Mailcode_Parser_Safeguard::ERROR_INVALID_COMMANDS |
|
| 425 | - */ |
|
| 417 | + /** |
|
| 418 | + * Like `makeHighlighted()`, but ignores missing command placeholders. |
|
| 419 | + * |
|
| 420 | + * @param string $string |
|
| 421 | + * @return string |
|
| 422 | + * @throws Mailcode_Exception |
|
| 423 | + * |
|
| 424 | + * @see Mailcode_Parser_Safeguard::ERROR_INVALID_COMMANDS |
|
| 425 | + */ |
|
| 426 | 426 | public function makeHighlightedPartial(string $string) : string |
| 427 | 427 | { |
| 428 | 428 | return $this->restore( |
@@ -432,11 +432,11 @@ discard block |
||
| 432 | 432 | ); |
| 433 | 433 | } |
| 434 | 434 | |
| 435 | - /** |
|
| 436 | - * Retrieves the commands collection contained in the string. |
|
| 437 | - * |
|
| 438 | - * @return Mailcode_Collection |
|
| 439 | - */ |
|
| 435 | + /** |
|
| 436 | + * Retrieves the commands collection contained in the string. |
|
| 437 | + * |
|
| 438 | + * @return Mailcode_Collection |
|
| 439 | + */ |
|
| 440 | 440 | public function getCollection() : Mailcode_Collection |
| 441 | 441 | { |
| 442 | 442 | if(isset($this->collection)) |
@@ -454,11 +454,11 @@ discard block |
||
| 454 | 454 | return $this->getCollection()->isValid(); |
| 455 | 455 | } |
| 456 | 456 | |
| 457 | - /** |
|
| 458 | - * @throws Mailcode_Exception |
|
| 459 | - * |
|
| 460 | - * @see Mailcode_Parser_Safeguard::ERROR_INVALID_COMMANDS |
|
| 461 | - */ |
|
| 457 | + /** |
|
| 458 | + * @throws Mailcode_Exception |
|
| 459 | + * |
|
| 460 | + * @see Mailcode_Parser_Safeguard::ERROR_INVALID_COMMANDS |
|
| 461 | + */ |
|
| 462 | 462 | protected function requireValidCollection() : void |
| 463 | 463 | { |
| 464 | 464 | if($this->getCollection()->isValid()) |
@@ -477,11 +477,11 @@ discard block |
||
| 477 | 477 | ); |
| 478 | 478 | } |
| 479 | 479 | |
| 480 | - /** |
|
| 481 | - * Retrieves a list of all placeholder IDs used in the text. |
|
| 482 | - * |
|
| 483 | - * @return string[] |
|
| 484 | - */ |
|
| 480 | + /** |
|
| 481 | + * Retrieves a list of all placeholder IDs used in the text. |
|
| 482 | + * |
|
| 483 | + * @return string[] |
|
| 484 | + */ |
|
| 485 | 485 | public function getPlaceholderStrings() : array |
| 486 | 486 | { |
| 487 | 487 | if(is_array($this->placeholderStrings)) |
@@ -508,13 +508,13 @@ discard block |
||
| 508 | 508 | return in_array($subject, $ids, true); |
| 509 | 509 | } |
| 510 | 510 | |
| 511 | - /** |
|
| 512 | - * Retrieves a placeholder instance by its ID. |
|
| 513 | - * |
|
| 514 | - * @param int $id |
|
| 515 | - * @throws Mailcode_Exception If the placeholder was not found. |
|
| 516 | - * @return Mailcode_Parser_Safeguard_Placeholder |
|
| 517 | - */ |
|
| 511 | + /** |
|
| 512 | + * Retrieves a placeholder instance by its ID. |
|
| 513 | + * |
|
| 514 | + * @param int $id |
|
| 515 | + * @throws Mailcode_Exception If the placeholder was not found. |
|
| 516 | + * @return Mailcode_Parser_Safeguard_Placeholder |
|
| 517 | + */ |
|
| 518 | 518 | public function getPlaceholderByID(int $id) : Mailcode_Parser_Safeguard_Placeholder |
| 519 | 519 | { |
| 520 | 520 | $placeholders = $this->getPlaceholders(); |
@@ -537,13 +537,13 @@ discard block |
||
| 537 | 537 | ); |
| 538 | 538 | } |
| 539 | 539 | |
| 540 | - /** |
|
| 541 | - * Retrieves a placeholder instance by its replacement text. |
|
| 542 | - * |
|
| 543 | - * @param string $string |
|
| 544 | - * @throws Mailcode_Exception |
|
| 545 | - * @return Mailcode_Parser_Safeguard_Placeholder |
|
| 546 | - */ |
|
| 540 | + /** |
|
| 541 | + * Retrieves a placeholder instance by its replacement text. |
|
| 542 | + * |
|
| 543 | + * @param string $string |
|
| 544 | + * @throws Mailcode_Exception |
|
| 545 | + * @return Mailcode_Parser_Safeguard_Placeholder |
|
| 546 | + */ |
|
| 547 | 547 | public function getPlaceholderByString(string $string) : Mailcode_Parser_Safeguard_Placeholder |
| 548 | 548 | { |
| 549 | 549 | $placeholders = $this->getPlaceholders(); |
@@ -176,27 +176,27 @@ |
||
| 176 | 176 | * @return array<string,string> |
| 177 | 177 | * @throws Mailcode_Exception |
| 178 | 178 | */ |
| 179 | - private function parseVarName() : array |
|
| 180 | - { |
|
| 181 | - $tokens = explode('.', ltrim($this->variable->getFullName(), '$')); |
|
| 182 | - |
|
| 183 | - if(count($tokens) === 2) |
|
| 184 | - { |
|
| 185 | - return array( |
|
| 186 | - 'path' => $tokens[0], |
|
| 187 | - 'name' => $tokens[1] |
|
| 188 | - ); |
|
| 189 | - } |
|
| 190 | - |
|
| 191 | - throw new Mailcode_Exception( |
|
| 192 | - 'Invalid variable name for a list property.', |
|
| 193 | - sprintf( |
|
| 194 | - 'Exactly 2 parts are required, variable [%s] has [%s].', |
|
| 195 | - $this->variable->getFullName(), |
|
| 196 | - count($tokens) |
|
| 197 | - ), |
|
| 198 | - self::ERROR_INVALID_LIST_VARIABLE_NAME |
|
| 199 | - ); |
|
| 200 | - } |
|
| 179 | + private function parseVarName() : array |
|
| 180 | + { |
|
| 181 | + $tokens = explode('.', ltrim($this->variable->getFullName(), '$')); |
|
| 182 | + |
|
| 183 | + if(count($tokens) === 2) |
|
| 184 | + { |
|
| 185 | + return array( |
|
| 186 | + 'path' => $tokens[0], |
|
| 187 | + 'name' => $tokens[1] |
|
| 188 | + ); |
|
| 189 | + } |
|
| 190 | + |
|
| 191 | + throw new Mailcode_Exception( |
|
| 192 | + 'Invalid variable name for a list property.', |
|
| 193 | + sprintf( |
|
| 194 | + 'Exactly 2 parts are required, variable [%s] has [%s].', |
|
| 195 | + $this->variable->getFullName(), |
|
| 196 | + count($tokens) |
|
| 197 | + ), |
|
| 198 | + self::ERROR_INVALID_LIST_VARIABLE_NAME |
|
| 199 | + ); |
|
| 200 | + } |
|
| 201 | 201 | } |
| 202 | 202 | |
@@ -20,9 +20,9 @@ discard block |
||
| 20 | 20 | */ |
| 21 | 21 | abstract class Mailcode_Translator_Syntax_ApacheVelocity extends Mailcode_Translator_Command |
| 22 | 22 | { |
| 23 | - /** |
|
| 24 | - * @var string[] |
|
| 25 | - */ |
|
| 23 | + /** |
|
| 24 | + * @var string[] |
|
| 25 | + */ |
|
| 26 | 26 | private $regexSpecialChars = array( |
| 27 | 27 | '?', |
| 28 | 28 | '.', |
@@ -47,15 +47,15 @@ discard block |
||
| 47 | 47 | } |
| 48 | 48 | |
| 49 | 49 | /** |
| 50 | - * Filters the string for use in an Apache Velocity (Java) |
|
| 51 | - * regex string: escapes all special characters. |
|
| 52 | - * |
|
| 53 | - * Velocity does its own escaping, so no need to escape special |
|
| 54 | - * characters as if they were a javascript string. |
|
| 55 | - * |
|
| 56 | - * @param string $string |
|
| 57 | - * @return string |
|
| 58 | - */ |
|
| 50 | + * Filters the string for use in an Apache Velocity (Java) |
|
| 51 | + * regex string: escapes all special characters. |
|
| 52 | + * |
|
| 53 | + * Velocity does its own escaping, so no need to escape special |
|
| 54 | + * characters as if they were a javascript string. |
|
| 55 | + * |
|
| 56 | + * @param string $string |
|
| 57 | + * @return string |
|
| 58 | + */ |
|
| 59 | 59 | public function filterRegexString(string $string) : string |
| 60 | 60 | { |
| 61 | 61 | // Special case: previously escaped quotes. |
@@ -26,51 +26,51 @@ discard block |
||
| 26 | 26 | */ |
| 27 | 27 | class Mailcode |
| 28 | 28 | { |
| 29 | - /** |
|
| 30 | - * @var Mailcode_Parser|NULL |
|
| 31 | - */ |
|
| 29 | + /** |
|
| 30 | + * @var Mailcode_Parser|NULL |
|
| 31 | + */ |
|
| 32 | 32 | protected $parser = null; |
| 33 | 33 | |
| 34 | - /** |
|
| 35 | - * @var Mailcode_Commands|NULL |
|
| 36 | - */ |
|
| 34 | + /** |
|
| 35 | + * @var Mailcode_Commands|NULL |
|
| 36 | + */ |
|
| 37 | 37 | protected $commands = null; |
| 38 | 38 | |
| 39 | - /** |
|
| 40 | - * @var Mailcode_Variables|NULL |
|
| 41 | - */ |
|
| 39 | + /** |
|
| 40 | + * @var Mailcode_Variables|NULL |
|
| 41 | + */ |
|
| 42 | 42 | protected $variables = null; |
| 43 | 43 | |
| 44 | - /** |
|
| 45 | - * @var Mailcode_Translator|NULL |
|
| 46 | - */ |
|
| 44 | + /** |
|
| 45 | + * @var Mailcode_Translator|NULL |
|
| 46 | + */ |
|
| 47 | 47 | protected $translator = null; |
| 48 | 48 | |
| 49 | - /** |
|
| 50 | - * Creates a new mailcode instance. |
|
| 51 | - * @return Mailcode |
|
| 52 | - */ |
|
| 49 | + /** |
|
| 50 | + * Creates a new mailcode instance. |
|
| 51 | + * @return Mailcode |
|
| 52 | + */ |
|
| 53 | 53 | public static function create() : Mailcode |
| 54 | 54 | { |
| 55 | 55 | return new Mailcode(); |
| 56 | 56 | } |
| 57 | 57 | |
| 58 | - /** |
|
| 59 | - * Parses the string to detect all commands contained within. |
|
| 60 | - * |
|
| 61 | - * @param string $string |
|
| 62 | - * @return Mailcode_Collection |
|
| 63 | - */ |
|
| 58 | + /** |
|
| 59 | + * Parses the string to detect all commands contained within. |
|
| 60 | + * |
|
| 61 | + * @param string $string |
|
| 62 | + * @return Mailcode_Collection |
|
| 63 | + */ |
|
| 64 | 64 | public function parseString(string $string) : Mailcode_Collection |
| 65 | 65 | { |
| 66 | 66 | return $this->getParser()->parseString($string); |
| 67 | 67 | } |
| 68 | 68 | |
| 69 | - /** |
|
| 70 | - * Retrieves the string parser instance used to detect commands. |
|
| 71 | - * |
|
| 72 | - * @return Mailcode_Parser |
|
| 73 | - */ |
|
| 69 | + /** |
|
| 70 | + * Retrieves the string parser instance used to detect commands. |
|
| 71 | + * |
|
| 72 | + * @return Mailcode_Parser |
|
| 73 | + */ |
|
| 74 | 74 | public function getParser() : Mailcode_Parser |
| 75 | 75 | { |
| 76 | 76 | if(!isset($this->parser)) |
@@ -81,12 +81,12 @@ discard block |
||
| 81 | 81 | return $this->parser; |
| 82 | 82 | } |
| 83 | 83 | |
| 84 | - /** |
|
| 85 | - * Retrieves the commands collection, which is used to |
|
| 86 | - * access information on the available commands. |
|
| 87 | - * |
|
| 88 | - * @return Mailcode_Commands |
|
| 89 | - */ |
|
| 84 | + /** |
|
| 85 | + * Retrieves the commands collection, which is used to |
|
| 86 | + * access information on the available commands. |
|
| 87 | + * |
|
| 88 | + * @return Mailcode_Commands |
|
| 89 | + */ |
|
| 90 | 90 | public function getCommands() : Mailcode_Commands |
| 91 | 91 | { |
| 92 | 92 | if(!isset($this->commands)) |
@@ -129,12 +129,12 @@ discard block |
||
| 129 | 129 | return $this->variables; |
| 130 | 130 | } |
| 131 | 131 | |
| 132 | - /** |
|
| 133 | - * Creates the translator, which can be used to convert commands |
|
| 134 | - * to another supported syntax. |
|
| 135 | - * |
|
| 136 | - * @return Mailcode_Translator |
|
| 137 | - */ |
|
| 132 | + /** |
|
| 133 | + * Creates the translator, which can be used to convert commands |
|
| 134 | + * to another supported syntax. |
|
| 135 | + * |
|
| 136 | + * @return Mailcode_Translator |
|
| 137 | + */ |
|
| 138 | 138 | public function createTranslator() : Mailcode_Translator |
| 139 | 139 | { |
| 140 | 140 | if(!isset($this->translator)) |
@@ -145,12 +145,12 @@ discard block |
||
| 145 | 145 | return $this->translator; |
| 146 | 146 | } |
| 147 | 147 | |
| 148 | - /** |
|
| 149 | - * Creates the styler, which can be used to retrieve the |
|
| 150 | - * CSS required to style the highlighted commands in HTML. |
|
| 151 | - * |
|
| 152 | - * @return Mailcode_Styler |
|
| 153 | - */ |
|
| 148 | + /** |
|
| 149 | + * Creates the styler, which can be used to retrieve the |
|
| 150 | + * CSS required to style the highlighted commands in HTML. |
|
| 151 | + * |
|
| 152 | + * @return Mailcode_Styler |
|
| 153 | + */ |
|
| 154 | 154 | public function createStyler() : Mailcode_Styler |
| 155 | 155 | { |
| 156 | 156 | return new Mailcode_Styler(); |
@@ -20,9 +20,9 @@ discard block |
||
| 20 | 20 | */ |
| 21 | 21 | abstract class Mailcode_Variables_Collection |
| 22 | 22 | { |
| 23 | - /** |
|
| 24 | - * @var Mailcode_Variables_Variable[] |
|
| 25 | - */ |
|
| 23 | + /** |
|
| 24 | + * @var Mailcode_Variables_Variable[] |
|
| 25 | + */ |
|
| 26 | 26 | protected $variables = array(); |
| 27 | 27 | |
| 28 | 28 | public function __construct() |
@@ -52,12 +52,12 @@ discard block |
||
| 52 | 52 | return count($this->variables); |
| 53 | 53 | } |
| 54 | 54 | |
| 55 | - /** |
|
| 56 | - * Checks whether the collection contains a variable with the specified name. |
|
| 57 | - * |
|
| 58 | - * @param string $fullName The variable name, with or without $ sign. |
|
| 59 | - * @return bool |
|
| 60 | - */ |
|
| 55 | + /** |
|
| 56 | + * Checks whether the collection contains a variable with the specified name. |
|
| 57 | + * |
|
| 58 | + * @param string $fullName The variable name, with or without $ sign. |
|
| 59 | + * @return bool |
|
| 60 | + */ |
|
| 61 | 61 | public function hasVariableName(string $fullName) : bool |
| 62 | 62 | { |
| 63 | 63 | $fullName = $this->fixName($fullName); |
@@ -73,14 +73,14 @@ discard block |
||
| 73 | 73 | return false; |
| 74 | 74 | } |
| 75 | 75 | |
| 76 | - /** |
|
| 77 | - * Retrieves a collection of all variable instances for |
|
| 78 | - * the specified name (there can be several with differing |
|
| 79 | - * matched texts because of spacing). |
|
| 80 | - * |
|
| 81 | - * @param string $fullName |
|
| 82 | - * @return Mailcode_Variables_Collection |
|
| 83 | - */ |
|
| 76 | + /** |
|
| 77 | + * Retrieves a collection of all variable instances for |
|
| 78 | + * the specified name (there can be several with differing |
|
| 79 | + * matched texts because of spacing). |
|
| 80 | + * |
|
| 81 | + * @param string $fullName |
|
| 82 | + * @return Mailcode_Variables_Collection |
|
| 83 | + */ |
|
| 84 | 84 | public function getByFullName(string $fullName) : Mailcode_Variables_Collection |
| 85 | 85 | { |
| 86 | 86 | $fullName = $this->fixName($fullName); |
@@ -98,12 +98,12 @@ discard block |
||
| 98 | 98 | return $collection; |
| 99 | 99 | } |
| 100 | 100 | |
| 101 | - /** |
|
| 102 | - * Prepends the $ sign to a variable name if it does not have it. |
|
| 103 | - * |
|
| 104 | - * @param string $fullName |
|
| 105 | - * @return string |
|
| 106 | - */ |
|
| 101 | + /** |
|
| 102 | + * Prepends the $ sign to a variable name if it does not have it. |
|
| 103 | + * |
|
| 104 | + * @param string $fullName |
|
| 105 | + * @return string |
|
| 106 | + */ |
|
| 107 | 107 | protected function fixName(string $fullName) : string |
| 108 | 108 | { |
| 109 | 109 | if(substr($fullName, 0, 1) === '$') |
@@ -114,12 +114,12 @@ discard block |
||
| 114 | 114 | return '$'.$fullName; |
| 115 | 115 | } |
| 116 | 116 | |
| 117 | - /** |
|
| 118 | - * Retrieves all variables, grouped by their hash - meaning |
|
| 119 | - * unique matched strings. |
|
| 120 | - * |
|
| 121 | - * @return Mailcode_Variables_Variable[] |
|
| 122 | - */ |
|
| 117 | + /** |
|
| 118 | + * Retrieves all variables, grouped by their hash - meaning |
|
| 119 | + * unique matched strings. |
|
| 120 | + * |
|
| 121 | + * @return Mailcode_Variables_Variable[] |
|
| 122 | + */ |
|
| 123 | 123 | public function getGroupedByHash() : array |
| 124 | 124 | { |
| 125 | 125 | $entries = array(); |
@@ -132,11 +132,11 @@ discard block |
||
| 132 | 132 | return $this->sortVariables($entries); |
| 133 | 133 | } |
| 134 | 134 | |
| 135 | - /** |
|
| 136 | - * Retrieves all variables, grouped by their name. |
|
| 137 | - * |
|
| 138 | - * @return Mailcode_Variables_Variable[] |
|
| 139 | - */ |
|
| 135 | + /** |
|
| 136 | + * Retrieves all variables, grouped by their name. |
|
| 137 | + * |
|
| 138 | + * @return Mailcode_Variables_Variable[] |
|
| 139 | + */ |
|
| 140 | 140 | public function getGroupedByName() : array |
| 141 | 141 | { |
| 142 | 142 | $entries = array(); |
@@ -168,19 +168,19 @@ discard block |
||
| 168 | 168 | return $this->sortVariables($entries); |
| 169 | 169 | } |
| 170 | 170 | |
| 171 | - /** |
|
| 172 | - * Retrieves all variables, in the order they were addded. |
|
| 173 | - * @return Mailcode_Variables_Variable[] |
|
| 174 | - */ |
|
| 171 | + /** |
|
| 172 | + * Retrieves all variables, in the order they were addded. |
|
| 173 | + * @return Mailcode_Variables_Variable[] |
|
| 174 | + */ |
|
| 175 | 175 | public function getAll() |
| 176 | 176 | { |
| 177 | 177 | return $this->variables; |
| 178 | 178 | } |
| 179 | 179 | |
| 180 | - /** |
|
| 181 | - * Retrieves the full names of the variables that are present in the collection. |
|
| 182 | - * @return string[] |
|
| 183 | - */ |
|
| 180 | + /** |
|
| 181 | + * Retrieves the full names of the variables that are present in the collection. |
|
| 182 | + * @return string[] |
|
| 183 | + */ |
|
| 184 | 184 | public function getNames() : array |
| 185 | 185 | { |
| 186 | 186 | $result = array(); |
@@ -198,13 +198,13 @@ discard block |
||
| 198 | 198 | return $result; |
| 199 | 199 | } |
| 200 | 200 | |
| 201 | - /** |
|
| 202 | - * Takes a list of variables and sorts them, throwing away |
|
| 203 | - * the source array's keys. |
|
| 204 | - * |
|
| 205 | - * @param Mailcode_Variables_Variable[] $entries |
|
| 206 | - * @return Mailcode_Variables_Variable[] |
|
| 207 | - */ |
|
| 201 | + /** |
|
| 202 | + * Takes a list of variables and sorts them, throwing away |
|
| 203 | + * the source array's keys. |
|
| 204 | + * |
|
| 205 | + * @param Mailcode_Variables_Variable[] $entries |
|
| 206 | + * @return Mailcode_Variables_Variable[] |
|
| 207 | + */ |
|
| 208 | 208 | protected function sortVariables(array $entries) |
| 209 | 209 | { |
| 210 | 210 | $result = array_values($entries); |
@@ -217,13 +217,13 @@ discard block |
||
| 217 | 217 | return $result; |
| 218 | 218 | } |
| 219 | 219 | |
| 220 | - /** |
|
| 221 | - * Merges the variables collection with the target collection |
|
| 222 | - * by inheriting all that collection's variables. |
|
| 223 | - * |
|
| 224 | - * @param Mailcode_Variables_Collection $collection |
|
| 225 | - * @return Mailcode_Variables_Collection |
|
| 226 | - */ |
|
| 220 | + /** |
|
| 221 | + * Merges the variables collection with the target collection |
|
| 222 | + * by inheriting all that collection's variables. |
|
| 223 | + * |
|
| 224 | + * @param Mailcode_Variables_Collection $collection |
|
| 225 | + * @return Mailcode_Variables_Collection |
|
| 226 | + */ |
|
| 227 | 227 | public function mergeWith(Mailcode_Variables_Collection $collection) : Mailcode_Variables_Collection |
| 228 | 228 | { |
| 229 | 229 | $variables = $collection->getGroupedByHash(); |
@@ -22,9 +22,9 @@ |
||
| 22 | 22 | { |
| 23 | 23 | const REGEX_VARIABLE_NAME = '/\$\s*([A-Z0-9_]+)\s*\.\s*([A-Z0-9_]+)|\$\s*([A-Z0-9_]+)/six'; |
| 24 | 24 | |
| 25 | - /** |
|
| 26 | - * @var Mailcode_Variables_Collection_Regular |
|
| 27 | - */ |
|
| 25 | + /** |
|
| 26 | + * @var Mailcode_Variables_Collection_Regular |
|
| 27 | + */ |
|
| 28 | 28 | protected $collection; |
| 29 | 29 | |
| 30 | 30 | /** |
@@ -20,19 +20,19 @@ discard block |
||
| 20 | 20 | */ |
| 21 | 21 | abstract class Mailcode_Parser_Statement_Tokenizer_Token implements Mailcode_Parser_Statement_Tokenizer_TypeInterface |
| 22 | 22 | { |
| 23 | - /** |
|
| 24 | - * @var string |
|
| 25 | - */ |
|
| 23 | + /** |
|
| 24 | + * @var string |
|
| 25 | + */ |
|
| 26 | 26 | protected $tokenID; |
| 27 | 27 | |
| 28 | - /** |
|
| 29 | - * @var string |
|
| 30 | - */ |
|
| 28 | + /** |
|
| 29 | + * @var string |
|
| 30 | + */ |
|
| 31 | 31 | protected $matchedText; |
| 32 | 32 | |
| 33 | - /** |
|
| 34 | - * @var mixed |
|
| 35 | - */ |
|
| 33 | + /** |
|
| 34 | + * @var mixed |
|
| 35 | + */ |
|
| 36 | 36 | protected $subject; |
| 37 | 37 | |
| 38 | 38 | /** |
@@ -62,20 +62,20 @@ discard block |
||
| 62 | 62 | return $this->sourceCommand; |
| 63 | 63 | } |
| 64 | 64 | |
| 65 | - /** |
|
| 66 | - * The ID of the type. i.e. the class name ("Keyword", "StringLiteral"). |
|
| 67 | - * @return string |
|
| 68 | - */ |
|
| 65 | + /** |
|
| 66 | + * The ID of the type. i.e. the class name ("Keyword", "StringLiteral"). |
|
| 67 | + * @return string |
|
| 68 | + */ |
|
| 69 | 69 | public function getTypeID() : string |
| 70 | 70 | { |
| 71 | 71 | $parts = explode('_', get_class($this)); |
| 72 | 72 | return array_pop($parts); |
| 73 | 73 | } |
| 74 | 74 | |
| 75 | - /** |
|
| 76 | - * Retrieves a unique ID of the token. |
|
| 77 | - * @return string |
|
| 78 | - */ |
|
| 75 | + /** |
|
| 76 | + * Retrieves a unique ID of the token. |
|
| 77 | + * @return string |
|
| 78 | + */ |
|
| 79 | 79 | public function getID() : string |
| 80 | 80 | { |
| 81 | 81 | return $this->tokenID; |
@@ -38,14 +38,14 @@ discard block |
||
| 38 | 38 | 'ExtractTokens' |
| 39 | 39 | ); |
| 40 | 40 | |
| 41 | - /** |
|
| 42 | - * @var Mailcode_Parser_Statement |
|
| 43 | - */ |
|
| 41 | + /** |
|
| 42 | + * @var Mailcode_Parser_Statement |
|
| 43 | + */ |
|
| 44 | 44 | protected $statement; |
| 45 | 45 | |
| 46 | - /** |
|
| 47 | - * @var string |
|
| 48 | - */ |
|
| 46 | + /** |
|
| 47 | + * @var string |
|
| 48 | + */ |
|
| 49 | 49 | protected $tokenized; |
| 50 | 50 | |
| 51 | 51 | /** |
@@ -53,9 +53,9 @@ discard block |
||
| 53 | 53 | */ |
| 54 | 54 | protected $tokensOrdered = array(); |
| 55 | 55 | |
| 56 | - /** |
|
| 57 | - * @var string[] |
|
| 58 | - */ |
|
| 56 | + /** |
|
| 57 | + * @var string[] |
|
| 58 | + */ |
|
| 59 | 59 | protected static $ids = array(); |
| 60 | 60 | |
| 61 | 61 | /** |
@@ -75,12 +75,12 @@ discard block |
||
| 75 | 75 | return $this->statement->getSourceCommand(); |
| 76 | 76 | } |
| 77 | 77 | |
| 78 | - /** |
|
| 79 | - * Retrieves all tokens detected in the statement string, in |
|
| 80 | - * the order they were found. |
|
| 81 | - * |
|
| 82 | - * @return Mailcode_Parser_Statement_Tokenizer_Token[] |
|
| 83 | - */ |
|
| 78 | + /** |
|
| 79 | + * Retrieves all tokens detected in the statement string, in |
|
| 80 | + * the order they were found. |
|
| 81 | + * |
|
| 82 | + * @return Mailcode_Parser_Statement_Tokenizer_Token[] |
|
| 83 | + */ |
|
| 84 | 84 | public function getTokens() |
| 85 | 85 | { |
| 86 | 86 | return $this->tokensOrdered; |
@@ -91,11 +91,11 @@ discard block |
||
| 91 | 91 | return !empty($this->tokensOrdered); |
| 92 | 92 | } |
| 93 | 93 | |
| 94 | - /** |
|
| 95 | - * Whether there were any unknown tokens in the statement. |
|
| 96 | - * |
|
| 97 | - * @return bool |
|
| 98 | - */ |
|
| 94 | + /** |
|
| 95 | + * Whether there were any unknown tokens in the statement. |
|
| 96 | + * |
|
| 97 | + * @return bool |
|
| 98 | + */ |
|
| 99 | 99 | public function hasUnknown() : bool |
| 100 | 100 | { |
| 101 | 101 | $unknown = $this->getUnknown(); |
@@ -103,11 +103,11 @@ discard block |
||
| 103 | 103 | return !empty($unknown); |
| 104 | 104 | } |
| 105 | 105 | |
| 106 | - /** |
|
| 107 | - * Retrieves all unknown content tokens, if any. |
|
| 108 | - * |
|
| 109 | - * @return Mailcode_Parser_Statement_Tokenizer_Token_Unknown[] |
|
| 110 | - */ |
|
| 106 | + /** |
|
| 107 | + * Retrieves all unknown content tokens, if any. |
|
| 108 | + * |
|
| 109 | + * @return Mailcode_Parser_Statement_Tokenizer_Token_Unknown[] |
|
| 110 | + */ |
|
| 111 | 111 | public function getUnknown() |
| 112 | 112 | { |
| 113 | 113 | $result = array(); |
@@ -278,13 +278,13 @@ discard block |
||
| 278 | 278 | return $token; |
| 279 | 279 | } |
| 280 | 280 | |
| 281 | - /** |
|
| 282 | - * Generates a unique alphabet-based ID without numbers |
|
| 283 | - * to use as token name, to avoid conflicts with the |
|
| 284 | - * numbers detection. |
|
| 285 | - * |
|
| 286 | - * @return string |
|
| 287 | - */ |
|
| 281 | + /** |
|
| 282 | + * Generates a unique alphabet-based ID without numbers |
|
| 283 | + * to use as token name, to avoid conflicts with the |
|
| 284 | + * numbers detection. |
|
| 285 | + * |
|
| 286 | + * @return string |
|
| 287 | + */ |
|
| 288 | 288 | protected function generateID() : string |
| 289 | 289 | { |
| 290 | 290 | static $alphas; |
@@ -30,14 +30,14 @@ discard block |
||
| 30 | 30 | '{\s*([a-z]+)\s+([a-z-]+)\s*:([^}]*)}' |
| 31 | 31 | ); |
| 32 | 32 | |
| 33 | - /** |
|
| 34 | - * @var Mailcode |
|
| 35 | - */ |
|
| 33 | + /** |
|
| 34 | + * @var Mailcode |
|
| 35 | + */ |
|
| 36 | 36 | protected $mailcode; |
| 37 | 37 | |
| 38 | - /** |
|
| 39 | - * @var Mailcode_Commands |
|
| 40 | - */ |
|
| 38 | + /** |
|
| 39 | + * @var Mailcode_Commands |
|
| 40 | + */ |
|
| 41 | 41 | protected $commands; |
| 42 | 42 | |
| 43 | 43 | /** |
@@ -51,24 +51,24 @@ discard block |
||
| 51 | 51 | $this->commands = $this->mailcode->getCommands(); |
| 52 | 52 | } |
| 53 | 53 | |
| 54 | - /** |
|
| 55 | - * Gets the regex format string used to detect commands. |
|
| 56 | - * |
|
| 57 | - * @return string |
|
| 58 | - */ |
|
| 54 | + /** |
|
| 55 | + * Gets the regex format string used to detect commands. |
|
| 56 | + * |
|
| 57 | + * @return string |
|
| 58 | + */ |
|
| 59 | 59 | protected static function getRegex() : string |
| 60 | 60 | { |
| 61 | 61 | return '/'.implode('|', self::COMMAND_REGEX_PARTS).'/sixU'; |
| 62 | 62 | } |
| 63 | 63 | |
| 64 | - /** |
|
| 65 | - * Parses a string to detect all commands within. Returns a |
|
| 66 | - * collection instance that contains information on all the |
|
| 67 | - * commands. |
|
| 68 | - * |
|
| 69 | - * @param string $string |
|
| 70 | - * @return Mailcode_Collection A collection with all unique commands found. |
|
| 71 | - */ |
|
| 64 | + /** |
|
| 65 | + * Parses a string to detect all commands within. Returns a |
|
| 66 | + * collection instance that contains information on all the |
|
| 67 | + * commands. |
|
| 68 | + * |
|
| 69 | + * @param string $string |
|
| 70 | + * @return Mailcode_Collection A collection with all unique commands found. |
|
| 71 | + */ |
|
| 72 | 72 | public function parseString(string $string) : Mailcode_Collection |
| 73 | 73 | { |
| 74 | 74 | $collection = new Mailcode_Collection(); |
@@ -103,14 +103,14 @@ discard block |
||
| 103 | 103 | return preg_replace('%<style\b[^>]*>(.*?)</style>%six', '', $subject); |
| 104 | 104 | } |
| 105 | 105 | |
| 106 | - /** |
|
| 107 | - * Processes a single match found in the string: creates the command, |
|
| 108 | - * and adds it to the collection if it's a valid command, or to the list |
|
| 109 | - * of invalid commands otherwise. |
|
| 110 | - * |
|
| 111 | - * @param Mailcode_Parser_Match $match |
|
| 112 | - * @param Mailcode_Collection $collection |
|
| 113 | - */ |
|
| 106 | + /** |
|
| 107 | + * Processes a single match found in the string: creates the command, |
|
| 108 | + * and adds it to the collection if it's a valid command, or to the list |
|
| 109 | + * of invalid commands otherwise. |
|
| 110 | + * |
|
| 111 | + * @param Mailcode_Parser_Match $match |
|
| 112 | + * @param Mailcode_Collection $collection |
|
| 113 | + */ |
|
| 114 | 114 | protected function processMatch(Mailcode_Parser_Match $match, Mailcode_Collection $collection) : void |
| 115 | 115 | { |
| 116 | 116 | $name = $match->getName(); |
@@ -173,14 +173,14 @@ discard block |
||
| 173 | 173 | throw new Mailcode_Exception('Not a command', '', self::ERROR_NOT_A_COMMAND); |
| 174 | 174 | } |
| 175 | 175 | |
| 176 | - /** |
|
| 177 | - * Parses a single regex match: determines which named group |
|
| 178 | - * matches, and retrieves the according information. |
|
| 179 | - * |
|
| 180 | - * @param array[] $matches The regex results array. |
|
| 181 | - * @param int $index The matched index. |
|
| 182 | - * @return Mailcode_Parser_Match |
|
| 183 | - */ |
|
| 176 | + /** |
|
| 177 | + * Parses a single regex match: determines which named group |
|
| 178 | + * matches, and retrieves the according information. |
|
| 179 | + * |
|
| 180 | + * @param array[] $matches The regex results array. |
|
| 181 | + * @param int $index The matched index. |
|
| 182 | + * @return Mailcode_Parser_Match |
|
| 183 | + */ |
|
| 184 | 184 | protected function parseMatch(array $matches, int $index) : Mailcode_Parser_Match |
| 185 | 185 | { |
| 186 | 186 | $name = ''; // the command name, e.g. "showvar" |
@@ -218,14 +218,14 @@ discard block |
||
| 218 | 218 | ); |
| 219 | 219 | } |
| 220 | 220 | |
| 221 | - /** |
|
| 222 | - * Creates an instance of the safeguard tool, which |
|
| 223 | - * is used to safeguard commands in a string with placeholders. |
|
| 224 | - * |
|
| 225 | - * @param string $subject The string to use to safeguard commands in. |
|
| 226 | - * @return Mailcode_Parser_Safeguard |
|
| 227 | - * @see Mailcode_Parser_Safeguard |
|
| 228 | - */ |
|
| 221 | + /** |
|
| 222 | + * Creates an instance of the safeguard tool, which |
|
| 223 | + * is used to safeguard commands in a string with placeholders. |
|
| 224 | + * |
|
| 225 | + * @param string $subject The string to use to safeguard commands in. |
|
| 226 | + * @return Mailcode_Parser_Safeguard |
|
| 227 | + * @see Mailcode_Parser_Safeguard |
|
| 228 | + */ |
|
| 229 | 229 | public function createSafeguard(string $subject) : Mailcode_Parser_Safeguard |
| 230 | 230 | { |
| 231 | 231 | return new Mailcode_Parser_Safeguard($this, $subject); |