vala
1.0.0
1.0.0
  • Учебник Vala
  • Основы
    • Элементы языка
      • Типы данных
      • Управляющие конструкции
      • Методы
      • Делегаты
      • Лямбды / Замыкания
      • Пространства имён
      • Структуры
      • Классы
    • ООП
      • Основы
      • Конструктор
      • Деструктор
      • Сигналы
      • Свойства(Properties)
      • Наследование
      • Абстрактные классы
      • Интерфейсы / Миксины
      • Полиморфизм
      • Сокрытие методов
      • Информация о типах времени выполнения(Run-Time Type Information)
      • Динамическое приведение типов(Dynamic Type Casting)
      • Универсальные шаблоны(Generics)
      • Создание объектов в стиле GObject
      • Интеграция с D-Bus
      • Профили(Другие бэкенды помимо GLib)
  • Продвинутые возможности
    • Ассерты и контрактное программирование
    • Обработка ошибок
    • Управление параметрами
    • Методы с поддержкой синтаксиса
    • Многопоточность
    • Главный цикл(The Main Loop)
    • Асинхронные методы
    • Слабые ссылки(Weak References)
    • Список аргументов переменной длины
    • Указатели
    • Классы не наследующие Object
    • Коллекции
      • Введение
      • HashSet<G>
      • ArrayList<G>
      • HashMap<K,V>
      • Lock-free структуры
  • Экспериментальные фичи
    • Введение
    • Строгий не null режим(Rust mode)
    • Литералы регулярных выражений(regexp)
    • Цепочки связанных выражений
  • Использование и создание библиотек
    • Введение
    • Инструменты
    • Генерирование VAPI файла из предыдущего с помощью vapigen.
    • Использование библиотек
    • Создание библиотеки
    • Vala and C
    • Meson
      • Config file
      • Static Library
      • Shared Library
      • Target GLib Version
  • Технические приёмы
    • Unit тестирование
    • Отладка
    • Использование GLib
  • Продвинуты гайд(WIP)
  • Habr
  • Примеры кода
  • Functional Programming
    • Gpseq
    • Compose
  • Examples
    • Basic
    • GTK
      • Базовые GTK программы
      • Flappy Bird(WIP)
      • DnD
    • Websocket
  • Apps
    • Games
  • Meson-Book
    • MesonBook
    • Wrap
    • Crosscompile
    • Object files
    • Library
    • Executable
    • Code Generation
    • Installing
    • Unit Tests
    • Meson 0.54
    • Meson 0.53
  • golang-book
    • Ваша первая программа
    • Типы
    • UPDATE.MD
Powered by GitBook
On this page
  • Релиз Meson 0.53 !
  • Новый модуль fs
  • Новый флаг --include-subprojects для команды meson dist
  • Добавлены шаблоны проектов для D, Rust, Objective-C!
  • Новая функция summary() для подведения итогов в конце сборки
  • Универсальный Overrider для выбора динамического компоновщика
  • Поддержка стандартов фортран (вплоть до f2018) в виде переменных fortran_std
  • Scalapack
  • Поиск по каталогам для find_program()
  • Tags для целей сборки
  • Словари с использованием строковой переменной в качестве ключа
  • Улучшена поддержка подпроектов CMake
  • compiler.get_linker_id ()
  • Зависимость CUDA
  • Добавлена ​​глобальная опция для отключения C ++ RTTI
  • Изменения API интроспекции

Was this helpful?

  1. Meson-Book

Meson 0.53

PreviousMeson 0.54NextВаша первая программа

Last updated 5 years ago

Was this helpful?

Релиз Meson 0.53 !

Новый модуль fs

Например для проверки файлов на существование:

fs = import('fs')
assert(fs.exists('important_file'),
       'The important file is missing.')

Новый флаг --include-subprojects для команды meson dist

Включает все подпроекты(wrap) в конечный tarball для команды (создает .tar.xz релиз исключая git метаданные и проводя полный цикл компиляции + тест + установка + sha-256 контрольные суммы перед запаковкой) Это может быть полезно для self contained пакетов с модом --wrap-mode=nodownload

Добавлены шаблоны проектов для D, Rust, Objective-C!

