/*
 * $Id: array.txt 9312 2008-09-05 00:08:34Z vszakats $
 */

/*
 * Las siguientes partes son derechos adquiridos de sus autores individuales.
 * www - http://www.harbour-project.org
 *
 * Copyright 2000 Alejandro de Grate <alex_degarate@hotmail.com>
 * Documentacin en Espaol de:
 *         ARRAY(), AADD(), ASIZE(), ATAIL(), ASIZE(),
 *         AINS(), ADEL(), ADEL(), AFILL(), ASCAN()
 *         AEVAL(), ACOPY(), ACLONE(), ASORT()
 *
 * Vea doc/license.txt por los trminos de la licencia.
 *
 */

/*  $DOC$
 *  $FUNCNAME$
 *      ARRAY()
 *  $CATEGORY$
 *      ARRAY
 *  $ONELINER$
 *      Crea un array sin inicializar de la longitud especificada
 *  $SYNTAX$
 *      ARRAY( <nElementos> [, <nElementos>...] ) --> aArray
 *  $ARGUMENTS$
 *      <nElementos> es el nmero de elementos de la dimensin especificada.
 *  $RETURNS$
 *      Un array con las dimensiones especificadas.
 *  $DESCRIPTION$
 *      Esta funcin retorna un array sin inicializar de tamao <nElementos>
 *      Si parmetros <nElementos> adicionales son especificados se crea
 *      un array anidado multidimensional sin inicializar dentro de la misma
 *      referencia del array.
 *      Crear una variable de memoria con el mismo nombre que el array puede
 *      destruir el array original y liberar el contenido entero del array.
 *      Esto depende, por supuesto del tipo de almacenamiento de ambos: del
 *      array y la variable con el mismo nombre que el array.
 *  $EXAMPLES$
 *      *  El siguiente ejemplo crea un array de diez elementos iniciales,
 *         luego en cada elemento de ese array, va creando submatrices
 *         lineales con la funcin ARRAY(). Cada una con la misma cantidad
 *         de items que la posicin que ocupa en aArray. Finalmente lo
 *         muestra.
 *
 *         LOCAL aArray := Array(10)
 *         LOCAL i := 1, j
 *
 *         FOR i = 1 to LEN( aArray )
 *           aArray [i] := Array(i)
 *         NEXT
 *
 *         FOR i = 1 to LEN( aArray )
 *            ? i
 *            FOR j = 1 to LEN( aArray [i] )
 *                ?? " ", aArray [i][j]
 *            NEXT
 *         NEXT
 *
 *  $STATUS$
 *      R
 *  $COMPLIANCE$
 *      Esta funcin es CA-Cl*pper Compatible en todos los casos, excepto que
 *      los arrays en Harbour pueden tener un nmero ilimitado de elementos
 *      mientras que Clipper tiene un lmite de 4096 elementos por dimensin.
 *      Los arrays en Harbour pueden tener un nmero ilimitado de dimensiones
 *  $FILES$
 *      El cdigo fuente est en source\vm\arrays.c
 *      La librera asociada es vm
 *  $SEEALSO$
 *      AADD(),ADEL(),AFILL(),AINS()
 *  $END$
 */


 *  $DOC$
 *  $FUNCNAME$
 *      AADD()
 *  $CATEGORY$
 *      ARRAY
 *  $ONELINER$
 *      Agrega dinmicamente un nuevo elemento al final de un array
 *  $SYNTAX$
 *      AADD(<aDestino>, <xValor>) --> Valor
 *  $ARGUMENTS$
 *      <aDestino> es el array al cual se agrega un nuevo elemento.
 *
 *      <xValor>   es el valor asignado al nuevo elemento.
 *  $RETURNS$
 *      AADD() evala <xValor> y retorna su valor.  Si <xValor> no esta
 *      especificado, AADD() retorna NIL.
 *  $DESCRIPTION$
 *      AADD() es una funcin que dinmicamente incrementa la longitud actual
 *      del array destino en un elemento y asigna el valor <xValor> al recin
 *      creado elemento del array.
 *      <xValor> puede ser un puntero de referencia a otro array, el cual
 *      puede ser asignado a la posicin subndice.
 *
 *      Es til para construir listas dinmicas o colas (queues).
 *      Cada vez que se ejecuta un comando @...GET, el sistema usa AADD()
 *      para agregar un nuevo elemento al final del array GetList, y entonces
 *      asignar un nuevo objeto Get al nuevo elemento.
 *  $EXAMPLES$
 *      *  Este ejemplo muestra el efecto de mltiples llamadas de la funcin
 *         AADD() a un array, donde va agrgando un nuevo elemento cada vez.
 *
 *      LOCAL aArray := {}
 *      FOR x:= 1 to 10
 *          AADD( aArray, x)
 *      NEXT
 *
 *      *  Este ejemplo crea un array multidemensional
 *      LOCAL aArray := {}             // Resultado: aArray es un array vaco
 *      AADD( aArray, {10, 10122734 }) // Resultado: aArray es {10, 10122734}
 *      AADD( aArray, {11, 13173645 }) // Resultado: aArray es
 *                                     { { 10, 10122734 }, { 11, 13173645 } }
 *  $STATUS$
 *      R
 *  $COMPLIANCE$
 *      Esta funcin es totalmente compatible con CA-Cl*pper.
 *  $PLATFORMS$
 *      Todas las plataformas
 *  $FILES$
 *      El cdigo fuente est en source\vm\arrays.c
 *      La librera asociada es vm
 *  $SEEALSO$
 *      AINS(), ASIZE()
 * $END$


