Giter Site home page Giter Site logo

gtk3-rs CI

This project is UNMAINTAINED. Please take a look at gtk4-rs instead!

The gtk-rs organization aims to provide safe Rust binding over GObject-based libraries. You can find more about it on https://gtk-rs.org.

This repository contains all the "core" crates of the gtk-rs organization. For more information about each crate, please refer to their README.md file in their directory.

Minimum supported Rust version

Currently, the minimum supported Rust version is 1.70.0.

Documentation

Ecosystem

The gtk3-rs repository contains Rust crates for GTK 3. However there is a large ecosystem of GObject libraries and many of these libraries have Rust bindings based on the tooling included in gtk-rs. Of particular note:

  • gtk-rs-core - bindings for some of the core libraries such as glib, gio, pango, graphene
  • gstreamer-rs - bindings for the GStreamer media framework

Additionally, Rust bindings for various libraries are hosted on GNOME's GitLab instance and can be found at https://gitlab.gnome.org/World/Rust.

When using crates that are not part of the gtk-rs repository, you will need to be careful and ensure that they do not pull in incompatible versions of core crates like glib-rs.

Regenerating

To regenerate crates using gir, please use the generator.py file as follows:

$ python3 generator.py

If you didn't do so yet, please check out all the submodules before via

$ git submodule update --checkout

Development

This repository is mostly split into two branches: master and crate. master contains the not yet released code and is where new developments are happening. crate contains the last release source code and isn't supposed to be updated.

This repository is structured as follows:

- crate/
   |
   |-- README.md
   |-- Gir.toml
   |-- Cargo.toml
   |-- src/
   |-- sys/

The crate is a "top" directory (so "atk" or "gdk" in here for example). Each crate contains:

  • README.md: explanations about the crate itself and eventually some details.
  • Cargo.toml: descriptor of the crate, used by cargo and Rust.
  • Gir.toml: configuration used by gir to generate most of the crates' code.
  • src: the source code of the crate.
  • sys: the 1:1 bindings of the C API.

The gir and gir-files top folders are not crates, but are git submodules which respectively contain the gir tool and the gir files used by the generator.

When running generator.py the tool will automatically update these git submodules and run the gir tool on the gir files to regenerate the code.

During development, it is useful to execute the generator with a different version of the gir tool or of the gir files, for instance to test if the code generation is successful before submitting a pull request to update one of the submodules. This can be done by specifying arguments to the generator script, for instance, to run the generator on a local copy of the gir files:

$ python3 generator.py --gir-files-directory ../gir-files/

See python3 generator.py --help for more details.

gtk-rs's Projects

atk icon atk

DEPRECATED, use https://github.com/gtk-rs/gtk3-rs repository instead!

cairo icon cairo

DEPRECATED, use https://github.com/gtk-rs/gtk-rs-core repository instead!

checker icon checker

Repository which contains various scripts to run for CI

docs icon docs

The old source repo of http://gtk-rs.org/docs/

examples icon examples

DEPRECATED, use https://github.com/gtk-rs/gtk-rs repository instead!

examples4 icon examples4

DEPRECATED, use https://github.com/gtk-rs/gtk4-rs repository instead!

gdk icon gdk

DEPRECATED, use https://github.com/gtk-rs/gtk3-rs repository instead!

gdk-pixbuf icon gdk-pixbuf

DEPRECATED, use https://github.com/gtk-rs/gtk-rs-core repository instead!

gdk4 icon gdk4

DEPRECATED, use https://github.com/gtk-rs/gtk4-rs repository instead!

gdkx11 icon gdkx11

DEPRECATED, use https://github.com/gtk-rs/gtk3-rs repository instead!

gio icon gio

DEPRECATED, use https://github.com/gtk-rs/gtk-rs-core repository instead!

gir icon gir

Tool to generate rust bindings and user API for glib-based libraries

glib icon glib

DEPRECATED, use https://github.com/gtk-rs/gtk-rs-core repository instead!

graphene icon graphene

DEPRECATED, use https://github.com/gtk-rs/gtk-rs-core repository instead!

gsk4 icon gsk4

DEPRECATED, use https://github.com/gtk-rs/gtk4-rs repository instead!

gtk icon gtk

DEPRECATED, use https://github.com/gtk-rs/gtk3-rs repository instead!

pango icon pango

DEPRECATED, use https://github.com/gtk-rs/gtk-rs-core repository instead!

pangocairo icon pangocairo

DEPRECATED, use https://github.com/gtk-rs/gtk-rs-core repository instead!

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.