src/JavaRef2.st
author hlopkmar
Fri, 13 May 2011 15:28:12 +0000
branchjk_new_structure
changeset 781 d27c59bcf38a
parent 777 e6e61412ae43
child 809 0fd3dbe06abb
permissions -rw-r--r--
added preResolve compatibility method + JavaStringRef - will be used soon
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
     1
"{ Package: 'stx:libjava' }"
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
     2
774
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
     3
Object subclass:#JavaRef2
777
e6e61412ae43 refactoring tests.. and more needed
hlopkmar
parents: 774
diff changeset
     4
	instanceVariableNames:'valueCache constantPool'
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
     5
	classVariableNames:''
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
     6
	poolDictionaries:''
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
     7
	category:'Languages-Java-Reader-Support-new'
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
     8
!
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
     9
758
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    10
!JavaRef2 class methodsFor:'documentation'!
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    11
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    12
documentation
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    13
"
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    14
    I am parent of all reference types found in runtime constant pool. I define basic api - resolve and invalidate.
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    15
    Basic use case is to call resolve on my instance to get resolved thing, or to call invalidate to tell me,
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    16
    that world has changed and my cache is no longer valid.
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    17
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    18
    [author:]
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    19
        Marcel Hlopko <hlopkmar@fel.cvut.cz>
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    20
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    21
    [instance variables:]
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    22
        isResolved - flag telling whether instance is resolved
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    23
        valueCache - field holding resolved object
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    24
        owner - java class owning constant pool
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    25
    [class variables:]
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    26
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    27
    [see also:]
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    28
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    29
"
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    30
! !
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    31
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    32
!JavaRef2 class methodsFor:'instance creation'!
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    33
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    34
new
758
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    35
    "Don't call me directly"
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    36
    
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
    37
    '[JavaRef] Dont instantiate me with new. Call my custom overriden object creation method' 
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
    38
        infoPrintCR.
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
    39
    ^ self basicNew initialize.
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    40
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
    41
    "Modified: / 11-04-2011 / 19:44:01 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    42
! !
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    43
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    44
!JavaRef2 methodsFor:'accessing'!
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    45
774
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    46
constantPool
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    47
^constantPool.
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    48
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    49
    "Created: / 10-05-2011 / 17:16:23 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    50
!
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    51
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    52
constantPool: aJavaConstantPool
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    53
    constantPool := aJavaConstantPool.
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    54
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    55
    "Created: / 10-05-2011 / 17:16:37 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    56
!
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    57
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    58
isResolved
758
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    59
    ^ valueCache isNil not.
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    60
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    61
    "Created: / 08-04-2011 / 11:36:03 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
758
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    62
    "Modified: / 08-04-2011 / 17:39:42 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    63
!
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    64
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    65
name
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    66
^ self subclassResponsibility.
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    67
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    68
    "Created: / 08-04-2011 / 13:53:30 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    69
!
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
    70
774
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    71
owner
777
e6e61412ae43 refactoring tests.. and more needed
hlopkmar
parents: 774
diff changeset
    72
    ^ constantPool owner.
e6e61412ae43 refactoring tests.. and more needed
hlopkmar
parents: 774
diff changeset
    73
e6e61412ae43 refactoring tests.. and more needed
hlopkmar
parents: 774
diff changeset
    74
    "Modified: / 12-05-2011 / 18:31:34 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
774
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    75
!
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    76
777
e6e61412ae43 refactoring tests.. and more needed
hlopkmar
parents: 774
diff changeset
    77
owner: javaClass 
e6e61412ae43 refactoring tests.. and more needed
hlopkmar
parents: 774
diff changeset
    78
    constantPool owner: javaClass.
e6e61412ae43 refactoring tests.. and more needed
hlopkmar
parents: 774
diff changeset
    79
e6e61412ae43 refactoring tests.. and more needed
hlopkmar
parents: 774
diff changeset
    80
    "Modified: / 12-05-2011 / 18:32:04 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
774
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    81
!
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
    82
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    83
valueCache
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    84
    ^ valueCache.
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    85
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    86
    "Created: / 08-04-2011 / 11:37:31 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    87
! !
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    88
781
d27c59bcf38a added preResolve compatibility method + JavaStringRef - will be used soon
hlopkmar
parents: 777
diff changeset
    89
!JavaRef2 methodsFor:'backward compatibility'!
d27c59bcf38a added preResolve compatibility method + JavaStringRef - will be used soon
hlopkmar
parents: 777
diff changeset
    90
d27c59bcf38a added preResolve compatibility method + JavaStringRef - will be used soon
hlopkmar
parents: 777
diff changeset
    91
preResolve
d27c59bcf38a added preResolve compatibility method + JavaStringRef - will be used soon
hlopkmar
parents: 777
diff changeset
    92
"does nothing and will be deleted as soon as transition to new resolving is finished"
d27c59bcf38a added preResolve compatibility method + JavaStringRef - will be used soon
hlopkmar
parents: 777
diff changeset
    93
d27c59bcf38a added preResolve compatibility method + JavaStringRef - will be used soon
hlopkmar
parents: 777
diff changeset
    94
    "Created: / 13-05-2011 / 17:26:06 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
d27c59bcf38a added preResolve compatibility method + JavaStringRef - will be used soon
hlopkmar
parents: 777
diff changeset
    95
! !
d27c59bcf38a added preResolve compatibility method + JavaStringRef - will be used soon
hlopkmar
parents: 777
diff changeset
    96
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    97
!JavaRef2 methodsFor:'comparing'!
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    98
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
    99
= anotherJavaRef
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   100
^ self subclassResponsibility.
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   101
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   102
    "Created: / 08-04-2011 / 12:15:36 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   103