/*  $DOC$
 *  $FUNCNAME$
 *      ASIZE()
 *  $CATEGORY$
 *      ARRAY
 *  $ONELINER$
 *      Ajusta (aumenta  decrementa) el tamao de un array
 *  $SYNTAX$
 *      ASIZE(<aDestino>, <nLongitud>) --> aDestino
 *  $ARGUMENTS$
 *      <aDestino> es el nombre del array a ser dinmicamente alterado
 *
 *      <nLongitud> es el valor Numrico del nuevo tamao de <aDestino>
 *  $RETURNS$
 *      ASIZE() retorna una referencia al array <aDestino>.
 *  $DESCRIPTION$
 *      Esta funcin dinmicamente incrementa  decrementa el tamao del
 *      array <aDestino> ajustando la longitud del array a <nLongitud>
 *      posiciones.
 *
 *      Si la longitud del array <aDestino> is acortada, aquellos elementos
 *      al final se pierden. Si la longitud del array es alargada un valor
 *      NIL es asignado a los elementos en las nuevas posiciones.
 *  $EXAMPLES$
 *      *  El siguiente ejemplo crea un array con un slo elemento, luego lo
 *         agranda y luego lo vuelve al tamao original.
 *
 *         aArray := { 1 }           // Resultado: aArray es { 1 }
 *         ASIZE( aArray, 3)         // Resultado: aArray es { 1, NIL, NIL }
 *         ASIZE( aArray, 1)         // Resultado: aArray es { 1 }
 *  $STATUS$
 *      R
 *  $COMPLIANCE$
 *      Si HB_COMPAT_C53 es definido, la funcin genera un Error, de otro
 *      modo retornar el mismo array.
 *  $FILES$
 *      El cdigo fuente est en source\vm\arrays.c
 *      La librera asociada es vm
 *  $SEEALSO$
 *      AADD(), ADEL(), AFILL(), AINS()
 *  $END$
 */


/*  $DOC$
 *  $FUNCNAME$
 *      ATAIL()
 *  $CATEGORY$
 *      ARRAY
 *  $ONELINER$
 *      Retorna el ltimo elemento de un array
 *  $SYNTAX$
 *      ATAIL( <aArray> ) --> Elemento
 *  $ARGUMENTS$
 *      <aArray> es el nombre del array a usar
 *  $RETURNS$
 *      ATAIL() retorna <Elemento> que puede ser un valor  una referencia
 *      contenida en el ltimo elemento en el array.
 *  $DESCRIPTION$
 *      Esta funcin devuelve el ltimo elemento en el array llamado <aArray>
 *      No modifica el tamao del array ni el valor de ningn subndice.
 *  $EXAMPLES$
 *      *  El siguiente ejemplo crea un array unidimensional y devuelve el
 *         ltimo elemento.
 *
 *         aArray := { "Cul", "es el", "futuro", "de xBase ?", "Harbour!" }
 *         ? ATAIL( aArray )
 *  $STATUS$
 *      R
 *  $COMPLIANCE$
 *      Esta funcin es totalmente compatible con CA-Cl*pper.
 *  $FILES$
 *      El cdigo fuente est en source\vm\arrays.c
 *      La librera asociada es vm
 *  $SEEALSO$
 *      LEN(),ARRAY(),ASIZE(),AADD()
 *  $END$
 */


