@@ -23,7 +23,7 @@ discard block |
||
23 | 23 | */ |
24 | 24 | function studly_case( string$input ):string |
25 | 25 | { |
26 | - return str_replace(' ','',ucwords(str_replace(['-', '_'], ' ', $input))); |
|
26 | + return str_replace(' ', '', ucwords(str_replace([ '-', '_' ], ' ', $input))); |
|
27 | 27 | } |
28 | 28 | |
29 | 29 | /** |
@@ -35,5 +35,5 @@ discard block |
||
35 | 35 | */ |
36 | 36 | function snake_case( string$input ):string |
37 | 37 | { |
38 | - return strtolower(preg_replace('/(?<=[^A-Z])(?=[A-Z])|(?<=[A-Z])(?=[A-Z][^A-Z])/','_',$input)); |
|
38 | + return strtolower(preg_replace('/(?<=[^A-Z])(?=[A-Z])|(?<=[A-Z])(?=[A-Z][^A-Z])/', '_', $input)); |
|
39 | 39 | } |
@@ -90,7 +90,7 @@ discard block |
||
90 | 90 | * |
91 | 91 | * @var int |
92 | 92 | */ |
93 | - private $level= 0; |
|
93 | + private $level=0; |
|
94 | 94 | |
95 | 95 | /** |
96 | 96 | * Section indent level. |
@@ -99,7 +99,7 @@ discard block |
||
99 | 99 | * |
100 | 100 | * @var int |
101 | 101 | */ |
102 | - private $sectionLevel= 0; |
|
102 | + private $sectionLevel=0; |
|
103 | 103 | |
104 | 104 | /** |
105 | 105 | * Opened nodes. |
@@ -108,7 +108,7 @@ discard block |
||
108 | 108 | * |
109 | 109 | * @var [ Htsl\Parser\Node\Contracts\ANode, ] |
110 | 110 | */ |
111 | - private $openedNodes= []; |
|
111 | + private $openedNodes=[ ]; |
|
112 | 112 | |
113 | 113 | /** |
114 | 114 | * Current scopes. |
@@ -117,7 +117,7 @@ discard block |
||
117 | 117 | * |
118 | 118 | * @var [ Htsl\Parser\Node\Contracts\ANode, ] |
119 | 119 | */ |
120 | - private $scopes= []; |
|
120 | + private $scopes=[ ]; |
|
121 | 121 | |
122 | 122 | /** |
123 | 123 | * Current line number. |
@@ -126,7 +126,7 @@ discard block |
||
126 | 126 | * |
127 | 127 | * @var int |
128 | 128 | */ |
129 | - private $lineNumber= 0; |
|
129 | + private $lineNumber=0; |
|
130 | 130 | |
131 | 131 | /** |
132 | 132 | * Current line. |
@@ -144,7 +144,7 @@ discard block |
||
144 | 144 | * |
145 | 145 | * @var [ Htsl\Parser\Section, ] |
146 | 146 | */ |
147 | - private $sections=[]; |
|
147 | + private $sections=[ ]; |
|
148 | 148 | |
149 | 149 | /** |
150 | 150 | * Whether the document is executed. |
@@ -184,13 +184,13 @@ discard block |
||
184 | 184 | */ |
185 | 185 | public function __construct( Htsl$htsl, Buffer$buffer, self$parent=null ) |
186 | 186 | { |
187 | - $this->htsl= $htsl; |
|
188 | - $this->buffer= $buffer; |
|
187 | + $this->htsl=$htsl; |
|
188 | + $this->buffer=$buffer; |
|
189 | 189 | |
190 | 190 | if( $parent ){ |
191 | - $this->parent= $parent; |
|
192 | - $this->docType= $parent->docType; |
|
193 | - $this->indentation= $parent->indentation; |
|
191 | + $this->parent=$parent; |
|
192 | + $this->docType=$parent->docType; |
|
193 | + $this->indentation=$parent->indentation; |
|
194 | 194 | }else{ |
195 | 195 | $this->parseFirstLine(); |
196 | 196 | } |
@@ -251,7 +251,7 @@ discard block |
||
251 | 251 | protected function getLine():Line |
252 | 252 | { |
253 | 253 | do{ |
254 | - $line= $this->buffer->getLine(); |
|
254 | + $line=$this->buffer->getLine(); |
|
255 | 255 | }while( $line->isEmpty() && $line->hasMore() ); |
256 | 256 | |
257 | 257 | return $line; |
@@ -268,7 +268,7 @@ discard block |
||
268 | 268 | */ |
269 | 269 | public function getConfig( string...$keys ) |
270 | 270 | { |
271 | - return $this->htsl->getConfig(array_shift($keys),$this->docType,...$keys); |
|
271 | + return $this->htsl->getConfig(array_shift($keys), $this->docType, ...$keys); |
|
272 | 272 | } |
273 | 273 | |
274 | 274 | /** |
@@ -316,16 +316,16 @@ discard block |
||
316 | 316 | */ |
317 | 317 | protected function parseFirstLine():self |
318 | 318 | { |
319 | - $line= $this->getLine(); |
|
319 | + $line=$this->getLine(); |
|
320 | 320 | |
321 | 321 | if( '@'===$line->getChar(0) ){ |
322 | 322 | return $this->setExtending($line); |
323 | 323 | } |
324 | 324 | |
325 | - $this->docType= $line->content; |
|
326 | - $docTypeContent= $this->getConfig('doc_types') or $this->throw("DocType $this->docType is not supported"); |
|
325 | + $this->docType=$line->content; |
|
326 | + $docTypeContent=$this->getConfig('doc_types') or $this->throw("DocType $this->docType is not supported"); |
|
327 | 327 | |
328 | - $this->indentation= $this->htsl->getConfig('indentation',$this->docType) ?? ( function( $scalarOrFalse ){ return is_scalar($scalarOrFalse)?$scalarOrFalse:false; } )($this->htsl->getConfig('indentation')); |
|
328 | + $this->indentation=$this->htsl->getConfig('indentation', $this->docType) ?? (function( $scalarOrFalse ){ return is_scalar($scalarOrFalse)? $scalarOrFalse : false; } )($this->htsl->getConfig('indentation')); |
|
329 | 329 | |
330 | 330 | return $this->appendLine($docTypeContent); |
331 | 331 | } |
@@ -341,7 +341,7 @@ discard block |
||
341 | 341 | */ |
342 | 342 | protected function setExtending( Line$firstLine ):self |
343 | 343 | { |
344 | - switch( $name= $firstLine->pregGet('/(?<=^@)[\w-:]+/') ){ |
|
344 | + switch( $name=$firstLine->pregGet('/(?<=^@)[\w-:]+/') ){ |
|
345 | 345 | default:{ |
346 | 346 | $this->throw("The @$name is not supported."); |
347 | 347 | }break; |
@@ -367,8 +367,8 @@ discard block |
||
367 | 367 | */ |
368 | 368 | protected function lineByLine():self |
369 | 369 | { |
370 | - while( ($line= $this->getLine())->hasMore() ){ |
|
371 | - $this->lineNumber+= 1; |
|
370 | + while( ($line=$this->getLine())->hasMore() ){ |
|
371 | + $this->lineNumber+=1; |
|
372 | 372 | |
373 | 373 | if( $this->embedment ){ |
374 | 374 | $this->embeddingParse($line); |
@@ -381,7 +381,7 @@ discard block |
||
381 | 381 | |
382 | 382 | $this->closeNodes($this->level); |
383 | 383 | |
384 | - $this->isExecuted= true; |
|
384 | + $this->isExecuted=true; |
|
385 | 385 | |
386 | 386 | return $this; |
387 | 387 | } |
@@ -417,10 +417,10 @@ discard block |
||
417 | 417 | */ |
418 | 418 | protected function startEmbedding( string$embedType ):self |
419 | 419 | { |
420 | - $embedmentClass= '\\Htsl\\Embedment\\'.ucfirst($embedType).'Embedment'; |
|
420 | + $embedmentClass='\\Htsl\\Embedment\\'.ucfirst($embedType).'Embedment'; |
|
421 | 421 | class_exists($embedmentClass) or $this->throw("Embed type $embedType not exists."); |
422 | 422 | |
423 | - $this->embedment= new $embedmentClass($this); |
|
423 | + $this->embedment=new $embedmentClass($this); |
|
424 | 424 | |
425 | 425 | return $this; |
426 | 426 | } |
@@ -435,7 +435,7 @@ discard block |
||
435 | 435 | public function breakEmbedding():self |
436 | 436 | { |
437 | 437 | $this->append($this->embedment->getContent()); |
438 | - $this->embedment= null; |
|
438 | + $this->embedment=null; |
|
439 | 439 | |
440 | 440 | return $this; |
441 | 441 | } |
@@ -451,7 +451,7 @@ discard block |
||
451 | 451 | */ |
452 | 452 | protected function parseLine( Line$line ):self |
453 | 453 | { |
454 | - $this->currentLine= $line; |
|
454 | + $this->currentLine=$line; |
|
455 | 455 | $this->setLevel($line->getIndentLevel()); |
456 | 456 | |
457 | 457 | $this->{'parse'.ucfirst($this->getLineType($line))}($line); |
@@ -470,10 +470,10 @@ discard block |
||
470 | 470 | */ |
471 | 471 | protected function getLineType( Line$line ):string |
472 | 472 | { |
473 | - $possibleType= self::POSSIBLE_LINE_TYPES; |
|
473 | + $possibleType=self::POSSIBLE_LINE_TYPES; |
|
474 | 474 | |
475 | 475 | for( $i=0; is_array($possibleType); ++$i ){ |
476 | - $possibleType= $possibleType[$line->getChar($i)]??$possibleType[' ']; |
|
476 | + $possibleType=$possibleType[ $line->getChar($i) ]??$possibleType[ ' ' ]; |
|
477 | 477 | } |
478 | 478 | |
479 | 479 | return $possibleType; |
@@ -488,7 +488,7 @@ discard block |
||
488 | 488 | * |
489 | 489 | * @todo Make this const private when php 7.1 |
490 | 490 | */ |
491 | - const POSSIBLE_LINE_TYPES= [ |
|
491 | + const POSSIBLE_LINE_TYPES=[ |
|
492 | 492 | '`'=> [ |
493 | 493 | '='=> 'expressionHtmlLine', |
494 | 494 | ' '=> 'htmlLine', |
@@ -512,7 +512,7 @@ discard block |
||
512 | 512 | */ |
513 | 513 | protected function parseHtmlLine( Line$line ):self |
514 | 514 | { |
515 | - return $this->openNode(new StringNode($this,$line))->appendLine($line->slice(1)); |
|
515 | + return $this->openNode(new StringNode($this, $line))->appendLine($line->slice(1)); |
|
516 | 516 | } |
517 | 517 | |
518 | 518 | /** |
@@ -526,7 +526,7 @@ discard block |
||
526 | 526 | */ |
527 | 527 | protected function parseStringLine( Line$line ):self |
528 | 528 | { |
529 | - return $this->openNode(new StringNode($this,$line))->appendLine($this->htmlEntities(trim($line->getContent()))); |
|
529 | + return $this->openNode(new StringNode($this, $line))->appendLine($this->htmlEntities(trim($line->getContent()))); |
|
530 | 530 | } |
531 | 531 | |
532 | 532 | /** |
@@ -540,11 +540,11 @@ discard block |
||
540 | 540 | */ |
541 | 541 | protected function parseExpressionLine( Line$line ):self |
542 | 542 | { |
543 | - $content= $line->slice(1); |
|
544 | - $ent_flag= var_export($this->htsl->getConfig('ENT_flags',$this->docType),true); |
|
545 | - $charset= var_export($this->htsl->getConfig('charset'),true); |
|
543 | + $content=$line->slice(1); |
|
544 | + $ent_flag=var_export($this->htsl->getConfig('ENT_flags', $this->docType), true); |
|
545 | + $charset=var_export($this->htsl->getConfig('charset'), true); |
|
546 | 546 | |
547 | - return $this->openNode(new StringNode($this,$line))->appendLine("<?=htmlentities($content,$ent_flag,$charset,false)?>"); |
|
547 | + return $this->openNode(new StringNode($this, $line))->appendLine("<?=htmlentities($content,$ent_flag,$charset,false)?>"); |
|
548 | 548 | } |
549 | 549 | |
550 | 550 | /** |
@@ -558,9 +558,9 @@ discard block |
||
558 | 558 | */ |
559 | 559 | protected function parseExpressionHtmlLine( Line$line ):self |
560 | 560 | { |
561 | - $content= $line->slice(1); |
|
561 | + $content=$line->slice(1); |
|
562 | 562 | |
563 | - return $this->openNode(new StringNode($this,$line))->appendLine("<?$content?>"); |
|
563 | + return $this->openNode(new StringNode($this, $line))->appendLine("<?$content?>"); |
|
564 | 564 | } |
565 | 565 | |
566 | 566 | /** |
@@ -574,7 +574,7 @@ discard block |
||
574 | 574 | */ |
575 | 575 | protected function parseCommentLine( Line$line ):self |
576 | 576 | { |
577 | - $node= new CommentNode($this,$line); |
|
577 | + $node=new CommentNode($this, $line); |
|
578 | 578 | |
579 | 579 | return $this->openNode($node)->appendLine($node->open()); |
580 | 580 | } |
@@ -590,7 +590,7 @@ discard block |
||
590 | 590 | */ |
591 | 591 | protected function parseTagLine( Line$line ):self |
592 | 592 | { |
593 | - $node= new TagNode($this,$line); |
|
593 | + $node=new TagNode($this, $line); |
|
594 | 594 | |
595 | 595 | $this->appendLine($node->open()); |
596 | 596 | |
@@ -610,7 +610,7 @@ discard block |
||
610 | 610 | */ |
611 | 611 | protected function parseControlLine( Line$line ):self |
612 | 612 | { |
613 | - $node= new ControlNode($this,$line); |
|
613 | + $node=new ControlNode($this, $line); |
|
614 | 614 | |
615 | 615 | return $this->appendLine($node->open())->openNode($node); |
616 | 616 | } |
@@ -626,7 +626,7 @@ discard block |
||
626 | 626 | */ |
627 | 627 | protected function parseDocControlLine( Line$line ):self |
628 | 628 | { |
629 | - switch( $name= $line->pregGet('/(?<=^@)[\w-:]+/') ){ |
|
629 | + switch( $name=$line->pregGet('/(?<=^@)[\w-:]+/') ){ |
|
630 | 630 | default:{ |
631 | 631 | $this->throw("The @$name is not supported."); |
632 | 632 | }break; |
@@ -658,10 +658,10 @@ discard block |
||
658 | 658 | */ |
659 | 659 | protected function extend( string$fileName ):self |
660 | 660 | { |
661 | - $this->parent= new static($this->htsl,$this->buffer->goSide($fileName)); |
|
661 | + $this->parent=new static($this->htsl, $this->buffer->goSide($fileName)); |
|
662 | 662 | |
663 | - $this->docType= $this->parent->docType; |
|
664 | - $this->indentation= $this->parent->indentation; |
|
663 | + $this->docType=$this->parent->docType; |
|
664 | + $this->indentation=$this->parent->indentation; |
|
665 | 665 | |
666 | 666 | return $this; |
667 | 667 | } |
@@ -677,7 +677,7 @@ discard block |
||
677 | 677 | */ |
678 | 678 | protected function insertIndentations( string$input ):string |
679 | 679 | { |
680 | - return preg_replace('/(?<=^|\\n)(?!$)/',str_repeat($this->indentation,$this->level-$this->sectionLevel),$input); |
|
680 | + return preg_replace('/(?<=^|\\n)(?!$)/', str_repeat($this->indentation, $this->level-$this->sectionLevel), $input); |
|
681 | 681 | } |
682 | 682 | |
683 | 683 | /** |
@@ -689,13 +689,13 @@ discard block |
||
689 | 689 | * |
690 | 690 | * @return \Htsl\Parser\Document |
691 | 691 | */ |
692 | - protected function include( Line$line ):self |
|
692 | + protected function include(Line$line):self |
|
693 | 693 | { |
694 | - $inclued= (new static($this->htsl,$this->buffer->goSide($line->pregGet('/(?<=\( ).*(?= \))/')),$this))->execute()->content; |
|
694 | + $inclued=(new static($this->htsl, $this->buffer->goSide($line->pregGet('/(?<=\( ).*(?= \))/')), $this))->execute()->content; |
|
695 | 695 | |
696 | - false===$this->indentation or $inclued= $this->insertIndentations($inclued); |
|
696 | + false===$this->indentation or $inclued=$this->insertIndentations($inclued); |
|
697 | 697 | |
698 | - return $this->openNode(new StringNode($this,$line))->append($inclued); |
|
698 | + return $this->openNode(new StringNode($this, $line))->append($inclued); |
|
699 | 699 | } |
700 | 700 | |
701 | 701 | /** |
@@ -709,7 +709,7 @@ discard block |
||
709 | 709 | */ |
710 | 710 | protected function defineSection( Line$line ):self |
711 | 711 | { |
712 | - $node= new SectionNode($this,$line); |
|
712 | + $node=new SectionNode($this, $line); |
|
713 | 713 | |
714 | 714 | $node->open(); |
715 | 715 | |
@@ -727,18 +727,18 @@ discard block |
||
727 | 727 | */ |
728 | 728 | protected function showSection( Line$line ):self |
729 | 729 | { |
730 | - $sectionName= $line->pregGet('/(?<=\( ).*(?= \))/'); |
|
730 | + $sectionName=$line->pregGet('/(?<=\( ).*(?= \))/'); |
|
731 | 731 | |
732 | - if( !isset($this->sections[$sectionName]) ){ |
|
733 | - return $this->openNode(new StringNode($this,$line)); |
|
732 | + if( !isset($this->sections[ $sectionName ]) ){ |
|
733 | + return $this->openNode(new StringNode($this, $line)); |
|
734 | 734 | } |
735 | - $content= $this->sections[$sectionName]->content; |
|
735 | + $content=$this->sections[ $sectionName ]->content; |
|
736 | 736 | |
737 | - false===$this->indentation or $content= $this->insertIndentations($content); |
|
737 | + false===$this->indentation or $content=$this->insertIndentations($content); |
|
738 | 738 | |
739 | 739 | $this->append($content); |
740 | 740 | |
741 | - $node= new NamelessSectionNode($this,$line); |
|
741 | + $node=new NamelessSectionNode($this, $line); |
|
742 | 742 | |
743 | 743 | $node->open(); |
744 | 744 | |
@@ -755,8 +755,8 @@ discard block |
||
755 | 755 | public function setSection( Section$section=null ):self |
756 | 756 | { |
757 | 757 | if( !$section ){ |
758 | - $this->sectionLevel= 0; |
|
759 | - $this->currentSection= null; |
|
758 | + $this->sectionLevel=0; |
|
759 | + $this->currentSection=null; |
|
760 | 760 | |
761 | 761 | return $this; |
762 | 762 | } |
@@ -765,17 +765,17 @@ discard block |
||
765 | 765 | $this->throw('Nesting definition of section is forbidden.'); |
766 | 766 | } |
767 | 767 | |
768 | - if( isset($this->parent->sections[$section->name]) ){ |
|
768 | + if( isset($this->parent->sections[ $section->name ]) ){ |
|
769 | 769 | $this->throw("Section {$section->name} already defined."); |
770 | 770 | } |
771 | 771 | |
772 | - $this->currentSection= $section; |
|
772 | + $this->currentSection=$section; |
|
773 | 773 | |
774 | 774 | if( $section->name ){ |
775 | - $this->parent->sections[$section->name]=$section; |
|
775 | + $this->parent->sections[ $section->name ]=$section; |
|
776 | 776 | } |
777 | 777 | |
778 | - $this->sectionLevel= $this->level+1; |
|
778 | + $this->sectionLevel=$this->level+1; |
|
779 | 779 | |
780 | 780 | return $this; |
781 | 781 | } |
@@ -791,8 +791,8 @@ discard block |
||
791 | 791 | { |
792 | 792 | if( $this->parent ){ |
793 | 793 | foreach( $this->sections as $name=>$section ){ |
794 | - if( !isset($this->parent->sections[$name]) ){ |
|
795 | - $this->parent->sections[$name]=$section; |
|
794 | + if( !isset($this->parent->sections[ $name ]) ){ |
|
795 | + $this->parent->sections[ $name ]=$section; |
|
796 | 796 | }; |
797 | 797 | } |
798 | 798 | } |
@@ -811,7 +811,7 @@ discard block |
||
811 | 811 | */ |
812 | 812 | public function htmlEntities( string$input ):string |
813 | 813 | { |
814 | - return htmlentities($input,$this->htsl->getConfig('ENT_flags',$this->docType),$this->htsl->getConfig('charset'),false); |
|
814 | + return htmlentities($input, $this->htsl->getConfig('ENT_flags', $this->docType), $this->htsl->getConfig('charset'), false); |
|
815 | 815 | } |
816 | 816 | |
817 | 817 | /** |
@@ -823,12 +823,12 @@ discard block |
||
823 | 823 | */ |
824 | 824 | protected function setLevel( int$level ):self |
825 | 825 | { |
826 | - $level-= $this->level; |
|
826 | + $level-=$this->level; |
|
827 | 827 | |
828 | 828 | if( $level<=0 ){ |
829 | 829 | $this->closeNodes(-$level); |
830 | 830 | }elseif( $level==1 ){ |
831 | - $this->level+= 1; |
|
831 | + $this->level+=1; |
|
832 | 832 | }else{ |
833 | 833 | $this->throw('Indent error.'); |
834 | 834 | } |
@@ -847,7 +847,7 @@ discard block |
||
847 | 847 | */ |
848 | 848 | protected function openNode( Node$node ):self |
849 | 849 | { |
850 | - array_push($this->openedNodes,$node); |
|
850 | + array_push($this->openedNodes, $node); |
|
851 | 851 | |
852 | 852 | $node->scope and $this->setScope($node); |
853 | 853 | |
@@ -868,13 +868,13 @@ discard block |
||
868 | 868 | if( empty($this->openedNodes) ) return $this; |
869 | 869 | |
870 | 870 | while( $level-->=0 ){ |
871 | - $node= array_pop($this->openedNodes); |
|
871 | + $node=array_pop($this->openedNodes); |
|
872 | 872 | |
873 | 873 | $node->scope and $this->removeScope($node); |
874 | 874 | |
875 | 875 | $closer=$node->close($this->currentLine) and $this->appendLine($closer); |
876 | 876 | |
877 | - $this->level-= $level>=0 ?1:0; |
|
877 | + $this->level-=$level>=0? 1 : 0; |
|
878 | 878 | } |
879 | 879 | |
880 | 880 | return $this; |
@@ -889,7 +889,7 @@ discard block |
||
889 | 889 | */ |
890 | 890 | protected function setScope( Node$scope ):int |
891 | 891 | { |
892 | - return array_unshift($this->scopes,$scope); |
|
892 | + return array_unshift($this->scopes, $scope); |
|
893 | 893 | } |
894 | 894 | |
895 | 895 | /** |
@@ -901,7 +901,7 @@ discard block |
||
901 | 901 | */ |
902 | 902 | public function getScope() |
903 | 903 | { |
904 | - return $this->scopes[0]??null; |
|
904 | + return $this->scopes[ 0 ]??null; |
|
905 | 905 | } |
906 | 906 | |
907 | 907 | /** |
@@ -933,7 +933,7 @@ discard block |
||
933 | 933 | */ |
934 | 934 | protected function appendLine( string$content ):self |
935 | 935 | { |
936 | - false===$this->indentation or $content= str_repeat($this->indentation,$this->level-$this->sectionLevel).$content."\n"; |
|
936 | + false===$this->indentation or $content=str_repeat($this->indentation, $this->level-$this->sectionLevel).$content."\n"; |
|
937 | 937 | |
938 | 938 | return $this->append($content); |
939 | 939 | } |
@@ -979,7 +979,7 @@ discard block |
||
979 | 979 | * |
980 | 980 | * @throw \Htsl\Parser\HtslParsingException |
981 | 981 | */ |
982 | - public function throw( string$message ) |
|
982 | + public function throw(string$message) |
|
983 | 983 | { |
984 | 984 | throw new HtslParsingException("$message at file {$this->buffer->filePath} line $this->lineNumber"); |
985 | 985 | } |
@@ -50,7 +50,7 @@ discard block |
||
50 | 50 | * |
51 | 51 | * @var array |
52 | 52 | */ |
53 | - private $attributes=[]; |
|
53 | + private $attributes=[ ]; |
|
54 | 54 | |
55 | 55 | /** |
56 | 56 | * Real constructor. |
@@ -62,14 +62,14 @@ discard block |
||
62 | 62 | protected function construct():parent |
63 | 63 | { |
64 | 64 | |
65 | - $name= $this->line->pregGet('/(?<=^-)[\w-:]+/'); |
|
65 | + $name=$this->line->pregGet('/(?<=^-)[\w-:]+/'); |
|
66 | 66 | $this->name=$name; |
67 | 67 | |
68 | - $this->loadConfig($name,$this->document); |
|
68 | + $this->loadConfig($name, $this->document); |
|
69 | 69 | |
70 | - $this->tagName=$this->config['name']??$name; |
|
71 | - $this->isEmpty= $this->line->getChar(-1)==='/' || $this->document->getConfig('empty_tags',$this->tagName); |
|
72 | - isset($this->config['default_attributes']) and array_walk($this->config['default_attributes'],function( $value,$key ){ $this->setAttribute($key,$value); }); |
|
70 | + $this->tagName=$this->config[ 'name' ]??$name; |
|
71 | + $this->isEmpty=$this->line->getChar(-1)==='/' || $this->document->getConfig('empty_tags', $this->tagName); |
|
72 | + isset($this->config[ 'default_attributes' ]) and array_walk($this->config[ 'default_attributes' ], function( $value, $key ){ $this->setAttribute($key, $value); }); |
|
73 | 73 | |
74 | 74 | return $this; |
75 | 75 | } |
@@ -83,16 +83,16 @@ discard block |
||
83 | 83 | */ |
84 | 84 | public function open():string |
85 | 85 | { |
86 | - if( isset($this->config['opener']) ) |
|
87 | - { return $this->config['opener']; } |
|
86 | + if( isset($this->config[ 'opener' ]) ) |
|
87 | + { return $this->config[ 'opener' ]; } |
|
88 | 88 | |
89 | 89 | $this->parsePrivateAttributes(); |
90 | 90 | $this->parseCommonAttributes(); |
91 | 91 | |
92 | - if( isset($this->config['in_scope']) && isset($this->config['scope_function']) && is_callable($this->config['scope_function']) ) |
|
93 | - { $this->config['scope_function']->call($this,$this->document->scope); } |
|
92 | + if( isset($this->config[ 'in_scope' ]) && isset($this->config[ 'scope_function' ]) && is_callable($this->config[ 'scope_function' ]) ) |
|
93 | + { $this->config[ 'scope_function' ]->call($this, $this->document->scope); } |
|
94 | 94 | |
95 | - $finisher= $this->isEmpty ? ' />' : '>'; |
|
95 | + $finisher=$this->isEmpty? ' />' : '>'; |
|
96 | 96 | |
97 | 97 | return "<{$this->tagName}{$this->attributesString}{$finisher}"; |
98 | 98 | } |
@@ -108,7 +108,7 @@ discard block |
||
108 | 108 | */ |
109 | 109 | public function close( Line$closerLine ):string |
110 | 110 | { |
111 | - return $this->isEmpty ? '' : $this->config['closer']??"</{$this->tagName}>"; |
|
111 | + return $this->isEmpty? '' : $this->config[ 'closer' ]??"</{$this->tagName}>"; |
|
112 | 112 | } |
113 | 113 | |
114 | 114 | /** |
@@ -120,7 +120,7 @@ discard block |
||
120 | 120 | */ |
121 | 121 | public function getEmbed():string |
122 | 122 | { |
123 | - return $this->config['embedding']??''; |
|
123 | + return $this->config[ 'embedding' ]??''; |
|
124 | 124 | } |
125 | 125 | |
126 | 126 | /** |
@@ -132,7 +132,7 @@ discard block |
||
132 | 132 | */ |
133 | 133 | public function getScope() |
134 | 134 | { |
135 | - return $this->config['scope']??null; |
|
135 | + return $this->config[ 'scope' ]??null; |
|
136 | 136 | } |
137 | 137 | |
138 | 138 | /** |
@@ -145,7 +145,7 @@ discard block |
||
145 | 145 | protected function parsePrivateAttributes():self |
146 | 146 | { |
147 | 147 | foreach( self::PRIVATE_ATTRIBUTES as $attribute ){ |
148 | - isset($this->config[$attribute]) and $this->{'parse'.Helper\camel_case($attribute)}(); |
|
148 | + isset($this->config[ $attribute ]) and $this->{'parse'.Helper\camel_case($attribute)}(); |
|
149 | 149 | } |
150 | 150 | |
151 | 151 | return $this; |
@@ -160,7 +160,7 @@ discard block |
||
160 | 160 | * |
161 | 161 | * @todo Make this const private when php 7.1 |
162 | 162 | */ |
163 | - const PRIVATE_ATTRIBUTES= [ |
|
163 | + const PRIVATE_ATTRIBUTES=[ |
|
164 | 164 | 'params', |
165 | 165 | 'name_value', |
166 | 166 | 'link', |
@@ -177,11 +177,11 @@ discard block |
||
177 | 177 | */ |
178 | 178 | protected function parseParams():self |
179 | 179 | { |
180 | - $params= preg_split('/(?<!\\\\)\\|/',$this->line->pregGet('/^-[\w-:]+\((.*?)\)(?= |(\\{>)?$)/',1)); |
|
180 | + $params=preg_split('/(?<!\\\\)\\|/', $this->line->pregGet('/^-[\w-:]+\((.*?)\)(?= |(\\{>)?$)/', 1)); |
|
181 | 181 | |
182 | - if( ($m= count($params)) != ($n= count($this->config['params'])) ){$this->document->throw("Tag $this->name has $n parameters $m given.");} |
|
182 | + if( ($m=count($params))!=($n=count($this->config[ 'params' ])) ){$this->document->throw("Tag $this->name has $n parameters $m given."); } |
|
183 | 183 | |
184 | - array_map(function( $key, $value ){return $this->setAttribute($key,str_replace('\\|','|',$value));},$this->config['params'],$params); |
|
184 | + array_map(function( $key, $value ){return $this->setAttribute($key, str_replace('\\|', '|', $value)); },$this->config[ 'params' ], $params); |
|
185 | 185 | |
186 | 186 | return $this; |
187 | 187 | } |
@@ -195,9 +195,9 @@ discard block |
||
195 | 195 | */ |
196 | 196 | protected function parseNameValue():self |
197 | 197 | { |
198 | - $params= $this->line->pregGet('/ <(.*?)>(?= |$)/',1) |
|
199 | - and $params= preg_split('/(?<!\\\\)\\|/',$params) |
|
200 | - and array_map(function( $key, $value ){return isset($key)&&isset($value) ? $this->setAttribute($key,$this->checkExpression(str_replace('\\|','|',$value))) : '';},$this->config['name_value'],$params); |
|
198 | + $params=$this->line->pregGet('/ <(.*?)>(?= |$)/', 1) |
|
199 | + and $params=preg_split('/(?<!\\\\)\\|/', $params) |
|
200 | + and array_map(function( $key, $value ){return isset($key) && isset($value)? $this->setAttribute($key, $this->checkExpression(str_replace('\\|', '|', $value))) : ''; },$this->config[ 'name_value' ], $params); |
|
201 | 201 | |
202 | 202 | return $this; |
203 | 203 | } |
@@ -239,13 +239,13 @@ discard block |
||
239 | 239 | */ |
240 | 240 | protected function parseLink():self |
241 | 241 | { |
242 | - return $this->setMultinameAttribute('link',$this->sectionLedBy('@',true),function( string$link ){ |
|
243 | - if( isset($this->config['target']) && ':'===$link{0} ){ |
|
242 | + return $this->setMultinameAttribute('link', $this->sectionLedBy('@', true), function( string$link ){ |
|
243 | + if( isset($this->config[ 'target' ]) && ':'===$link{0} ){ |
|
244 | 244 | return 'javascript'.$link; |
245 | - }elseif( '//'===($firstTwoLetters=substr($link,0,2)) ){ |
|
245 | + }elseif( '//'===($firstTwoLetters=substr($link, 0, 2)) ){ |
|
246 | 246 | return 'http:'.$link; |
247 | 247 | }elseif( '\\\\'===$firstTwoLetters ){ |
248 | - return 'https://'.substr($link,2); |
|
248 | + return 'https://'.substr($link, 2); |
|
249 | 249 | }else{ |
250 | 250 | return $this->checkExpression($link); |
251 | 251 | } |
@@ -261,7 +261,7 @@ discard block |
||
261 | 261 | */ |
262 | 262 | protected function parseTarget():self |
263 | 263 | { |
264 | - return $this->setMultinameAttribute('target',$this->sectionLedBy('>',true)); |
|
264 | + return $this->setMultinameAttribute('target', $this->sectionLedBy('>', true)); |
|
265 | 265 | } |
266 | 266 | |
267 | 267 | /** |
@@ -273,7 +273,7 @@ discard block |
||
273 | 273 | */ |
274 | 274 | protected function parseAlt():self |
275 | 275 | { |
276 | - return $this->setMultinameAttribute('alt',$this->sectionLedBy('_',true)); |
|
276 | + return $this->setMultinameAttribute('alt', $this->sectionLedBy('_', true)); |
|
277 | 277 | } |
278 | 278 | |
279 | 279 | /** |
@@ -289,8 +289,8 @@ discard block |
||
289 | 289 | */ |
290 | 290 | private function setMultinameAttribute( string$name, string$value, callable$processer=null ):self |
291 | 291 | { |
292 | - if( strlen($value) && !empty($this->config[$name]) ){ |
|
293 | - return $this->setAttribute($this->config[$name],call_user_func($processer??[$this,'checkExpression',],$value)); |
|
292 | + if( strlen($value) && !empty($this->config[ $name ]) ){ |
|
293 | + return $this->setAttribute($this->config[ $name ], call_user_func($processer??[ $this, 'checkExpression', ], $value)); |
|
294 | 294 | } |
295 | 295 | |
296 | 296 | return $this; |
@@ -305,33 +305,33 @@ discard block |
||
305 | 305 | */ |
306 | 306 | protected function parseCommonAttributes():string |
307 | 307 | { |
308 | - $attributes= ''; |
|
308 | + $attributes=''; |
|
309 | 309 | |
310 | - $id= $this->sectionLedBy('#') |
|
311 | - and $this->setAttribute('id',$id); |
|
310 | + $id=$this->sectionLedBy('#') |
|
311 | + and $this->setAttribute('id', $id); |
|
312 | 312 | |
313 | - $classes= $this->line->pregGet('/ \.[^ ]+(?= |$)/') |
|
314 | - and preg_match_all('/\.((?(?!\()[^.]+|(?<exp>\((?:[^()]+|(?&exp)?)+?\))))/',$classes,$matches) |
|
315 | - and $classes= implode(' ',array_filter(array_map(function( $className ){return $this->checkExpression($className);},$matches[1]))) |
|
316 | - and $this->setAttribute('class',$classes); |
|
313 | + $classes=$this->line->pregGet('/ \.[^ ]+(?= |$)/') |
|
314 | + and preg_match_all('/\.((?(?!\()[^.]+|(?<exp>\((?:[^()]+|(?&exp)?)+?\))))/', $classes, $matches) |
|
315 | + and $classes=implode(' ', array_filter(array_map(function( $className ){return $this->checkExpression($className); },$matches[ 1 ]))) |
|
316 | + and $this->setAttribute('class', $classes); |
|
317 | 317 | |
318 | - $title= $this->sectionLedBy('^',true) |
|
319 | - and $this->setAttribute('title',$title); |
|
318 | + $title=$this->sectionLedBy('^', true) |
|
319 | + and $this->setAttribute('title', $title); |
|
320 | 320 | |
321 | - $style= $this->line->pregGet('/ \[([^\]]+;)(?=\]( |$))/',1) |
|
322 | - and $this->setAttribute('style',$style); |
|
321 | + $style=$this->line->pregGet('/ \[([^\]]+;)(?=\]( |$))/', 1) |
|
322 | + and $this->setAttribute('style', $style); |
|
323 | 323 | |
324 | - $eventListeners= $this->line->pregMap('/ %(\w+)\{>(.*?)<\}(?= |$)/',function( $string, $name, $code ){ |
|
325 | - $this->setAttribute('on'.$name,str_replace('"','"',$code)); |
|
324 | + $eventListeners=$this->line->pregMap('/ %(\w+)\{>(.*?)<\}(?= |$)/', function( $string, $name, $code ){ |
|
325 | + $this->setAttribute('on'.$name, str_replace('"', '"', $code)); |
|
326 | 326 | }) |
327 | - and implode('',$eventListeners); |
|
327 | + and implode('', $eventListeners); |
|
328 | 328 | |
329 | - $other= $this->line->pregGet('/(?<=\{).*?(?=;\}( |$))/') |
|
329 | + $other=$this->line->pregGet('/(?<=\{).*?(?=;\}( |$))/') |
|
330 | 330 | and array_map(function( $keyValue ){ |
331 | - preg_replace_callback('/^([\w-:]+)(?:\?(.+?))?(?:\=(.*))?$/',function($matches){ |
|
332 | - $this->setAttribute($matches[1],($matches[3]??$matches[1])?:$matches[1],$matches[2]??null); |
|
331 | + preg_replace_callback('/^([\w-:]+)(?:\?(.+?))?(?:\=(.*))?$/', function( $matches ){ |
|
332 | + $this->setAttribute($matches[ 1 ], ($matches[ 3 ]??$matches[ 1 ])?: $matches[ 1 ], $matches[ 2 ]??null); |
|
333 | 333 | },$keyValue); |
334 | - },explode(';',$other)); |
|
334 | + },explode(';', $other)); |
|
335 | 335 | |
336 | 336 | return $attributes; |
337 | 337 | } |
@@ -347,7 +347,7 @@ discard block |
||
347 | 347 | */ |
348 | 348 | protected function checkExpression( string$value ):string |
349 | 349 | { |
350 | - return preg_match('/^\(.*\)$/',$value) ? '<?=str_replace(\'"\',\'"\','.substr($value,1,-1).')?>' : str_replace('"','"',$value); |
|
350 | + return preg_match('/^\(.*\)$/', $value)? '<?=str_replace(\'"\',\'"\','.substr($value, 1, -1).')?>' : str_replace('"', '"', $value); |
|
351 | 351 | } |
352 | 352 | |
353 | 353 | /** |
@@ -360,13 +360,13 @@ discard block |
||
360 | 360 | protected function getAttributesString():string |
361 | 361 | { |
362 | 362 | ksort($this->attributes); |
363 | - return implode('',array_map(static function( string$key, array$data ){ |
|
364 | - return (isset($data['condition'])&&strlen($data['condition'])? |
|
365 | - "<?php if( {$data['condition']} ){?> $key=\"{$data['value']}\"<?php }?>" |
|
363 | + return implode('', array_map(static function( string$key, array$data ){ |
|
364 | + return (isset($data[ 'condition' ]) && strlen($data[ 'condition' ])? |
|
365 | + "<?php if( {$data[ 'condition' ]} ){?> $key=\"{$data[ 'value' ]}\"<?php }?>" |
|
366 | 366 | : |
367 | - " $key=\"{$data['value']}\"" |
|
367 | + " $key=\"{$data[ 'value' ]}\"" |
|
368 | 368 | ); |
369 | - },array_keys($this->attributes),$this->attributes)); |
|
369 | + },array_keys($this->attributes), $this->attributes)); |
|
370 | 370 | } |
371 | 371 | |
372 | 372 | /** |
@@ -380,10 +380,10 @@ discard block |
||
380 | 380 | */ |
381 | 381 | protected function setAttribute( string$key, string$value, string$condition=null ):self |
382 | 382 | { |
383 | - if( isset($this->attributes[$key]) ) |
|
383 | + if( isset($this->attributes[ $key ]) ) |
|
384 | 384 | { $this->document->throw("Attribute $key of $this->name cannot redeclare."); } |
385 | 385 | |
386 | - $this->attributes[$key]=[ |
|
386 | + $this->attributes[ $key ]=[ |
|
387 | 387 | 'value'=> $value, |
388 | 388 | 'condition'=> $condition, |
389 | 389 | ]; |
@@ -407,7 +407,7 @@ discard block |
||
407 | 407 | */ |
408 | 408 | public function offsetExists( $offset ):bool |
409 | 409 | { |
410 | - return isset($this->attributes[$offset]); |
|
410 | + return isset($this->attributes[ $offset ]); |
|
411 | 411 | } |
412 | 412 | |
413 | 413 | /** |
@@ -421,7 +421,7 @@ discard block |
||
421 | 421 | */ |
422 | 422 | public function offsetGet( $offset ) |
423 | 423 | { |
424 | - return $this->attributes[$offset]??null; |
|
424 | + return $this->attributes[ $offset ]??null; |
|
425 | 425 | } |
426 | 426 | |
427 | 427 | /** |
@@ -434,7 +434,7 @@ discard block |
||
434 | 434 | */ |
435 | 435 | public function offsetSet( $offset, $value ) |
436 | 436 | { |
437 | - $this->setAttribute($offset,$value); |
|
437 | + $this->setAttribute($offset, $value); |
|
438 | 438 | } |
439 | 439 | |
440 | 440 | /** |
@@ -446,7 +446,7 @@ discard block |
||
446 | 446 | */ |
447 | 447 | public function offsetUnset( $offset ) |
448 | 448 | { |
449 | - if( isset($this->attributes[$offset]) ) |
|
450 | - { unset($this->attributes[$offset]); } |
|
449 | + if( isset($this->attributes[ $offset ]) ) |
|
450 | + { unset($this->attributes[ $offset ]); } |
|
451 | 451 | } |
452 | 452 | } |