Rust bindings for the Python interpreter
Go to file
Daniel Grunwald 2904330b1c Improve build.rs when configuring using the python in PATH
* First try "pythonX.Y" and
  "pythonX" before using the generic "python"
* Use LDVERSION to detect 'dmu' suffix (PEP-3149)
2015-06-28 21:45:53 +02:00
examples Update documentation 2015-04-19 00:39:04 +02:00
extensions Add py_method!() macro for creating method descriptors. 2015-06-25 23:58:57 +02:00
python3-sys Improve build.rs when configuring using the python in PATH 2015-06-28 21:45:53 +02:00
python27-sys Improve build.rs when configuring using the python in PATH 2015-06-28 21:45:53 +02:00
src Fix python 3 build on windows. 2015-06-28 21:45:53 +02:00
.gitignore Update link to documentation. 2015-04-19 07:50:50 +02:00
.travis.yml Disable python3 build on travis -- not sure if there's any python3 installed on the build machine 2015-05-24 21:14:53 +02:00
Cargo.toml Make python 3 the default. 2015-06-27 23:50:50 +02:00
LICENSE MIT license headers 2015-04-19 05:22:03 +02:00
Makefile py_module_initializer! for python 3 2015-05-24 20:06:08 +02:00
README.md Update link to documentation. 2015-04-19 07:50:50 +02:00
appveyor.yml Add windows CI. 2015-06-27 15:15:06 +02:00
build.rs windows support for build script 2015-05-28 11:17:14 +01:00

README.md

rust-cpython Build Status

Rust bindings for the python interpreter.


Copyright (c) 2015 Daniel Grunwald. Rust-cpython is licensed under the MIT license. Python is licensed under the Python License.

Usage

cpython is available on crates.io so you can use it like this (in your Cargo.toml):

[dependencies.cpython]
version = "*"

Example program displaying the value of sys.version:

extern crate cpython;

use cpython::{PythonObject, Python};

fn main() {
    let gil_guard = Python::acquire_gil();
    let py = gil_guard.python();
    let sys = py.import("sys").unwrap();
    let version = sys.get("version").unwrap().extract::<String>().unwrap();
    println!("Hello Python {}", version);
}