/*  $DOC$
 *  $FUNCNAME$
 *      AINS()
 *  $CATEGORY$
 *      ARRAY
 *  $ONELINER$
 *      Inserta un elemento NIL en una posicin del array
 *  $SYNTAX$
 *      AINS( <aArray>, <nPos> ) --> aDestino
 *  $ARGUMENTS$
 *      <aArray> es el nombre del array al que se va a insertar un item
 *
 *      <nPos>   es la posicin en el <aArray>
 *  $RETURNS$
 *      AINS() retorna una referencia al array destino, <aDestino>
 *  $DESCRIPTION$
 *      Esta funcin inserta un valor NIL en el array llamado <aArray>
 *      en la posicion <nPos>.
 *
 *      Todos los elementos del array comenzando con la <nPos> sern
 *      desplazados hacia arriba una posicin y el ltimo item en el array
 *      ser removido completamente. En otras palabras, si se va a insertar
 *      un item en la quinta posicin de un array de diez elementos, el
 *      elemento que previamente estaba en la quinta posicin ahora ser
 *      reubicado a la sexta posicin. El elemento recin agregado ser de
 *      tipo NIL y el ltimo elemento es descartado. La longitud del array
 *      <aArray> permanece sin cambios.
 *  $EXAMPLES$
 *      *  El siguiente ejemplo crea un array lineal, al cual se inserta un
 *         elemento en la quinta posicin, perdindose el ltimo.
 *
 *         LOCAL aArray:= { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }
 *         AINS( aArray, 5)
 *
 *         Resultado: aArray es { 1, 2, 3, 4, NIL, 5, 6, 7, 8, 9 }
 *  $STATUS$
 *      R
 *  $COMPLIANCE$
 *      Esta funcin es totalmente compatible con CA-Cl*pper.
 *  $FILES$
 *      El cdigo fuente est en source\vm\arrays.c
 *      La librera asociada es vm
 *  $SEEALSO$
 *      AADD(), ACOPY(), ADEL(), AEVAL(), AFILL(), ASIZE()
 *  $END$
 */


/*  $DOC$
 *  $FUNCNAME$
 *      ADEL()
 *  $CATEGORY$
 *      ARRAY
 *  $ONELINER$
 *      Borra un elemento del array
 *  $SYNTAX$
 *      ADEL(<aDestino>, <nPos>) --> aDestino
 *  $ARGUMENTS$
 *      <aDestino> es el nombre del array cuyo elemento ser removido.
 *
 *      <nPos>     es la posicin del elemento a borrar
 *  $RETURNS$
 *      ADEL() retorna una referencia al array destino, <aDestino>
 *  $DESCRIPTION$
 *      Esta funcin borra el elemento que se encuentra en la posicin <nPos>
 *      en el array <aDestino>. Todos los elementos en el array <aDestino>
 *      ms all de la posicin dada <nPos> sern movidos hacia abajo una
 *      posicin en el array.
 *      En otras palabras, si se borra un item de la quinta posicin de un
 *      array de diez elementos, el elemento que estaba en la sexta posicin
 *      ahora ser reubicado a la quinta posicin.
 *      La longitud del array <aDestino> permanece sin cambios y el ltimo
 *      elemento en el array toma el valor NIL.
 *  $EXAMPLES$
 *      *  El siguiente ejemplo crea un array lineal, del cual se borra el
 *         elemento en la quinta posicin.
 *
 *         LOCAL aArray:= { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }
 *         ADEL( aArray, 5)
 *
 *         Resultado: aArray es { 1, 2, 3, 4, 6, 7, 8, 9, NIL }
 *  $STATUS$
 *      R
 *  $COMPLIANCE$
 *      Esta funcin es totalmente compatible con CA-Cl*pper.
 *  $FILES$
 *      El cdigo fuente est en source\vm\arrays.c
 *      La librera asociada es vm
 *  $SEEALSO$
 *      ACOPY(), AINS(), AFILL()
 *  $END$
 */


