Publicado Ruby 3.2.0 Preview 2

Nos complace anunciar la publicación de Ruby 3.2.0-preview2. Ruby 3.2 añade muchas características y mejoras en desempeño.

Soporte para WebAssembly basado en WASI

Esta es un porte inicial del soporte para WebAssembly basado en WASI. Esto permite que un binario de CRuby esté disponible en navegadores Web, ambientes sin servidor Edge y otros empotrables WebAssembly/WASI. Actualmente este porte pasa los juegos de pruebas básicas de bootstrap que no usan el API de Threads.

Trasfondo

WebAssembly (Wasm) fue introducido inicialmente para ejecutar programas de manera segura y rápida en navegadores web. Pero buena parte de su objetivo –ejecutar programar eficientemente y con seguridad– es anhelado hace tiempo no sólo para el web sino para aplicaciones en general.

WASI (The WebAssembly System Interface) fue diseñado para ese caso de uso. Aunque una aplicación necesita comunicarse con el sistema operativo, WebAssembly corre en una máquina virtual que no tiene una interfaz del sistema. WASI lo estandariza.

El soporte para WebAssembly/WASI en ruby pretende aprovechar estos proyectos. Habilita a los desarrolladores de ruby para escribir aplicaciones que corran en esa plataforma prometida.

Caso de uso

Este soporte hace posible que los desarrolladores utilicen CRuby en un ambiente WebAssembly. Un caso de uso de ejemplo es el soporte CRuby del espacio de juego TryRuby. Ahora usted puede probar CRuby original en su navegador web.

Puntos técnicos

Hoy en día WASI y WebAssembly carecen de algunas características para implementar Fibras, excepciones y el Recolector de Basura porque aún está evolucionado y también por razones de seguridad. Así que CRuby llena ese vació mediante Asyncify, que es una técnica de transformación binaria para controlar la ejecución en el espacio del usuario.

Además, construimos un Sistema Virtual de Archivos (VFS) sobre WASI que permite empaquetar con facilidad aplicación Ruby en un sólo archivo .wasm. Esto hace un poco más fácil la distribución de aplicaciones.

Enlaces relacionados

Temporizadore para Regexp

Se introduce una característica de temporizador durante concordancias de expresiones regulares.

Regexp.timeout = 1.0

/^a*b?a*$/ =~ "a" * 50000 + "x"
#=> Regexp::TimeoutError is raised in one second

Se sabe que la concordancia de expresiones regulares puede tardar un tiempo inesperadamente largo. Si su código intenta concordar una expresión regular posiblemente ineficiente con una cadena no confiable, un atacante podría explotarlo para lograr una Denegación de Servicio efectiva (también llamada Denegación de servicio por expresiones regulares o ReDoS).

El riesgo de Denegaciones de Servicio (DoS) puede prevenirse o mitigarse significativamente al configurar Regexp.timeout de acuerdo a los requerimientos de su aplicación Ruby. Por favor pruébelo en su aplicación, después le damos la bienvenida a su retroalimentación.

Observe que Regexp.timeout es una configuración global. Si quiere usar una configuración del temporizador diferente para una cierta expresión regular, puede usar la palabra reservada timeout junto con Regexp.new.

Regexp.timeout = 1.0

# Esta regexp no tiene tiempo límite
long_time_re = Regexp.new("^a*b?a*$", timeout: nil)

long_time_re =~ "a" * 50000 + "x" # nunca interrumpido

La propuesta original está en https://bugs.ruby-lang.org/issues/17837

Otras características nuevas y notables

Ya no se incluyen fuentes de terceros

  • Ya no incluimos las fuentes de terceros como libyaml y libffi.

    • la fuente de libyaml fue eliminada de psych. Puede instalar libyaml-dev en plataformas Ubuntu/Debian. El nombre del paquete difiere en cada plataforma.

    • libffi será eliminado de fiddle durante la segunda versión previa.

Lenguaje

  • Argumentos anónimos para el resto y con palabra clave para el resto ahora pueden ser pasados como argumentos, en lugar de sólo ser usados en parámetros de métodos. [Característica #18351]

      def foo(*)
        bar(*)
      end
      def baz(**)
        quux(**)
      end
    
  • Un proc que acepte un solo argumento posicional y palabras clave ya no hará splat automaticamente. [Falla #18633]

    proc{|a, **k| a}.call([1, 2])
    # Ruby 3.1 and before
    # => 1
    # Ruby 3.2 and after
    # => [1, 2]
    
  • El orden de evaluación de la asignación de constantes para constantes establecidas en objetos explícitos se ha hecho consistente con el orden de evaluación de la asignación de atributos. Con este código:

      foo::BAR = baz
    

    foo ahora es llamado antes que baz. De forma similar, para asignaciones múltiples a constantes, se usa un orden de evalulacón de izquierda a derecha. Con el siguiente código:

        foo1::BAR1, foo2::BAR2 = baz1, baz2
    

    Ahora se usa el siguiente orden de evaluación:

    1. foo1
    2. foo2
    3. baz1
    4. baz2

    [Falla #15928]

  • El patrón Find ya no es experimental. [Característica #18585]

  • Los métodos que reciben un parametro para el resto (como *args) y que quieren delegar argumentos de palabra clave con foo(*args) ahora deben marcarse con ruby2_keywords (si es que aún hace falta). En otras palabras, todos los métodos que quieren delegar argumentos de palabra clave por medio de *args ahora deben marcarse con ruby2_keywords, sin excepción. Esto hará más fácil la transición a otras formas de delegación una vez una librería pueda requerir Ruby 3+. Antes, la opción ruby2_keywords se mantenía si el método receptor tomaba *args, pero esto era una falla y una inconsistencia. Una buena técnica para encontrar posibles ruby2_keywords faltantes es ejecutar la suite de pruebas, y donde falle buscar el último método que debe recibiri argumentos de palabra clave , usar puts nil caller, nil allí, y revisar que cada método/bloque en la cadena de llamados que delegue palabras clave esté marcado correctamente como ruby2_keywords. [Falla #18625] [Falla #16466]

      def target(**kw)
      end
    
      # Accidentalmente funcionaba sin ruby2_keywords en Ruby 2.7-3.1,
      # necesita ruby2_keywords en 3.2+.
      # Tal como (*args, **kwargs) o (...) se necesitarían tanto en #foo
      # como  #bar cuando se migró de ruby2_keywords.
      ruby2_keywords def bar(*args)
        target(*args)
      end
    
      ruby2_keywords def foo(*args)
        bar(*args)
      end
    
      foo(k: 1)
    

Mejoras en desempeño

YJIT

  • Soporte para arm64 / aarch64 sobre plataformas UNIX.
  • La compilación de YJIT requiere Rust 1.58.1+. [Característica #18481]

Otros cambios notables desde 3.1

Asuntos de compatibilidad

Nota: Excluyendo arreglos de fallas.

Constantes eliminadas

Las siguientes constantes despreciadas han sido eliminados.

Métodos eliminados

Los siguientes métodos despreciados han sido eliminados.

Asuntos de compatibilidad en Stdlib

  • Psych ya no incluye las fuentes de libyaml. Los usuarios necesitan instalar la librería libyaml por si mismos con el sistema de paquetes. [Característica #18571]

Actualización al API en C

Eliminado del API en C

Las siguientes APIs han sido eliminadas.

Actualizaciones a la librería estándar

  • Se actualizaron las siguientes gemas predeterminadas.

    • TBD
  • Se actualizaron las siguientes gemas incluidas.

    • TBD
  • Las siguientes gemas predeterminadas ahora son gemas incluidas (bundled). Debe agregar las siguientes librerías al Gemfile en entornos que usan bundler.

    • TBD

Ver más detalles en NEWS o en la bitácora de cambios.

Con esos cambios, 2393 archivos cambiados, 168931 inserciones(+), 113411 eliminaciones(-) desde Ruby 3.1.0!

Descargas

  • https://cache.ruby-lang.org/pub/ruby/3.2/ruby-3.2.0-preview2.tar.gz

    SIZE: 19816780
    SHA1: 2106c77fc1600daf41ae137ecc4cf7937e27f67f
    SHA256: 8a78fd7a221b86032f96f25c1d852954c94d193b9d21388a9b434e160b7ed891
    SHA512: 5e9ddcb1a43cff449b0062cc716bfb80a9ebbb14a1b063f34005e2998c2c5033badb44e882232db9b2fceda9376f6615986e983511fda2575d60894752b605cc
    
  • https://cache.ruby-lang.org/pub/ruby/3.2/ruby-3.2.0-preview2.tar.xz

    SIZE: 14578112
    SHA1: 538b3ea4dc0d99f60f8bd6f71e65a56ceeb41c18
    SHA256: 01fac0929dccdabc0686c1109da6c187897a401da9ff8851242befa92f7fd430
    SHA512: 0f4cc919284fdfa1a42b6381760d1b3a4660da4b0fcdd2adf01ea04a425548b3c5ac090866915675db73964a1055090e54dd97cf4628cbb69403e541c71c28ff
    
  • https://cache.ruby-lang.org/pub/ruby/3.2/ruby-3.2.0-preview2.zip

    SIZE: 24150109
    SHA1: 69ffffc52cad626166f73f21f25c29c9d73fe0e8
    SHA256: 67f9ad3110be1975b3ce547c0a6e2c910dfc1945fd6e9bb1bd340568897c6554
    SHA512: 1447e099e7a8da0ff206fda6f4e466640d6e86e9da8148315ab0154684b1fd22c02c0022b5a2f4d3fc00103b4e8cef8e35a770174921fd8c6abeca9ad41c1818
    

Lo que es Ruby

Ruby fue desarrollado inicialmente por Matz (Yukihiro Matsumoto) en 1993, y ahora es desarrollado como Código Abierto. Corre en múltiples plataformas y se usa en todo el mundo especialmente para desarrollo web.