| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294 | Smalltalk current createPackage: 'Helios-Browser'!HLWidget subclass: #HLBrowser instanceVariableNames: 'model packagesListWidget classesListWidget protocolsListWidget methodsListWidget sourceWidget' package: 'Helios-Browser'!!HLBrowser methodsFor: 'accessing'!announcer	^ self model announcer!environment	^ self model environment!model	^ model ifNil: [ model := HLBrowserModel new ]!model: aModel	model := aModel! !!HLBrowser methodsFor: 'keybindings'!registerBindingsOn: aBindingGroup	HLBrowserCommand registerConcreteClassesOn: aBindingGroup for: self model		"aBindingGroup     	addGroupKey: 66 labelled: 'Browse';        addGroupKey: 71 labelled: 'Go to';        addGroupKey: 84 labelled: 'Toggle';		addGroupKey: 77 labelled: 'Move'.				(aBindingGroup at: 'Move')		addGroupKey: 77 labelled: 'Method';		addGroupKey: 67 labelled: 'Class';		addGroupKey: 80 labelled: 'Protocol'.        	HLMoveMethodToCommand concreteClasses do: [ :each |  			(aBindingGroup at: 'Move') 				at: each bindingGroup   				add: (each on: self model) asBinding ].			   	HLBrowserCommand concreteClasses do: [ :each |  			aBindingGroup 				at: each bindingGroup  				add: (each on: self model) asBinding ]"! !!HLBrowser methodsFor: 'rendering'!renderContentOn: html	html with: (HLContainer with: (HLHorizontalSplitter     	with: (HLVerticalSplitter        	with: (HLVerticalSplitter            	with: self packagesListWidget                with: self classesListWidget)            with: (HLVerticalSplitter            	with: self protocolsListWidget                with: self methodsListWidget))         with: self sourceWidget)).		self packagesListWidget focus! !!HLBrowser methodsFor: 'widgets'!classesListWidget	^ classesListWidget ifNil: [      	classesListWidget := HLClassesListWidget on: self model.		classesListWidget next: self protocolsListWidget ]!methodsListWidget	^ methodsListWidget ifNil: [      	methodsListWidget := HLMethodsListWidget on: self model ]!packagesListWidget	^ packagesListWidget ifNil: [      	packagesListWidget := HLPackagesListWidget on: self model.		packagesListWidget next: self classesListWidget ]!protocolsListWidget	^ protocolsListWidget ifNil: [      	protocolsListWidget := HLProtocolsListWidget on: self model.		protocolsListWidget next: self methodsListWidget ]!sourceWidget	^ sourceWidget ifNil: [      	sourceWidget := HLBrowserSourceWidget on: self model ]! !HLBrowser class instanceVariableNames: 'nextId'!!HLBrowser class methodsFor: 'accessing'!nextId	nextId ifNil: [ nextId := 0 ].    ^ 'browser_', (nextId + 1) asString!tabLabel	^ 'Browser'!tabPriority	^ 0! !!HLBrowser class methodsFor: 'testing'!canBeOpenAsTab	^ true! !HLNavigationListWidget subclass: #HLBrowserListWidget instanceVariableNames: 'model' package: 'Helios-Browser'!!HLBrowserListWidget methodsFor: 'accessing'!model	^ model!model: aBrowserModel	model := aBrowserModel.        self observeModel! !!HLBrowserListWidget methodsFor: 'actions'!observeModel!observeSystem! !!HLBrowserListWidget methodsFor: 'initialization'!initialize	super initialize.        self observeSystem! !!HLBrowserListWidget class methodsFor: 'instance creation'!on: aModel	^ self new     	model: aModel;        yourself! !HLBrowserListWidget subclass: #HLClassesListWidget instanceVariableNames: '' package: 'Helios-Browser'!!HLClassesListWidget methodsFor: 'accessing'!getChildrenOf: aClass	^ self items select: [ :each | each superclass = aClass ]!getRootClassesOf: aCollection	^ aCollection select: [ :each |    		(aCollection includes: each superclass) not ]!iconForItem: aClass	^ aClass theNonMetaClass comment isEmpty    	ifFalse: [ 'icon-none' ]      	ifTrue: [ 'icon-question-sign' ]!showInstance	^ self model showInstance! !!HLClassesListWidget methodsFor: 'actions'!focusMethodsListWidget	self model announcer announce: HLMethodsListFocus new!focusProtocolsListWidget	self model announcer announce: HLProtocolsListFocus new!observeModel	self model announcer     	on: HLPackageSelected do: [ :ann | self onPackageSelected: ann item ];    	on: HLShowInstanceToggled do: [ :ann | self onShowInstanceToggled ];		on: HLClassSelected do: [ :ann | self onClassSelected: ann item ];		on: HLClassesFocusRequested do: [ :ann | self onClassesFocusRequested ]!observeSystem	SystemAnnouncer current    	on: ClassAdded        do: [ :ann | self onClassAdded: ann theClass ];        on: ClassRemoved        do: [ :ann | self onClassRemoved: ann theClass ]!selectItem: aClass    self model selectedClass: aClass!showInstance: aBoolean	self model showInstance: aBoolean! !!HLClassesListWidget methodsFor: 'private'!setItemsForPackage: aPackage	self items: (aPackage     	ifNil: [ #() ]  		ifNotNil: [ ((aPackage classes         	collect: [ :each | each theNonMetaClass ]) asSet asArray)             	sort: [:a :b | a name < b name ] ]).!setItemsForSelectedPackage	self setItemsForPackage: self model selectedPackage! !!HLClassesListWidget methodsFor: 'reactions'!onClassAdded: aClass	aClass package = self model selectedPackage ifFalse: [ ^ self ].        self setItemsForSelectedPackage.    self refresh!onClassRemoved: aClass	aClass package = self model selectedPackage ifFalse: [ ^ self ].    aClass = self model selectedClass ifTrue: [ self selectItem: nil ].        self setItemsForSelectedPackage.    self refresh!onClassSelected: aClass	self selectedItem: aClass.	aClass ifNil: [ ^ self ].        self focus!onClassesFocusRequested	self focus!onPackageSelected: aPackage    self selectedItem: nil.        self setItemsForSelectedPackage.    self refresh!onShowInstanceToggled	self refresh! !!HLClassesListWidget methodsFor: 'rendering'!renderButtonsOn: html	html div         class: 'btn-group';		at: 'data-toggle' put: 'buttons-radio';		with: [            	html button                 class: (String streamContents: [ :str |                	str nextPutAll: 'btn'.                    self showInstance ifTrue: [                     	str nextPutAll: ' active'] ]);  				with: 'Instance';                onClick: [ self showInstance: true ].  			html button  				class: (String streamContents: [ :str |                	str nextPutAll: 'btn'.                    self model showInstance ifFalse: [                     	str nextPutAll: ' active'] ]);  				with: 'Class';				onClick: [ self model showInstance: false ] ].                   	html button            	class: 'btn';            at: 'data-toggle' put: 'button';  			with: 'Comment'!renderItem: aClass level: anInteger on: html	| li |    	li := html li.    li    	at: 'list-data' put: (self items indexOf: aClass);    	class: (self cssClassForItem: aClass);        with: [         	html a            	with: [             		(html tag: 'i') class: (self iconForItem: aClass).  					self renderItemLabel: aClass level: anInteger on: html ];				onClick: [                  	self activateListItem: li asJQuery ] ].                        (self getChildrenOf: aClass) do: [ :each |    	self renderItem: each level: anInteger + 1 on: html ]!renderItem: aClass on: html	super renderItem: aClass on: html.    (self getChildrenOf: aClass) do: [ :each |    	self renderItem: each level: 1 on: html ]!renderItemLabel: aClass level: anInteger on: html	html span asJQuery html: (String streamContents: [ :str |		anInteger timesRepeat: [			str nextPutAll: '    '].			str nextPutAll: aClass name ])!renderItemLabel: aClass on: html	self renderItemLabel: aClass level: 0 on: html!renderListOn: html	(self getRootClassesOf: self items)    	do: [ :each | self renderItem: each on: html ]! !HLBrowserListWidget subclass: #HLMethodsListWidget instanceVariableNames: '' package: 'Helios-Browser'!!HLMethodsListWidget methodsFor: 'accessing'!allProtocol	^ self model allProtocol!iconForItem: aSelector	| override overriden method |        method := self methodForSelector: aSelector.    override := self isOverride: method.    overriden := self isOverridden: method.    	^ override    	ifTrue: [ overriden			ifTrue: [ 'icon-resize-vertical' ]			ifFalse: [ 'icon-arrow-up' ] ]		ifFalse: [			overriden			ifTrue: [ 'icon-arrow-down' ]			ifFalse: [ 'icon-none' ] ]!methodForSelector: aSelector	^ self model selectedClass    	methodDictionary at: aSelector!methodsInProtocol: aString	self model selectedClass ifNil: [ ^ #() ].    	^ aString = self allProtocol    	ifTrue: [ self model selectedClass methods ]      	ifFalse: [ self model selectedClass methodsInProtocol: aString ]!overrideSelectors	^ self selectorsCache     	at: 'override'        ifAbsentPut: [         	self model selectedClass allSuperclasses				inject: Set new into: [ :acc :each | acc addAll: each selectors; yourself ] ]!overridenSelectors	^ self selectorsCache     	at: 'overriden'        ifAbsentPut: [         	self model selectedClass allSubclasses				inject: Set new into: [ :acc :each | acc addAll: each selectors; yourself ] ]!selectorsCache	^ self class selectorsCache!selectorsInProtocol: aString	^ (self methodsInProtocol: aString)    	collect: [ :each | each selector ]! !!HLMethodsListWidget methodsFor: 'actions'!observeModel	self model announcer 		on: HLProtocolSelected 		do: [ :ann | self onProtocolSelected: ann item ];		on: HLShowInstanceToggled 		do: [ :ann | self onProtocolSelected: nil ];		on: HLMethodSelected 		do: [ :ann | self onMethodSelected: ann item ];		on: HLMethodsFocusRequested 		do: [ :ann | self onMethodsFocusRequested ]!observeSystem	SystemAnnouncer current     	on: MethodAdded         do: [ :ann | self onMethodAdded: ann method ];        on: MethodRemoved         do: [ :ann | self onMethodRemoved: ann method ]!selectItem: aSelector	aSelector ifNil: [ ^ self model selectedMethod: nil ].   	self model selectedMethod: (self methodForSelector: aSelector)! !!HLMethodsListWidget methodsFor: 'cache'!flushSelectorsCache	selectorsCache := Dictionary new! !!HLMethodsListWidget methodsFor: 'initialization'!initialize	super initialize.    self flushSelectorsCache! !!HLMethodsListWidget methodsFor: 'private'!setItemsForProtocol: aString	^ self items: (aString    	ifNil: [ #() ]      	ifNotNil: [ self selectorsInProtocol: aString ])!setItemsForSelectedProtocol	self setItemsForProtocol: self model selectedProtocol! !!HLMethodsListWidget methodsFor: 'reactions'!onMethodAdded: aMethod	self model selectedClass = aMethod methodClass ifFalse: [ ^ self ].        self setItemsForSelectedProtocol.    self refresh!onMethodRemoved: aMethod	self items detect: [ :each | each = aMethod selector ] ifNone: [ ^ self ].    self selectedItem ifNotNil: [      	(aMethod methodClass = self model selectedClass and: [ aMethod selector = self selectedItem selector ])  			ifTrue: [ self selectItem: nil ] ].    self setItemsForSelectedProtocol.self refresh!onMethodSelected: aMethod	self selectedItem: aMethod.	aMethod ifNil: [ ^ self ].        self focus!onMethodsFocusRequested	self focus!onProtocolSelected: aString    self selectedItem: nil.    	self setItemsForSelectedProtocol.    self refresh! !!HLMethodsListWidget methodsFor: 'rendering'!renderContentOn: html	self model showInstance    	ifFalse: [ html div         	class: 'class_side';             with: [ super renderContentOn: html ] ]      	ifTrue: [ super renderContentOn: html ]!renderItemLabel: aSelector on: html	html with: aSelector! !!HLMethodsListWidget methodsFor: 'testing'!isOverridden: aMethod   ^ self selectorsCache isOverridden: aMethod!isOverride: aMethod   ^ self selectorsCache isOverride: aMethod! !HLMethodsListWidget class instanceVariableNames: 'selectorsCache'!!HLMethodsListWidget class methodsFor: 'accessing'!selectorsCache	^ HLSelectorsCache current! !HLBrowserListWidget subclass: #HLPackagesListWidget instanceVariableNames: '' package: 'Helios-Browser'!!HLPackagesListWidget methodsFor: 'accessing'!initializeItems	^ items := self model packages sort:[:a :b|						a name < b name]!items	^ items ifNil: [self initializeItems]! !!HLPackagesListWidget methodsFor: 'actions'!focusClassesListWidget	self model announcer announce: HLClassesListFocus new!observeModel    self model announcer 		on: HLPackageSelected 		do: [ :ann | self onPackageSelected: ann item ];		on: HLPackagesFocusRequested 		do: [ :ann | self onPackagesFocusRequested ]!selectItem: aPackage	self model selectedPackage: aPackage! !!HLPackagesListWidget methodsFor: 'reactions'!onPackageSelected: aPackage	self selectedItem: aPackage.	self focus!onPackagesFocusRequested	self focus! !!HLPackagesListWidget methodsFor: 'rendering'!renderButtonsOn: html	html span class: 'info'; with: 'Auto commit'.	html div         class: 'btn-group switch';		at: 'data-toggle' put: 'buttons-radio';		with: [            	html button                 class: (String streamContents: [ :str |                	str nextPutAll: 'btn' ]);  				with: 'On'.  			html button  				class: (String streamContents: [ :str |                	str nextPutAll: 'btn active' ]);  				with: 'Off' ].                    html a          	class: 'btn';			with: 'Commit'.! !HLBrowserListWidget subclass: #HLProtocolsListWidget instanceVariableNames: '' package: 'Helios-Browser'!!HLProtocolsListWidget methodsFor: 'accessing'!allProtocol	^ self model allProtocol!selectedItem	^ super selectedItem" ifNil: [ self allProtocol ]"! !!HLProtocolsListWidget methodsFor: 'actions'!observeModel    self model announcer 		on: HLClassSelected 		do: [ :ann | self onClassSelected: ann item ];    	on: HLShowInstanceToggled 		do: [ :ann | self onClassSelected: self model selectedClass ];    	on: HLProtocolSelected		do: [ :ann | self onProtocolSelected: ann item ];		on: HLProtocolsFocusRequested 		do: [ :ann | self onProtocolsFocusRequested ]!observeSystem    SystemAnnouncer current    	on: ProtocolAdded         do: [ :ann | self onProtocolAdded: ann protocol to: ann theClass ];        on: ProtocolRemoved        do: [ :ann | self onProtocolRemoved: ann protocol from: ann theClass ]!selectItem: aString    self model selectedProtocol: aString! !!HLProtocolsListWidget methodsFor: 'private'!setItemsForClass: aClass	self items: (aClass    	ifNil: [ Array with: self allProtocol ]      	ifNotNil: [         	(Array with: self allProtocol)             	addAll: aClass protocols;                 yourself ])!setItemsForSelectedClass	self setItemsForClass: self model selectedClass! !!HLProtocolsListWidget methodsFor: 'reactions'!onClassSelected: aClass    self selectedItem: nil.        self setItemsForSelectedClass.    self refresh!onProtocolAdded: aString to: aClass	aClass = self model selectedClass ifFalse: [ ^ self ].        self setItemsForSelectedClass.    self refresh!onProtocolRemoved: aString from: aClass	aClass = self model selectedClass ifFalse: [ ^ self ].        self model selectedProtocol = aString     	ifTrue: [ self selectItem: nil ].            self setItemsForSelectedClass.    self refresh!onProtocolSelected: aString	self selectedItem: aString.	aString ifNil: [ ^ self ].        self focus!onProtocolsFocusRequested	self focus! !!HLProtocolsListWidget methodsFor: 'rendering'!renderContentOn: html	self model showInstance    	ifFalse: [ html div         	class: 'class_side';             with: [ super renderContentOn: html ] ]      	ifTrue: [ super renderContentOn: html ]! !Object subclass: #HLBrowserModel instanceVariableNames: 'announcer environment selectedPackage selectedClass selectedProtocol selectedSelector showInstance showComment' package: 'Helios-Browser'!!HLBrowserModel methodsFor: 'accessing'!announcer	^ announcer ifNil: [ announcer := Announcer new ]!environment	^ environment ifNil: [ HLManager current environment ]!environment: anEnvironment	environment := anEnvironment!packages	^ self environment packages!selectedClass	^ selectedClass!selectedClass: aClass	selectedClass = aClass ifTrue: [ 		aClass ifNil: [ ^ self ].		self selectedProtocol: nil ].    	aClass    		ifNil: [ selectedClass := nil ]    	ifNotNil: [			self showInstance    				ifTrue: [ selectedClass := aClass theNonMetaClass ]     			ifFalse: [ selectedClass := aClass theMetaClass ] ].	self selectedProtocol: nil.	self announcer announce: (HLClassSelected on: self selectedClass)!selectedMethod	^ self selectedClass ifNotNil: [ 			self selectedClass methodDictionary 				at: selectedSelector 				ifAbsent: [ nil ] ]!selectedMethod: aCompiledMethod	selectedSelector = aCompiledMethod ifTrue: [ ^ self ].        aCompiledMethod    	ifNil: [ selectedSelector := nil ]      	ifNotNil: [			selectedSelector = aCompiledMethod selector ifTrue: [ ^ self ].			selectedSelector := aCompiledMethod selector ].    self announcer announce: (HLMethodSelected on: aCompiledMethod)!selectedPackage	^ selectedPackage!selectedPackage: aPackage	selectedPackage = aPackage ifTrue: [ ^ self ].    	selectedPackage := aPackage.	self selectedClass: nil.    self announcer announce: (HLPackageSelected on: aPackage)!selectedProtocol	^ selectedProtocol!selectedProtocol: aString	selectedProtocol = aString ifTrue: [ ^ self ].    	selectedProtocol := aString.    self selectedMethod: nil.    self announcer announce: (HLProtocolSelected on: aString)!showComment	^ showComment ifNil: [ false ]!showComment: aBoolean	showComment := aBoolean.        self announcer announce: HLShowCommentToggled new!showInstance	^ showInstance ifNil: [ true ]!showInstance: aBoolean	showInstance := aBoolean.        self selectedClass ifNotNil: [    	self selectedClass: (aBoolean    		ifTrue: [self selectedClass theNonMetaClass ]    	  	ifFalse: [ self selectedClass theMetaClass ]) ].        self announcer announce: HLShowInstanceToggled new! !!HLBrowserModel methodsFor: 'actions'!addInstVarNamed: aString	self environment addInstVarNamed: aString to: self selectedClass.	self announcer announce: (HLInstVarAdded new		theClass: self selectedClass;		variableName: aString;		yourself)!focusOnClasses	self announcer announce: HLClassesFocusRequested new!focusOnMethods	self announcer announce: HLMethodsFocusRequested new!focusOnPackages	self announcer announce: HLPackagesFocusRequested new!focusOnProtocols	self announcer announce: HLProtocolsFocusRequested new!focusOnSourceCode	self announcer announce: HLSourceCodeFocusRequested new!save: aString	(self shouldCompileClassDefinition: aString)		ifTrue: [ self compileClassDefinition: aString ]		ifFalse: [ self compileMethod: aString ]!saveSourceCode	self announcer announce: HLSaveSourceCode new! !!HLBrowserModel methodsFor: 'commands actions'!moveMethodToClass: aClassName	console log: 'moveMethodToClass ', aClassName! !!HLBrowserModel methodsFor: 'compiling'!compileClassComment: aString	self environment 		compileClassComment: aString 		for: self selectedClass!compileClassDefinition: aString	self environment compileClassDefinition: aString!compileMethod: aString	self withCompileErrorHandling: [ self environment 		compileMethod: aString 		for: self selectedClass		protocol: self compilationProtocol ]! !!HLBrowserModel methodsFor: 'defaults'!allProtocol	^ '-- all --'!unclassifiedProtocol	^ 'as yet unclassified'! !!HLBrowserModel methodsFor: 'error handling'!handleCompileError: anError	self announcer announce: (HLCompileErrorRaised new		error: anError;		yourself)!handleParseError: anError	| split line column messageToInsert |		split := anError messageText tokenize: ' : '.	messageToInsert := split second.	"21 = 'Parse error on line ' size + 1"	split := split first copyFrom: 21 to: split first size.		split := split tokenize: ' column '.	line := split first.	column := split second.		self announcer announce: (HLParseErrorRaised new		line: line asNumber;		column: column asNumber;		message: messageToInsert;		error: anError;		yourself)!handleUnkownVariableError: anError	self announcer announce: (HLUnknownVariableErrorRaised new		error: anError;		yourself)!withCompileErrorHandling: aBlock	[		[			aBlock 				on: ParseError				do: [:ex | self handleParseError: ex ]		]			on: UnknownVariableError			do: [ :ex | self handleUnkownVariableError: ex ]	]		on: CompilerError		do: [ :ex | self handleCompileError: ex ]! !!HLBrowserModel methodsFor: 'private'!compilationProtocol	| currentProtocol |		currentProtocol := self selectedProtocol.	currentProtocol ifNil: [ currentProtocol := self unclassifiedProtocol ].	self selectedMethod ifNotNil: [ currentProtocol := self selectedMethod protocol ].	^ currentProtocol = self allProtocol		ifTrue: [ self unclassifiedProtocol ]		ifFalse: [ currentProtocol ]! !!HLBrowserModel methodsFor: 'testing'!shouldCompileClassDefinition: aString	^ self selectedClass isNil or: [		aString first asUppercase = aString first ]! !!HLBrowserModel class methodsFor: 'actions'!on: anEnvironment	^ self new    	environment: anEnvironment;        yourself! !HLWidget subclass: #HLBrowserSourceWidget instanceVariableNames: 'model methodContents codeWidget' package: 'Helios-Browser'!!HLBrowserSourceWidget methodsFor: 'accessing'!codeWidget	^ codeWidget ifNil: [ codeWidget := HLSourceCodeWidget on: self model ]!contents	^ self codeWidget contents!contents: aString	self methodContents: aString.	self codeWidget contents: aString!methodContents	^ methodContents ifNil: [ methodContents := '' ]!methodContents: aString	methodContents := aString!model	^ model!model: aBrowserModel	model := aBrowserModel.        self observeModel! !!HLBrowserSourceWidget methodsFor: 'actions'!focus	self codeWidget focus!observeModel	self model announcer 		on: HLMethodSelected 		do: [ :ann | self onMethodSelected: ann item ];    	on: HLClassSelected 		do: [ :ann | self onClassSelected: ann item ];    	on: HLProtocolSelected 		do: [ :ann | self onProtocolSelected: ann item ];		on: HLSourceCodeFocusRequested 		do: [ :ann | self onSourceCodeFocusRequested ]!observeSystem	SystemAnnouncer current    	on: MethodModified        do: [ :ann | self onMethodModified: ann method ]! !!HLBrowserSourceWidget methodsFor: 'initialization'!initialize	super initialize.        self observeSystem! !!HLBrowserSourceWidget methodsFor: 'reactions'!onClassSelected: aClass	aClass ifNil: [ ^ self contents: '' ].        self contents: aClass definition!onMethodModified: aMethod	self model selectedClass = aMethod methodClass ifFalse: [ ^ self ].	self model selectedMethod ifNil: [ ^ self ].    self model selectedMethod selector = aMethod selector ifFalse: [ ^ self ].    self refresh!onMethodSelected: aCompiledMethod	aCompiledMethod ifNil: [ ^ self contents: '' ].        self contents: aCompiledMethod source!onProtocolSelected: aString	self model selectedClass ifNil: [ ^ self contents: '' ].        self contents: self model selectedClass definition!onSourceCodeFocusRequested	self focus! !!HLBrowserSourceWidget methodsFor: 'rendering'!renderContentOn: html	self codeWidget renderOn: html! !!HLBrowserSourceWidget methodsFor: 'testing'!hasFocus	^ self codeWidget hasFocus!hasModification	^ (self methodContents = self contents) not! !!HLBrowserSourceWidget methodsFor: 'updating'!refresh	self hasModification ifTrue: [ ^ self ].    self hasFocus ifTrue: [ ^ self ].	self contents: self model selectedMethod source! !!HLBrowserSourceWidget class methodsFor: 'instance creation'!on: aBrowserModel	^ self new    	model: aBrowserModel;        yourself! !Object subclass: #HLClassCache instanceVariableNames: 'class selectorsCache overrideCache overriddenCache' package: 'Helios-Browser'!!HLClassCache methodsFor: 'accessing'!overriddenCache	^ overriddenCache ifNil: [ overriddenCache := HashedCollection new ]!overrideCache	^ overrideCache ifNil: [ overrideCache := HashedCollection new ]!selectorsCache	^ selectorsCache!selectorsCache: aCache	selectorsCache := aCache!theClass	^ class!theClass: aClass	class := aClass! !!HLClassCache methodsFor: 'actions'!invalidateChildrenSelector: aSelector	self theClass subclasses do: [ :each |    	(self selectorsCache cacheFor: each)        	removeSelector: aSelector;        	invalidateChildrenSelector: aSelector ]!invalidateParentSelector: aSelector	self theClass superclass ifNotNil: [    	(self selectorsCache cacheFor: self theClass superclass)        	removeSelector: aSelector;			invalidateParentSelector: aSelector ]!invalidateSelector: aSelector	self     	invalidateParentSelector: aSelector;        invalidateChildrenSelector: aSelector;        removeSelector: aSelector! !!HLClassCache methodsFor: 'private'!removeSelector: aSelector	self overriddenCache     	removeKey: aSelector        ifAbsent: [ ].    self overrideCache     	removeKey: aSelector        ifAbsent: [ ]! !!HLClassCache methodsFor: 'testing'!isOverridden: aMethod	^ self overriddenCache     	at: aMethod selector      	ifAbsentPut: [ aMethod isOverridden ]!isOverride: aMethod	^ self overrideCache    	at: aMethod selector      	ifAbsentPut: [ aMethod isOverride ]! !!HLClassCache class methodsFor: 'instance creation'!on: aClass selectorsCache: aSelectorsCache	^ self new    	theClass: aClass;        selectorsCache: aSelectorsCache;        yourself! !Object subclass: #HLSelectorsCache instanceVariableNames: 'classesCache' package: 'Helios-Browser'!!HLSelectorsCache methodsFor: 'accessing'!cacheFor: aClass	aClass ifNil: [ ^ nil ].    	^ self classesCache    	at: aClass name        ifAbsentPut: [ self newCacheFor: aClass ]!classesCache	^ classesCache ifNil: [ classesCache := HashedCollection new ]! !!HLSelectorsCache methodsFor: 'actions'!observeSystem	SystemAnnouncer current		on: MethodAdded        do: [ :ann | self onMethodAdded: ann method ];        on: MethodRemoved        do: [ :ann | self onMethodRemoved: ann method ]! !!HLSelectorsCache methodsFor: 'factory'!newCacheFor: aClass	^ HLClassCache     	on: aClass        selectorsCache: self! !!HLSelectorsCache methodsFor: 'initialization'!initialize	super initialize.    self observeSystem! !!HLSelectorsCache methodsFor: 'private'!invalidateCacheFor: aMethod	(self cacheFor: aMethod methodClass)    	invalidateSelector: aMethod selector! !!HLSelectorsCache methodsFor: 'reactions'!onMethodAdded: aMethod	self invalidateCacheFor: aMethod!onMethodRemoved: aMethod	self invalidateCacheFor: aMethod! !!HLSelectorsCache methodsFor: 'testing'!isOverridden: aMethod	^ (self cacheFor: aMethod methodClass)    	isOverridden: aMethod!isOverride: aMethod	^ (self cacheFor: aMethod methodClass)    	isOverride: aMethod! !HLSelectorsCache class instanceVariableNames: 'current'!!HLSelectorsCache class methodsFor: 'accessing'!current	^ current ifNil: [ current := super new ]!flush	current := nil! !!HLSelectorsCache class methodsFor: 'instance creation'!new	self shouldNotImplement! !!CompiledMethod methodsFor: '*Helios-Browser'!isOverridden	| selector |        selector := self selector.    self methodClass allSubclassesDo: [ :each |	    (each includesSelector: selector)        	ifTrue: [ ^ true ] ].	^ false!isOverride	| superclass |        superclass := self methodClass superclass.	superclass ifNil: [ ^ false ].	    ^ (self methodClass superclass lookupSelector: self selector) notNil! !
 |