Skip to content

Commit

Permalink
Add a global verbose option (#2080)
Browse files Browse the repository at this point in the history
Debugging #2079 i realized that we currently require `RUST_LOG=debug` for users to debug issues like missing inclusions. I added a global counting `-v` flag.

We currently use `-v` to configure cargo verbosity level. For simplicity, it now configures both at the same time. Fine-grained control is still possible by setting `RUST_LOG`.

The levels:
* Default: Show build information and `cargo build` output.
* `-v`: Use `cargo build -v`.
* `-vv`: Show debug logging and use `cargo build -vv`.
* `-vvv`: Show trace logging.

This can be extended to support a quiet option.
  • Loading branch information
konstin authored May 23, 2024
1 parent 2d44d1b commit f485ee4
Show file tree
Hide file tree
Showing 10 changed files with 173 additions and 41 deletions.
2 changes: 2 additions & 0 deletions Changelog.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@

## [Unreleased]

* Add a global `-v` option [#2080](https://github.com/PyO3/maturin/pull/2080)

## [1.5.1] - 2024-03-21

* Fix usage of `--compatibility` when run as a PEP517 backend in [#1992](https://github.com/PyO3/maturin/pull/1992)
Expand Down
1 change: 1 addition & 0 deletions src/build_options.rs
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,7 @@ pub struct CargoOptions {
pub ignore_rust_version: bool,

/// Use verbose output (-vv very verbose/build.rs output)
// Note that this duplicates the global option, but clap seems to be fine with that.
#[arg(short = 'v', long, action = clap::ArgAction::Count)]
pub verbose: u8,

Expand Down
82 changes: 60 additions & 22 deletions src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,10 @@ use maturin::{generate_json_schema, GenerateJsonSchemaOptions};
use maturin::{upload_ui, PublishOpt};
use std::env;
use std::path::PathBuf;
use std::str::FromStr;
use tracing::{debug, instrument};
use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt};
use tracing_subscriber::filter::Directive;
use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt, EnvFilter, Layer};

#[derive(Debug, Parser)]
#[command(
Expand All @@ -33,10 +35,29 @@ use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt};
after_help = "Visit https://maturin.rs to learn more about maturin.",
styles = cargo_options::styles(),
)]
/// Build and publish crates with pyo3, cffi and uniffi bindings as well
/// as rust binaries as python packages
struct Opt {
/// Use verbose output.
///
/// * Default: Show build information and `cargo build` output.
/// * `-v`: Use `cargo build -v`.
/// * `-vv`: Show debug logging and use `cargo build -vv`.
/// * `-vvv`: Show trace logging.
///
/// You can configure fine-grained logging using the `RUST_LOG` environment variable.
/// (<https://docs.rs/tracing-subscriber/latest/tracing_subscriber/filter/struct.EnvFilter.html#directives>)
#[arg(global = true, action = clap::ArgAction::Count, long, short)]
verbose: u8,
#[command(subcommand)]
command: Command,
}

