2014-05-06 1:17 GMT+02:00 Carlo <snoob...@gmail.com>: > Hi > > The problem seems to be due to the use of an internal collection class of > OrderedCollection which has restrictions on use of #at:put:. This means > that certain methods will have to delegate to the internal collection class > to be ’safe’; in this scenario it is the XMLOrderedList > >>copyReplaceFrom:to:with: > > I don’t have write access to the > http://www.smalltalkhub.com/#!/~PharoExtras/XMLParser/ project but here > is a unit test and code change that seems to work. > > Cheers > Carlo > > XMLOrderedListTest>>testConcatenation > | anXmlOrderedList expectedConcatenationResult | > expectedConcatenationResult := XMLOrderedList new add: '1'; yourself. > self > shouldnt: [ anXmlOrderedList := expectedConcatenationResult , > XMLOrderedList new ] > raise: SubscriptOutOfBounds > description: > 'Expect that concatenation does not fail even though internal collection > class of XMLOrderedList is an OrderedCollection. See comment for > XMLOrderedList>>copyReplaceFrom:to:with:'. > self assert: anXmlOrderedList equals: expectedConcatenationResult. > > > XMLOrderedList >>copyReplaceFrom: start to: stop with: > replacementCollection > "Delegate to my internal collection class as it may restrict copying and > replacing. > See comment for OrderedCollection>>copyReplaceFrom:to:with: and > OrderedCollection>>at:put:" > > ^ self collection copyReplaceFrom: start to: stop with: > replacementCollection > >
But the test fails :) XMLOrderedList >>copyReplaceFrom: start to: stop with: replacementCollection should return self, not the collection. XMLOrderedList >>copyReplaceFrom: start to: stop with: replacementCollection "Delegate to my internal collection class as it may restrict copying and replacing. See comment for OrderedCollection>>copyReplaceFrom:to:with: and OrderedCollection>>at:put:" self collection copyReplaceFrom: start to: stop with: replacementCollection. > > On 05 May 2014, at 7:13 PM, Ben Coman <b...@openinworld.com> wrote: > > > Thanks. That info made it much easier to try. Sorry I didn't end up with > an answer for you, but I confirm there is some issue here, or something new > I can learn when other chip in. > > Here is what I tried. > > * Installed XMLParser (monty.58) from Configuration Browser in Pharo 3. > > * Ran your code. Got the same error. > > * From the call stack I observed that > XMLOrderedCollection(SequenceableCollection)>>copyReplaceFrom:to:with: > has the line "newSequenceableCollection := self species new: newSize." > such that it seems your error might be reduced to the question of why the > following two snippets fail: > d := OrderedCollection new: 1. > d at: 1 put: 1. > > e := OrderedCollection new: 3. > e at: 2 put: 1. > > However I'm sorry that is beyond my knowledge, and I'm hoping someone else > can chip in so I can learn something. > > Pushing on, I noticed that XMLOrderedList has an instance variable > /collection/ which holds the OrderedCollection. > > Now I wonder (without great experience and hoping to learn something) if > it smells funny that XMLOrderedList inherits all of SequencableCollection > methods that can not operate on /collection/. > > I noticed that XMLOrderedList was using an inherited > SequenceableCollection>>copyReplaceFrom:to:with > while OrderedCollection overrode that method with its own. So taking > inspiration XMLOrderedList>>copyFrom:to: to override > SequencableCollection>>copyReplaceFrom:to:with: to work with /collection/ > seems to solve your problem: > XMLOrderedList>>copyReplaceFrom: start to: stop with: > replacementCollection > ^ self newWithCollection: > (collection copyReplaceFrom: start to: stop with: > replacementCollection ) > > > Along the way I noticed a few (possible) bugs that seems not related to > your problem: > > * When stepping through XMLOrderedList>>setCollection: > there is a red-box-of-death for the instance variables, which can be > solved by defining the following. > XMLOrderedList>>size > ^ collection ifNil: [ 0 ] ifNotNil: [ collection size] > > * In the debugger the /collection/ instance variable is not shown! (e.g. > line XMLOrderedList>>at:put:). > Can someone confirm this should show? > > HTH > cheers -ben > > Thushar G R wrote: > > XMLOrderedList belongs to package XML-Parser-Nodes. > > a := XMLOrderedList new. > a add:'1'. > a , XMLOrderedList new. > > Here select all and Do it. On line 3 (a , XMLOrderedList new.) i am > expected to get a copy of 'a' , but instead it throws an error > SubscriptOutOfBounds. > > > > > OrderedCollection(Object)>>errorSubscriptBounds: > OrderedCollection>>ensureBoundsFrom:to: > OrderedCollection>>at:put: > OrderedCollection(SequenceableCollection)>>replaceFrom:to:with:startingAt: > XMLOrderedList>>replaceFrom:to:with:startingAt: > XMLOrderedList(SequenceableCollection)>>copyReplaceFrom:to:with: > XMLOrderedList(SequenceableCollection)>>, > UndefinedObject>>DoIt > OpalCompiler>>evaluate > SmalltalkEditor>>evaluateSelectionAndDo: > PluggableTextMorph>>inspectIt in Block: [ textMorph editor > evaluateSelectionAndDo: [ :resu...etc... > PluggableTextMorph>>handleEdit: in Block: [ result := editBlock value ] > TextMorphForEditView(TextMorph)>>handleEdit: > PluggableTextMorph>>handleEdit: > PluggableTextMorph>>inspectIt > SmalltalkEditor class>>buildSmalltalkEditorKeymappingsOn: in Block: [ > :morph | morph inspectIt ] > BlockClosure>>cull: > BlockClosure>>cull:cull: > BlockClosure>>cull:cull:cull: > KMCategoryBinding>>completeMatch:buffer: > KMKeymap>>notifyCompleteMatchTo:buffer: in Block: [ :l | l completeMatch: > self buffer: aBuffer ] > Array(SequenceableCollection)>>do: > KMKeymap>>notifyCompleteMatchTo:buffer: > KMKeymap>>onMatchWith:notify:andDo: > KMCategory>>onMatchWith:notify:andDo: in Block: [ :entry | entry > onMatchWith: anEventBuffer notify...etc... > Set>>do: > KMCategory>>onMatchWith:notify:andDo: > KMCategoryBinding>>verifyMatchWith:notifying:thenDoing: > KMDispatcher>>dispatch: in Block: [ :aTarget | ... > OrderedCollection>>do: > > > Plese refer to the above stack. > > Thanks in advance. > > thushar > > > On Mon, May 5, 2014 at 6:28 PM, Ben Coman <b...@openinworld.com> wrote: > >> Thushar G R wrote: >> >>> Hi, >>> >>> I am getting an error while doing this. >>> >>> a := XMLOrderedList new. >>> a add:'1'. >>> a , XMLOrderedList new. >>> >>> Thanks, >>> >>> Thushar >>> >> I could give you "an answer" ;) - but it would be what you wanted. It >> would help if you told what the error was, where it occurs (which of the >> three lines), and what you expect each line is doing (especially the third >> line). >> >> Also I don't see XMLOrderedList in the default Pharo image, so it would >> help if you describe where you got that from and how you installed it. >> >> cheers -ben >> >> > > >