Graham Samuel wrote:

> Well, Richard, I am always very willing to believe that I’ve
> misunderstood something, but this is what happened (this material is
> extracted from conversations I had on this list in the middle of
> March).
>
> 1. I had an XML file - it was actually a .gpx file, which shows a
> geographical route as a series of waypoints. The ‘top level’ of
> this structure is ‘gpx’. I mean the first three lines are (watch
> for wordwrap):
>
> <?xml version="1.0" encoding="UTF-8"?>
> <gpx xmlns="http://www.topografix.com/GPX/1/1"; creator="Geolives"
> version="1.1" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance";
> xsi:schemaLocation="http://www.topografix.com/GPX/1/1
> http://www.topografix.com/GPX/1/1/gpx.xsd";>
>   <metadata />
>   <trk>
>
> 2. I converted it to an array using the function ConvertXMLToArray,
> by Trevor deVore - from Mike Doub’s Master Library.
>
> 3. I put the result into an array called ‘gGeneralArray’ - I can see
> this in the IDE as a nested structure.
>
> 4. I executed
>
>   put the keys of gGeneralArray
>
> in the message box, and got the result
>
>  gpx
>
> 5. I discussed this on the use-list, and Mike Bonner suggested
>
>> try
>> put the keys of gGeneralArray["gpx”]
>> and you'll get the next level of keys.
>
> 6. I did that and got
>
> wpt[1]
> trk
> @attributes
> wpt[4]
> wpt[2]
> metadata
> wpt[3]
>
> I just did this all again to prove to myself that I hadn’t made an
> obvious error.I am definitely only dealing with one array, so I can’t
> explain this, and the LC dictionary certainly doesn’t help.
>
> Tell me where I went wrong!

You're using other people's code so you're off the hook. :)

There does appear to be a problem there, but I'm not sure it's with LiveCode, and even with the oddities in that example the "keys" function appears to be working as designed.

The "keys" should return a list of all keys, even when the value of any of them may be another array.

This is consistent with what you found: your array gGeneralArray contain one element, and that element is another array. You can also query the keys for the sub-array and obtain its keys, as you did.

Consider this much simpler example in which we have three keys, two of which have values that are not arrays and one of which has an array for its value:

on mouseUp
   put "1" into tA[1]
   put "2.1" into tA[2][1]
   put "2.2" into tA[2][2]
   put 3 into tA[3]
   put the keys of tA
end mouseUp

In my Message Box I get:

3
1
2

...showing that all keys are accounted for, even tA[2] where the value is another array.

So while the "keys" function seems to be fine here, your example above has other interesting factors that make it somewhat curious, no doubt contributing to the confusion here:

Nothing in the XML shown contains any of the elements shown in the sub-array keys listing, so it's not possible to see how it was parsed given what we have here.

Moreover, some of those sub-array keys appear to contain array notation in in the name itself, which may be valid but is unusual and potentially confusing.

Key names are pretty flexible, even more than the Dictionary entry recommends, allowing (IIRC) pretty much any character other than NULLs (and in v7 perhaps even NULLs are allowed).

So using "[" and "]" is as valid as part of a key name as any other characters, but stylistically the choice is confusing, and unlikely the actual name of the element as expressed in the source XML.

To figure out how you got the output you did I'd have to put together a test stack after gathering up the relevant handlers from Master Library, and given Trevor's characteristically excellent coding I'm sure the final analysis would make sense of that example.

But for the moment, I think the key lesson here (if you'll pardon the pun) is that sometimes stumbling across edge cases like this one can lead one to think features are more intimidating or confusing than they need to me.

Arrays in LiveCode are fairly straightforward name-value pairs, and there's not even very much we can do with them: put, get, delete, and obtain the keys. That's pretty much it.

If we stumble across an extremely uncommon case like the one you had the misfortune to discover above, it may seem much more complicated than it really is.

This is why I recommend experimentation on one's own to learn a specific feature, like arrays. Get the basic operations down in an hour experimenting on a throwaway stack, and then even confusing edge cases like this one will become less daunting.

--
 Richard Gaskin
 Fourth World Systems
 Software Design and Development for the Desktop, Mobile, and the Web
 ____________________________________________________________________
 ambassa...@fourthworld.com                http://www.FourthWorld.com

_______________________________________________
use-livecode mailing list
use-livecode@lists.runrev.com
Please visit this url to subscribe, unsubscribe and manage your subscription 
preferences:
http://lists.runrev.com/mailman/listinfo/use-livecode

Reply via email to