Merged JK's version from Monticello
Name: PetitParser-JanKurs.275
Author: JanKurs
Time: 31-03-2015, 05:51:24.398 PM
UUID: 9ab3be24-8393-4794-a7e6-e318f3195673
Name: PetitTests-JanKurs.73
Author: JanKurs
Time: 21-02-2015, 01:10:13.115 PM
UUID: de4f77e3-2d07-476b-855e-69f845edfc7c
"{ Package: 'stx:goodies/petitparser' }"
PPDelegateParser subclass:#PPMemoizedParser
instanceVariableNames:'buffer context hash'
classVariableNames:''
poolDictionaries:''
category:'PetitParser-Parsers'
!
!PPMemoizedParser methodsFor:'operations'!
memoized
"Ther is no point in memoizing more than once."
^ self
! !
!PPMemoizedParser methodsFor:'parsing'!
parseOn: aPPContext
| memento contextMemento aStream |
"TODO: JK memoizing needs review!!"
contextMemento := aPPContext remember.
(hash == aPPContext hash)
ifFalse: [ self reset: aPPContext ].
memento := (buffer at: contextMemento ifAbsentPut: [ PPMemento new ]).
memento contextMemento isNil
ifTrue: [
aStream := aPPContext stream.
memento result: (aStream size - aStream position + 2 < memento count
ifTrue: [ PPFailure message: 'overflow' context: aPPContext ]
ifFalse: [ memento increment. parser parseOn: aPPContext ]).
memento contextMemento: aPPContext remember ]
ifFalse: [ context restore: memento contextMemento ].
^ memento result.
!
reset: aPPContext
hash := aPPContext hash.
context := aPPContext.
buffer := Dictionary new.
! !
!PPMemoizedParser class methodsFor:'documentation'!
version
^ '$Header: /cvs/stx/stx/goodies/petitparser/PPMemoizedParser.st,v 1.3 2012-05-04 21:58:48 vrany Exp $'
!
version_CVS
^ '$Header: /cvs/stx/stx/goodies/petitparser/PPMemoizedParser.st,v 1.3 2012-05-04 21:58:48 vrany Exp $'
!
version_SVN
^ '§Id: PPMemoizedParser.st 2 2010-12-17 18:44:23Z vranyj1 §'
! !