Compare commits
No commits in common. "1b8830eab335623ba9cbfe34f1038cb41638c791" and "861d29646242a2116268668ee011a0e87b320080" have entirely different histories.
1b8830eab3
...
861d296462
3 changed files with 12 additions and 24 deletions
|
|
@ -11,24 +11,18 @@ env:
|
|||
|
||||
jobs:
|
||||
build:
|
||||
runs-on: hestia
|
||||
defaults:
|
||||
run:
|
||||
working-directory: /tmp/breadpaper-build
|
||||
|
||||
runs-on: hestia-host
|
||||
steps:
|
||||
- name: checkout
|
||||
working-directory: /tmp
|
||||
run: |
|
||||
rm -rf /tmp/breadpaper-build
|
||||
git clone --branch "${GITHUB_REF_NAME}" --depth 1 \
|
||||
"https://git.breadway.dev/${GITHUB_REPOSITORY}.git" /tmp/breadpaper-build
|
||||
"https://git.breadway.dev/${GITHUB_REPOSITORY}.git" .
|
||||
|
||||
- name: build
|
||||
run: /home/breadway/.cargo/bin/cargo build --release --locked
|
||||
run: cargo build --release --locked
|
||||
|
||||
- name: test
|
||||
run: /home/breadway/.cargo/bin/cargo test --release --locked
|
||||
run: cargo test --release --locked
|
||||
|
||||
- name: prepare artifacts
|
||||
run: |
|
||||
|
|
@ -43,7 +37,6 @@ jobs:
|
|||
ln -sfn "${VERSION}" "${DL_DIR}/breadpaper/latest"
|
||||
|
||||
- name: ensure bread-ecosystem
|
||||
working-directory: /tmp
|
||||
run: |
|
||||
if [[ -d "${ECOSYSTEM_DIR}/.git" ]]; then
|
||||
git -C "${ECOSYSTEM_DIR}" pull --ff-only
|
||||
|
|
@ -53,5 +46,4 @@ jobs:
|
|||
fi
|
||||
|
||||
- name: regenerate index.json
|
||||
working-directory: /tmp
|
||||
run: bash "${ECOSYSTEM_DIR}/scripts/gen-index.sh"
|
||||
|
|
|
|||
16
src/main.rs
16
src/main.rs
|
|
@ -4,19 +4,17 @@ use std::process;
|
|||
use clap::{Parser, Subcommand};
|
||||
|
||||
#[derive(Parser)]
|
||||
#[command(name = "breadpaper", version, about = "Wallpaper manager for the bread desktop")]
|
||||
#[command(name = "breadpaper", about = "Wallpaper manager for the bread desktop")]
|
||||
struct Cli {
|
||||
/// Image file to set as wallpaper (shorthand for `set`)
|
||||
path: Option<PathBuf>,
|
||||
|
||||
#[command(subcommand)]
|
||||
command: Option<Command>,
|
||||
command: Command,
|
||||
}
|
||||
|
||||
#[derive(Subcommand)]
|
||||
enum Command {
|
||||
/// Set wallpaper, generate pywal palette, and reload bread themes
|
||||
Set {
|
||||
/// Path to the image file
|
||||
path: PathBuf,
|
||||
},
|
||||
/// Print the current wallpaper path
|
||||
|
|
@ -26,11 +24,9 @@ enum Command {
|
|||
fn main() {
|
||||
let cli = Cli::parse();
|
||||
|
||||
let result = match (cli.command, cli.path) {
|
||||
(Some(Command::Set { path }), _) | (None, Some(path)) => breadpaper::set(&path),
|
||||
(Some(Command::Get), _) | (None, None) => {
|
||||
breadpaper::get().map(|p| println!("{}", p.display()))
|
||||
}
|
||||
let result = match cli.command {
|
||||
Command::Set { path } => breadpaper::set(&path),
|
||||
Command::Get => breadpaper::get().map(|p| println!("{}", p.display())),
|
||||
};
|
||||
|
||||
if let Err(e) = result {
|
||||
|
|
|
|||
|
|
@ -5,13 +5,13 @@ use anyhow::{Context, Result, bail};
|
|||
|
||||
pub fn apply(path: &Path) -> Result<()> {
|
||||
let status = Command::new("awww")
|
||||
.arg("img")
|
||||
.arg("set")
|
||||
.arg(path)
|
||||
.status()
|
||||
.context("failed to run awww — is awww-daemon running?")?;
|
||||
|
||||
if !status.success() {
|
||||
bail!("awww img exited with {}", status);
|
||||
bail!("awww set exited with {}", status);
|
||||
}
|
||||
Ok(())
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue