Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bynect/mongo-vapi
Vala bindings for the Mongo C Driver
https://github.com/bynect/mongo-vapi
driver libmongoc makefile meson mesonbuild mongo mongoc mongoclient mongodb mongodb-driver vala vala-bindings vala-libraries vala-library valac vapi vapidir
Last synced: 2 months ago
JSON representation
Vala bindings for the Mongo C Driver
- Host: GitHub
- URL: https://github.com/bynect/mongo-vapi
- Owner: bynect
- License: mit
- Created: 2020-09-28T01:55:57.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2024-01-15T12:17:35.000Z (about 1 year ago)
- Last Synced: 2024-01-15T15:47:23.882Z (about 1 year ago)
- Topics: driver, libmongoc, makefile, meson, mesonbuild, mongo, mongoc, mongoclient, mongodb, mongodb-driver, vala, vala-bindings, vala-libraries, vala-library, valac, vapi, vapidir
- Language: Vala
- Homepage:
- Size: 136 KB
- Stars: 7
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Mongo C Vapi
Vala bindings for the [Mongo C Driver](https://github.com/mongodb/mongo-c-driver "mongo-c-driver").
Note: The bindings are currently not being updated
## Generate VAPI file
#### Oneliner```sh
#the vapi file will be generated in the ./vapi folder
$ git clone https://github.com/bynect/mongo-vapi.git && cd mongo-vapi && make compose
```#### Generate one file
You can generate a single file containing both `libbson` and `libmongoc` bindings living under the _Mongo_ namespace by using this command:```sh
#make
$ make compose#python (only vapis)
$ python3 compose.py --onefile#meson
$ meson build
```#### Generate separated file
You can also generate two separate file containing `libbson` and `libmongoc` bindings living under the _Bson_ and _Mongo_ namespace respectively.```sh
#for make
#set the variable in line or export it
$ SEPARATED_VAPI= make compose#for python (only vapis)
$ python3 compose.py#for meson
$ meson build -Donefile=false
```__If you want to run tests or examples using two different file (separated option), you have to set the `SEPARATED_VAPI` environmental variable.__ (Only for make, Meson does it automatically).
## Build with make
### Examples```sh
#hello mongo example
$ make example-hello#basic crud operations to local database
$ make example-crud#bcon / json example
$ make example-bcon
```__If you want to run tests or examples using two different file (separated option), you have to set the `SEPARATED_VAPI` environmental variable.__
### Tests
```sh
#check connection to local database
$ make test-status
```__If you want to run tests or examples using two different file (separated option), you have to set the `SEPARATED_VAPI` environmental variable.__
## Build with Meson
You can use Meson as an alternative build method to make.
Avaible options (see meson_options.txt):* `-Donefile`: Generate a single file and namespace. Default to true.
* `-Dverbose`: Set verbosity. Default to false.
* `-Dtest`: Build test. Default to true.
* `-Dexample`: Build samples. Default to true.
```sh
#add -Donefile=false for separated vapis
$ meson build
#run ninja from the build directory
$ ninja -C build
```## Helper
There is a small Python script that will generate the Vapi from the partials file.
Also there is a Makefile that has some helper targets for testing and examples.You can see the avaible options using:
```sh
#Makefile help
$ make#Python script help
$ python3 compose.py -h
```## Usage
To use this bindings you have to add the following arguments to `valac`:
* `--pkg libmongoc-1.0`: This links libmongoc to your Vala application.
* `--pkg libbson-1.0`: Add this only if you have generated separated vapis.
* `--vapidir X`: _X_ is the directory where the generated files are stored.
* `--pkg posix`: Add only if you didn't included the `.deps` file in the vapidir.
If you are using Meson you can add the following dependencies:
* dependency('libmongoc-1.0')
* dependency('libbson-1.0')
Also you need to add the `vapidir` option and the `--pkg` option for posix (if not included in the vapidir), like this:
```meson
add_project_arguments(['--vapidir', X, '--pkg', 'posix'], language: 'vala')
```_X_ is the directory where the generated files are stored.
## Dependencies
* [`libmongoc-1.0`](http://mongoc.org/libmongoc/current/installing.html): the binded library
* `libbson-1.0`: installed with libmongoc, used explicitly if vapis are separated
* `posix`: used for datetime and minor details
* `glib-2.0` and `gobject-2.0`: used by Vala
* `json-glib-1.0`: used by the [BconDoc.vala](samples/BconDoc.vala) samples
## Notes
* Because the codebase to bind is fairly big, the vapi file is divided in partials file. The file itself can be easily generated with the included Python script / Makefile / Meson script.
* While the vast majority of the methods and classes have the same or a very similar name to the C counterpart, some of the names maybe a little tweaked to be more Vala-friendly.
* Deprecated or next-to-deprecation features _won't be binded_.
* The tags/releases/versions of this repository are not related to `libmongoc` versions.
* If you need only the VAPI file, you can download it from the [releases allegates](https://github.com/bynect/mongo-vapi/releases). Generating by yourself is probably better though.
* Test and samples require a running instance of mongodb (`mongod`).
* I am not sure if `--pkg posix` is required explicitly, but it is needed for datetime types.
## Changelog
* Add meson as an alternative build method.
* Add support for separated vapis for `libbson` and `libmongoc`.
* Add support for BCON notation.
* Add support for Crud operation.
Also see [TODO.md](./TODO.md).
## License
Copyright @bynect
This is free and open source software.
You can use/modify/redistribute it under the terms of the MIT license.
See LICENSE for for more details.