Skip to content

Commit

Permalink
Featurize defmt
Browse files Browse the repository at this point in the history
  • Loading branch information
bugadani committed Sep 15, 2023
1 parent 98d8f81 commit dfdc200
Show file tree
Hide file tree
Showing 5 changed files with 40 additions and 7 deletions.
16 changes: 16 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,10 @@ jobs:
target: "armv7-unknown-linux-gnueabihf"
arch: "armhf"
features: "--features=raspberry"
- os: "ubuntu-22.04"
target: "x86_64-unknown-linux-gnu"
arch: "x86_64"
features: "--features=defmt"
runs-on: ${{ matrix.platform.os }}

steps:
Expand All @@ -69,6 +73,9 @@ jobs:
platform:
- target: "x86_64-unknown-linux-gnu"
arch: "x86_64"
- target: "x86_64-unknown-linux-gnu"
arch: "x86_64"
features: "--features=defmt"
- target: "aarch64-unknown-linux-gnu"
arch: "arm64"
features: "--features=raspberry"
Expand Down Expand Up @@ -96,6 +103,9 @@ jobs:
platform:
- target: "x86_64-unknown-linux-gnu"
arch: "x86_64"
- target: "x86_64-unknown-linux-gnu"
arch: "x86_64"
features: "--features=defmt"
- target: "aarch64-unknown-linux-gnu"
arch: "arm64"
features: "--features=raspberry"
Expand Down Expand Up @@ -127,6 +137,9 @@ jobs:
platform:
- target: "x86_64-unknown-linux-gnu"
arch: "x86_64"
- target: "x86_64-unknown-linux-gnu"
arch: "x86_64"
features: "--features=defmt"
- target: "aarch64-unknown-linux-gnu"
arch: "arm64"
features: "--features=raspberry"
Expand Down Expand Up @@ -157,6 +170,9 @@ jobs:
platform:
- target: "x86_64-unknown-linux-gnu"
arch: "x86_64"
- target: "x86_64-unknown-linux-gnu"
arch: "x86_64"
features: "--features=defmt"
- target: "aarch64-unknown-linux-gnu"
arch: "arm64"
features: "--features=raspberry"
Expand Down
9 changes: 7 additions & 2 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,29 +18,34 @@ jobs:
- os: "ubuntu-22.04"
target: "x86_64-unknown-linux-gnu"
arch: "x86_64"
features: "--features=defmt"
- os: "ubuntu-22.04"
target: "x86_64-unknown-linux-musl"
arch: "x86_64"
features: "--features=defmt"
- os: "ubuntu-22.04"
target: "aarch64-unknown-linux-gnu"
arch: "arm64"
features: "--features=raspberry"
features: "--features=raspberry,defmt"
- os: "ubuntu-22.04"
target: "armv7-unknown-linux-gnueabihf"
arch: "armhf"
features: "--features=raspberry"
features: "--features=raspberry,defmt"
# Windows
- os: "windows-2022"
target: "x86_64-pc-windows-msvc"
arch: "x86_64"
features: "--features=defmt"
# macOs
- os: "macos-12"
target: "aarch64-apple-darwin"
# This is not true, but simplifies the logic of the action.
arch: "x86_64"
features: "--features=defmt"
- os: "macos-12"
target: "x86_64-apple-darwin"
arch: "x86_64"
features: "--features=defmt"
runs-on: ${{ matrix.platform.os }}
steps:

Expand Down
8 changes: 6 additions & 2 deletions espflash/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -40,8 +40,8 @@ clap_complete = { version = "4.3", optional = true }
comfy-table = { version = "7.0.1", optional = true }
crossterm = { version = "0.25.0", optional = true } # 0.26.x causes issues on Windows
ctrlc = { version = "3.4.0", optional = true }
defmt-decoder = { version = "=0.3.8", features = ["unstable"] }
defmt-parser = { version = "=0.3.3", features = ["unstable"] }
defmt-decoder = { version = "=0.3.8", features = ["unstable"], optional = true }
defmt-parser = { version = "=0.3.3", features = ["unstable"], optional = true }
dialoguer = { version = "0.10.4", optional = true }
directories = { version = "5.0.1", optional = true }
env_logger = { version = "0.10.0", optional = true }
Expand Down Expand Up @@ -84,4 +84,8 @@ cli = [
"dep:regex",
"dep:update-informer",
]
defmt = [
"dep:defmt-decoder",
"dep:defmt-parser",
]
raspberry = ["dep:rppal"]
13 changes: 10 additions & 3 deletions espflash/src/cli/monitor/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -23,13 +23,14 @@ use log::error;
use miette::{IntoDiagnostic, Result};

use crate::{
cli::monitor::parser::{esp_defmt::EspDefmt, InputParser, ResolvingPrinter},
cli::monitor::parser::{InputParser, ResolvingPrinter},
connection::reset_after_flash,
interface::Interface,
};

pub mod parser;

mod line_endings;
mod parser;
mod symbols;

/// Type that ensures that raw mode is disabled when dropped.
Expand Down Expand Up @@ -57,7 +58,13 @@ pub fn monitor(
pid: u16,
baud: u32,
) -> serialport::Result<()> {
monitor_with(serial, elf, pid, baud, EspDefmt::new(elf))
#[cfg(feature = "defmt")]
let parser = parser::esp_defmt::EspDefmt::new(elf);

#[cfg(not(feature = "defmt"))]
let parser = parser::serial::Serial;

monitor_with(serial, elf, pid, baud, parser)
}

/// Open a serial monitor on the given interface, using the given input parser.
Expand Down
1 change: 1 addition & 0 deletions espflash/src/cli/monitor/parser/mod.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
#[cfg(feature = "defmt")]
pub mod esp_defmt;
pub mod serial;

Expand Down

0 comments on commit dfdc200

Please sign in to comment.