@designliquido/delegua 0.34.3 → 0.35.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,319 +1,499 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.tupla = exports.todosEmCondicao = exports.texto = exports.tamanho = exports.reduzir = exports.real = exports.primeiroEmCondicao = exports.paraCada = exports.ordenar = exports.mapear = exports.inteiro = exports.incluido = exports.filtrarPor = exports.encontrarUltimoIndice = exports.encontrarUltimo = exports.encontrarIndice = exports.encontrar = exports.algum = exports.aleatorioEntre = exports.aleatorio = void 0;
3
4
  const excecoes_1 = require("../excecoes");
4
5
  const objeto_delegua_classe_1 = require("../estruturas/objeto-delegua-classe");
5
6
  const funcao_padrao_1 = require("../estruturas/funcao-padrao");
6
7
  const delegua_classe_1 = require("../estruturas/delegua-classe");
7
8
  const estruturas_1 = require("../estruturas");
8
- function default_1(interpretador, pilhaEscoposExecucao) {
9
- const todosEmCondicao = async function (vetor, funcaoCondicional) {
10
- if (vetor === null || vetor === undefined)
11
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função todosEmCondicao() não pode ser nulo.'));
12
- const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
13
- const valorFuncaoCondicional = funcaoCondicional.hasOwnProperty('valor')
14
- ? funcaoCondicional.valor
15
- : funcaoCondicional;
16
- if (!Array.isArray(valorVetor)) {
17
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função todosEmCondicao() deve ser um vetor.'));
18
- }
19
- if (valorFuncaoCondicional.constructor.name !== 'DeleguaFuncao') {
20
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função todosEmCondicao() deve ser uma função.'));
21
- }
22
- for (let indice = 0; indice < valorVetor.length; ++indice) {
23
- if (!(await valorFuncaoCondicional.chamar(interpretador, [valorVetor[indice]])))
24
- return false;
25
- }
26
- return true;
27
- };
28
- // Retorna um número aleatório entre 0 e 1.
29
- pilhaEscoposExecucao.definirVariavel('aleatorio', new funcao_padrao_1.FuncaoPadrao(1, function () {
30
- return Math.random();
31
- }));
32
- // Retorna um número aleatório de acordo com o parâmetro passado.
33
- // Mínimo(inclusivo) - Máximo(exclusivo)
34
- pilhaEscoposExecucao.definirVariavel('aleatorioEntre', new funcao_padrao_1.FuncaoPadrao(1, async function (minimo, maximo) {
35
- // eslint-disable-next-line prefer-rest-params
36
- if (arguments.length <= 0) {
37
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'A função recebe ao menos um parâmetro.'));
38
- }
39
- const valorMinimo = minimo.hasOwnProperty('valor') ? minimo.valor : minimo;
40
- if (arguments.length === 1) {
41
- if (typeof valorMinimo !== 'number') {
42
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'O parâmetro deve ser um número.'));
43
- }
44
- return Math.floor(Math.random() * (0 - valorMinimo)) + valorMinimo;
45
- }
46
- if (arguments.length > 2) {
47
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'A quantidade de parâmetros máxima para esta função é 2.'));
48
- }
49
- const valorMaximo = maximo.hasOwnProperty('valor') ? maximo.valor : maximo;
50
- if (typeof valorMinimo !== 'number' || typeof valorMaximo !== 'number') {
51
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Os dois parâmetros devem ser do tipo número.'));
52
- }
53
- return Promise.resolve(Math.floor(Math.random() * (valorMaximo - valorMinimo)) + valorMinimo);
54
- }));
55
- pilhaEscoposExecucao.definirVariavel('algum', new funcao_padrao_1.FuncaoPadrao(2, async function (vetor, funcaoPesquisa) {
56
- const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
57
- const valorFuncaoPesquisa = funcaoPesquisa.hasOwnProperty('valor') ? funcaoPesquisa.valor : funcaoPesquisa;
58
- if (!Array.isArray(valorVetor)) {
59
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
60
- }
61
- if (valorFuncaoPesquisa.constructor.name !== 'DeleguaFuncao') {
62
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função deve ser uma função.'));
63
- }
64
- for (let indice = 0; indice < valorVetor.length; ++indice) {
65
- if (await valorFuncaoPesquisa.chamar(interpretador, [valorVetor[indice]])) {
66
- return true;
67
- }
68
- }
69
- return false;
70
- }));
71
- pilhaEscoposExecucao.definirVariavel('encontrar', new funcao_padrao_1.FuncaoPadrao(1, async function (vetor, funcaoPesquisa) {
72
- const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
73
- const valorFuncaoPesquisa = funcaoPesquisa.hasOwnProperty('valor') ? funcaoPesquisa.valor : funcaoPesquisa;
74
- if (!Array.isArray(valorVetor)) {
75
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
76
- }
77
- if (valorFuncaoPesquisa.constructor.name !== 'DeleguaFuncao') {
78
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função deve ser uma função.'));
79
- }
80
- for (let indice = 0; indice < valorVetor.length; ++indice) {
81
- if (await valorFuncaoPesquisa.chamar(interpretador, [valorVetor[indice]])) {
82
- return valorVetor[indice];
83
- }
84
- }
85
- return null;
86
- }));
87
- pilhaEscoposExecucao.definirVariavel('encontrarUltimo', new funcao_padrao_1.FuncaoPadrao(1, async function (vetor, funcaoPesquisa) {
88
- const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
89
- const valorFuncaoPesquisa = funcaoPesquisa.hasOwnProperty('valor') ? funcaoPesquisa.valor : funcaoPesquisa;
90
- if (!Array.isArray(valorVetor)) {
91
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
92
- }
93
- if (valorFuncaoPesquisa.constructor.name !== 'DeleguaFuncao') {
94
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função deve ser uma função.'));
95
- }
96
- for (let indice = valorVetor.length - 1; indice >= 0; --indice) {
97
- if (await valorFuncaoPesquisa.chamar(interpretador, [valorVetor[indice]])) {
98
- return valorVetor[indice];
99
- }
100
- }
101
- }));
102
- pilhaEscoposExecucao.definirVariavel('encontrarIndice', new funcao_padrao_1.FuncaoPadrao(2, async function (vetor, funcaoPesquisa) {
103
- const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
104
- const valorFuncaoPesquisa = funcaoPesquisa.hasOwnProperty('valor') ? funcaoPesquisa.valor : funcaoPesquisa;
105
- if (!Array.isArray(valorVetor)) {
106
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
107
- }
108
- if (valorFuncaoPesquisa.constructor.name !== 'DeleguaFuncao') {
109
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função deve ser uma função.'));
110
- }
111
- for (let indice = 0; indice < valorVetor.length; ++indice) {
112
- if (await valorFuncaoPesquisa.chamar(interpretador, [valorVetor[indice]])) {
113
- return indice;
114
- }
115
- }
116
- return -1;
117
- }));
118
- pilhaEscoposExecucao.definirVariavel('encontrarUltimoIndice', new funcao_padrao_1.FuncaoPadrao(2, async function (vetor, funcaoPesquisa) {
119
- const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
120
- const valorFuncaoPesquisa = funcaoPesquisa.hasOwnProperty('valor') ? funcaoPesquisa.valor : funcaoPesquisa;
121
- if (!Array.isArray(valorVetor)) {
122
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
123
- }
124
- if (valorFuncaoPesquisa.constructor.name !== 'DeleguaFuncao') {
125
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função deve ser uma função.'));
126
- }
127
- for (let indice = valorVetor.length - 1; indice >= 0; --indice) {
128
- if (await valorFuncaoPesquisa.chamar(interpretador, [valorVetor[indice]])) {
129
- return indice;
130
- }
131
- }
132
- }));
133
- pilhaEscoposExecucao.definirVariavel('incluido', new funcao_padrao_1.FuncaoPadrao(2, async function (vetor, valor) {
134
- const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
135
- const valorValor = valor.hasOwnProperty('valor') ? valor.valor : valor;
136
- if (!Array.isArray(valorVetor)) {
137
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
138
- }
139
- for (let indice = 0; indice < valorVetor.length; ++indice) {
140
- if (valorVetor[indice] == valorValor) {
141
- return true;
142
- }
143
- }
144
- return false;
145
- }));
146
- pilhaEscoposExecucao.definirVariavel('inteiro', new funcao_padrao_1.FuncaoPadrao(1, async function (numero) {
147
- if (numero === null || numero === undefined)
148
- return Promise.resolve(0);
149
- const valor = numero.hasOwnProperty('valor') ? numero.valor : numero;
150
- if (isNaN(valor)) {
151
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Valor não parece ser um número. Somente números ou textos com números podem ser convertidos para inteiro.'));
152
- }
153
- if (!/^(-)?\d+(\.\d+)?$/.test(valor)) {
154
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Valor não parece estar estruturado como um número (texto vazio, falso ou não definido). Somente números ou textos com números podem ser convertidos para inteiro.'));
155
- }
156
- return Promise.resolve(parseInt(valor));
157
- }));
158
- pilhaEscoposExecucao.definirVariavel('mapear', new funcao_padrao_1.FuncaoPadrao(1, async function (vetor, funcaoMapeamento) {
159
- if (vetor === null || vetor === undefined)
160
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função mapear() não pode ser nulo.'));
161
- const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
162
- const valorFuncaoMapeamento = funcaoMapeamento.hasOwnProperty('valor')
163
- ? funcaoMapeamento.valor
164
- : funcaoMapeamento;
165
- if (!Array.isArray(valorVetor)) {
166
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função mapear() deve ser um vetor.'));
167
- }
168
- if (valorFuncaoMapeamento.constructor.name !== 'DeleguaFuncao') {
169
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função mapear() deve ser uma função.'));
170
- }
171
- const resultados = [];
172
- for (let indice = 0; indice < valorVetor.length; ++indice) {
173
- resultados.push(await valorFuncaoMapeamento.chamar(interpretador, [valorVetor[indice]]));
174
- }
175
- return resultados;
176
- }));
177
- pilhaEscoposExecucao.definirVariavel('todos', new funcao_padrao_1.FuncaoPadrao(2, todosEmCondicao));
178
- pilhaEscoposExecucao.definirVariavel('todosEmCondicao', new funcao_padrao_1.FuncaoPadrao(2, todosEmCondicao));
179
- pilhaEscoposExecucao.definirVariavel('filtrarPor', new funcao_padrao_1.FuncaoPadrao(1, async function (vetor, funcaoFiltragem) {
180
- if (vetor === null || vetor === undefined)
181
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função filtrarPor() não pode ser nulo.'));
182
- const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
183
- const valorFuncaoFiltragem = funcaoFiltragem.hasOwnProperty('valor')
184
- ? funcaoFiltragem.valor
185
- : funcaoFiltragem;
186
- if (!Array.isArray(valorVetor)) {
187
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função filtrarPor() deve ser um vetor.'));
188
- }
189
- if (valorFuncaoFiltragem.constructor.name !== 'DeleguaFuncao') {
190
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função filtrarPor() deve ser uma função.'));
191
- }
192
- const resultados = [];
193
- for (let indice = 0; indice < valorVetor.length; ++indice) {
194
- const deveRetornarValor = await valorFuncaoFiltragem.chamar(interpretador, [valorVetor[indice]]);
195
- if (deveRetornarValor === false)
196
- continue;
197
- resultados.push(valorVetor[indice]);
198
- }
199
- return resultados;
200
- }));
201
- pilhaEscoposExecucao.definirVariavel('primeiroEmCondicao', new funcao_padrao_1.FuncaoPadrao(2, async function (vetor, funcaoFiltragem) {
202
- if (vetor === null || vetor === undefined)
203
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função primeiroEmCondicao() não pode ser nulo.'));
204
- const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
205
- const valorFuncaoFiltragem = funcaoFiltragem.hasOwnProperty('valor')
206
- ? funcaoFiltragem.valor
207
- : funcaoFiltragem;
208
- if (!Array.isArray(valorVetor)) {
209
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função primeiroEmCondicao() deve ser um vetor.'));
210
- }
211
- if (valorFuncaoFiltragem.constructor.name !== 'DeleguaFuncao') {
212
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função primeiroEmCondicao() deve ser uma função.'));
213
- }
214
- for (let indice = 0; indice < valorVetor.length; ++indice) {
215
- const valorResolvido = await valorFuncaoFiltragem.chamar(interpretador, [valorVetor[indice]]);
216
- if (valorResolvido !== null) {
217
- return valorResolvido;
218
- }
219
- }
220
- return undefined;
221
- }));
222
- pilhaEscoposExecucao.definirVariavel('paraCada', new funcao_padrao_1.FuncaoPadrao(2, async function (vetor, funcaoFiltragem) {
223
- if (vetor === null || vetor === undefined)
224
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função paraCada() não pode ser nulo.'));
225
- const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
226
- const valorFuncaoFiltragem = funcaoFiltragem.hasOwnProperty('valor')
227
- ? funcaoFiltragem.valor
228
- : funcaoFiltragem;
229
- if (!Array.isArray(valorVetor)) {
230
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função paraCada() deve ser um vetor.'));
231
- }
232
- if (valorFuncaoFiltragem.constructor.name !== 'DeleguaFuncao') {
233
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função paraCada() deve ser uma função.'));
234
- }
235
- for (let indice = 0; indice < valorVetor.length; ++indice) {
236
- await valorFuncaoFiltragem.chamar(interpretador, [valorVetor[indice]]);
237
- }
238
- }));
239
- pilhaEscoposExecucao.definirVariavel('ordenar', new funcao_padrao_1.FuncaoPadrao(1, async function (vetor) {
240
- if (vetor === null || vetor === undefined)
241
- throw new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função ordenar() não pode ser nulo.');
242
- const objeto = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
243
- if (!Array.isArray(objeto)) {
244
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Valor inválido. Objeto inserido não é um vetor.'));
245
- }
246
- let trocado;
247
- const tamanho = objeto.length;
248
- do {
249
- trocado = false;
250
- for (let i = 0; i < tamanho - 1; i++) {
251
- if (objeto[i] > objeto[i + 1]) {
252
- [objeto[i], objeto[i + 1]] = [objeto[i + 1], objeto[i]];
253
- trocado = true;
254
- }
255
- }
256
- } while (trocado);
257
- return Promise.resolve(objeto);
258
- }));
259
- pilhaEscoposExecucao.definirVariavel('real', new funcao_padrao_1.FuncaoPadrao(1, async function (numero) {
260
- if (numero === null || numero === undefined)
261
- return Promise.resolve(parseFloat('0'));
262
- const valor = numero.hasOwnProperty('valor') ? numero.valor : numero;
263
- if (!/^(-)?\d+(\.\d+)?$/.test(valor)) {
264
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Valor não parece estar estruturado como um número (texto/valor vazio, falso ou não definido). Somente números ou textos com números podem ser convertidos para real.'));
265
- }
266
- return Promise.resolve(parseFloat(valor));
267
- }));
268
- pilhaEscoposExecucao.definirVariavel('reduzir', new funcao_padrao_1.FuncaoPadrao(3, async function (vetor, funcaoReducao, padrao = null) {
269
- const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
270
- const valorFuncaoReducao = funcaoReducao.hasOwnProperty('valor') ? funcaoReducao.valor : funcaoReducao;
271
- const valorPadrao = padrao.hasOwnProperty('valor') ? padrao.valor : padrao;
272
- if (!Array.isArray(valorVetor)) {
273
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
274
- }
275
- if (valorFuncaoReducao.constructor.name !== 'DeleguaFuncao') {
276
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função deve ser uma função.'));
277
- }
278
- let resultado = valorPadrao;
279
- let inicio = 0;
280
- if (!resultado) {
281
- resultado = vetor[0];
282
- inicio = 1;
283
- }
284
- for (let index = inicio; index < vetor.length; ++index) {
285
- resultado = await valorFuncaoReducao.chamar(interpretador, [resultado, vetor[index]]);
286
- }
287
- return resultado;
288
- }));
289
- pilhaEscoposExecucao.definirVariavel('tamanho', new funcao_padrao_1.FuncaoPadrao(1, async function (objeto) {
290
- const valorObjeto = objeto.hasOwnProperty('valor') ? objeto.valor : objeto;
291
- if (typeof valorObjeto === 'number') {
292
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Função global tamanho() não funciona com números.'));
293
- }
294
- if (valorObjeto instanceof objeto_delegua_classe_1.ObjetoDeleguaClasse) {
295
- return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Função global tamanho não funciona com objetos complexos.'));
296
- }
297
- if (valorObjeto instanceof estruturas_1.DeleguaFuncao) {
298
- return Promise.resolve(valorObjeto.declaracao.parametros.length);
299
- }
300
- if (valorObjeto instanceof funcao_padrao_1.FuncaoPadrao) {
301
- return Promise.resolve(valorObjeto.valorAridade);
302
- }
303
- if (valorObjeto instanceof delegua_classe_1.DeleguaClasse) {
304
- const metodos = valorObjeto.metodos;
305
- let tamanho = 0;
306
- if (metodos.inicializacao && metodos.inicializacao.eInicializador) {
307
- tamanho = metodos.inicializacao.declaracao.parametros.length;
9
+ const construtos_1 = require("../construtos");
10
+ /**
11
+ * Retorna um número aleatório entre 0 e 1.
12
+ * @returns {Promise<number>} Número real.
13
+ */
14
+ async function aleatorio(interpretador) {
15
+ return Promise.resolve(Math.random());
16
+ }
17
+ exports.aleatorio = aleatorio;
18
+ /**
19
+ * Retorna um número aleatório de acordo com o parâmetro passado.
20
+ * Mínimo(inclusivo) - Máximo(exclusivo).
21
+ * @param {number} minimo O número mínimo.
22
+ * @param {number} maximo O número máximo.
23
+ * @returns {Promise<number>} Um número real entre os valores máximo e mínimo especificados.
24
+ */
25
+ async function aleatorioEntre(interpretador, minimo, maximo) {
26
+ // eslint-disable-next-line prefer-rest-params
27
+ if (arguments.length <= 0) {
28
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'A função recebe ao menos um parâmetro.'));
29
+ }
30
+ const valorMinimo = minimo.hasOwnProperty('valor') ? minimo.valor : minimo;
31
+ if (arguments.length === 2) {
32
+ if (typeof valorMinimo !== 'number') {
33
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'O parâmetro deve ser um número.'));
34
+ }
35
+ return Math.floor(Math.random() * (0 - valorMinimo)) + valorMinimo;
36
+ }
37
+ if (arguments.length > 3) {
38
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'A quantidade de parâmetros máxima para esta função é 2.'));
39
+ }
40
+ const valorMaximo = maximo.hasOwnProperty('valor') ? maximo.valor : maximo;
41
+ if (typeof valorMinimo !== 'number' || typeof valorMaximo !== 'number') {
42
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Os dois parâmetros devem ser do tipo número.'));
43
+ }
44
+ return Promise.resolve(Math.floor(Math.random() * (valorMaximo - valorMinimo)) + valorMinimo);
45
+ }
46
+ exports.aleatorioEntre = aleatorioEntre;
47
+ /**
48
+ * Verifica se algum dos elementos satisfaz à condição para por parâmetro.
49
+ * @param {InterpretadorInterface} interpretador A instância do interpretador.
50
+ * @param {VariavelInterface | any} vetor Uma variável de Delégua ou um vetor nativo de JavaScript.
51
+ * @param {VariavelInterface | any} funcaoPesquisa A função que ensina o método de pesquisa.
52
+ * @returns {Promise<boolean>} Verdadeiro se algum elemento no vetor com a condição. Falso caso contrário.
53
+ */
54
+ async function algum(interpretador, vetor, funcaoPesquisa) {
55
+ const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
56
+ const valorFuncaoPesquisa = funcaoPesquisa.hasOwnProperty('valor') ? funcaoPesquisa.valor : funcaoPesquisa;
57
+ if (!Array.isArray(valorVetor)) {
58
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
59
+ }
60
+ if (valorFuncaoPesquisa.constructor.name !== 'DeleguaFuncao') {
61
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função deve ser uma função.'));
62
+ }
63
+ for (let indice = 0; indice < valorVetor.length; ++indice) {
64
+ if (await valorFuncaoPesquisa.chamar(interpretador, [valorVetor[indice]])) {
65
+ return true;
66
+ }
67
+ }
68
+ return false;
69
+ }
70
+ exports.algum = algum;
71
+ /**
72
+ * Encontra o primeiro elemento de um vetor cuja função de pesquisa retorne
73
+ * verdadeiro na avaliação de cada elemento.
74
+ * @param {InterpretadorInterface} interpretador A instância do interpretador.
75
+ * @param {VariavelInterface | any} vetor Uma variável de Delégua ou um vetor nativo de JavaScript.
76
+ * @param {VariavelInterface | any} funcaoPesquisa A função que ensina o método de pesquisa.
77
+ * @returns {Promise<any>} Um elemento, caso o elemento seja encontraro, ou nulo em caso contrário.
78
+ */
79
+ async function encontrar(interpretador, vetor, funcaoPesquisa) {
80
+ const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
81
+ const valorFuncaoPesquisa = funcaoPesquisa.hasOwnProperty('valor') ? funcaoPesquisa.valor : funcaoPesquisa;
82
+ if (!Array.isArray(valorVetor)) {
83
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
84
+ }
85
+ if (valorFuncaoPesquisa.constructor.name !== 'DeleguaFuncao') {
86
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função deve ser uma função.'));
87
+ }
88
+ for (let indice = 0; indice < valorVetor.length; ++indice) {
89
+ if (await valorFuncaoPesquisa.chamar(interpretador, [valorVetor[indice]])) {
90
+ return valorVetor[indice];
91
+ }
92
+ }
93
+ return null;
94
+ }
95
+ exports.encontrar = encontrar;
96
+ /**
97
+ * Encontra o índice do primeiro elemento de um vetor cuja função de pesquisa retorne
98
+ * verdadeiro na avaliação de cada elemento.
99
+ * @param {InterpretadorInterface} interpretador A instância do interpretador.
100
+ * @param {VariavelInterface | any} vetor Uma variável de Delégua ou um vetor nativo de JavaScript.
101
+ * @param {VariavelInterface | any} funcaoPesquisa A função que ensina o método de pesquisa.
102
+ * @returns {Promise<number>} O número correspondente ao índice se o elemento for encontrado, ou nulo em caso contrário.
103
+ */
104
+ async function encontrarIndice(interpretador, vetor, funcaoPesquisa) {
105
+ const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
106
+ const valorFuncaoPesquisa = funcaoPesquisa.hasOwnProperty('valor') ? funcaoPesquisa.valor : funcaoPesquisa;
107
+ if (!Array.isArray(valorVetor)) {
108
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
109
+ }
110
+ if (valorFuncaoPesquisa.constructor.name !== 'DeleguaFuncao') {
111
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função deve ser uma função.'));
112
+ }
113
+ for (let indice = 0; indice < valorVetor.length; ++indice) {
114
+ if (await valorFuncaoPesquisa.chamar(interpretador, [valorVetor[indice]])) {
115
+ return indice;
116
+ }
117
+ }
118
+ return -1;
119
+ }
120
+ exports.encontrarIndice = encontrarIndice;
121
+ /**
122
+ * Encontrar o último elemento de um vetor cuja função de pesquisa retorne
123
+ * verdadeiro na avaliação de cada elemento.
124
+ * @param {InterpretadorInterface} interpretador A instância do interpretador.
125
+ * @param {VariavelInterface | any} vetor Uma variável de Delégua ou um vetor nativo de JavaScript.
126
+ * @param {VariavelInterface | any} funcaoPesquisa A função que ensina o método de pesquisa.
127
+ * @returns {Promise<number>} O número correspondente ao índice se o elemento for encontrado, ou nulo em caso contrário.
128
+ */
129
+ async function encontrarUltimo(interpretador, vetor, funcaoPesquisa) {
130
+ const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
131
+ const valorFuncaoPesquisa = funcaoPesquisa.hasOwnProperty('valor') ? funcaoPesquisa.valor : funcaoPesquisa;
132
+ if (!Array.isArray(valorVetor)) {
133
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
134
+ }
135
+ if (valorFuncaoPesquisa.constructor.name !== 'DeleguaFuncao') {
136
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função deve ser uma função.'));
137
+ }
138
+ for (let indice = valorVetor.length - 1; indice >= 0; --indice) {
139
+ if (await valorFuncaoPesquisa.chamar(interpretador, [valorVetor[indice]])) {
140
+ return valorVetor[indice];
141
+ }
142
+ }
143
+ return null;
144
+ }
145
+ exports.encontrarUltimo = encontrarUltimo;
146
+ /**
147
+ *
148
+ * @param {InterpretadorInterface} interpretador A instância do interpretador.
149
+ * @param {VariavelInterface | any} vetor Uma variável de Delégua ou um vetor nativo de JavaScript.
150
+ * @param {VariavelInterface | any} funcaoPesquisa A função que ensina o método de pesquisa.
151
+ * @returns {Promise<number>} O número correspondente ao índice se o elemento for encontrado, ou nulo em caso contrário.
152
+ */
153
+ async function encontrarUltimoIndice(interpretador, vetor, funcaoPesquisa) {
154
+ const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
155
+ const valorFuncaoPesquisa = funcaoPesquisa.hasOwnProperty('valor') ? funcaoPesquisa.valor : funcaoPesquisa;
156
+ if (!Array.isArray(valorVetor)) {
157
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
158
+ }
159
+ if (valorFuncaoPesquisa.constructor.name !== 'DeleguaFuncao') {
160
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função deve ser uma função.'));
161
+ }
162
+ for (let indice = valorVetor.length - 1; indice >= 0; --indice) {
163
+ if (await valorFuncaoPesquisa.chamar(interpretador, [valorVetor[indice]])) {
164
+ return indice;
165
+ }
166
+ }
167
+ return null;
168
+ }
169
+ exports.encontrarUltimoIndice = encontrarUltimoIndice;
170
+ /**
171
+ *
172
+ * @param interpretador
173
+ * @param vetor
174
+ * @param funcaoFiltragem
175
+ * @returns
176
+ */
177
+ async function filtrarPor(interpretador, vetor, funcaoFiltragem) {
178
+ if (vetor === null || vetor === undefined)
179
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função filtrarPor() não pode ser nulo.'));
180
+ const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
181
+ const valorFuncaoFiltragem = funcaoFiltragem.hasOwnProperty('valor')
182
+ ? funcaoFiltragem.valor
183
+ : funcaoFiltragem;
184
+ if (!Array.isArray(valorVetor)) {
185
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função filtrarPor() deve ser um vetor.'));
186
+ }
187
+ if (valorFuncaoFiltragem.constructor.name !== 'DeleguaFuncao') {
188
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função filtrarPor() deve ser uma função.'));
189
+ }
190
+ const resultados = [];
191
+ for (let indice = 0; indice < valorVetor.length; ++indice) {
192
+ const deveRetornarValor = await valorFuncaoFiltragem.chamar(interpretador, [valorVetor[indice]]);
193
+ if (deveRetornarValor === false)
194
+ continue;
195
+ resultados.push(valorVetor[indice]);
196
+ }
197
+ return resultados;
198
+ }
199
+ exports.filtrarPor = filtrarPor;
200
+ /**
201
+ *
202
+ * @param {InterpretadorInterface} interpretador A instância do interpretador.
203
+ * @param {VariavelInterface | any} vetor Uma variável de Delégua ou um vetor nativo de JavaScript.
204
+ * @param valor
205
+ * @returns
206
+ */
207
+ async function incluido(interpretador, vetor, valor) {
208
+ const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
209
+ const valorValor = valor.hasOwnProperty('valor') ? valor.valor : valor;
210
+ if (!Array.isArray(valorVetor)) {
211
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
212
+ }
213
+ for (let indice = 0; indice < valorVetor.length; ++indice) {
214
+ if (valorVetor[indice] == valorValor) {
215
+ return true;
216
+ }
217
+ }
218
+ return false;
219
+ }
220
+ exports.incluido = incluido;
221
+ /**
222
+ *
223
+ * @param {InterpretadorInterface} interpretador A instância do interpretador.
224
+ * @param numero
225
+ * @returns
226
+ */
227
+ async function inteiro(interpretador, numero) {
228
+ if (numero === null || numero === undefined)
229
+ return Promise.resolve(0);
230
+ const valor = numero.hasOwnProperty('valor') ? numero.valor : numero;
231
+ if (isNaN(valor)) {
232
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Valor não parece ser um número. Somente números ou textos com números podem ser convertidos para inteiro.'));
233
+ }
234
+ if (!/^(-)?\d+(\.\d+)?$/.test(valor)) {
235
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Valor não parece estar estruturado como um número (texto vazio, falso ou não definido). Somente números ou textos com números podem ser convertidos para inteiro.'));
236
+ }
237
+ return Promise.resolve(parseInt(valor));
238
+ }
239
+ exports.inteiro = inteiro;
240
+ /**
241
+ *
242
+ * @param interpretador
243
+ * @param vetor
244
+ * @param funcaoMapeamento
245
+ * @returns
246
+ */
247
+ async function mapear(interpretador, vetor, funcaoMapeamento) {
248
+ if (vetor === null || vetor === undefined)
249
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função mapear() não pode ser nulo.'));
250
+ const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
251
+ const valorFuncaoMapeamento = funcaoMapeamento.hasOwnProperty('valor')
252
+ ? funcaoMapeamento.valor
253
+ : funcaoMapeamento;
254
+ if (!Array.isArray(valorVetor)) {
255
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função mapear() deve ser um vetor.'));
256
+ }
257
+ if (valorFuncaoMapeamento.constructor.name !== 'DeleguaFuncao') {
258
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função mapear() deve ser uma função.'));
259
+ }
260
+ const resultados = [];
261
+ for (let indice = 0; indice < valorVetor.length; ++indice) {
262
+ resultados.push(await valorFuncaoMapeamento.chamar(interpretador, [valorVetor[indice]]));
263
+ }
264
+ return resultados;
265
+ }
266
+ exports.mapear = mapear;
267
+ /**
268
+ *
269
+ * @param vetor
270
+ * @returns
271
+ */
272
+ async function ordenar(interpretador, vetor) {
273
+ if (vetor === null || vetor === undefined)
274
+ throw new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função ordenar() não pode ser nulo.');
275
+ const objeto = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
276
+ if (!Array.isArray(objeto)) {
277
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Valor inválido. Objeto inserido não é um vetor.'));
278
+ }
279
+ let trocado;
280
+ const tamanho = objeto.length;
281
+ do {
282
+ trocado = false;
283
+ for (let i = 0; i < tamanho - 1; i++) {
284
+ if (objeto[i] > objeto[i + 1]) {
285
+ [objeto[i], objeto[i + 1]] = [objeto[i + 1], objeto[i]];
286
+ trocado = true;
308
287
  }
309
- return Promise.resolve(tamanho);
310
288
  }
311
- return Promise.resolve(valorObjeto.length);
312
- }));
313
- pilhaEscoposExecucao.definirVariavel('texto', new funcao_padrao_1.FuncaoPadrao(1, async function (valorOuVariavel) {
314
- return Promise.resolve(`${valorOuVariavel.hasOwnProperty('valor') ? valorOuVariavel.valor : valorOuVariavel}`);
315
- }));
316
- return pilhaEscoposExecucao;
289
+ } while (trocado);
290
+ return Promise.resolve(objeto);
291
+ }
292
+ exports.ordenar = ordenar;
293
+ /**
294
+ *
295
+ * @param interpretador
296
+ * @param vetor
297
+ * @param funcaoFiltragem
298
+ * @returns
299
+ */
300
+ async function paraCada(interpretador, vetor, funcaoFiltragem) {
301
+ if (vetor === null || vetor === undefined)
302
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função paraCada() não pode ser nulo.'));
303
+ const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
304
+ const valorFuncaoFiltragem = funcaoFiltragem.hasOwnProperty('valor')
305
+ ? funcaoFiltragem.valor
306
+ : funcaoFiltragem;
307
+ if (!Array.isArray(valorVetor)) {
308
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função paraCada() deve ser um vetor.'));
309
+ }
310
+ if (valorFuncaoFiltragem.constructor.name !== 'DeleguaFuncao') {
311
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função paraCada() deve ser uma função.'));
312
+ }
313
+ for (let indice = 0; indice < valorVetor.length; ++indice) {
314
+ await valorFuncaoFiltragem.chamar(interpretador, [valorVetor[indice]]);
315
+ }
316
+ }
317
+ exports.paraCada = paraCada;
318
+ /**
319
+ *
320
+ * @param interpretador
321
+ * @param vetor
322
+ * @param funcaoFiltragem
323
+ * @returns
324
+ */
325
+ async function primeiroEmCondicao(interpretador, vetor, funcaoFiltragem) {
326
+ if (vetor === null || vetor === undefined)
327
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função primeiroEmCondicao() não pode ser nulo.'));
328
+ const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
329
+ const valorFuncaoFiltragem = funcaoFiltragem.hasOwnProperty('valor')
330
+ ? funcaoFiltragem.valor
331
+ : funcaoFiltragem;
332
+ if (!Array.isArray(valorVetor)) {
333
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função primeiroEmCondicao() deve ser um vetor.'));
334
+ }
335
+ if (valorFuncaoFiltragem.constructor.name !== 'DeleguaFuncao') {
336
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função primeiroEmCondicao() deve ser uma função.'));
337
+ }
338
+ for (let indice = 0; indice < valorVetor.length; ++indice) {
339
+ const valorResolvido = await valorFuncaoFiltragem.chamar(interpretador, [valorVetor[indice]]);
340
+ if (valorResolvido !== null) {
341
+ return valorResolvido;
342
+ }
343
+ }
344
+ return undefined;
345
+ }
346
+ exports.primeiroEmCondicao = primeiroEmCondicao;
347
+ /**
348
+ *
349
+ * @param interpretador
350
+ * @param numero
351
+ * @returns
352
+ */
353
+ async function real(interpretador, numero) {
354
+ if (numero === null || numero === undefined)
355
+ return Promise.resolve(parseFloat('0'));
356
+ const valor = numero.hasOwnProperty('valor') ? numero.valor : numero;
357
+ if (!/^(-)?\d+(\.\d+)?$/.test(valor)) {
358
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Valor não parece estar estruturado como um número (texto/valor vazio, falso ou não definido). Somente números ou textos com números podem ser convertidos para real.'));
359
+ }
360
+ return Promise.resolve(parseFloat(valor));
361
+ }
362
+ exports.real = real;
363
+ /**
364
+ *
365
+ * @param interpretador
366
+ * @param vetor
367
+ * @param funcaoReducao
368
+ * @param padrao
369
+ * @returns
370
+ */
371
+ async function reduzir(interpretador, vetor, funcaoReducao, padrao = null) {
372
+ const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
373
+ const valorFuncaoReducao = funcaoReducao.hasOwnProperty('valor') ? funcaoReducao.valor : funcaoReducao;
374
+ const valorPadrao = padrao.hasOwnProperty('valor') ? padrao.valor : padrao;
375
+ if (!Array.isArray(valorVetor)) {
376
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função deve ser um vetor.'));
377
+ }
378
+ if (valorFuncaoReducao.constructor.name !== 'DeleguaFuncao') {
379
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função deve ser uma função.'));
380
+ }
381
+ let resultado = valorPadrao;
382
+ let inicio = 0;
383
+ if (!resultado) {
384
+ resultado = vetor[0];
385
+ inicio = 1;
386
+ }
387
+ for (let index = inicio; index < vetor.length; ++index) {
388
+ resultado = await valorFuncaoReducao.chamar(interpretador, [resultado, vetor[index]]);
389
+ }
390
+ return resultado;
391
+ }
392
+ exports.reduzir = reduzir;
393
+ /**
394
+ *
395
+ * @param objeto
396
+ * @returns
397
+ */
398
+ async function tamanho(interpretador, objeto) {
399
+ const valorObjeto = objeto.hasOwnProperty('valor') ? objeto.valor : objeto;
400
+ if (typeof valorObjeto === 'number') {
401
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Função global tamanho() não funciona com números.'));
402
+ }
403
+ if (valorObjeto instanceof objeto_delegua_classe_1.ObjetoDeleguaClasse) {
404
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Função global tamanho não funciona com objetos complexos.'));
405
+ }
406
+ if (valorObjeto instanceof estruturas_1.DeleguaFuncao) {
407
+ return Promise.resolve(valorObjeto.declaracao.parametros.length);
408
+ }
409
+ if (valorObjeto instanceof funcao_padrao_1.FuncaoPadrao) {
410
+ return Promise.resolve(valorObjeto.valorAridade);
411
+ }
412
+ if (valorObjeto instanceof delegua_classe_1.DeleguaClasse) {
413
+ const metodos = valorObjeto.metodos;
414
+ let tamanho = 0;
415
+ if (metodos.inicializacao && metodos.inicializacao.eInicializador) {
416
+ tamanho = metodos.inicializacao.declaracao.parametros.length;
417
+ }
418
+ return Promise.resolve(tamanho);
419
+ }
420
+ return Promise.resolve(valorObjeto.length);
421
+ }
422
+ exports.tamanho = tamanho;
423
+ /**
424
+ *
425
+ * @param interpretador
426
+ * @param valorOuVariavel
427
+ * @returns
428
+ */
429
+ async function texto(interpretador, valorOuVariavel) {
430
+ return Promise.resolve(`${valorOuVariavel.hasOwnProperty('valor') ? valorOuVariavel.valor : valorOuVariavel}`);
431
+ }
432
+ exports.texto = texto;
433
+ /**
434
+ *
435
+ * @param interpretador
436
+ * @param vetor
437
+ * @param funcaoCondicional
438
+ * @returns
439
+ */
440
+ async function todosEmCondicao(interpretador, vetor, funcaoCondicional) {
441
+ if (vetor === null || vetor === undefined)
442
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função todosEmCondicao() não pode ser nulo.'));
443
+ const valorVetor = vetor.hasOwnProperty('valor') ? vetor.valor : vetor;
444
+ const valorFuncaoCondicional = funcaoCondicional.hasOwnProperty('valor')
445
+ ? funcaoCondicional.valor
446
+ : funcaoCondicional;
447
+ if (!Array.isArray(valorVetor)) {
448
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O primeiro parâmetro da função todosEmCondicao() deve ser um vetor.'));
449
+ }
450
+ if (valorFuncaoCondicional.constructor.name !== 'DeleguaFuncao') {
451
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Parâmetro inválido. O segundo parâmetro da função todosEmCondicao() deve ser uma função.'));
452
+ }
453
+ for (let indice = 0; indice < valorVetor.length; ++indice) {
454
+ if (!(await valorFuncaoCondicional.chamar(interpretador, [valorVetor[indice]])))
455
+ return false;
456
+ }
457
+ return true;
458
+ }
459
+ exports.todosEmCondicao = todosEmCondicao;
460
+ /**
461
+ * Transforma um vetor de elementos em uma tupla de N elementos, sendo N a
462
+ * largura do vetor.
463
+ * @param interpretador
464
+ * @param vetor
465
+ * @returns
466
+ */
467
+ async function tupla(interpretador, vetor) {
468
+ const valorVetor = !Array.isArray(vetor) && vetor.hasOwnProperty('valor') ?
469
+ vetor.valor :
470
+ vetor;
471
+ if (!Array.isArray(valorVetor)) {
472
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Argumento de função nativa `tupla` não parece ser um vetor.'));
473
+ }
474
+ switch (valorVetor.length) {
475
+ case 2:
476
+ return Promise.resolve(new construtos_1.Dupla(valorVetor[0], valorVetor[1]));
477
+ case 3:
478
+ return Promise.resolve(new construtos_1.Trio(valorVetor[0], valorVetor[1], valorVetor[2]));
479
+ case 4:
480
+ return Promise.resolve(new construtos_1.Quarteto(valorVetor[0], valorVetor[1], valorVetor[2], valorVetor[3]));
481
+ case 5:
482
+ return Promise.resolve(new construtos_1.Quinteto(valorVetor[0], valorVetor[1], valorVetor[2], valorVetor[3], valorVetor[4]));
483
+ case 6:
484
+ return Promise.resolve(new construtos_1.Sexteto(valorVetor[0], valorVetor[1], valorVetor[2], valorVetor[3], valorVetor[4], valorVetor[5]));
485
+ case 7:
486
+ return Promise.resolve(new construtos_1.Septeto(valorVetor[0], valorVetor[1], valorVetor[2], valorVetor[3], valorVetor[4], valorVetor[5], valorVetor[6]));
487
+ case 8:
488
+ return Promise.resolve(new construtos_1.Octeto(valorVetor[0], valorVetor[1], valorVetor[2], valorVetor[3], valorVetor[4], valorVetor[5], valorVetor[6], valorVetor[7]));
489
+ case 9:
490
+ return Promise.resolve(new construtos_1.Noneto(valorVetor[0], valorVetor[1], valorVetor[2], valorVetor[3], valorVetor[4], valorVetor[5], valorVetor[6], valorVetor[7], valorVetor[8]));
491
+ case 10:
492
+ return Promise.resolve(new construtos_1.Deceto(valorVetor[0], valorVetor[1], valorVetor[2], valorVetor[3], valorVetor[4], valorVetor[5], valorVetor[6], valorVetor[7], valorVetor[8], valorVetor[9]));
493
+ case 1:
494
+ default:
495
+ return Promise.reject(new excecoes_1.ErroEmTempoDeExecucao(this.simbolo, 'Para ser transformado em uma tupla, vetor precisa ter de 2 a 10 elementos.'));
496
+ }
317
497
  }
318
- exports.default = default_1;
498
+ exports.tupla = tupla;
319
499
  //# sourceMappingURL=biblioteca-global.js.map