ParseTreeIndex.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Wed, 09 Apr 2014 09:56:45 +0200
changeset 14192 5784c7eaf4a9
parent 14055 d5de1e564e5d
child 14507 10775bc746c4
permissions -rw-r--r--
class: ParseTreeIndex class definition added: #source #source:
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
13864
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     1
"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
 COPYRIGHT (c) 2006 by eXept Software AG
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
              All Rights Reserved
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
 This software is furnished under a license and may be used
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
 hereby transferred.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
"{ Package: 'stx:libtool' }"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
SortedCollection subclass:#ParseTreeIndex
14192
5784c7eaf4a9 class: ParseTreeIndex
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 14055
diff changeset
    15
	instanceVariableNames:'tree source'
13864
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
	classVariableNames:''
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
	poolDictionaries:''
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
	category:'Interface-CodeView-Syntax'
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
Magnitude subclass:#Element
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
	instanceVariableNames:'next prev node'
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
	classVariableNames:''
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
	poolDictionaries:''
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
	privateIn:ParseTreeIndex
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
!ParseTreeIndex class methodsFor:'documentation'!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
copyright
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
 COPYRIGHT (c) 2006 by eXept Software AG
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
              All Rights Reserved
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
 This software is furnished under a license and may be used
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
 only in accordance with the terms of that license and with the
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
 inclusion of the above copyright notice.   This software may not
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
 be provided or otherwise made available to, or used by, any
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
 other person.  No title to or ownership of the software is
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
 hereby transferred.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
documentation
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
    For given parse tree, a ParseTreeIndex provides an
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
    fast access to individual (leave) nodes by keeping
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
    an index. Used by CodeView2 for various queries
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
    Experimental
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
    [author:]
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
        Jan Vrany <jan.vrany@fit.cvut.cz>
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
    [instance variables:]
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
    [class variables:]
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
    [see also:]
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
! !
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
!ParseTreeIndex methodsFor:'accessing'!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
14192
5784c7eaf4a9 class: ParseTreeIndex
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 14055
diff changeset
    66
source
5784c7eaf4a9 class: ParseTreeIndex
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 14055
diff changeset
    67
    ^ source
5784c7eaf4a9 class: ParseTreeIndex
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 14055
diff changeset
    68
!
5784c7eaf4a9 class: ParseTreeIndex
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 14055
diff changeset
    69
5784c7eaf4a9 class: ParseTreeIndex
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 14055
diff changeset
    70
source:something
5784c7eaf4a9 class: ParseTreeIndex
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 14055
diff changeset
    71
    source := something.
5784c7eaf4a9 class: ParseTreeIndex
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 14055
diff changeset
    72
!
5784c7eaf4a9 class: ParseTreeIndex
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 14055
diff changeset
    73
13864
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
tree
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
    ^ tree
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
tree:aParseNode
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
    tree := aParseNode.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
! !
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
!ParseTreeIndex methodsFor:'utilities'!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
newElementFor: aParseNode
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
    ^(Element new node: aParseNode)
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
    "Created: / 16-02-2012 / 21:00:46 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
! !
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
!ParseTreeIndex::Element class methodsFor:'documentation'!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
copyright
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
 COPYRIGHT (c) 2010 by Jan Vrany, SWING Research Group. CTU in Prague
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
              All Rights Reserved
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
Permission is hereby granted, free of charge, to any person
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
obtaining a copy of this software and associated documentation
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
files (the 'Software'), to deal in the Software without
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
restriction, including without limitation the rights to use,
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   102
copy, modify, merge, publish, distribute, sublicense, and/or sell
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
copies of the Software, and to permit persons to whom the
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
Software is furnished to do so, subject to the following
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   105
conditions:
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
The above copyright notice and this permission notice shall be
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
included in all copies or substantial portions of the Software.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   110
THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   111
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   112
OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   115
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   116
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
OTHER DEALINGS IN THE SOFTWARE.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   118
"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   119
! !
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   121
!ParseTreeIndex::Element methodsFor:'accessing'!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   122
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
assigned
14055
d5de1e564e5d Fixed ParseTreeIndex::Element
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 13940
diff changeset
   124
    | p |
