Выпуск Rust 1.12.1

Мы рады представить новую версию Rust 1.12.1. Rust — это системный язык программирования, нацеленный на безопасную работу с памятью, скорость и параллельное выполнение кода.


Как обычно, вы можете установить Rust 1.12.1 с соответствующей страницы официального сайта, или с помощью rustup выполнив команду rustup update stable.


Что вошло в стабильную версию 1.12.1


Секундочку… один-точка-двенадцать-точка… один?


Несколько недель назад, в анонсе версии 1.12, мы сказали:


Выпуск 1.12 — возможно, самый значительный с момента выпуска 1.0.

И это правда. Одним из важных изменений был масштабный рефакторинг компилятора. Новый бэкенд MIR изменил его архитектуру и некоторые детали реализации. В целом процесс модернизации прошел так:


  • Начальная поддержка MIR появилась в ночных сборках Rust 1.6.
  • Когда работа была завершена, был добавлен флаг компиляции --enable-orbit,
    что бы разработчики компилятора могли испытать новый бэкенд.
  • Начиная с октября, мы всегда выполняли сборку MIR, даже если
    он не использовался.
  • Был добавлен параметр командной стоки -Z orbit, что бы пользователи ночных
    сборок могли испытать и использовать MIR вместо этапа компиляции 'trans'.
  • После длительного тестирования в течение нескольких месяцев, для версии
    Rust 1.12, мы сделали MIR бэкендом по умолчанию.
  • В Rust 1.13, будет доступен только MIR.

Столь глобальные изменения даются нелегко и очень важны. Поэтому важно сделать всё правильно и тщательно. Вот почему этот процесс идёт так долго. Мы регулярно тестируем компилятор с каждым из пакетов на crates.io, мы просим пользователей проверить -Z orbit на их исходниках, и после шести недель бета-тестирования, так и не возникло существенных проблем. Поэтому мы приняли решение использовать MIR по умолчанию в версии 1.12.


Но большие изменения это всегда риск, хоть мы старались свести его к минимуму. И так, после выхода 1.12, были найдены регрессии, которые мы не смогли обнаружить при тестировании. Не все из них связаны с MIR, просто, при столь масштабных изменениях, легко проявляются ошибки в других местах.


Зачем делать промежуточный релиз?


Учитывая, что у нас шестинедельный цикл выпуска, и мы на полпути к Rust 1.13, почему мы решили выпустить исправление к версии 1.12, а не предложить пользователям просто подождать следующего релиза? Ранее мы говорили нечто подобное: «промежуточные релизы будут происходить только в крайних случаях, таких как уязвимость в стандартной библиотеке».


Мы заботимся не только о стабильности, но и о удобстве использования языка. Мы могли бы сказать всем вам подождать, но мы хотим, чтобы вы знали насколько серьезно мы настроены. Выпуск промежуточного релиза, в данной ситуации, это еще и способ показать наше стремление как можно быстрее исправлять ошибки.


Кроме того, раз уж речь не идёт о проблемах безопасности, это хороший повод попрактиковаться в выпуске промежуточных релизов. Мы никогда не делали этого раньше, и хотя процесс выпуска новой версии частично автоматизирован, но не полностью. Наличие промежуточного релиза позволит выявить ошибки среди других инструментальных средств, например rustup. А еще убедиться, что всё пройдёт по плану, если нам когда-нибудь понадобится, выпустить аварийный релиз из-за проблем безопасности или по любой другой причине.


Это первый промежуточный релиз Rust после выхода Rust 0.3.1, случившегося в 2012, он знаменует 72 недели с момента выпуска Rust 1.0, когда мы приняли наш шестинедельный такт выпуска релизов со строгими гарантиями стабильности. И хотя нам очень жаль, что в 1.12 есть регрессии, мы гордимся стабильностью Rust и будем прилагать все усилия, что бы сделать его платформой на которую можно положиться.


Мы хотим, чтобы Rust был самой надежной в мире платформой для разработки программного обеспечения.


Примечание о тестировании с использованием бета-версий


Есть кое-что, что вы, как пользователь Rust, можете сделать, чтобы помочь нам исправить ошибки как можно раньше: проверяйте свой код с использованием бета-версий! Каждый бета-релиз, это релиз-кандидат следующей стабильной версии, так давайте использовать средства непрерывной интеграции. Так вы сможете сообщить нам о проблемах еще до того как они попадут в стабильный релиз! Это совсем не сложно. Например, если вы используете Travis, добавьте это в свой .travis.yml:


language: rust
rust:
  - stable
  - beta

И ваши тесты будут выполняться для двух версий компилятора. Кроме того, если вы не хотите, что бы ошибка в бета-версии приводила к ошибке всей сборки, добавьте это:


matrix:
  allow_failures:
    - rust: beta

Сборка с бета-версией может стать красной, но ваша стабильная сборка останется зелёной.


Большинство других систем непрерывной интеграции, таких как AppVeyor, должны иметь подобную возможность. Обратитесь к документации используемой вами системы.


Подробности


В версии 1.12.1 было исправлено девять ошибок, естественно, все эти исправления были перенесены в бета-версию 1.13.


  • ICE: 'rustc' паниковал с сообщением 'assertion failed: concrete_substs.is_normalized_for_trans ()' #36381
  • Путаница с двойным отрицанием и логическими переменными
  • rustc 1.12.0 завершался с SIGSEGV при сборке релиза для пакета syn 0.8.0
  • Rustc 1.12.0 Windows-сборка пакета ethcore прерывалась с ошибкой LLVM
  • 1.12.0: Использовалось много памяти при линковке релиз-версии с отладочной информацией
  • Повреждение памяти после перехода на 1.12
  • «Let NullaryConstructor = something;» приводит в внутренней ошибке компилятора: «tried to overwrite interned AdtDef»
  • Fix ICE: inject bitcast if types mismatch for invokes/calls/stores
  • debuginfo: Более правильная обработка spread_arg в MIR-trans.

Кроме того, есть еще четыре регрессии. Мы решили не включать их в 1.12.1 по разным причинам, но постараемся устранить их как можно скорее.


  • ICE, возможно, связанный с типами ассоциированных типов?
  • Ошибка компиляции пакета использующего большой static phf: Map, на i686-pc-windows-gnu Beta
  • Регрессия: ошибка «no method found» при вызове метода дважды, с HRTB impl
  • ICE: фиктивный тип sizing_type_of

Полный перечень изменений между версиями 1.12.0 и 1.12.1 здесь.

Комментарии (3)

  • 8 ноября 2016 в 14:02

    0

    Зачем с опозданием на 3 недели переводить новость промежуточном релизе 1.12.1, если через два дня ожидается 1.13?
    • 8 ноября 2016 в 14:12

      0

      Лучше поздно чем никогда)
    • 8 ноября 2016 в 14:17

      +1

      Перевод был сделан давно. К сожалению, его не удалось оперативно разместить здесь.
      Это первый промежуточный релиз Rust, он интересен сообществу. Не хотелось бы совсем его игнорировать.

© Habrahabr.ru