An array is a group of variables, all having the same name. You can use an element of an array any place you would use a variable. Each element of this array has a key. The key is a string or a number. To access any particular element of the array, the name of the array and its key must be given.
For example, to create an element of an array:
put "Hello world" into myArr -- myArr = "Hello world" put "Example" into myArr["test"] -- myArr["test"] = "Example" put myArr["test"] && myArr into myArr -- myArr = Example Hello world"
Please note that arrays are not numerically indexed, so myArr["1"] = myArr. And also myArr[temp] = myArr["temp"], if temp is still not an assigned variable.
You can create multidimensional arrays indicating more than one key, look at the following example:
put "Position 1,1" into maxDim[1,1] put "Position 1,2" into maxDim[1,2] put "Position 2,1" into maxDim[2,1] put "Position 2,2" into maxDim[2,2]
A single dimensional array is known as a linear array. A two-dimensional can be thought of as a linear array of linear arrays. In other words, the following is equivalent to that above.
put "Position 1,1" into maxDim put "Position 1,2" into maxDim put "Position 2,1" into maxDim put "Position 2,2" into maxDim
There is no limit to the number of dimensions for the array. However, when you create some elements of an array, then create some additional elements of that same array with a higher dimension, the previous elements are replaced with the elements of the higher dimension. For example:
put "Hello" into myArr put "Bye" into myArr[1,2] -- here the "Hello" doesn't exist anymore
In the previous example myArr becomes the content of the array , this is useful in recursive operation on arrays, because you may pass just the second (or more) level of an array as a new array.
You can delete or or get rid of an element of the array. Once deleted, you can't recover its value or key.
delete variable myCircuit["test"] - the element myCircuit["test"] no longer exists
If you empty an element, the element remains in the array, but has no value.
put empty into myWire["test"] -- the element myWire["test"] = empty
You can delete an entire array with empty, both keys and values will be deleted:
put empty into myMax -- the array myMax = empty
In order to empty a complex array, use this:
function emptyArray tarr repeat for each key tKey in tArr put empty into tArr2[tKey] put emptyArray(tArr[tkey]) into tArr2[tkey] end repeat return tArr2 end emptyArray
You can obtain the list of the keys with the keys keyword:
put the keys of myArray into allMyKeys
Note that the above will only work for a single dimension of keys, it doesn't recover all subkeys. Look over the following example:
#let's create a matrix 2x3 put "Position 1,1" into myArr put "Position 1,2" into myArr put "Position 1,3" into myArr put "Position 2,1" into myArr put "Position 2,2" into myArr put "Position 2,3" into myArr put the keys of myArr #this obtain just 1 and 2 put the keys of myArr #this obtain 1, 2 and 3 put the keys of myArr #this obtain 1, 2 and 3
Suppose you have a variable containing a string. You can transform that variable into an array of the same name. Just use the split command. The split command needs to know how you want to transform the string, so you have to declare how to read the data. Look over the following examples:
First let's create a big string and then look at different versions of the split command:
put "Max Red, CEO" & return & "Clark Blue, VIP" & return & "Chuck Green, STAR" into myRat /* myRat = Max Red, CEO Clark Blue, VIP Chuck Green, STAR */
split myRat by comma /* myRat = Max Red myRat = CEO Clark Blue myRat = VIP Chuck Green myRat = STAR */
split myRat by return and comma /* myRat["Max Red"] = CEO myRat["Clark Blue"] = VIP myRat["Chuck Green"] = STAR */
split myVar by row /* myRat = Max Red, CEO myRat = Clark Blue, VIP myRat = Chuck Green, STAR */
Sometimes values in a list are separated by TAB chars.
put "First day" & TAB & "Second hour" & TAB & "Third minuet" into myCat
split myCat by column /* myCat = First day myCat[2} = Second hour myCat = Third minuet */
The Combine command does the opposite. It will convert an array into a list, provided that the keys are numbers. Any of the 4 above examples could be converted back into a list variable with the Combine command.
Arrays can't be visualized by LiveCode on the screen, only a list can be visualized. The debugger shows the array in a tree style, this is in the variables section when the program is stopped for errors.
You can save an array in a file using arrayDecode. This function coverts array to a binary format that LiveCode can export. The arrayEncode does the opposite. It will convert a binary format into an array so that LiveCode can import. See http://lessons.runrev.com/s/lessons/m/4071/l/9597-how-do-i-store-an-array-in-a-text-file-and-then-retrieve-it-again
list of arrays (default) (please help us to finish this)