d5de1e564e5d Fixed ParseTreeIndex::Element
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 13940
diff changeset
   125
d5de1e564e5d Fixed ParseTreeIndex::Element
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 13940
diff changeset
   126
    ^ node isVariableNode 
d5de1e564e5d Fixed ParseTreeIndex::Element
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 13940
diff changeset
   127
        and:[(p := node parent) notNil
d5de1e564e5d Fixed ParseTreeIndex::Element
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 13940
diff changeset
   128
            and:[p isAssignment
d5de1e564e5d Fixed ParseTreeIndex::Element
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 13940
diff changeset
   129
                and:[p variable == node]]].
13864
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
    "Created: / 01-07-2013 / 21:53:34 / Jan Vrany <jan.vrany@fit.cvut.cz>"
14055
d5de1e564e5d Fixed ParseTreeIndex::Element
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 13940
diff changeset
   132
    "Modified: / 25-02-2014 / 20:52:27 / Jan Vrany <jan.vrany@fit.cvut.cz>"
13864
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
firstElementInChain
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
    |first prev|
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
    first := self.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   139
    [ (prev := first previousElement) notNil ] whileTrue:[
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
        first := prev.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   141
    ].
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
    ^ first
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   143
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   144
    "Created: / 21-08-2011 / 09:51:35 / cg"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
name
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
    ^node isVariable ifTrue:[node name] ifFalse:[nil]
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   149
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   150
    "Created: / 01-07-2013 / 21:56:37 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   152
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   153
next
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   154
    ^ next
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   155
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
next:aSyntaxElement
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   158
    next := aSyntaxElement.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   159
    next prev: self.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   160
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   161
    "Modified: / 14-02-2010 / 17:44:48 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   162
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
nextElement
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   165
    ^ next
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   166
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   167
    "Created: / 21-08-2011 / 09:47:11 / cg"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   168
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   169
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   170
nextElement:aSyntaxElement
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   171
    next := aSyntaxElement.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   172
    next prev: self.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   173
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   174
    "Modified: / 14-02-2010 / 17:44:48 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   175
    "Created: / 21-08-2011 / 09:47:15 / cg"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   176
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   177
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   178
node
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   179
    ^ node
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   180
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   182
node:something
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   183
    node := something.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   184
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   185
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
prev
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   187
    ^ prev
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   188
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   189
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   190
prev:aSyntaxElement
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   191
    prev := aSyntaxElement.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   192
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   193
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   194
previousElement
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   195
    ^ prev
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   196
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   197
    "Created: / 21-08-2011 / 09:47:23 / cg"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   198
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   199
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   200
previousElement:aSyntaxElement
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   201
    prev := aSyntaxElement.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   202
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   203
    "Created: / 21-08-2011 / 09:47:28 / cg"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   204
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   205
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   206
start
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   207
    ^ node startPosition
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   208
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   209
    "Modified: / 16-02-2012 / 20:56:36 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   210
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   211
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   212
stop
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   213
    ^ node endPosition
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   214
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   215
    "Modified: / 16-02-2012 / 20:56:48 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   216
! !
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   217
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   218
!ParseTreeIndex::Element methodsFor:'comparing'!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   219
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   220
< anObject
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   221
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   222
    anObject isNumber ifTrue:[^self stop < anObject].
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   223
    anObject class == self class ifFalse:[^false].
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   224
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   225
    ^self stop < anObject start
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   226
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   227
    "Created: / 14-02-2010 / 13:39:46 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   228
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   229
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   230
= anObject
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   231
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   232
    anObject class == self class ifFalse:[^false].
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   233
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   234
    ^self start == (anObject start) and:
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   235
        [self stop == (anObject stop) and:
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   236
            [self node class == (anObject node class)]].
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   237
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   238
    "Created: / 14-02-2010 / 13:33:36 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   239
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   240
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   241
hash
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   242
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   243
    ^self start hash bitXor:[self stop hash bitXor:[node class hash]].
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   244
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   245
    "Created: / 14-02-2010 / 13:30:00 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   246
