Skip to content

Commit

Permalink
Add args: --edit-page and --edit-patch
Browse files Browse the repository at this point in the history
Fix #383

Co-authored-by: Niklas Mohrin <[email protected]>
  • Loading branch information
lengyijun and niklasmohrin committed Jan 13, 2025
1 parent 120e2a9 commit af896f1
Show file tree
Hide file tree
Showing 3 changed files with 101 additions and 12 deletions.
8 changes: 8 additions & 0 deletions src/cli.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,14 @@ pub(crate) struct Cli {
#[arg(short = 'l', long = "list")]
pub list: bool,

/// Edit custom page with `EDITOR`
#[arg(long, requires = "command")]
pub edit_page: bool,

/// Edit custom patch with `EDITOR`
#[arg(long, requires = "command", conflicts_with = "edit_page")]
pub edit_patch: bool,

/// Render a specific markdown file
#[arg(
short = 'f',
Expand Down
71 changes: 59 additions & 12 deletions src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,10 +32,15 @@ compile_error!(

use std::{
env,
fs::create_dir_all,
io::{self, IsTerminal},
path::Path,
process,
process::Command,
};

use anyhow::anyhow;
use anyhow::Context;
use app_dirs::AppInfo;
use clap::Parser;

Expand Down Expand Up @@ -240,6 +245,30 @@ fn get_languages_from_env() -> Vec<String> {
)
}

fn spawn_editor(custom_pages_dir: &Path, file_name: &str) -> anyhow::Result<()> {
let _ = create_dir_all(custom_pages_dir);
if !custom_pages_dir.is_dir() {
return Err(anyhow!("Fail to create dir {:?}", custom_pages_dir));
}

let custom_page_path = custom_pages_dir.join(file_name);
let Some(custom_page_path) = custom_page_path.to_str() else {
return Err(anyhow!("`custom_page_path.to_str()` failed"));
};
let Ok(editor) = env::var("EDITOR") else {
return Err(anyhow!(
"To edit a custom page, please set the `EDITOR` environment variable."
));
};
println!("Editing {custom_page_path:?}");

let status = Command::new(&editor).arg(custom_page_path).status()?;
if !status.success() {
return Err(anyhow!("{editor} exit with code {:?}", status.code()));
}
Ok(())
}

fn main() {
// Initialize logger
init_log();
Expand Down Expand Up @@ -271,6 +300,34 @@ fn main() {
}
};

let custom_pages_dir = config
.directories
.custom_pages_dir
.as_ref()
.map(PathWithSource::path);

// Note: According to the TLDR client spec, page names must be transparently
// lowercased before lookup:
// https://github.com/tldr-pages/tldr/blob/main/CLIENT-SPECIFICATION.md#page-names
let command = args.command.join("-").to_lowercase();

if args.edit_patch || args.edit_page {
let file_name = if args.edit_patch {
format!("{command}.patch.md")
} else {
format!("{command}.page.md")
};

custom_pages_dir
.context("To edit custom pages/patches, please specify a custom pages directory.")
.and_then(|custom_pages_dir| spawn_editor(custom_pages_dir, &file_name))
.unwrap_or_else(|err| {
print_error(enable_styles, &err);
process::exit(1);
});
return;
}

// Show various paths
if args.show_paths {
show_paths(&config);
Expand Down Expand Up @@ -313,19 +370,14 @@ fn main() {

// Check cache presence and freshness
if !cache_updated
&& (args.list || !args.command.is_empty())
&& (args.list || !command.is_empty())
&& check_cache(&cache, &args, enable_styles) == CheckCacheResult::CacheMissing
{
process::exit(1);
}

// List cached commands and exit
if args.list {
let custom_pages_dir = config
.directories
.custom_pages_dir
.as_ref()
.map(PathWithSource::path);
println!(
"{}",
cache.list_pages(custom_pages_dir, &platforms).join("\n")
Expand All @@ -334,12 +386,7 @@ fn main() {
}

// Show command from cache
if !args.command.is_empty() {
// Note: According to the TLDR client spec, page names must be transparently
// lowercased before lookup:
// https://github.com/tldr-pages/tldr/blob/main/CLIENT-SPECIFICATION.md#page-names
let command = args.command.join("-").to_lowercase();

if !command.is_empty() {
// Collect languages
let languages = args
.language
Expand Down
34 changes: 34 additions & 0 deletions tests/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -990,3 +990,37 @@ fn test_raw_render_file() {
.success()
.stdout(diff(include_str!("cache/pages/common/inkscape-v1.md")));
}

#[test]
fn test_edit_page() {
let testenv = TestEnv::new().write_custom_pages_config();

let args = vec!["--edit-page", "foo"];

testenv
.command()
.args(&args)
.env("EDITOR", "touch")
.assert()
.success();
assert!(testenv.custom_pages_dir.path().join("foo.page.md").exists());
}

#[test]
fn test_edit_patch() {
let testenv = TestEnv::new().write_custom_pages_config();

let args = vec!["--edit-patch", "foo"];

testenv
.command()
.args(&args)
.env("EDITOR", "touch")
.assert()
.success();
assert!(testenv
.custom_pages_dir
.path()
.join("foo.patch.md")
.exists());
}

0 comments on commit af896f1

Please sign in to comment.