/*  $DOC$
 *  $FUNCNAME$
 *      AFILL()
 *  $CATEGORY$
 *      ARRAY
 *  $ONELINER$
 *      Rellena un array con un valor especificado
 *  $SYNTAX$
 *      AFILL( <aDestino>, <xValor>, [<nInicio>], [<nContador>]) --> aDestino
 *  $ARGUMENTS$
 *      <aDestino>  es el nombre del array a rellenar
 *
 *      <xValor>    es la expresin con la que ser rellenado <aDestino>
 *
 *      <nInicio>   es la posicin de comienzo, subndice del array
 *
 *      <nContador> es el nmero de elementos que se van a rellenar
 *  $RETURNS$
 *      AFILL() retorna una referencia al array destino, <aDestino>
 *  $DESCRIPTION$
 *      Esta funcin rellena cada elemento del array llamado <aDestino> con
 *      el valor <xValor>. Si es especificado, <nInicio> marca el elemento
 *      de inicio para continuar rellenando por <nContador> posiciones.
 *      Si no es especificado, el valor de  <nInicio> ser 1, y el valor de
 *      <nContador> ser el valor de LEN(<aDestino>); y todos las posiciones
 *      del array <aDestino> sern llenadas con la expresin de <xValor>.
 *
 *      Advertencia !:
 *      Esta funcin slo trabaja en una sola dimensin de <aDestino>.
 *      Si hay punteros de referencia a otros arrays dentro de un subndice
 *      de <aDestino> estos valores se perdern, porque esta funcin los
 *      sobreescribe con los nuevos valores.
 *  $EXAMPLES$
 *      *  El siguiente ejemplo crea un array con valores asignados, luego
 *         lo rellena con el valor cinco.
 *
 *         LOCAL aTest := { NIL, 0, 1, 2 }
 *         Afill( aTest, 5)            // Resultado aTest es { 5, 5, 5, 5 }
 *  $STATUS$
 *      R
 *  $COMPLIANCE$
 *      Esta funcin es totalmente compatible con CA-Cl*pper.
 *  $FILES$
 *      El cdigo fuente est en source\vm\arrays.c
 *      La librera asociada es vm
 *  $SEEALSO$
 *      AADD(), AEVAL(), DBSTRUCT(), DIRECTORY()
 *  $END$
 */


/*  $DOC$
 *  $FUNCNAME$
 *      ASCAN()
 *  $CATEGORY$
 *      ARRAY
 *  $ONELINER$
 *      Busca en un array por un valor o hasta que el block devuelva .T.
 *  $SYNTAX$
 *      ASCAN( <aDestino>, <xBuscar>,
 *             [<nInicio>], [<nContador>] ) --> nParadoEn
 *  $ARGUMENTS$
 *      <aDestino>  es el nombre del array a examinar
 *
 *      <xBuscar >  es la expresin a encontrar en <aDestino>
 *
 *      <nInicio>   es la posicin a la cual comenzar la bsqueda
 *
 *      <nContador> es el nmero de elementos a examinar
 *  $RETURNS$
 *      ASCAN() retorna un valor numrico <nParadoEn>, de la posicin donde
 *      <xBuscar> fu encontrada.
 *  $DESCRIPTION$
 *      Esta funcin examina el contenido de un array llamado <aDestino> en
 *      busca del valor de <xBuscar>. El valor devuelto es la posicin en el
 *      array <aDestino> en el cual <xBuscar> fue encontrada.
 *      Si esta expresin no es encontrada el valor retornado es cero.
 *
 *      Si es especificada, la posicin de inicio al cual comenzar la
 *      bsqueda puede ser establecida con el valor pasado en <nInicio>.
 *      Por defecto es uno.
 *
 *      Si es especificado, el nmero de elementos del array a examinar puede
 *      ser establecido con el valor pasado en <nContador>. Por defecto es
 *      el nmero total de elementos en el array <aDestino>.
 *
 *      Si <xBuscar> es un bloque de cdigo, la operacin de la funcin es
 *      ligeramente diferente. Cada referencia del subindice del array es
 *      pasada al bloque de cdigo para ser evaluada. La rutina de bsqueda
 *      continuar hasta que el valor obtenido del bloque de cdigo sea
 *      verdadero (.T.)  hasta que el final del array haya sido alcanzado.
 *  $EXAMPLES$
 *      *  El siguiente ejemplo utiliza una funcin de biblioteca para llenar
 *         el array aDir con los nombres de archivos en el directorio actual.
 *         Posteriormente, busca si entre ellos esta presente el archivo
 *         test.prg, devuelve cero si no esta,  mayor de cero si est.
 *
 *         LOCAL aDir := DIRECTORY( "*.*")
 *         ? ASCAN( aDir,,,{|x,y| x[1] == "test.prg" } )
 *  $STATUS$
 *      R
 *  $COMPLIANCE$
 *      Esta funcin no es compatible con CA-Cl*pper . La funcin ASCAN() de
 *      Clipper es afectada por la condicin  SET EXACT ON/OFF
 *  $FILES$
 *      El cdigo fuente est en source\vm\arrays.c
 *      La librera asociada es vm
 *  $SEEALSO$
 *      AEVAL(), EVAL()
 *  $END$
 */

/*  $DOC$
 *  $FUNCNAME$
 *      AEVAL()
 *  $CATEGORY$
 *      ARRAY
 *  $ONELINER$
 *      Ejecuta un bloque de cdigo por cada elemento en el array
 *  $SYNTAX$
 *      AEVAL(<aArray>, <bBlock>, [<nInicio>], [<nContador>]) --> aArray
 *  $ARGUMENTS$
 *      <aArray>   es el array a ser evaluado.
 *
 *      <bBloque>  es el bloque de cdigo a evaluar para cada elemento
 *                 procesado
 *      <nInicio>  es el elemento de inicio del array a evaluar.
 *
 *      <nContador> es el nmero de elementos a procesar desde <nInicio>
 *                  hasta el final del array <aArray>
 *  $RETURNS$
 *      AEVAL() retorna una referencia a <aArray>
 *  $DESCRIPTION$
 *      Esta funcin evala y procesa los elementos en <aArray>.
 *      Un bloque de cdigo pasado como <bBloque> define la operacion a ser
 *      ejecutada sobre cada elemento del array. Todos los elementos en
 *      <aArray> sern evaluados a menos que sea especificada la posicin de
 *      comienzo en <nInicio> por <nContador> elementos.
 *      Por defecto <nInicio> es uno.
 *
 *      Dos parmetros son pasados al bloque de cdigo <bBloque>. Los
 *      elementos individuales en el array son el primer parmetro y su
 *      posicin en el array es el segundo.
 *
 *      AEVAL() no reemplaza al bucle FOR...NEXT para procesar arrays.
 *      Si un array es una unidad autnoma, AEVAL() es apropiado. Si el array
 *      va a ser alterado  si los elementos van a ser reevaluados, un
 *      bucle FOR...NEXT es ms apropiado.
 *  $EXAMPLES$
 *
 *  $STATUS$
 *      R
 *  $COMPLIANCE$
 *      Esta funcin es totalmente compatible con CA-Cl*pper.
 *  $FILES$
 *      El cdigo fuente est en source\vm\arrays.c
 *      La librera asociada es vm
 *  $SEEALSO$
 *      EVAL(),DBEVAL()
 *  $END$
 */