#[derive(Debug, Parser)]
#[allow(clippy::large_enum_variant)]
/// Build and publish crates with pyo3, cffi and uniffi bindings as well
/// as rust binaries as python packages
enum Opt {
enum Command {
#[command(name = "build", alias = "b")]
/// Build the crate into python packages
Build {
Expand Down Expand Up @@ -328,8 +349,10 @@ fn run() -> Result<()> {
#[cfg(feature = "wild")]
let opt = Opt::parse_from(wild::args_os());

match opt {
Opt::Build {
setup_logging(opt.verbose)?;

match opt.command {
Command::Build {
build,
release,
strip,
Expand All @@ -345,7 +368,7 @@ fn run() -> Result<()> {
assert!(!wheels.is_empty());
}
#[cfg(feature = "upload")]
Opt::Publish {
Command::Publish {
build,
mut publish,
debug,
Expand All @@ -370,7 +393,7 @@ fn run() -> Result<()> {

upload_ui(&items, &publish)?
}
Opt::ListPython { target } => {
Command::ListPython { target } => {
let found = if target.is_some() {
let target = Target::from_target_triple(target)?;
PythonInterpreter::find_by_target(&target, None)
Expand All @@ -384,12 +407,12 @@ fn run() -> Result<()> {
eprintln!(" - {interpreter}");
}
}
Opt::Develop(develop_options) => {
Command::Develop(develop_options) => {
let target = Target::from_target_triple(develop_options.cargo_options.target.clone())?;
let venv_dir = detect_venv(&target)?;
develop(develop_options, &venv_dir)?;
}
Opt::SDist { manifest_path, out } => {
Command::SDist { manifest_path, out } => {
let build_options = BuildOptions {
out,
cargo: CargoOptions {
Expand All @@ -403,15 +426,15 @@ fn run() -> Result<()> {
.build_source_distribution()?
.context("Failed to build source distribution, pyproject.toml not found")?;
}
Opt::Pep517(subcommand) => pep517(subcommand)?,
Command::Pep517(subcommand) => pep517(subcommand)?,
#[cfg(feature = "scaffolding")]
Opt::InitProject { path, options } => init_project(path, options)?,
Command::InitProject { path, options } => init_project(path, options)?,
#[cfg(feature = "scaffolding")]
Opt::NewProject { path, options } => new_project(path, options)?,
Command::NewProject { path, options } => new_project(path, options)?,
#[cfg(feature = "scaffolding")]
Opt::GenerateCI(generate_ci) => generate_ci.execute()?,
Command::GenerateCI(generate_ci) => generate_ci.execute()?,
#[cfg(feature = "upload")]
Opt::Upload { mut publish, files } => {
Command::Upload { mut publish, files } => {
if files.is_empty() {
eprintln!("⚠️ Warning: No files given, exiting.");
return Ok(());
Expand All @@ -421,17 +444,17 @@ fn run() -> Result<()> {
upload_ui(&files, &publish)?
}
#[cfg(feature = "cli-completion")]
Opt::Completions { shell } => {
Command::Completions { shell } => {
shell.generate(&mut Opt::command(), &mut std::io::stdout());
}
#[cfg(feature = "zig")]
Opt::Zig(subcommand) => {
Command::Zig(subcommand) => {
subcommand
.execute()
.context("Failed to run zig linker wrapper")?;
}
#[cfg(feature = "schemars")]
Opt::GenerateJsonSchema(args) => generate_json_schema(args)?,
Command::GenerateJsonSchema(args) => generate_json_schema(args)?,
}

Ok(())
Expand Down Expand Up @@ -459,9 +482,19 @@ fn setup_panic_hook() {
}));
}

fn main() {
#[cfg(not(debug_assertions))]
setup_panic_hook();
fn setup_logging(verbose: u8) -> Result<()> {
// `RUST_LOG` takes precedence over these
let default_directive = match verbose {
// `-v` runs `cargo build -v`, but doesn't show maturin debug logging yet.
0..=1 => tracing::level_filters::LevelFilter::OFF.into(),
2 => Directive::from_str("debug").unwrap(),
3.. => Directive::from_str("trace").unwrap(),
};

let filter = EnvFilter::builder()
.with_default_directive(default_directive)
.from_env()
.context("Invalid RUST_LOG directives")?;

let logger = tracing_subscriber::fmt::layer()
// Avoid showing all the details from the spans
Expand All @@ -470,11 +503,16 @@ fn main() {
.with_span_events(tracing_subscriber::fmt::format::FmtSpan::CLOSE);

tracing_subscriber::registry()
// `RUST_LOG` support
.with(tracing_subscriber::EnvFilter::from_default_env())
.with(logger)
.with(logger.with_filter(filter))
.init();

Ok(())
}

fn main() {
#[cfg(not(debug_assertions))]
setup_panic_hook();

if let Err(e) = run() {
eprintln!("💥 maturin failed");
for cause in e.chain() {
Expand Down
9 changes: 9 additions & 0 deletions tests/cmd/generate-ci.stdout
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,15 @@ Options:
-m, --manifest-path <PATH>
Path to Cargo.toml

-v, --verbose...
Use verbose output.

* Default: Show build information and `cargo build` output. * `-v`: Use `cargo build -v`.
* `-vv`: Show debug logging and use `cargo build -vv`. * `-vvv`: Show trace logging.

You can configure fine-grained logging using the `RUST_LOG` environment variable.
(<https://docs.rs/tracing-subscriber/latest/tracing_subscriber/filter/struct.EnvFilter.html#directives>)

-o, --output <PATH>
Output path

Expand Down
34 changes: 27 additions & 7 deletions tests/cmd/init.stdout
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,32 @@ Create a new cargo project in an existing directory
Usage: maturin[EXE] init [OPTIONS] [PATH]

Arguments:
[PATH] Project path
[PATH]
Project path

Options:
--name <NAME> Set the resulting package name, defaults to the directory name
--mixed Use mixed Rust/Python project layout
--src Use Python first src layout for mixed Rust/Python project
-b, --bindings <BINDINGS> Which kind of bindings to use [possible values: pyo3, cffi, uniffi,
bin]
-h, --help Print help
--name <NAME>
Set the resulting package name, defaults to the directory name

-v, --verbose...
Use verbose output.

* Default: Show build information and `cargo build` output. * `-v`: Use `cargo build -v`.
* `-vv`: Show debug logging and use `cargo build -vv`. * `-vvv`: Show trace logging.

You can configure fine-grained logging using the `RUST_LOG` environment variable.
(<https://docs.rs/tracing-subscriber/latest/tracing_subscriber/filter/struct.EnvFilter.html#directives>)

--mixed
Use mixed Rust/Python project layout

--src
Use Python first src layout for mixed Rust/Python project

-b, --bindings <BINDINGS>
Which kind of bindings to use

[possible values: pyo3, cffi, uniffi, bin]

-h, --help
Print help (see a summary with '-h')
16 changes: 14 additions & 2 deletions tests/cmd/list-python.stdout
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,17 @@ Search and list the available python installations
Usage: maturin[EXE] list-python [OPTIONS]

Options:
--target <TARGET>
-h, --help Print help
--target <TARGET>


-v, --verbose...
Use verbose output.

* Default: Show build information and `cargo build` output. * `-v`: Use `cargo build -v`.
* `-vv`: Show debug logging and use `cargo build -vv`. * `-vvv`: Show trace logging.

You can configure fine-grained logging using the `RUST_LOG` environment variable.
(<https://docs.rs/tracing-subscriber/latest/tracing_subscriber/filter/struct.EnvFilter.html#directives>)

-h, --help
Print help (see a summary with '-h')
18 changes: 15 additions & 3 deletions tests/cmd/maturin.stdout
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Build and publish crates with pyo3, cffi and uniffi bindings as well as rust binaries as python
packages

Usage: maturin[EXE] <COMMAND>
Usage: maturin[EXE] [OPTIONS] <COMMAND>

Commands:
build Build the crate into python packages
Expand All @@ -16,7 +16,19 @@ Commands:
help Print this message or the help of the given subcommand(s)

Options:
-h, --help Print help
-V, --version Print version
-v, --verbose...
Use verbose output.

* Default: Show build information and `cargo build` output. * `-v`: Use `cargo build -v`.
* `-vv`: Show debug logging and use `cargo build -vv`. * `-vvv`: Show trace logging.

You can configure fine-grained logging using the `RUST_LOG` environment variable.
(<https://docs.rs/tracing-subscriber/latest/tracing_subscriber/filter/struct.EnvFilter.html#directives>)

-h, --help
Print help (see a summary with '-h')

-V, --version
Print version

Visit https://maturin.rs to learn more about maturin.
34 changes: 27 additions & 7 deletions tests/cmd/new.stdout
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,32 @@ Create a new cargo project
Usage: maturin[EXE] new [OPTIONS] <PATH>

Arguments:
<PATH> Project path
<PATH>
Project path

Options:
--name <NAME> Set the resulting package name, defaults to the directory name
--mixed Use mixed Rust/Python project layout
--src Use Python first src layout for mixed Rust/Python project
-b, --bindings <BINDINGS> Which kind of bindings to use [possible values: pyo3, cffi, uniffi,
bin]
-h, --help Print help
--name <NAME>
Set the resulting package name, defaults to the directory name

-v, --verbose...
Use verbose output.

* Default: Show build information and `cargo build` output. * `-v`: Use `cargo build -v`.
* `-vv`: Show debug logging and use `cargo build -vv`. * `-vvv`: Show trace logging.

You can configure fine-grained logging using the `RUST_LOG` environment variable.
(<https://docs.rs/tracing-subscriber/latest/tracing_subscriber/filter/struct.EnvFilter.html#directives>)

--mixed
Use mixed Rust/Python project layout

--src
Use Python first src layout for mixed Rust/Python project

-b, --bindings <BINDINGS>
Which kind of bindings to use

[possible values: pyo3, cffi, uniffi, bin]

-h, --help
Print help (see a summary with '-h')
9 changes: 9 additions & 0 deletions tests/cmd/sdist.stdout
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,15 @@ Options:
-m, --manifest-path <MANIFEST_PATH>
The path to the Cargo.toml

-v, --verbose...
Use verbose output.

* Default: Show build information and `cargo build` output. * `-v`: Use `cargo build -v`.
* `-vv`: Show debug logging and use `cargo build -vv`. * `-vvv`: Show trace logging.

You can configure fine-grained logging using the `RUST_LOG` environment variable.
(<https://docs.rs/tracing-subscriber/latest/tracing_subscriber/filter/struct.EnvFilter.html#directives>)

-o, --out <OUT>
The directory to store the built wheels in. Defaults to a new "wheels" directory in the
project's target directory
Expand Down
9 changes: 9 additions & 0 deletions tests/cmd/upload.stdout
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,15 @@ Options:
[env: MATURIN_REPOSITORY=]
[default: pypi]

-v, --verbose...
Use verbose output.

* Default: Show build information and `cargo build` output. * `-v`: Use `cargo build -v`.
* `-vv`: Show debug logging and use `cargo build -vv`. * `-vvv`: Show trace logging.

You can configure fine-grained logging using the `RUST_LOG` environment variable.
(<https://docs.rs/tracing-subscriber/latest/tracing_subscriber/filter/struct.EnvFilter.html#directives>)

--repository-url <REPOSITORY_URL>
The URL of the registry where the wheels are uploaded to. This overrides --repository.

Expand Down

0 comments on commit f485ee4

Please sign in to comment.