PPSequenceParser.st
author convert-repo
Thu, 19 Dec 2019 04:27:47 +0000
changeset 649 6c22f55541f2
parent 644 0bf7cd45f7eb
permissions -rw-r--r--
update tags
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
644
0bf7cd45f7eb #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
     1
"{ Encoding: utf8 }"
0bf7cd45f7eb #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
     2
4
90de244a7fa2 move to package
Claus Gittinger <cg@exept.de>
parents: 0
diff changeset
     3
"{ Package: 'stx:goodies/petitparser' }"
0
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
644
0bf7cd45f7eb #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
     5
"{ NameSpace: Smalltalk }"
0bf7cd45f7eb #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
     6
0
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
PPListParser subclass:#PPSequenceParser
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
	instanceVariableNames:''
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
	classVariableNames:''
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
	poolDictionaries:''
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
	category:'PetitParser-Parsers'
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
!
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
180
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    15
!PPSequenceParser methodsFor:'*petitanalyzer-private'!
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    16
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    17
cycleSet: aDictionary
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    18
	| firstSet |
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    19
	1 to: parsers size do: [ :index |
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    20
		firstSet := aDictionary at: (parsers at: index).
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    21
		(firstSet anySatisfy: [ :each | each isNullable ])
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    22
			ifFalse: [ ^ parsers copyFrom: 1 to: index ] ].
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    23
	^ parsers
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    24
!
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    25
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    26
firstSets: aFirstDictionary into: aSet
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    27
	| nullable |
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    28
	parsers do: [ :parser |
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    29
		nullable := false.
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    30
		(aFirstDictionary at: parser) do: [ :each |
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    31
			each isNullable
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    32
				ifTrue: [ nullable := true ]
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    33
				ifFalse: [ aSet add: each ] ].
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    34
		nullable
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    35
			ifFalse: [ ^ self ] ].
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    36
	aSet add: PPSentinel instance
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    37
!
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    38
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    39
followSets: aFollowDictionary firstSets: aFirstDictionary into: aSet
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    40
	parsers keysAndValuesDo: [ :index :parser |
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    41
		| followSet firstSet |
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    42
		followSet := aFollowDictionary at: parser.
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    43
		index = parsers size
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    44
			ifTrue: [ followSet addAll: aSet ]
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    45
			ifFalse: [
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    46
				(self class withAll: (parsers 
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    47
					copyFrom: index + 1 to: parsers size))
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    48
						firstSets: aFirstDictionary
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    49
						into: (firstSet := IdentitySet new).
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    50
				(firstSet anySatisfy: [ :each | each isNullable ])
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    51
					ifTrue: [ followSet addAll: aSet ].
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    52
				followSet addAll: (firstSet 
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    53
					reject: [ :each | each isNullable ]) ] ]
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    54
! !
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    55
0
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
!PPSequenceParser methodsFor:'operations'!
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
, aRule
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
	^ self copyWith: aRule
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
!
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
permutation: anArrayOfIntegers
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
	"Answer a permutation of the receivers sequence."
12
ace2bacc5f6a Checkin from browser
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 4
diff changeset
    64
	
0
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
	anArrayOfIntegers do: [ :index |
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
		(index isInteger and: [ index between: 1 and: parsers size ])
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
			ifFalse: [ self error: 'Invalid permutation index: ' , index printString ] ].
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
	^ self ==> [ :nodes | anArrayOfIntegers collect: [ :index | nodes at: index ] ]
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
! !
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
180
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    71
!PPSequenceParser methodsFor:'operators-mapping'!
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    72
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    73
map: aBlock
644
0bf7cd45f7eb #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
    74
        ^ aBlock argumentCount == self children size
0bf7cd45f7eb #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
    75
                ifTrue: [ self ==> [ :nodes | aBlock valueWithArguments: nodes ] ]
0bf7cd45f7eb #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
    76
                ifFalse: [ self error: aBlock argumentCount asString , ' arguments expected.' ]
180
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    77
! !
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
    78
0
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
!PPSequenceParser methodsFor:'parsing'!
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
parseOn: aStream
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
	"This is optimized code that avoids unnecessary block activations, do not change."
12
ace2bacc5f6a Checkin from browser
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 4
diff changeset
    83
	
0
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
	| start elements element |
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
	start := aStream position.
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
	elements := Array new: parsers size.
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
	1 to: parsers size do: [ :index |
12
ace2bacc5f6a Checkin from browser
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 4
diff changeset
    88
		element := (parsers at: index) 
0
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
			parseOn: aStream.
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
		element isPetitFailure ifTrue: [
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
			aStream position: start.
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
			^ element ].
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
		elements at: index put: element ].
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
	^ elements
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
! !
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
!PPSequenceParser class methodsFor:'documentation'!
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
12
ace2bacc5f6a Checkin from browser
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 4
diff changeset
    99
version
644
0bf7cd45f7eb #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
   100
    ^ '$Header$'
12
ace2bacc5f6a Checkin from browser
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 4
diff changeset
   101
!
ace2bacc5f6a Checkin from browser
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 4
diff changeset
   102
ace2bacc5f6a Checkin from browser
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 4
diff changeset
   103
version_CVS
644
0bf7cd45f7eb #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
   104
    ^ '$Header$'
12
ace2bacc5f6a Checkin from browser
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 4
diff changeset
   105
!
ace2bacc5f6a Checkin from browser
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 4
diff changeset
   106
0
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
version_SVN
644
0bf7cd45f7eb #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 180
diff changeset
   108
    ^ '$Id$'
0
739fe9b7253e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
! !
180
Claus Gittinger <cg@exept.de>
parents: 12
diff changeset
   110