/*  $DOC$
 *  $FUNCNAME$
 *      ACOPY()
 *  $CATEGORY$
 *      ARRAY
 *  $ONELINER$
 *      Copia elementos de un array a otro
 *  $SYNTAX$
 *      ACOPY( <aOrigen>, <aDestino>, [<nInicio>], [<nContador>],
 *             [<nPosDestino>] )--> aDestino
 *  $ARGUMENTS$
 *      <aOrigen>    es el array desde el que se copian los elementos.
 *
 *      <aDestino>   es el array al que se copian los elementos.
 *
 *      <nInicio>    es la posicin desde donde se inicia la copia en
 *                   <aOrigen>. Por defecto es uno.
 *      <nContador>  es el nmero de elementos a copiar comenzando en la
 *                   posicin <nInicio>
 *
 *      <nPosDestino> es la posicin de inicio en el array <aDestino> hacia
 *                    donde se copian los elementos. Por defecto es uno.
 *  $RETURNS$
 *      ACOPY() retorna una referencia al array <aDestino>
 *  $DESCRIPTION$
 *      ACOPY() copia elementos desde el array <aOrigen> hacia el array
 *      <aDestino>. Esta funcin copia todo tipo de datos.
 *
 *      Si un elemento en el array <aOrigen> es un puntero de referencia a
 *      otro array (submatriz), esa referencia ser copiada al array
 *      <aDestino> pero no todas las dimensiones sern copiadas de un array
 *      al otro. Esto debe ser realizado via funcin ACLONE().
 *
 *      Note
 *      Si el array <aOrigen> es mayor que <aDestino>, los elementos en el
 *      array comienzan a ser copiados en <nPosDestino> y continuan
 *      copiandose hasta que el final del array <aDestino> es alcanzado, los
 *      elementos que sobran en <aOrigen> se descartan.
 *      La funcin ACOPY() no agrega posiciones al array destino, el tamao
 *      del array <aDestino> permanece constante.
 *  $EXAMPLES$
 *      * El ejemplo siguiente copia un array sobre otro.
 *
 *      LOCAL nContador := 2, nInicio := 1, aUltimo, aPrimero
 *      aUltimo  := { "HARBOUR", " es el ", "Heredero" }
 *      aPrimero := { "CLIPPER", " fue el ", "Pionero" }
 *      ACOPY( aUltimo, aPrimero, nInicio, nContador)
 *  $STATUS$
 *      R
 *  $COMPLIANCE$
 *      Esta funcin es totalmente compatible con CA-Cl*pper.
 *  $FILES$
 *      El cdigo fuente est en source\vm\arrays.c
 *      La librera asociada es vm
 *  $SEEALSO$
 *      ACLONE(),ADEL(),AEVAL(),AFILL(),AINS(),ASORT()
 *  $END$
 */


/*  $DOC$
 *  $FUNCNAME$
 *      ACLONE()
 *  $CATEGORY$
 *      ARRAY
 *  $ONELINER$
 *      Duplica un array anidado  multidimensional
 *  $SYNTAX$
 *      ACLONE( <aOrigen> ) --> aDuplicado
 *  $ARGUMENTS$
 *      <aOrigen> es el nombre del array a ser clonado.
 *  $RETURNS$
 *      ACLONE() retorna <aDuplicate> un nueva referencia a otro array
 *      exactamente igual al original.
 *  $DESCRIPTION$
 *      Esta funcin realiza una copia completa del array llamado <aOrigen>.
 *      Crea todas las dimensiones en el array <aDestino> que existen en el
 *      array original y luego llena cada dimensin con los mismos valores
 *      de los elementos en el original.
 *      Ambos arrays coexisten como entidades distintas.
 *  $EXAMPLES$
 *      * El ejemplo siguiente crea un array bidimensional y lo duplica.
 *        Se muestra que son copiadas ambas dimensiones.
 *
 *        LOCAL aOrigen, aDestino
 *        aOrigen  := { {1, 2}, {3, 4}, {5, 6}, {7, 8}, {9, 10} }
 *        aDestino := ACLONE( aOrigen )
 *
 *        * primera dimensin
 *        ? "Impares son: "                // Resultado: es {1, 3, 5, 7, 9}
 *        FOR n := 1 TO LEN( aDestino)
 *            ?? aDestino [n][1]
 *        NEXT
 *
 *        * segunda dimensin
 *        ? "Pares   son: "                // Resultado: es {2, 4, 6, 8, 10}
 *        FOR n := 1 TO LEN( aDestino)
 *            ?? aDestino [n][2]
 *        NEXT
 *
 *  $STATUS$
 *      R
 *  $COMPLIANCE$
 *      Clipper retorna NIL si el parmetro no es un array.
 *  $FILES$
 *      El cdigo fuente est en source\vm\arrays.c
 *      La librera asociada es vm
 *  $SEEALSO$
 *      ACOPY(),ADEL(),AINS(),ASIZE()
 *  $END$
 */


