Rust bindings for the Python interpreter
Go to file
Ewan Higgs dbcdbedc59 Fix up get_item so it returns PyResult (w/o lifetime elision).
Make concat and repeate return PyObject. Also uncomment tests of concat and
repeat.
2015-09-07 23:03:22 +02:00
.cargo
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 up get_item so it returns PyResult (w/o lifetime elision). 2015-09-07 23:03:22 +02:00
.gitignore
.travis.yml
Cargo.toml rust-cpython 0.0.4 2015-08-25 20:02:50 +02:00
LICENSE
Makefile
README.md Initial version of `argparse!` 2015-08-02 21:56:03 +02:00
appveyor.yml
build.rs

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.

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);
}