linked lists
BlitzMax Forums/BlitzMax Beginners Area/linked lists
| ||
| Silly question (searched high and low and can't find anything), but does the built in linked list library have a way of getting the first and/or last member of the list? Something like myList:TList = new Tlist listAddLast myList, "one" listAddLast myList, "two" listAddLast myList, "three" ' I want to do something like a$ = myList.first ' ie get the first member in the list 'or a$ = myList.last ' ie get the first member in the list I am trying to avoid stepping through the whole list with EachIn just to get the last member. thanks, Richard. |
| ||
| ahem! nothing to see here, move along. |
| ||
| Oi! I told you to move along! So do it dammit! |
| ||
| Umm TList.First() TList.Last() |
| ||
| oops :) I skimmed the source twice and missed them both times :) |
| ||
| Thanks Bot - just what I was after - couldn't find it in the docs anywhere. Richard. PS What about "tList.next()" and "tList.prev()"? |
| ||
| Now that *would* require you to extend the type (or manually access the _pred and _succ properties of the Link). |
| ||
| No extension needed, just usage of OO is needed as the none OO part does not contain this functionality ( which is why it isn't mentioned in the docs ) |
| ||
| How could the Prevlink and Nextlink methods be used? I still struggle with converting tlinks into something tangible. |
| ||
| with a TLink, you can typecast the _value field. i.e. string(myTLink._value) for string |
| ||
| Can you please elaborate - how can I get the next/prev member of the tList. many thanks, Richard. |
| ||
Local myList:TList = New TList
myList.AddLast("test1")
myList.AddLast("test2")
myList.AddLast("test3")
myList.AddLast("test4")
myList.AddLast("test5")
Local current:TLink = myList.FirstLink()
Print String(current._value)
current = current._succ
While current <> myList._head
Print String(current._value)
current = current._succ
Wend
|
| ||
| Great! - many thanks, Richard |