/*  $DOC$
 *  $FUNCNAME$
 *      ASORT()
 *  $CATEGORY$
 *      ARRAY
 *  $ONELINER$
 *      Ordena un array
 *  $SYNTAX$
 *      ASORT( <aDestino>, [<nInicio>], [<nContador>],
 *             [<bOrden>] ) --> aDestino
 *  $ARGUMENTS$
 *      <aDestino>  es el nombre del array a ser ordenado.
 *
 *      <nInicio>   es el primer elemento para comenzar el ordenamiento.
 *                  Por defecto es uno.
 *
 *      <nContador> es el nmero de elementos a ordenar comenzando en la
 *                  posicin <nInicio>. Por defecto son todos los elementos
 *
 *      <bOrden>    es el bloque de cdigo para el orden de ordenamiento,
 *                  por defecto es en orden ascendente {| x, y | x < y }.
 *                  El bloque de cdigo debe recibir dos elementos del array
 *                  como parametros y debe retornar .T. si el orden es el
 *                  correcto, .F. en caso contrario.
 *  $RETURNS$
 *      ASORT() retorna una referencia al reciente array ordenado <aDestino>
 *       NIL si el parmetro <aDestino> no es un array.
 *  $DESCRIPTION$
 *      Esta funcion ordena todo  parte de un array dado. Si <bOrden> es
 *      omitido, la funcin espera que <aDestino> sea un array unidimensional
 *      conteniendo un solo tipo de datos (uno de: CHARACTER, DATE, LOGICAL,
 *      NUMERIC) y ordena este array en orden ascendente: los caracteres son
 *      ordenados por su valor ASCII, las fechas son ordenadas
 *      cronologicamente el valor lgico .F. va antes de .T. y los valores
 *      numricos son ordenados por su valor.
 *
 *      Si <bOrden> es especificado este es usado para manejar la forma de
 *      ordenamiento. Cada vez que el bloque es evaluado, dos elementos del
 *      array son pasados al bloque de cdigo, y el bloque debe retornar un
 *      valor lgico que define si esos elementos estan en orden (.T.)  no
 *      (.F.). Usando este bloque se puede ordenar arrays multidimensionales
 *      hacer un ordenamiento descendente  an (pero para que querria Ud.
 *      hacerlo) ordenar un array que contenga diferentes tipo de datos.
 *  $EXAMPLES$
 *      * El siguiente ejemplo ordena valores numericos en orden ascendente
 *
 *        ASORT( { 3, 1, 4, 42, 5, 9 })   // Resultado: { 1, 3, 4, 5, 9, 42}
 *
 *      * El siguiente ejemplo ordena cadenas en orden descendente
 *        LOCAL aKeys := { "Ctrl", "Alt", "Delete" }, n
 *        LOCAL bOrden := {| x, y | UPPER( x ) > UPPER( y ) }
 *        ASORT( aKeys,,, bOrden )
 *        FOR n = 1 TO LEN( aKeys )
 *            ? aKeys [n]          // Resultado: { "Delete", "Ctrl", "Alt"}
 *        NEXT
 *
 *      * El siguiente ejemplo ordena dos arrays bidimensionales de acuerdo
 *        al segundo elemento de cada par.
 *
 *        LOCAL aPair := { {"Sun",8}, {"Mon",1}, {"Tue",57}, {"Wed",-6} }
 *        ASORT( aPair,,, {| x, y | x[2] < y[2] } )
 *
 *        FOR n = 1 TO LEN( aPair )
 *            ? aPair [n][1],  aPair [n][2]
 *        NEXT
 *        // Resultado: { {"Wed",-6}, {"Mon",1}, {"Sun",8}, {"Tue",57} }
 *  $STATUS$
 *      R
 *  $COMPLIANCE$
 *      La frecuencia de llamada al bloque de cdigo y el orden difiere de
 *      Clipper debido a que Harbour usa un algoritmo distinto (ms rpido)
 *      de ordenamiento (quicksort).
 *  $FILES$
 *      El cdigo fuente est en source\vm\arrays.c
 *      La librera asociada es vm
 *  $SEEALSO$
 *      ASCAN(),EVAL(),SORT
 *  $END$
 */