Команда meson init --language сгенерирует новый проект с Meson

Новая функция summary() для подведения итогов в конце сборки

project('My Project', version : '1.0')
summary({'bindir': get_option('bindir'),
         'libdir': get_option('libdir'),
         'datadir': get_option('datadir'),
        }, section: 'Directories')
summary({'Some boolean': false,
         'Another boolean': true,
         'Some string': 'Hello World',
         'A list': ['string', 1, true],
        }, section: 'Configuration')

Output:

My Project 1.0

  Directories
             prefix: /opt/gnome
             bindir: bin
             libdir: lib/x86_64-linux-gnu
            datadir: share

  Configuration
       Some boolean: False
    Another boolean: True
        Some string: Hello World
             A list: string
                     1
                     True

Универсальный Overrider для выбора динамического компоновщика

До meson 0.52.0 вам нужно было устанавливаливать динамический компоновщик, используя специфичные для компилятора флаги, передаваемые через флаги компилятору языки, и надеяться, что все получится.

В meson 0.52.0 meson научился обнаруживать компоновщик и принимать разумные решения по его использованию. К сожалению, это не помогло в выбре компоновщика по умолчанию. Теперь для этого есть общий механизм: вы можете использовать переменную среды LD (с обычными правилами переменных среды meson) или добавить следующее в кросс-файл:

[binaries]
ld = 'gold'

И Meson выберет компоновщик автоматически, если это возможно.

Поддержка стандартов фортран (вплоть до f2018) в виде переменных fortran_std

Scalapack

scalapack = dependency('scalapack')

Исторически и до сегодняшнего дня сложилось что Scalapack сетап сломан и не находится с помощью pkg-config или FindScalapack.cmake Теперь Meson может найти Scalapack на следующих сетапах

  • Linux: Intel MKL or OpenMPI + Netlib

  • MacOS: Intel MKL or OpenMPI + Netlib

  • Windows: Intel MKL (OpenMPI not available on Windows)

Поиск по каталогам для find_program()

Теперь можно дать список абсолютных путей, по которым find_program()следует также искать, используя dirsключевое слово аргумент.

Например, в Linux /sbinи /usr/sbinне всегда в $PATH:

prog = find_program('mytool', dirs : ['/usr/sbin', '/sbin'])

Tags для целей сборки

Если соответствующие инструменты доступны, Meson будет генерировать цели 'ctags', 'TAGS' и 'cscope', если вы не определили свои собственные.

Словари с использованием строковой переменной в качестве ключа

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

d = {'a' + 'b' : 42}
k = 'cd'
d += {k : 43}

Улучшена поддержка подпроектов CMake

  • Использование API файла CMake для CMake > = 3.14

  • Обрабатывание явных зависимостей через add_dependency

  • Базовая поддержка для add_custom_target

  • Улучшенна поддержкаadd_custom_command

  • Поддержка библиотеки объектов в Windows (?)

compiler.get_linker_id ()

начиная с 0.53.0, compiler.get_linker_id()позволяет получить имя компоновщика в нижнем регистре. Поскольку в каждом семействе компиляторов обычно используются различные компоновщики, в зависимости от операционной системы, это помогает пользователям определять логику для угловых случаев, которые иначе сложно обработать.

Зависимость CUDA

Встроенная поддержка компиляции и связывания с CUDA Toolkit с использованием dependencyфункции:

project('CUDA test', 'cpp', meson_version: '>= 0.53.0')
exe = executable('prog', 'prog.cc', dependencies: dependency('cuda'))

Добавлена ​​глобальная опция для отключения C ++ RTTI

Новая bool опция называется cpp_rtti.

Изменения API интроспекции

dependencies (--dependencies, intro-dependencies.json):

  • добавлена опция versionkey

сканирование зависимостей (--scan-dependencies):

  • добавлена опция versionkey, содержащий требуемую версию зависимости

Тесты и бенчмарки (--tests, --benchmarks, intro-tests.json, intro-benchmarks.json):

  • добавлена опция protocolkey

В этом выпуске еще больше проектов CMake поддерживаются через благодаря следующим внутренним улучшениям:

См. для получения дополнительной информации.

dist
CMake subprojects
Зависимость CUDA