From 0c4840e0fd8f4517c0981249bc58d206b5b3e05a Mon Sep 17 00:00:00 2001 From: Fabiano Frizzo Date: Fri, 14 Oct 2022 08:36:23 -0300 Subject: [PATCH] Add new flag 'port_append' to give the ability to remove port from base url --- src/cli.rs | 4 ++++ src/cmd/serve.rs | 10 +++++++++- src/main.rs | 12 +++++++++++- 3 files changed, 24 insertions(+), 2 deletions(-) diff --git a/src/cli.rs b/src/cli.rs index 504d5a424b..d3d603ddd2 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -80,6 +80,10 @@ pub enum Command { /// Only rebuild the minimum on change - useful when working on a specific page/section #[clap(short = 'f', long)] fast: bool, + + /// Append port to the base url + #[clap(long, default_value_t = true)] + port_append: bool, }, /// Try to build the project without rendering it. Checks links diff --git a/src/cmd/serve.rs b/src/cmd/serve.rs index 0242a9a075..c55b599392 100644 --- a/src/cmd/serve.rs +++ b/src/cmd/serve.rs @@ -241,6 +241,7 @@ fn create_new_site( base_url: &str, config_file: &Path, include_drafts: bool, + port_append: bool, ws_port: Option, ) -> Result<(Site, String)> { SITE_CONTENT.write().unwrap().clear(); @@ -251,7 +252,11 @@ fn create_new_site( let base_url = if base_url == "/" { String::from("/") } else { - let base_address = format!("{}:{}", base_url, interface_port); + let base_address = if port_append { + format!("{}:{}", base_url, interface_port) + } else { + base_url.to_string() + }; if site.config.base_url.ends_with('/') { format!("http://{}/", base_address) @@ -291,6 +296,7 @@ pub fn serve( open: bool, include_drafts: bool, fast_rebuild: bool, + port_append: bool, utc_offset: UtcOffset, ) -> Result<()> { let start = Instant::now(); @@ -302,6 +308,7 @@ pub fn serve( base_url, config_file, include_drafts, + port_append, None, )?; messages::report_elapsed_time(start); @@ -502,6 +509,7 @@ pub fn serve( base_url, config_file, include_drafts, + port_append, ws_port, ) { Ok((s, _)) => { diff --git a/src/main.rs b/src/main.rs index 1b9fb3773e..f706765f25 100644 --- a/src/main.rs +++ b/src/main.rs @@ -58,7 +58,16 @@ fn main() { } } } - Command::Serve { interface, mut port, output_dir, base_url, drafts, open, fast } => { + Command::Serve { + interface, + mut port, + output_dir, + base_url, + drafts, + open, + fast, + port_append, + } => { if port != 1111 && !port_is_available(port) { console::error("The requested port is not available"); std::process::exit(1); @@ -83,6 +92,7 @@ fn main() { open, drafts, fast, + port_append, UtcOffset::current_local_offset().unwrap_or(UtcOffset::UTC), ) { messages::unravel_errors("Failed to serve the site", &e);