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

Was this helpful?

  1. Использование и создание библиотек

Создание библиотеки

Vala еще не может напрямую создавать динамические или статические библиотеки. Для создания библиотеки используйте ключ -с (только комиляция) и линкуйте объектные файлы вашим любимым линкером, таким как libtool или ar.

$ valac -c ...(исходные файлы)

ar cx ...(объектные файлы)

или компилируя промежуточный C код с помощью gcc.

$ valac -C ...(исходные файлы)

$ gcc -o my-best-library.so --shared -fPIC ...(файлы на C)...

Пример

Это пример того, как написать простую библиотеку на Vala, а так же как ее скомпилировать и протестировать без предварительной установки.

Сохраните следующий код в файл test.vala. Это код самой настоящей библиотеки, функции которой мы хотим вызывать из нашей главной программы.

public class MyLib : Object {

    public void hello() {
        stdout.printf("Hello World, MyLib\n");
    }

    public int sum(int x, int y) {
        return x + y;
    }
}

Используйте следующую команду для генерирования файлов test.c, test.h и test.vapi. Это будут С версии нашей библиотеки и VAPI файл, представляющий собой интерфейс к библиотеке.

$ valac -C -H test.h --library test test.vala --basedir ./

Теперь компилируем библиотеку:

$ gcc --shared -fPIC -o libtest.so $(pkg-config --cflags --libs gobject-2.0) test.c

Сохраните следующий код в файл hello.vala. Этот код будет использовать созданную нами библиотеку.

void main() {
    var test = new MyLib();
    test.hello();
    int x = 4, y = 5;
    stdout.printf("The sum of %d and %d is %d\n", x, y, test.sum(x, y));
}

Теперь компилируем код библиотеки, указав компилятору на использование только что созданной нами библиотеки.

$ valac -X -I. -X -L. -X -ltest -o hello hello.vala test.vapi --basedir ./

Теперь мы может запустить программу. Эта команда говорит, что все требуемые библиотеки будут находится в текущем каталоге.

$ LD_LIBRARY_PATH=$PWD ./hello

Вывод программы должен выглядеть так:

Привет Мир, MyLib
Сумма 4 и 5 равна 9

С опцией --gir вы можете так же создать GObjectIntrospection (GIR) файл для вашей библиотеки:

valac -C test.vala --library test --gir Test-1.0.gir

GIR файл - это описание API в XML.

Связывание библиотек VAPI файлами.

VAPI файлы являются внешним интерфейсом Vala библиотеки. Когда библиотека написана на Vala, этот файл создается компилятором и содержит все public определения со всех Vala файлов. Для библиотек написанных на С VAPI файл выглядит сложнее, особенно если соглашения об именовании не соответствуют таковым в GLib. В этом случае VAPI файл будет содержать множество определений, как стандартизированный интерфейс на Vala будет транслироваться в С.

Данный процесс обычно состоит из трех шагов,

Запуск vala-gen-introspect для генерации метаданных из С библиотеки.

Добавление дополнительных метаданных для стандартизации интерфейса или для других изменений.

PreviousИспользование библиотекNextVala and C

Last updated 6 years ago

Was this helpful?