O método collection.find( ) devolve o primeiro valor na coleção para o qual nomMet, aplicado em cada elemento, devolve true.
Nota: este método não modificar a coleção original.
De forma pré-determinada, collection.find( ) busca em toda a coleção. Opcionalmente, pode passar em posicIni o índice do elemento desde o qual começar a pesquisa.
- Se posicIni >= longitude da coleção, se devolve -1, e a pesquisa não é efetuada.
- Se posicIni < 0, se considera como o ponto de início do cálculo da posição (posicIni :=posicIni +length).
Nota: mesmo se posicIni for negativo, a coleção continua buscando de esquerda a direita. - Se posicIni = 0, se busca em toda a coleção (pré-determinado).
Em nomMet, passe o nome do método a usar para avaliar os elementos da coleção, junto com seus parâmetros em param (opcional). nomMet pode realizar qualquer teste, com ou sem os parâmetros. Este método recebe um parâmetro Object em $1 e deve definir $1.result como true para o primeiro elemento que cumpra a condição.
nomMet recebe os parâmetros abaixo:
- em $1.value: valor do elemento a avaliar
- em $2: param
- em $N...: param2...paramN
nomMet define os parâmetros abaixo:
- $1.result (booleano): true se o valor do elemento coincide com a condição de pesquisa.
- $1.stop (booleano, opcional): true para deter a retrochamada do método. O valor devolvido for o último calculado.
Se quiser obter o primeiro elemento com uma longitude inferior a 5:
O código para o método LengthLessThan é:
C_OBJECT($1)
C_LONGINT($2)
If(Value type($1.value)=Is text)
$1.result:=(Length($1.value))<$2
End if
Se quiser encontrar o nome de uma cidade dentro de uma coleção:
O código para o método é FindCity:
C_OBJECT($1)
C_TEXT($2)
$1.result:=$1.value.name=$2