Template repo for tiny cross-platform apps that can be modified on phone, tablet or computer.
1{
2 {type='rows', default={font={size=21}, line_height=25},
3 {type='text', font={size=28}, line_height=50,
4 {'Lua@{Lua} > tablas',
5 attrs={
6 Lua={target='--lua'},
7 }},
8 },
9 {type='filler', height=15},
10 {type='text', "Las tablas de Lua son una forma versátil de agrupar datos de maneras que facilitan cortarlos y dividirlos."},
11 {type='filler', height=15},
12 {type='text', '{} es un valor/expresión de tabla vacía.'},
13 {type='filler', height=10},
14 {type='text',
15 {'h = {11, 12, 13} crea un em@{arreglo}, una tabla que puede consultarse por em@{claves} numéricas.',
16 attrs={
17 em={font={italic=true}}}}},
18 {type='text', ' h[1] es ahora 11, h[2] es 12 y así sucesivamente.'},
19 {type='filler', height=10},
20 {type='text', 'h = {a=34} crea una tabla que puede consultarse por claves de cadena.'},
21 {type='text', " h['a'] es ahora 34, h['b'] es 35."},
22 {type='text', ' También puedes acortar claves de cadena constantes usando puntos. h.a es 34, h.b es 35.'},
23 {type='filler', height=10},
24 {type='text', 'si h es un arreglo. #h es una expresión que devuelve la longitud de h'},
25 {type='text', " Las claves de cadena no cuentan hacia la longitud de un arreglo."},
26 {type='text', ' Los arreglos también se detienen en la primera ranura faltante/nil. La longitud de {1, 2, nil, 4} es 2.'},
27 {type='filler', height=15},
28 {type='text', 'Algunas funciones útiles que operan en tablas:', font_size=28},
29 {type='filler', height=15},
30 {type='text', 'pairs(h)', font={size=24}},
31 {type='text',
32 {' Devuelve un em@{iterador}, un tipo de función, que te permite recorrer convenientemente todas las claves de una tabla.',
33 attrs={
34 em={font={italic=true}}}}},
35 {type='text', ' Por ejemplo, este programa imprimirá el contenido de una tabla: for key, value in pairs(h) do print(key, value) end'},
36 {type='filler', height=15},
37 {type='text', 'Algunas funciones útiles que operan en arreglos:', font_size=28},
38 {type='filler', height=15},
39 {type='text', 'ipairs(h)', font={size=24}},
40 {type='text', " Devuelve un iterador que te permite recorrer convenientemente índices y elementos de un arreglo."},
41 {type='text', ' Por ejemplo, este programa imprimirá el contenido de un arreglo: for _, x in ipairs(h) do print(x) end'},
42 {type='filler', height=10},
43 {type='text', 'table.insert(h, value)', font={size=24}},
44 {type='text', ' Añade un valor al final del arreglo h.'},
45 {type='filler', height=10},
46 {type='text', 'table.insert(h, index, value)', font={size=24}},
47 {type='text', ' Inserta un valor en el índice en el medio del arreglo h.'},
48 {type='filler', height=10},
49 {type='text', 'table.remove(h)', font={size=24}},
50 {type='text', ' Remueve el valor en el índice final del arreglo h.'},
51 {type='filler', height=10},
52 {type='text', 'table.remove(h, index)', font={size=24}},
53 {type='text', ' Remueve el valor en el índice en el medio del arreglo h, compactando los valores posteriores hacia arriba.'},
54 {type='filler', height=10},
55 {type='text', 'table.sort(h)', font={size=24}},
56 {type='text', ' Ordena los elementos en el arreglo h.'},
57 {type='filler', height=10},
58 {type='text', 'table.sort(h, f)', font={size=24}},
59 {type='text', ' Ordena los elementos en el arreglo h por una función de comparación personalizada f.'},
60 {type='text', ' f necesita aceptar 2 argumentos y devolver true si el primero es menor que el segundo.'},
61 {type='filler', height=10},
62 {type='text', 'table.reverse(h)', font={size=24}},
63 {type='text', ' Invierte el orden de los elementos del arreglo h para que el elemento final se convierta en el primero, etc.'},
64 {type='filler', height=10},
65 {type='text', 'table.concat(h)', font={size=24}},
66 {type='text', ' Concatena todos los elementos del arreglo h en una sola cadena y la devuelve.'},
67 {type='text', ' Todos los elementos deben ser cadenas.'},
68 }
69}