Skip to content

Commit

Permalink
Hack to make submodules importable
Browse files Browse the repository at this point in the history
via `from spk.solve import ...`

PyO3/pyo3#1517 (comment)

Signed-off-by: J Robert Ray <[email protected]>
  • Loading branch information
J Robert Ray committed Sep 22, 2021
1 parent d0a8276 commit 22d9df2
Showing 1 changed file with 26 additions and 28 deletions.
54 changes: 26 additions & 28 deletions src/solve/python.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
// SPDX-License-Identifier: Apache-2.0
// https://github.com/imageworks/spk
use pyo3::prelude::*;
use pyo3::py_run;

use super::errors::SolverError;
use super::graph::{
Expand All @@ -17,7 +18,7 @@ fn init_submodule_errors(py: &Python, module: &PyModule) -> PyResult<()> {
Ok(())
}

fn init_submodule_graph(module: &PyModule) -> PyResult<()> {
fn init_submodule_graph(_py: &Python, module: &PyModule) -> PyResult<()> {
module.add_class::<Change>()?;
module.add_class::<Decision>()?;
module.add_class::<Graph>()?;
Expand All @@ -33,7 +34,7 @@ fn init_submodule_graph(module: &PyModule) -> PyResult<()> {
Ok(())
}

fn init_submodule_solution(module: &PyModule) -> PyResult<()> {
fn init_submodule_solution(_py: &Python, module: &PyModule) -> PyResult<()> {
module.add_class::<Solution>()?;
Ok(())
}
Expand All @@ -44,37 +45,34 @@ fn init_submodule_solver(py: &Python, module: &PyModule) -> PyResult<()> {
Ok(())
}

fn init_submodule_validation(module: &PyModule) -> PyResult<()> {
fn init_submodule_validation(_py: &Python, module: &PyModule) -> PyResult<()> {
module.add_class::<Validator>()?;
Ok(())
}

macro_rules! add_submodule {
($m:ident, $py:ident, $mod_name:expr, $init_fn:ident) => {
let submod = PyModule::new(*$py, $mod_name)?;
// Hack to make `from spk.solve.foo import ...` work
py_run!(
*$py,
submod,
&format!(
"import sys; sys.modules['spkrs.solve.{}'] = submod",
$mod_name
)
);
$init_fn($py, submod)?;
$m.add_submodule(submod)?;
};
}

pub fn init_module(py: &Python, m: &PyModule) -> PyResult<()> {
{
let submod_errors = PyModule::new(*py, "_errors")?;
init_submodule_errors(py, submod_errors)?;
m.add_submodule(submod_errors)?;
}
{
let submod_graph = PyModule::new(*py, "graph")?;
init_submodule_graph(submod_graph)?;
m.add_submodule(submod_graph)?;
}
{
let submod_solver = PyModule::new(*py, "_solver")?;
init_submodule_solver(py, submod_solver)?;
m.add_submodule(submod_solver)?;
}
{
let submod_solution = PyModule::new(*py, "_solution")?;
init_submodule_solution(submod_solution)?;
m.add_submodule(submod_solution)?;
}
{
let submod_validation = PyModule::new(*py, "validation")?;
init_submodule_validation(submod_validation)?;
m.add_submodule(submod_validation)?;
}
add_submodule!(m, py, "_errors", init_submodule_errors);
add_submodule!(m, py, "graph", init_submodule_graph);
add_submodule!(m, py, "_solver", init_submodule_solver);
add_submodule!(m, py, "_solution", init_submodule_solution);
add_submodule!(m, py, "validation", init_submodule_validation);

m.add_class::<Graph>()?;
m.add_class::<Solution>()?;
Expand Down

0 comments on commit 22d9df2

Please sign in to comment.