CypressJSONReader.st
author Jan Vrany <jan.vrany@labware.com>
Wed, 08 Jul 2020 11:26:45 +0100
changeset 29 443911ff729a
parent 27 8215eadbe42b
permissions -rw-r--r--
Move some extensions to stx:libcompat
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
     1
"{ Package: 'stx:goodies/cypress' }"
8a5b7afa28ff - First shot
jv
parents:
diff changeset
     2
15
31a33727c629 - Getting rid of old Cypress implementation.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12
diff changeset
     3
Object subclass:#CypressJSONReader
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
     4
	instanceVariableNames:'stream'
8a5b7afa28ff - First shot
jv
parents:
diff changeset
     5
	classVariableNames:''
8a5b7afa28ff - First shot
jv
parents:
diff changeset
     6
	poolDictionaries:''
15
31a33727c629 - Getting rid of old Cypress implementation.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12
diff changeset
     7
	category:'Cypress-New-Reader & Writer'
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
     8
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
     9
27
8215eadbe42b Issue #239: Fix all Smalltak/X source files to be in unicode (UTF8 without BOM) and prefixed by "{ Encoding: utf8 }" when any unicode character is present
Patrik Svestka <patrik.svestka@gmail.com>
parents: 20
diff changeset
    10
CypressJSONReader comment:'Main comment stating the purpose of this class and relevant relationship to other classes.
8215eadbe42b Issue #239: Fix all Smalltak/X source files to be in unicode (UTF8 without BOM) and prefixed by "{ Encoding: utf8 }" when any unicode character is present
Patrik Svestka <patrik.svestka@gmail.com>
parents: 20
diff changeset
    11
8215eadbe42b Issue #239: Fix all Smalltak/X source files to be in unicode (UTF8 without BOM) and prefixed by "{ Encoding: utf8 }" when any unicode character is present
Patrik Svestka <patrik.svestka@gmail.com>
parents: 20
diff changeset
    12
Possible useful expressions for doIt or printIt.
8215eadbe42b Issue #239: Fix all Smalltak/X source files to be in unicode (UTF8 without BOM) and prefixed by "{ Encoding: utf8 }" when any unicode character is present
Patrik Svestka <patrik.svestka@gmail.com>
parents: 20
diff changeset
    13
8215eadbe42b Issue #239: Fix all Smalltak/X source files to be in unicode (UTF8 without BOM) and prefixed by "{ Encoding: utf8 }" when any unicode character is present
Patrik Svestka <patrik.svestka@gmail.com>
parents: 20
diff changeset
    14
Structure:
8215eadbe42b Issue #239: Fix all Smalltak/X source files to be in unicode (UTF8 without BOM) and prefixed by "{ Encoding: utf8 }" when any unicode character is present
Patrik Svestka <patrik.svestka@gmail.com>
parents: 20
diff changeset
    15
 instVar1		type -- comment about the purpose of instVar1
8215eadbe42b Issue #239: Fix all Smalltak/X source files to be in unicode (UTF8 without BOM) and prefixed by "{ Encoding: utf8 }" when any unicode character is present
Patrik Svestka <patrik.svestka@gmail.com>
parents: 20
diff changeset
    16
 instVar2		type -- comment about the purpose of instVar2
8215eadbe42b Issue #239: Fix all Smalltak/X source files to be in unicode (UTF8 without BOM) and prefixed by "{ Encoding: utf8 }" when any unicode character is present
Patrik Svestka <patrik.svestka@gmail.com>
parents: 20
diff changeset
    17
8215eadbe42b Issue #239: Fix all Smalltak/X source files to be in unicode (UTF8 without BOM) and prefixed by "{ Encoding: utf8 }" when any unicode character is present
Patrik Svestka <patrik.svestka@gmail.com>
parents: 20
diff changeset
    18
Any further useful comments about the general approach of this implementation.'
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    19
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    20
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    21
15
31a33727c629 - Getting rid of old Cypress implementation.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12
diff changeset
    22
!CypressJSONReader class methodsFor:'instance creation'!
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    23
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    24
new
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    25
	self error: 'Instantiate the parser with a stream.'
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    26
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    27
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    28
on: aStream
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    29
	^ self basicNew initializeOn: aStream
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    30
! !
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    31
15
31a33727c629 - Getting rid of old Cypress implementation.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12
diff changeset
    32
!CypressJSONReader class methodsFor:'accessing'!
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    33
12
ec118792047a - Package writing rewritten to use new model. Writes package according to recent spec.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1
diff changeset
    34
parse: aStringOrFilename
ec118792047a - Package writing rewritten to use new model. Writes package according to recent spec.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1
diff changeset
    35
        ^ self parseStream: aStringOrFilename readStream
ec118792047a - Package writing rewritten to use new model. Writes package according to recent spec.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1
diff changeset
    36
ec118792047a - Package writing rewritten to use new model. Writes package according to recent spec.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1
diff changeset
    37
    "Modified (format): / 11-09-2012 / 11:38:41 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    38
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    39
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    40
parseStream: aStream
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    41
	^ (self on: aStream) parse
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    42
! !
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    43
15
31a33727c629 - Getting rid of old Cypress implementation.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12
diff changeset
    44