!
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   104
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   105
hash
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   106
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   107
^ self subclassResponsibility.
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   108
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   109
    "Created: / 08-04-2011 / 12:15:51 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   110
! !
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   111
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   112
!JavaRef2 methodsFor:'initialization'!
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   113
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   114
initialize
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   115
    valueCache := nil.
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   116
    super initialize.
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   117
758
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   118
    "Modified: / 08-04-2011 / 17:39:23 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   119
! !
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   120
774
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   121
!JavaRef2 methodsFor:'logging'!
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   122
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   123
info: arg 
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   124
    Transcript show: arg printString.
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   125
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   126
    "Created: / 10-05-2011 / 16:50:48 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   127
!
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   128
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   129
warning: arg 
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   130
    Transcript show: arg printString.
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   131
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   132
    "Created: / 10-05-2011 / 15:01:08 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   133
! !
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   134
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   135
!JavaRef2 methodsFor:'private - resolving'!
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   136
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   137
findResolvedStaticValue
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   138
    "raise an error: must be redefined in concrete subclass(es)"
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   139
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   140
    ^ self subclassResponsibility
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   141
!
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   142
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   143
findResolvedValue
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   144
    "raise an error: must be redefined in concrete subclass(es)"
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   145
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   146
    ^ self subclassResponsibility
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   147
! !
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   148
758
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   149
!JavaRef2 methodsFor:'queries'!
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   150
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   151
isJavaRef
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   152
"return true if object represents reference in java constant pool"
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   153
^ true.
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   154
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   155
    "Created: / 08-04-2011 / 16:15:05 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
771
fb8026dda011 Merged with /trunk
vranyj1
parents: 761
diff changeset
   156
!
fb8026dda011 Merged with /trunk
vranyj1
parents: 761
diff changeset
   157
fb8026dda011 Merged with /trunk
vranyj1
parents: 761
diff changeset
   158
isNewJavaRef
fb8026dda011 Merged with /trunk
vranyj1
parents: 761
diff changeset
   159
    "only temporary, to know if ref is old (claus' version) or new (m version)"
fb8026dda011 Merged with /trunk
vranyj1
parents: 761
diff changeset
   160
    
fb8026dda011 Merged with /trunk
vranyj1
parents: 761
diff changeset
   161
    ^ true.
fb8026dda011 Merged with /trunk
vranyj1
parents: 761
diff changeset
   162
fb8026dda011 Merged with /trunk
vranyj1
parents: 761
diff changeset
   163
    "Created: / 10-05-2011 / 12:20:05 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
758
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   164
! !
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   165
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   166
!JavaRef2 methodsFor:'resolving'!
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   167
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   168
invalidate
758
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   169
    "Invalidate reference. Cache will be cleared and next call to resolve will cause resolving from scratch."
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   170
    
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   171
    valueCache := nil.
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   172
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   173
    "Created: / 08-04-2011 / 11:42:43 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
758
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   174
    "Modified: / 08-04-2011 / 17:39:28 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   175
!
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   176
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   177
invalidateForClass: internalJavaClassName 
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   178
    "Invalidate (means call invalidate) reference if it has something to do with given class (e.g Class named internalJavaClassName was unloaded).
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   179
     Return true, if reference was invalidated."
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   180
    
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   181
    ^ self subclassResponsibility.
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   182
be8e84381ce0 Merged with /branches/jk
vranyj1
parents: 752
diff changeset
   183
    "Created: / 08-04-2011 / 15:59:57 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   184
!
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   185
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   186
resolve
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   187
    "
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   188
     Do it all method - resolves current reference and returns expected element (JavaMethod, JavaField etc.)
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   189
     Hides implementation details of the way of dealing with invalidation etc. User should not need to call anything
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   190
     else."
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   191
    
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   192
    self isResolved ifFalse: [ self findResolvedValue ].
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   193
    ^ valueCache.
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   194
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   195
    "Created: / 08-04-2011 / 11:30:21 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
761
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
   196
!
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
   197
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
   198
resolveStatic
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
   199
    "
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
   200
     Do it all method - resolves current reference and returns expected element (JavaMethod, JavaField etc.)
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
   201
     Hides implementation details of the way of dealing with invalidation etc. User should not need to call anything
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
   202
     else."
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
   203
    
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
   204
    self isResolved ifFalse: [ self findResolvedStaticValue ].
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
   205
    ^ valueCache.
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
   206
43e017ec7958 Merged with /branches/jk
vranyj1
parents: 758
diff changeset
   207
    "Created: / 26-04-2011 / 13:19:15 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
774
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   208
!
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   209
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   210
updateClassRefsFrom: oldOwner to: newOwner 
777
e6e61412ae43 refactoring tests.. and more needed
hlopkmar
parents: 774
diff changeset
   211
    self owner = oldOwner ifTrue: [ self owner: newOwner. ].
774
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   212
    self info: 'updating class refs from: ' , oldOwner printString , ' to ' 
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   213
                , newOwner printString.
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   214
ac54730a2b74 cleaning.. removed JavaConstantPoolContent
hlopkmar
parents: 772
diff changeset
   215
    "Created: / 10-05-2011 / 16:50:48 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
777
e6e61412ae43 refactoring tests.. and more needed
hlopkmar
parents: 774
diff changeset
   216
    "Modified: / 12-05-2011 / 18:31:25 / Marcel Hlopko <hlopkmar@fel.cvut.cz>"
752
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   217
! !
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   218
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   219
!JavaRef2 class methodsFor:'documentation'!
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   220
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   221
version_SVN
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   222
    ^ '$Id$'
ff7bc6428c9c branch jk_new_structure resurrected
vranyj1
parents:
diff changeset
   223
! !