diff options
Diffstat (limited to 'es-es')
-rw-r--r-- | es-es/raku-es.html.markdown | 115 |
1 files changed, 56 insertions, 59 deletions
diff --git a/es-es/raku-es.html.markdown b/es-es/raku-es.html.markdown index 0c186682..8efa0349 100644 --- a/es-es/raku-es.html.markdown +++ b/es-es/raku-es.html.markdown @@ -10,7 +10,6 @@ translators: - ["Luis F. Uceta", "https://github.com/uzluisf"] lang: es-es --- - Raku es un lenguaje de programación altamente capaz y con características abundantes para hacerlo el lenguage ideal por los próximos 100 años. @@ -58,7 +57,7 @@ my $nombre'de-variable_ = 5; # Esto funciona! my $booleano = True; # `True` y `False` son valores booleanos en Raku. my $inverso = !$booleano; # Puedes invertir un booleano con el operador prefijo `!` my $bool-forzado = so $str; # Y puedes usar el operador prefijo `so` que - # convierte su operador en un Bool + # convierte su operador en un Bool ``` ### Arrays y Listas @@ -74,7 +73,7 @@ my @letras = <a b c>; # array de palabras, delimitado por espacios. my @array = 1, 2, 3; say @array[2]; # Los índices de un array empiezan por el 0 -- Este es - # el tercer elemento. + # el tercer elemento. say "Interpola todos los elementos de un array usando [] : @array[]"; #=> Interpola todos los elementos de un array usando [] : 1 2 3 @@ -84,7 +83,7 @@ say "Interpola todos los elementos de un array usando [] : @array[]"; my @llaves = 0, 2; @array[@llaves] = @letras; # Asignación usando un array que contiene valores - # índices + # índices say @array; #=> a 6 b ``` @@ -99,8 +98,8 @@ say @array; #=> a 6 b ## cualquier llave duplicada es deduplicada. my %hash = 1 => 2, 3 => 4; -my %hash = foo => "bar", # las llaves reciben sus comillas - # automáticamente. +my %hash = foo => "bar", # las llaves reciben sus comillas + # automáticamente. "some other" => "value", # las comas colgantes estań bien. ; @@ -151,9 +150,9 @@ say devolver-vacio; # imprime Nil ## Algunas estructuras de control producen un valor. Por ejemplo if: sub devuelva-si { - if True { - "Truthy"; - } + if True { + "Truthy"; + } } say devuelva-si; # imprime Truthy @@ -166,7 +165,7 @@ say return-for; # imprime Nil ## Una subrutina puede tener argumentos opcionales: sub con-opcional($arg?) { # el signo "?" marca el argumento opcional say "Podría returnar `(Any)` (valor de Perl parecido al 'null') si no me pasan - un argumento, o returnaré mi argumento"; + un argumento, o returnaré mi argumento"; $arg; } con-opcional; # devuelve Any @@ -178,9 +177,9 @@ con-opcional(1); # devuelve 1 sub hola-a($nombre = "Mundo") { say "¡Hola, $nombre!"; } -hola-a; #=> ¡Hola, Mundo! -hola-a(); #=> ¡Hola, Mundo! -hola-a('Tú'); #=> ¡Hola, Tú! +hola-a; #=> ¡Hola, Mundo! +hola-a(); #=> ¡Hola, Mundo! +hola-a('Tú'); #=> ¡Hola, Tú! ## De igual manera, al usar la sintaxis parecida a la de los hashes ## (¡Hurra, sintaxis unificada!), puedes pasar argumentos *nombrados* @@ -204,12 +203,12 @@ sub con-nombre-mandatorio(:$str!) { say "$str!"; } con-nombre-mandatorio(str => "Mi texto"); #=> Mi texto! -con-nombre-mandatorio; # error al tiempo de ejecución: - # "Required named parameter not passed" - # ("Parámetro nombrado requerido no proveído") -con-nombre-mandatorio(3);# error al tiempo de ejecución: - # "Too many positional parameters passed" - # ("Demasiados argumentos posicionales proveídos") +con-nombre-mandatorio; # error al tiempo de ejecución: + # "Required named parameter not passed" + # ("Parámetro nombrado requerido no proveído") +con-nombre-mandatorio(3); # error al tiempo de ejecución: + # "Too many positional parameters passed" + # ("Demasiados argumentos posicionales proveídos") ## Si una subrutina toma un argumento booleano nombrado ... sub toma-un-bool($nombre, :$bool) { @@ -277,7 +276,7 @@ mutar $m; # ¡$n es ahora 43! ## por naturaleza: mutar 42; # Parámetro '$n' esperaba un contenedor mutable, - # pero recibió un valor Int + # pero recibió un valor Int ## Si en cambio quieres una copia, debes usar `is copy`. @@ -287,7 +286,7 @@ my $x = 42; sub x-almacena() is rw { $x } x-almacena() = 52; # En este caso, los paréntesis son mandatorios # (porque de otra forma, Raku piensa que la función - # `x-almacena` es un identificador). + # `x-almacena` es un identificador). say $x; #=> 52 ``` @@ -347,7 +346,7 @@ say $edad > 18 ?? "Eres un adulto" !! "Eres menor de 18"; given "foo bar" { say $_; #=> foo bar when /foo/ { # No te preocupies acerca de la coincidencia inteligente – - # solo ten presente que `when` la usa. + # solo ten presente que `when` la usa. # Esto es equivalente a `if $_ ~~ /foo/`. say "¡Yay!"; } @@ -379,9 +378,9 @@ loop { loop (my $i = 0; $i < 5; $i++) { next if $i == 3; # `next` salta a la siguiente iteración, al igual - # que `continue` en otros lenguajes. Ten en cuenta que - # también puedes usar la condicionales postfix (sufijas) - # bucles, etc. + # que `continue` en otros lenguajes. Ten en cuenta que + # también puedes usar la condicionales postfix (sufijas) + # bucles, etc. say "¡Este es un bucle al estilo de C!"; } @@ -398,18 +397,18 @@ for @array { .say; # Esto es también permitido. # Una invocación con punto (dot call) sin "tópico" (recibidor) es - # enviada a `$_` por defecto. + # enviada a `$_` por defecto. $_.say; # lo mismo de arriba, lo cual es equivalente. } for @array { # Puedes... next if $_ == 3; # Saltar a la siguiente iteración (`continue` en - # lenguages parecido a C) + # lenguages parecido a C) redo if $_ == 4; # Re-hacer la iteración, manteniendo la - # misma variable tópica (`$_`) + # misma variable tópica (`$_`) last if $_ == 5; # Salir fuera del bucle (como `break` - # en lenguages parecido a C) + # en lenguages parecido a C) } ## La sintaxis de "bloque puntiagudo" no es específica al bucle for. @@ -433,7 +432,7 @@ if computación-larga() -> $resultado { ## - "infix" (infijo): en medio de (como `*` en `4 * 3`). ## - "circumfix" (circunfijo): alrededor de (como `[`-`]` en `[1, 2]`). ## - "post-circumfix" (pos-circunfijo): alrededor de un término, -## posterior a otro término. +## posterior a otro término. ## (como `{`-`}` en `%hash{'key'}`) ## La lista de asociatividad y precedencia se explica más abajo. @@ -506,8 +505,8 @@ False ~~ True; # True ## ociosos/infinitos, usando la Whatever Star: my @array = 1..*; # 1 al Infinito! `1..Inf` es lo mismo. say @array[^10]; # puedes pasar arrays como subíndices y devolverá - # un array de resultados. Esto imprimirá - # "1 2 3 4 5 6 7 8 9 10" (y no se quedaré sin memoria!) + # un array de resultados. Esto imprimirá + # "1 2 3 4 5 6 7 8 9 10" (y no se quedaré sin memoria!) ## Nota: Al leer una lista infinita, Raku "cosificará" los elementos que ## necesita y los mantendrá en la memoria. Ellos no serán calculados más de ## una vez. Tampoco calculará más elementos de los que necesita. @@ -518,7 +517,7 @@ say join(' ', @array[15..*]); #=> 15 16 17 18 19 ## lo que es equivalente a: say join(' ', @array[-> $n { 15..$n }]); ## Nota: Si tratas de hacer cualquiera de esos con un array infinito, -## provocará un array infinito (tu programa nunca terminará) +## provocará un array infinito (tu programa nunca terminará) ## Puedes usar eso en los lugares que esperaría, como durante la asignación ## a un array @@ -716,8 +715,7 @@ multi dilo(Str $s) { # un multi es una subrutina por defecto } dilo("azul"); # prints "Cadena de texto: azul" dilo(True); # falla al *tiempo de compilación* con - # "calling 'dilo' will never work with arguments of types ..." - # (invocar 'dilo' nunca funcionará con argumentos de tipos ...") + # (invocar 'dilo' nunca funcionará con argumentos de tipos ...") ## con precondición arbitraria (¿recuerdas los subconjuntos?): multi es-grande(Int $n where * > 50) { "¡Sí!" } # usando una clausura multi es-grande(Int $ where 10..50) { "Tal vez." } # Usando coincidencia inteligente @@ -743,7 +741,7 @@ multi sin_ti-o-contigo { ## en muchos lugares. ## ## - `is`, por ejemplo, es actualmente un `multi sub` llamado -## `trait_mod:<is>`. +## `trait_mod:<is>`. ## - `is rw`, es simplemente un despacho a una función con esta signatura: ## sub trait_mod:<is>(Routine $r, :$rw!) {} ## @@ -847,7 +845,7 @@ class Clase-Atrib { method asignar-valor($param) { # Métodos pueden tomar parámetros. $!attrib = $param; # Esto funciona porque `$!` es siempre mutable. - # $.attrib = $param; # Incorrecto: No puedes usar la versión inmutable `$.`. + # $.attrib = $param; # Incorrecto: No puedes usar la versión inmutable `$.`. $.otro-atrib = 5; # Esto funciona porque `$.otro-atrib` es `rw`. } @@ -864,7 +862,7 @@ my $class-obj = Clase-Atrib.new(atrib => 5); say $class-obj.devolver-valor; #=> 5 # $class-obj.atrib = 5; # Esto falla porque `has $.atrib` es inmutable $class-obj.otro-atrib = 10; # En cambio, esto funciona porque el atributo - # público es mutable (`rw`). + # público es mutable (`rw`). ``` ### Herencia de Objeto @@ -900,7 +898,7 @@ $Richard.hablar; #=> "Hola, mi nombre es Richard" my Niño $Madison .= new(edad => 1, nombre => 'Madison'); $Madison.hablar; # imprime "Goo goo ga ga" dado que el método fue cambiado - # en la clase Niño. + # en la clase Niño. # $Madison.color-favorito # no funciona porque no es heredado ## Cuando se usa `my T $var` (donde `T` es el nombre de la clase), `$var` @@ -1022,11 +1020,11 @@ try { when X::AdHoc { say "Error: $_" } #=>Error: Failed to open file /dir/foo: no such file or directory - ## Cualquier otra excepción será levantada de nuevo, dado que no - ## tenemos un `default`. - ## Básicamente, si un `when` + ## Cualquier otra excepción será levantada de nuevo, dado que no + ## tenemos un `default`. + ## Básicamente, si un `when` ## Basically, if a `when` matches (or there's a `default`) marks the - ## exception as + ## exception as ## "handled" so that it doesn't get re-thrown from the `CATCH`. ## You still can re-throw the exception (see below) by hand. } @@ -1084,7 +1082,7 @@ module Hello::World { # forma de llaves unit module Parse::Text; # forma de ámbito de archivo grammar Parse::Text::Grammar { # Una gramática (grammar en inglés) es un paquete, - # en el cual puedes usar `use` + # en el cual puedes usar `use` } # Aprenderás más acerca de gramáticas en la sección de regex ## Como se dijo anteriormente, cualquier parte del modelo seis es también un @@ -1180,19 +1178,19 @@ for ^5 -> $a { ## * Phasers al tiempo de compilación BEGIN { say "[*] Se ejecuta al tiempo de compilación, " ~ - "tan pronto como sea posible, una sola vez" } + "tan pronto como sea posible, una sola vez" } CHECK { say "[*] Se ejecuta al tiempo de compilación, " ~ - "tan tarde como sea posible, una sola vez" } + "tan tarde como sea posible, una sola vez" } ## * Phasers al tiempo de ejecución INIT { say "[*] Se ejecuta al tiempo de ejecución, " ~ - "tan pronto como sea posible, una sola vez" } + "tan pronto como sea posible, una sola vez" } END { say "Se ejecuta al tiempo de ejecución, " ~ "tan tarde como sea posible, una sola vez" } ## * Phasers de bloques ENTER { say "[*] Se ejecuta cada vez que entra en un bloque, " ~ - "se repite en bloques de bucle" } + "se repite en bloques de bucle" } LEAVE { say "Se ejecuta cada vez que abandona un bloque, incluyendo " ~ "cuando una excepción ocurre. Se repite en bloques de bucle"} @@ -1381,8 +1379,8 @@ say 5!; #=> 120 sub infix:<veces>(Int $n, Block $r) { # infijo va en el medio for ^$n { $r(); # Necesitas los paréntesis explícitos para invocar la función - # almacenada en la variable `$r`. De lo contrario, te estaría - # refiriendo a la variable (no a la función), como con `&r`. + # almacenada en la variable `$r`. De lo contrario, te estaría + # refiriendo a la variable (no a la función), como con `&r`. } } 3 veces -> { say "hola" }; #=> hola @@ -1412,7 +1410,7 @@ say "abc"{1}; #=> b %h{$llave}:delete; ## es equivalente a: postcircumfix:<{ }>(%h, $llave, :delete); # (puedes invocar - # operadores de esta forma) + # operadores de esta forma) ## ¡*Todos* usan los mismos bloques básicos! ## Categorías sintácticas (prefix, infix, ...), argumentos nombrados ## (adverbios), ... - usados para construir el lenguaje - están al alcance @@ -1542,7 +1540,7 @@ say @fib[^10]; #=> 1 1 2 3 5 8 13 21 34 55 ## para los parseos ambiguos es determinado por un examen multi-nivel de ## desempate: ## - La coincidencia de token más larga. `foo\s+` le gana a `foo` -## (por 2 o más posiciones) +## (por 2 o más posiciones) ## - El prefijo literal más largo. `food\w*` le gana a `foo\w*` (por 1) ## - Declaración desde la gramática más derivada a la menos derivada ## (las gramáticas son actualmente clases) @@ -1688,7 +1686,7 @@ so 'fooABCABCbar' ~~ / foo ( 'A' <[A..Z]> 'C' ) + bar /; # `True`. (usando `so` ## Ok. Comenzando con las explicaciones de grupos. Como dijimos, ### nuestra objeto `Match` está disponible en la variable `$/`: say $/; # Imprimirá algo extraño (explicaremos luego) o - # "Nil" si nada coincidió + # "Nil" si nada coincidió ## Como dijimos anteriormente, un objeto Match tiene indexación de array: say $/[0]; #=> 「ABC」 「ABC」 @@ -1733,9 +1731,9 @@ say $/[0][0].Str; #=> ~ say $/[0].list.perl; #=> (Match.new(...),).list # Podemos ver que es una lista de objetos Match. # Estos contienen un montón de información: dónde la - # coincidencia comenzó o terminó, el "ast" - # (chequea las acciones más abajo), etc. - # Verás capturas nombradas más abajo con las gramáticas. + # coincidencia comenzó o terminó, el "ast" + # (chequea las acciones más abajo), etc. + # Verás capturas nombradas más abajo con las gramáticas. ## Alternativas - el `or` de regexes ## Advertencia: Es diferente a los regexes de PCRE. @@ -1794,7 +1792,7 @@ sub MAIN($nombre) { say "¡Hola, $nombre!" } ## (usando un "Bool" por un argumento nombrado para que podamos hacer ## `--replace` a cambio de `--replace=1`) subset File of Str where *.IO.d; # convierte a un objeto IO para chequear si - # un archivo existe + # un archivo existe multi MAIN('add', $key, $value, Bool :$replace) { ... } multi MAIN('remove', $key) { ... } @@ -1926,8 +1924,7 @@ Si quieres ir más allá de lo que se muestra aquí, puedes: explicaciones. Las publicaciones fueron suspendidas al final del 2015 cuando el lenguaje fue declarado estable y Raku.c fue lanzado. - Unirte a `#raku` en `irc.freenode.net`. Las personas aquí son siempre serviciales. - - Chequear la [fuente de las funciones y clases de Raku - ](https://github.com/rakudo/rakudo/tree/master/src/core.c). Rakudo está principalmente + - Chequear la [fuente de las funciones y clases de Raku](https://github.com/rakudo/rakudo/tree/master/src/core.c). Rakudo está principalmente escrito en Raku (con mucho de NQP, "Not Quite Perl" ("No Perl Todavía"), un subconjunto de Raku que es más fácil de implementar y optimizar). - Leer [documentos acerca del diseño del lenguaje](http://design.raku.org). |