!CypressJSONReader methodsFor:'adding'!
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    45
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    46
addProperty: anAssociation to: anObject
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    47
	"Add the property anAssociation described with key and value to anObject. Subclasses might want to refine this implementation."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    48
	
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    49
	^ anObject 
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    50
		add: anAssociation;
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    51
		yourself
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    52
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    53
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    54
addValue: anObject to: aCollection
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    55
	"Add anObject to aCollection. Subclasses might want to refine this implementation."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    56
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    57
	^ aCollection copyWith: anObject
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    58
! !
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    59
15
31a33727c629 - Getting rid of old Cypress implementation.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12
diff changeset
    60
!CypressJSONReader methodsFor:'creating'!
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    61
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    62
createArray
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    63
	"Create an empty collection. Subclasses might want to refine this implementation."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    64
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    65
	^ Array new
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    66
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    67
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    68
createFalse
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    69
	"Create the false literal. Subclasses might want to refine this implementation."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    70
	
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    71
	^ false
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    72
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    73
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    74
createNull
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    75
	"Create the null literal. Subclasses might want to refine this implementation."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    76
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    77
	^ nil
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    78
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    79
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    80
createNumber: aString
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    81
	"Create a number literal. Subclasses might want to refine this implementation."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    82
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    83
	^ aString asNumber
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    84
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    85
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    86
createObject
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    87
	"Create an empty object. Subclasses might want to refine this implementation."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    88
	
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    89
	^ Dictionary new
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    90
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    91
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    92
createProperty: aKey with: aValue
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    93
	"Create an empty attribute value pair. Subclasses might want to refine this implementation."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    94
	
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    95
	^ aKey -> aValue
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    96
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    97
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    98
createString: aString
8a5b7afa28ff - First shot
jv
parents:
diff changeset
    99
	"Create a string literal. Subclasses might want to refine this implementation."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   100
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   101
	^ aString
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   102
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   103
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   104
createTrue
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   105
	"Create the true literal. Subclasses might want to refine this implementation."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   106
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   107
	^ true
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   108
! !
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   109
15
31a33727c629 - Getting rid of old Cypress implementation.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12
diff changeset
   110
!CypressJSONReader methodsFor:'initialization'!
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   111
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   112
initializeOn: aStream
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   113
	self initialize.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   114
	stream := aStream
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   115
! !
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   116
15
31a33727c629 - Getting rid of old Cypress implementation.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12
diff changeset
   117
