Rust bindings for the Python interpreter
Find a file
2015-08-21 21:28:13 +02:00
.cargo rust-cpython 0.0.2 2015-07-04 20:28:40 +02:00
examples Add an example of calling a python function from rust 2015-07-27 21:56:59 +03:00
extensions Add parameter extraction support to py_fn! and py_method!. 2015-08-03 00:06:15 +02:00
python3-sys Fix compiler warning (unused std::fs) 2015-08-21 21:28:13 +02:00
python27-sys Fix compiler warning (unused std::fs) 2015-08-21 21:28:13 +02:00
src Fix compiler error 2015-08-21 21:27:11 +02:00
.gitignore Update link to documentation. 2015-04-19 07:50:50 +02:00
.travis.yml Enable python 3 CI 2015-06-28 21:46:24 +02:00
appveyor.yml Enable python 3 CI 2015-06-28 21:46:24 +02:00
build.rs windows support for build script 2015-05-28 11:17:14 +01:00
Cargo.toml Switch to my interpolate_idents fork until a fix is released 2015-08-02 17:29:04 +02:00
LICENSE MIT license headers 2015-04-19 05:22:03 +02:00
Makefile Enable python 3 CI 2015-06-28 21:46:24 +02:00
README.md Initial version of argparse! 2015-08-02 21:56:03 +02:00

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.

Supported Python versions:

  • Python 2.7
  • Python 3.3
  • Python 3.4

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};
use cpython::ObjectProtocol; //for call method

fn main() {
    let gil = Python::acquire_gil();
    let py = gil.python();

    let sys = py.import("sys").unwrap();
    let version: String = sys.get("version").unwrap().extract().unwrap();

    let os = py.import("os").unwrap();
    let getenv = os.get("getenv").unwrap();
    let user: String = getenv.call(("USER",), None).unwrap().extract().unwrap();

    println!("Hello {}, I'm Python {}", user, version);
}