! !
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   247
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   248
!ParseTreeIndex::Element methodsFor:'double dispatching'!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   249
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   250
lessFromInteger:anInteger
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   251
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   252
    ^self stop < anInteger
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   253
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   254
    "Created: / 14-02-2010 / 13:49:50 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   255
! !
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   256
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   257
!ParseTreeIndex::Element methodsFor:'printing & storing'!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   258
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   259
printOn:aStream
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   260
    "append a printed representation if the receiver to the argument, aStream"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   261
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   262
    super printOn:aStream.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   263
    aStream nextPutAll:'('.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   264
    node class name printOn: aStream.
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   265
    aStream nextPut:$).
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   266
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   267
    "Modified: / 21-08-2011 / 09:33:51 / cg"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   268
    "Modified: / 16-02-2012 / 19:23:22 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   269
! !
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   270
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   271
!ParseTreeIndex::Element methodsFor:'testing'!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   272
13940
352ed7a67f83 class: ParseTreeIndex
Claus Gittinger <cg@exept.de>
parents: 13864
diff changeset
   273
isGlobal
352ed7a67f83 class: ParseTreeIndex
Claus Gittinger <cg@exept.de>
parents: 13864
diff changeset
   274
    ^ node isGlobal
352ed7a67f83 class: ParseTreeIndex
Claus Gittinger <cg@exept.de>
parents: 13864
diff changeset
   275
!
352ed7a67f83 class: ParseTreeIndex
Claus Gittinger <cg@exept.de>
parents: 13864
diff changeset
   276
13864
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   277
isInstanceVariable
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   278
    ^node isVariable and:[node isInstance]
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   279
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   280
    "Created: / 01-07-2013 / 21:54:40 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   281
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   282
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   283
isSelector
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   284
    ^ node class == SelectorNode
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   285
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   286
    "Created: / 21-08-2011 / 09:09:19 / cg"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   287
    "Modified: / 16-02-2012 / 21:04:28 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   288
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   289
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   290
isSelf
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   291
    ^ node isSelf
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   292
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   293
    "Created: / 21-08-2011 / 09:31:20 / cg"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   294
    "Modified: / 16-02-2012 / 19:25:11 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   295
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   296
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   297
isVariable
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   298
    ^ node isVariable
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   299
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   300
    "Created: / 21-08-2011 / 09:09:00 / cg"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   301
    "Modified: / 16-02-2012 / 19:24:38 / Jan Vrany <jan.vrany@fit.cvut.cz>"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   302
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   303
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   304
isVariableOrSelf
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   305
    ^ self isVariable or:[self isSelf]
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   306
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   307
    "Created: / 21-08-2011 / 09:31:33 / cg"
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   308
! !
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   309
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   310
!ParseTreeIndex class methodsFor:'documentation'!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   311
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   312
version
14192
5784c7eaf4a9 class: ParseTreeIndex
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 14055
diff changeset
   313
    ^ '$Header: /cvs/stx/stx/libtool/ParseTreeIndex.st,v 1.4 2014-04-09 07:56:45 vrany Exp $'
13864
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   314
!
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   315
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   316
version_CVS
14192
5784c7eaf4a9 class: ParseTreeIndex
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 14055
diff changeset
   317
    ^ '$Header: /cvs/stx/stx/libtool/ParseTreeIndex.st,v 1.4 2014-04-09 07:56:45 vrany Exp $'
13864
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   318
! !
ec523973e8b9 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   319