41 lines
1.1 KiB
Smalltalk
41 lines
1.1 KiB
Smalltalk
|
"
|
||
|
A parser that parses a sequence of parsers.
|
||
|
"
|
||
|
Class {
|
||
|
#name : 'PPSequenceParser',
|
||
|
#superclass : 'PPListParser',
|
||
|
#category : 'PetitParser-Parsers'
|
||
|
}
|
||
|
|
||
|
{ #category : 'operators' }
|
||
|
PPSequenceParser >> , aRule [
|
||
|
^ self copyWith: aRule
|
||
|
]
|
||
|
|
||
|
{ #category : 'parsing' }
|
||
|
PPSequenceParser >> parseOn: aPPContext [
|
||
|
"This is optimized code that avoids unnecessary block activations, do not change."
|
||
|
|
||
|
| memento elements element |
|
||
|
memento := aPPContext remember.
|
||
|
elements := Array new: parsers size.
|
||
|
1 to: parsers size do: [ :index |
|
||
|
element := (parsers at: index)
|
||
|
parseOn: aPPContext.
|
||
|
element isPetitFailure ifTrue: [
|
||
|
aPPContext restore: memento.
|
||
|
^ element ].
|
||
|
elements at: index put: element ].
|
||
|
^ elements
|
||
|
]
|
||
|
|
||
|
{ #category : 'operators-mapping' }
|
||
|
PPSequenceParser >> permutation: anArrayOfIntegers [
|
||
|
"Answer a permutation of the receivers sequence."
|
||
|
|
||
|
anArrayOfIntegers do: [ :index |
|
||
|
(index isInteger and: [ index between: 1 and: parsers size ])
|
||
|
ifFalse: [ self error: 'Invalid permutation index: ' , index printString ] ].
|
||
|
^ self ==> [ :nodes | anArrayOfIntegers collect: [ :index | nodes at: index ] ]
|
||
|
]
|