prepare release

This commit is contained in:
Nikolay Kim 2017-08-12 09:31:14 -07:00
parent 25472e5428
commit 0abc39ef4f
6 changed files with 4 additions and 145 deletions

View file

@ -1,7 +1,7 @@
Changes
-------
0.2.x (08-12-2017)
0.2.0 (08-12-2017)
^^^^^^^^^^^^^^^^^^
* Added inheritance support #15

View file

@ -1,8 +1,8 @@
[package]
name = "pyo3"
version = "0.2.0"
description = "Bindings to Python"
authors = ["PyO3 Project and Contributors <https://github.com/PyO3"]
description = "Bindings to Python interpreter"
authors = ["PyO3 Project and Contributors"]
readme = "README.md"
keywords = ["pyo3", "python", "cpython"]
homepage = "https://github.com/pyo3/pyo3"
@ -18,10 +18,7 @@ log = "0.3"
libc = "0.2"
spin = "0.4"
num-traits = "0.1"
pyo3cls = { path = "pyo3cls" }
[dev-dependencies]
#compiletest_rs = "*"
pyo3cls = "0.2.0"
[build-dependencies]
regex = "0.2"

View file

@ -1,91 +0,0 @@
#!/usr/bin/env python
import sysconfig
import subprocess
import json
import os
import sys
import platform
if os.path.dirname(__file__):
os.chdir(os.path.dirname(__file__))
if platform.system() == 'Windows' or platform.system().startswith('CYGWIN'):
sys.exit(0) # test not supported on windows - ignore it
so_files = [
sysconfig.get_config_var("LIBDIR")+"/"+sysconfig.get_config_var("LDLIBRARY"),
sysconfig.get_config_var("LIBPL")+"/"+sysconfig.get_config_var("LDLIBRARY")
]
so_file = None
for name in so_files:
if os.path.isfile(name):
so_file = name
if not so_file:
print('Could not find %r' % so_files)
sys.exit(1)
so_symbols = set()
for line in subprocess.check_output(['readelf', '-Ws', so_file]).splitlines():
if line:
so_symbols.add(line.decode('utf-8').split()[-1])
assert 'PyList_Type' in so_symbols
assert 'PyList_New' in so_symbols
cfgs = []
if sys.version_info.major == 3:
sys_lib = 'python3-sys'
for i in range(4, sys.version_info.minor+1):
cfgs += ['--cfg', 'Py_3_{}'.format(i)]
else:
raise RuntimeError("Unsupported version: %s" % sys.version_info)
interesting_config_flags = [
"Py_USING_UNICODE",
"Py_UNICODE_WIDE",
"WITH_THREAD",
"Py_DEBUG",
"Py_REF_DEBUG",
"Py_TRACE_REFS",
"COUNT_ALLOCS"
]
for name in interesting_config_flags:
if sysconfig.get_config_var(name):
cfgs += ['--cfg', 'py_sys_config="{}"'.format(name)]
interesting_config_values = ['Py_UNICODE_SIZE']
for name in interesting_config_values:
cfgs += ['--cfg', 'py_sys_config="{}_{}"'.format(name, sysconfig.get_config_var(name))]
json_output = subprocess.check_output(['rustc', '-Z', 'ast-json', '../{}/src/lib.rs'.format(sys_lib)] + cfgs)
doc = json.loads(json_output.decode('utf-8'))
foreign_symbols = set()
def visit(node, foreign):
if isinstance(node, dict):
node_node = node.get('node', None)
if isinstance(node_node, dict) and node_node.get('variant') in ('Static', 'Fn') and foreign:
foreign_symbols.add(node['ident'])
if isinstance(node_node, dict) and node_node.get('variant') == 'ForeignMod':
foreign = True
for v in node.values():
visit(v, foreign)
elif isinstance(node, list):
for v in node:
visit(v, foreign)
elif isinstance(node, (int, type(u''), bool, type(None))):
pass
else:
raise Exception('Unsupported node type {}'.format(type(node)))
visit(doc, foreign=False)
assert 'PyList_Type' in foreign_symbols, "Failed getting statics from rustc -Z ast-json"
assert 'PyList_New' in foreign_symbols, "Failed getting functions from rustc -Z ast-json"
names = sorted(foreign_symbols - so_symbols)
if names:
print('Symbols missing in {}:'.format(so_file))
print('\n'.join(names))
sys.exit(1)
else:
print('Symbols in {} OK.'.format(so_file))

View file

@ -1,12 +0,0 @@
#![feature(proc_macro)]
extern crate pyo3;
use pyo3::{py, PyResult, Python, PyModule};
#[py::class]
//~^ ERROR: custom attribute panicked
//~^^ HELP: #[class] can only be used with normal structs
enum MyClass {
A,
B,
}

View file

@ -1,9 +0,0 @@
#![feature(proc_macro)]
extern crate pyo3;
use pyo3::{py, PyResult, Python, PyModule};
#[py::modinit(rust2py)]
//~^ ERROR: custom attribute panicked
//~^^ HELP: #[modinit] can only be used with fn block
struct Rust2Py;

View file

@ -1,26 +0,0 @@
//extern crate compiletest_rs as compiletest;
//use std::path::PathBuf;
//use std::env::var;
/*
fn run_mode(mode: &'static str) {
let mut config = compiletest::default_config();
let cfg_mode = mode.parse().ok().expect("Invalid mode");
config.target_rustcflags = Some("-L target/debug/deps/".to_string());
config.mode = cfg_mode;
if let Ok(name) = var::<&str>("TESTNAME") {
let s : String = name.to_string();
config.filter = Some(s)
}
config.src_base = PathBuf::from(format!("tests/{}", mode));
compiletest::run_tests(&config);
}
#[test]
fn compile_tests() {
run_mode("compile-fail");
// run_mode("run-pass");
}*/