Project

General

Profile

Testasd » History » Version 65

Per Amundsen, 02/08/2023 09:40 AM

1 45 Per Amundsen
h1. Multidimensional arrays
2
3 62 Per Amundsen
*/marray -aTNBAV <name> [N..] <item> <value>*
4
*/marray -eTNBAV <name> [N..] <N> <item> <value>*
5 1 Per Amundsen
*/marray -iTNBAV <name> [N..] <N> <item> <value>*
6
*/marray -d <name> [N..] <N>*
7 54 Per Amundsen
*/marray -f <name>*
8
9 65 Per Amundsen
*Parameters*
10
11
<name> - Name of the table to modify.
12
[N..] - Indicates the item should be added/inserted/deleted from sub table position N, subsequent N parameters travels further down.
13
<N> - The Nth item in a table or sub table to modify.
14
<item> - The item name.
15
<value> - The item value.
16
17 45 Per Amundsen
*Switches*
18
19 64 Per Amundsen
-a - Add a new item to a table.
20
-e - Edit a item in a table.
21
-i - Insert a new item to a table.
22
-d - Delete a item from a table.
23
-f - Free/delete a table.
24 62 Per Amundsen
-T - Indicates the type is text.
25
-N - Indicates the type is a number.
26
-B - Indicates the type is a boolean.
27
-A - Indicates the type is a sub table/array.
28
-V - TODO Indicates the type is a binvar..
29
30 50 Per Amundsen
*$marray(name, N, [N..])*
31 1 Per Amundsen
32 45 Per Amundsen
gets the Nth item in a table, subsequent N parameters gets the Nth item from a sub table, infinite sub depth.
33
34 1 Per Amundsen
*Switches*
35 49 Per Amundsen
36 60 Per Amundsen
.item - Get item.
37 55 Per Amundsen
.value - Get item value.
38 62 Per Amundsen
.type - Get item type. (0 = text, 1 = number, 2 = bool, 3 = binvar, 4 = sub table)
39 55 Per Amundsen
.json - Generate a json table from all items in the current table and all sub tables.
40
.ini - Generate a ini output from all items in the current table and all sub tables.
41 63 Per Amundsen
.xml - Generate a xml output from all items in the current table and all sub tables.
42 1 Per Amundsen
43
*Example*
44 56 Per Amundsen
45 1 Per Amundsen
<pre>
46 56 Per Amundsen
; Add item1/value1 to the table 'table1'.
47 62 Per Amundsen
//marray -a table1 item1 value1
48 56 Per Amundsen
49 62 Per Amundsen
; Add sub table 'item2' to the table 'table1'.
50
//marray -aA table1 item2 value2
51 57 Per Amundsen
52 55 Per Amundsen
; Insert item3/value3 at position '1' in the table 'table1'.
53 62 Per Amundsen
//marray -i table1 1 item3 value3
54 55 Per Amundsen
55
; Print number of items in table 'table1'.
56
//echo -ag Number of items in table1 is $marray(table1, 0)
57
58
; Print the first items in table 'table1'.
59 1 Per Amundsen
//echo -ag First item in table1 is $marray(table1, 1).item
60 55 Per Amundsen
61 1 Per Amundsen
; Delete the first item in table 'table1'.
62 55 Per Amundsen
//marray -d table1 1
63
64
; Free the table 'table1'.
65
//marray -f table1
66
67
; Add a new sub table to table 'table1',
68 62 Per Amundsen
//marray -aA table1 sub1 sub1
69 55 Per Amundsen
70 56 Per Amundsen
; Add a new item to the sub table located at position '1' in table 'table1'.
71 62 Per Amundsen
//marray -a table1 1 item1 value1
72 55 Per Amundsen
73
; Print the first item in the table 'table1', which is a sub table.
74
//echo -ag First item in table1 is $marray(table1, 1).item - $marray(table1, 1).type
75
76
; Print the first item in the sub table located at position '1' in table 'table1'.
77
//echo -ag First item in sub table1 is $marray(table1, 1, 1).item
78 63 Per Amundsen
79
; Generates a json output of table 'table1'.
80
// echo -ag $marray(table1).json
81
82
; Generates a ini output of table 'table1'.
83
// echo -ag $marray(table1).ini
84
85
; Generates a xml output of sub at position '1' in table 'table1'.
86
// echo -ag $marray(table1, 1).xml
87 1 Per Amundsen
</pre>