!CypressJSONReader methodsFor:'parsing'!
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   118
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   119
parse
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   120
	| result |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   121
	result := self whitespace; parseValue.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   122
	stream atEnd
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   123
		ifFalse: [ self error: 'end of input expected' ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   124
	^ result
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   125
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   126
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   127
parseArray
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   128
	| result |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   129
	self expect: '['.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   130
	result := self createArray.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   131
	(self match: ']')
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   132
		ifTrue: [ ^ result ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   133
	[ stream atEnd ] whileFalse: [
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   134
		result := self
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   135
			addValue: self parseValue
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   136
			to: result.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   137
		(self match: ']') 
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   138
			ifTrue: [ ^ result ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   139
		self expect: ',' ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   140
	self error: 'end of array expected'
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   141
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   142
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   143
parseObject
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   144
	| result |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   145
	self expect: '{'.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   146
	result := self createObject.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   147
	(self match: '}')
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   148
		ifTrue: [ ^ result ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   149
	[ stream atEnd ] whileFalse: [
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   150
		result := self
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   151
			addProperty: self parseProperty
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   152
			to: result.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   153
		(self match: '}')
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   154
			ifTrue: [ ^ result ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   155
		self expect: ',' ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   156
	self error: 'end of object expected'
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   157
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   158
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   159
parseValue
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   160
	| char |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   161
	stream atEnd ifFalse: [ 
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   162
		char := stream peek.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   163
		char = ${
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   164
			ifTrue: [ ^ self parseObject ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   165
		char = $[
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   166
			ifTrue: [ ^ self parseArray ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   167
		char = $"
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   168
			ifTrue: [ ^ self parseString ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   169
		(char = $- or: [ char between: $0 and: $9 ])
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   170
			ifTrue: [ ^ self parseNumber ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   171
		(self match: 'true')
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   172
			ifTrue: [ ^ self createTrue ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   173
		(self match: 'false')
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   174
			ifTrue: [ ^ self createFalse ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   175
		(self match: 'null')
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   176
			ifTrue: [ ^ self createNull ] ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   177
	self error: 'invalid input'
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   178
! !
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   179
15
31a33727c629 - Getting rid of old Cypress implementation.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12
diff changeset
   180
!CypressJSONReader methodsFor:'parsing-internal'!
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   181
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   182
parseCharacter
20
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   183
        | char |
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   184
        (char := stream next) = $\ 
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   185
                ifFalse: [ ^ char ].
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   186
        (char := stream next) = $" 
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   187
                ifTrue: [ ^ char ].
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   188
        char = $\
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   189
                ifTrue: [ ^ char ].
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   190
        char = $/
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   191
                ifTrue: [ ^ char ].
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   192
        char = $b
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   193
                ifTrue: [ ^ Character backspace ].
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   194
        char = $f
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   195
                ifTrue: [ ^ Character newPage ].
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   196
        char = $n
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   197
                ifTrue: [ ^ Character linefeed ].
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   198
        char = $r
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   199
                ifTrue: [ ^ Character return ].
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   200
        char = $t
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   201
                ifTrue: [ ^ Character tab ].
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   202
        char = $u
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   203
                ifTrue: [ ^ self parseCharacterHex ].
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   204
        self error: 'invalid escape character \' , (String with: char)
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   205
cdf3ee8ceeaa - fixes
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 15
diff changeset
   206
    "Modified: / 18-09-2012 / 14:22:02 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   207
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   208
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   209
parseCharacterHex
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   210
	| value |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   211
	value := self parseCharacterHexDigit.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   212
	3 timesRepeat: [ value := (value << 4) + self parseCharacterHexDigit ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   213
	^ Character unicodeCodePoint: value
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   214
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   215
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   216
parseCharacterHexDigit
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   217
	| digit |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   218
	stream atEnd ifFalse: [
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   219
		digit _ stream next asUppercase digitValue.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   220
		"accept hex digits"
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   221
		(digit >= 0 and: [ digit < 16 ]) ifTrue: [ ^ digit ]].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   222
	self error: 'hex-digit expected'.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   223
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   224
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   225
parseNumber
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   226
	| negated number |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   227
	negated := stream peek = $-.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   228
	negated ifTrue: [ stream next ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   229
	number := self parseNumberInteger.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   230
	(stream peek = $.) ifTrue: [
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   231
		stream next. 
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   232
		number := number + self parseNumberFraction ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   233
	(stream peek = $e or: [ stream peek = $E ]) ifTrue: [
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   234
		stream next.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   235
		number := number * self parseNumberExponent ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   236
	negated ifTrue: [ number := number negated ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   237
	^ self whitespace; createNumber: number
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   238
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   239
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   240
parseNumberExponent
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   241
    | number negated |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   242
    number := 0.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   243
    negated := stream peek = $-.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   244
    (negated or: [ stream peek = $+ ])
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   245
        ifTrue: [ stream next ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   246
    [ stream atEnd not and: [ stream peek isDigit ] ] whileTrue: [ number := 10 * number + (stream next digitValue) ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   247
    negated
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   248
        ifTrue: [ number := number negated ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   249
    ^ 10 raisedTo: number
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   250
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   251
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   252
parseNumberFraction
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   253
    | number power |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   254
    number := 0.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   255
    power := 1.0.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   256
    [ stream atEnd not and: [ stream peek isDigit ] ]
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   257
        whileTrue: [ 
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   258
            number := 10 * number + (stream next digitValue).
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   259
            power := power * 10.0 ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   260
    ^ number / power
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   261
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   262
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   263
parseNumberInteger
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   264
    | number |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   265
    number := 0.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   266
    [ stream atEnd not and: [ stream peek isDigit ] ] whileTrue: [ number := 10 * number + (stream next asciiValue - 48) ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   267
    ^ number
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   268
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   269
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   270
parseProperty
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   271
	| name value |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   272
	name := self parseString.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   273
	self expect: ':'.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   274
	value := self parseValue.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   275
	^ self createProperty: name with: value.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   276
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   277
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   278
parseString
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   279
	| result |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   280
	self expect: '"'.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   281
	result := WriteStream on: String new.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   282
	[ stream atEnd or: [ stream peek = $" ] ] 
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   283
		whileFalse: [ result nextPut: self parseCharacter ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   284
	^ self expect: '"'; createString: result contents
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   285
! !
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   286
15
31a33727c629 - Getting rid of old Cypress implementation.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12
diff changeset
   287
!CypressJSONReader methodsFor:'private'!
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   288
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   289
expect: aString
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   290
	"Expects aString and consume input, throw an error otherwise."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   291
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   292
	^ (self match: aString) ifFalse: [ self error: aString , ' expected' ]
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   293
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   294
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   295
match: aString
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   296
	"Tries to match aString, consume input and answer true if successful."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   297
	
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   298
	| position |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   299
	position := stream position.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   300
	aString do: [ :each |
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   301
		(stream atEnd or: [ stream next ~= each ]) ifTrue: [ 
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   302
			stream position: position.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   303
			^ false ] ].
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   304
	self whitespace.
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   305
	^ true
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   306
!
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   307
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   308
whitespace
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   309
	"Strip whitespaces from the input stream."
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   310
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   311
	[ stream atEnd not and: [ stream peek isSeparator ] ]
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   312
		whileTrue: [ stream next ]
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   313
! !
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   314
15
31a33727c629 - Getting rid of old Cypress implementation.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12
diff changeset
   315
!CypressJSONReader class methodsFor:'documentation'!
1
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   316
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   317
version_SVN
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   318
    ^ '$Id::                                                                                                                        $'
8a5b7afa28ff - First shot
jv
parents:
diff changeset
   319
! !