2025-03-29 16:55:26 -04:00
|
|
|
// TODO: Header
|
2025-03-29 08:01:13 -04:00
|
|
|
|
2025-03-30 11:20:21 -04:00
|
|
|
use cxx_qt_lib::QString;
|
2025-04-13 09:35:55 -04:00
|
|
|
use std::error::Error;
|
2025-04-13 11:58:28 -04:00
|
|
|
use std::process::{Command, Stdio};
|
2025-04-13 10:20:43 -04:00
|
|
|
use structopt::StructOpt;
|
2025-03-30 11:20:21 -04:00
|
|
|
|
|
|
|
|
pub mod colors;
|
2025-03-30 13:14:58 -04:00
|
|
|
pub mod filesystem;
|
2025-03-29 08:01:13 -04:00
|
|
|
|
2025-04-13 10:20:43 -04:00
|
|
|
fn run_gui(root_path: std::path::PathBuf) -> Result<(), Box<dyn Error>> {
|
|
|
|
|
println!("Starting the GUI editor at {:?}", root_path);
|
|
|
|
|
|
2025-03-29 08:01:13 -04:00
|
|
|
use cxx_qt_lib::{QGuiApplication, QQmlApplicationEngine, QUrl};
|
|
|
|
|
|
|
|
|
|
let mut app = QGuiApplication::new();
|
|
|
|
|
let mut engine = QQmlApplicationEngine::new();
|
|
|
|
|
|
2025-03-30 11:20:21 -04:00
|
|
|
if let Some(engine) = engine.as_mut() {
|
|
|
|
|
engine.add_import_path(&QString::from("qml/"));
|
|
|
|
|
}
|
2025-03-29 08:01:13 -04:00
|
|
|
if let Some(engine) = engine.as_mut() {
|
|
|
|
|
engine.load(&QUrl::from("qml/main.qml"));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if let Some(app) = app.as_mut() {
|
|
|
|
|
app.exec();
|
|
|
|
|
}
|
2025-04-13 09:35:55 -04:00
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
|
}
|
|
|
|
|
|
2025-04-13 10:20:43 -04:00
|
|
|
fn run_tui(root_path: std::path::PathBuf) -> Result<(), Box<dyn Error>> {
|
|
|
|
|
println!("Starting the TUI editor at {:?}", root_path);
|
2025-04-13 09:35:55 -04:00
|
|
|
Ok(())
|
|
|
|
|
}
|
|
|
|
|
|
2025-04-13 11:58:28 -04:00
|
|
|
/// Command line interface IDE with full GUI and headless modes.
|
|
|
|
|
/// If no flags are provided the GUI editor is launched in a separate process.
|
|
|
|
|
/// If no path is provided the current directory is used.
|
2025-04-13 10:20:43 -04:00
|
|
|
#[derive(StructOpt, Debug)]
|
2025-04-13 11:58:28 -04:00
|
|
|
#[structopt(name = "clide", verbatim_doc_comment)]
|
2025-04-13 10:20:43 -04:00
|
|
|
struct Cli {
|
2025-04-13 11:58:28 -04:00
|
|
|
/// The root directory for the project to open with the clide editor.
|
2025-04-13 10:20:43 -04:00
|
|
|
#[structopt(parse(from_os_str))]
|
|
|
|
|
pub path: Option<std::path::PathBuf>,
|
|
|
|
|
|
2025-04-13 11:58:28 -04:00
|
|
|
/// Run clide in headless mode.
|
2025-04-13 10:20:43 -04:00
|
|
|
#[structopt(name = "tui", short, long)]
|
|
|
|
|
pub tui: bool,
|
2025-04-13 11:58:28 -04:00
|
|
|
|
|
|
|
|
/// Run the clide GUI in the current process, blocking the terminal and showing all output streams.
|
|
|
|
|
#[structopt(name = "gui", short, long)]
|
|
|
|
|
pub gui: bool,
|
2025-04-13 09:35:55 -04:00
|
|
|
}
|
|
|
|
|
|
2025-04-13 10:20:43 -04:00
|
|
|
fn main() -> Result<(), Box<dyn Error>> {
|
|
|
|
|
let args = Cli::from_args();
|
2025-04-13 09:35:55 -04:00
|
|
|
|
2025-04-13 11:01:37 -04:00
|
|
|
let root_path = match args.path {
|
|
|
|
|
// If the CLI was provided a directory convert it to absolute.
|
|
|
|
|
Some(path) => std::path::absolute(path)?,
|
|
|
|
|
// If no path was provided, use current directory.
|
|
|
|
|
None => std::env::current_dir().unwrap_or_else(|_|
|
|
|
|
|
// If we can't find the CWD attempt to open the home directory.
|
|
|
|
|
dirs::home_dir().expect("Failed to access filesystem.")),
|
|
|
|
|
};
|
2025-04-13 09:35:55 -04:00
|
|
|
|
2025-04-13 11:58:28 -04:00
|
|
|
match args.gui {
|
|
|
|
|
true => run_gui(root_path),
|
|
|
|
|
false => {
|
|
|
|
|
// Open the TUI editor if requested, otherwise use the QML GUI by default.
|
|
|
|
|
match args.tui {
|
|
|
|
|
true => run_tui(root_path),
|
|
|
|
|
false => {
|
|
|
|
|
// Relaunch the CLIDE GUI in a separate process.
|
|
|
|
|
Command::new(std::env::current_exe()?)
|
|
|
|
|
.args(&["--gui"])
|
|
|
|
|
.stdout(Stdio::null())
|
|
|
|
|
.stderr(Stdio::null())
|
|
|
|
|
.stdin(Stdio::null())
|
|
|
|
|
.spawn()?;
|
|
|
|
|
Ok(())
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-04-13 09:35:55 -04:00
|
|
|
}
|
2025-03-29 08:01:13 -04:00
|
|
|
}
|