feat(core): populate config directory with default content if not present

This commit is contained in:
Federico Terzi 2021-07-07 22:05:39 +02:00
parent 0c1a8dd080
commit 1895488f6b
6 changed files with 150 additions and 2 deletions

View File

@ -17,8 +17,10 @@
* along with espanso. If not, see <https://www.gnu.org/licenses/>. * along with espanso. If not, see <https://www.gnu.org/licenses/>.
*/ */
use log::{error};
use self::util::MigrationError; use self::util::MigrationError;
use crate::preferences::Preferences; use crate::preferences::Preferences;
use crate::exit_code::{LAUNCHER_CONFIG_DIR_POPULATION_FAILURE, LAUNCHER_SUCCESS};
use super::{CliModule, CliModuleArgs}; use super::{CliModule, CliModuleArgs};
@ -161,7 +163,14 @@ fn launcher_main(args: CliModuleArgs) -> i32 {
true true
}; };
// TODO: initialize config directory if not present if !espanso_config::is_legacy_config(&paths.config) {
if let Err(err) = crate::config::populate_default_config(&paths.config) {
error!("Error populating the config directory: {:?}", err);
// TODO: show an error message with GUI
return LAUNCHER_CONFIG_DIR_POPULATION_FAILURE;
}
}
if should_launch_daemon { if should_launch_daemon {
// We hide the dock icon on macOS to avoid having it around when the daemon is running // We hide the dock icon on macOS to avoid having it around when the daemon is running
@ -173,7 +182,7 @@ fn launcher_main(args: CliModuleArgs) -> i32 {
daemon::launch_daemon(&paths_overrides).expect("failed to launch daemon"); daemon::launch_daemon(&paths_overrides).expect("failed to launch daemon");
} }
0 LAUNCHER_SUCCESS
} }
#[cfg(not(feature = "modulo"))] #[cfg(not(feature = "modulo"))]

58
espanso/src/config.rs Normal file
View File

@ -0,0 +1,58 @@
/*
* This file is part of espanso.
*
* Copyright (C) 2019-2021 Federico Terzi
*
* espanso is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* espanso is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with espanso. If not, see <https://www.gnu.org/licenses/>.
*/
use anyhow::Result;
use log::info;
use std::path::Path;
const DEFAULT_CONFIG_FILE_CONTENT: &str = include_str!("./res/config/default.yml");
const DEFAULT_MATCH_FILE_CONTENT: &str = include_str!("./res/config/base.yml");
pub fn populate_default_config(config_dir: &Path) -> Result<()> {
if !config_dir.is_dir() {
info!("generating base configuration directory in: {:?}", config_dir);
std::fs::create_dir_all(config_dir)?;
}
let sub_config_dir = config_dir.join("config");
let sub_match_dir = config_dir.join("match");
if !sub_config_dir.is_dir() {
info!("generating config directory in: {:?}", sub_config_dir);
std::fs::create_dir_all(&sub_config_dir)?;
}
if !sub_match_dir.is_dir() {
info!("generating match directory in: {:?}", sub_match_dir);
std::fs::create_dir_all(&sub_match_dir)?;
}
let default_file = sub_config_dir.join("default.yml");
let match_file = sub_match_dir.join("base.yml");
if !default_file.is_file() {
info!("populating default.yml file with initial content: {:?}", default_file);
std::fs::write(default_file, DEFAULT_CONFIG_FILE_CONTENT)?;
}
if !match_file.is_file() {
info!("populating base.yml file with initial content: {:?}", match_file);
std::fs::write(match_file, DEFAULT_MATCH_FILE_CONTENT)?;
}
Ok(())
}

View File

@ -40,6 +40,9 @@ pub const MIGRATE_UNEXPECTED_FAILURE: i32 = 101;
pub const ADD_TO_PATH_SUCCESS: i32 = 0; pub const ADD_TO_PATH_SUCCESS: i32 = 0;
pub const ADD_TO_PATH_FAILURE: i32 = 1; pub const ADD_TO_PATH_FAILURE: i32 = 1;
pub const LAUNCHER_SUCCESS: i32 = 0;
pub const LAUNCHER_CONFIG_DIR_POPULATION_FAILURE: i32 = 1;
use std::sync::Mutex; use std::sync::Mutex;
lazy_static! { lazy_static! {

View File

@ -36,6 +36,7 @@ use simplelog::{
use crate::cli::{LogMode, PathsOverrides}; use crate::cli::{LogMode, PathsOverrides};
mod cli; mod cli;
mod config;
mod engine; mod engine;
mod exit_code; mod exit_code;
mod gui; mod gui;

View File

@ -0,0 +1,37 @@
# espanso match file
# For a complete introduction, visit the official docs at: https://espanso.org/docs/
# You can use this file to define the base matches (aka snippets)
# that will be available in every application when using espanso.
# Matches are substitution rules: when you type the "trigger" string
# it gets replaced by the "replace" string.
matches:
# Simple text replacement
- trigger: ":espanso"
replace: "Hi there!"
# NOTE: espanso uses YAML to define matches, so pay attention to the indentation!
# But matches can also be dynamic:
# Print the current date
- trigger: ":date"
replace: "{{mydate}}"
vars:
- name: mydate
type: date
params:
format: "%m/%d/%Y"
# Print the output of a shell command
- trigger: ":shell"
replace: "{{output}}"
vars:
- name: output
type: shell
params:
cmd: "echo Hello from your shell"
# And much more! For more information, visit the docs: https://espanso.org/docs/

View File

@ -0,0 +1,40 @@
# espanso configuration file
# For a complete introduction, visit the official docs at: https://espanso.org/docs/
# You can use this file to define the global configuration options for espanso.
# These are the parameters that will be used by default on every application,
# but you can also override them on a per-application basis.
# To make customization easier, this file contains some of the commonly used
# parameters. Feel free to uncomment and tune them to fit your needs!
# --- Toggle key
# Customize the key used to disable and enable espanso (when double tapped)
# Available options: CTRL, SHIFT, ALT, CMD, OFF
# You can also specify the key variant, such as LEFT_CTRL, RIGHT_SHIFT, etc...
# toggle_key: ALT
# You can also disable the toggle key completely with
# toggle_key: OFF
# --- Injection Backend
# Espanso supports multiple ways of injecting text into applications. Each of
# them has its quirks, therefore you may want to change it if you are having problems.
# By default, espanso uses the "Auto" backend which should work well in most cases,
# but you may want to try the "Clipboard" or "Inject" backend in case of issues.
# backend: Clipboard
# --- Auto-restart
# Enable/disable the config auto-reload after a file change is detected.
# auto_restart: false
# --- Clipboard threshold
# Because injecting long texts char-by-char is a slow operation, espanso automatically
# uses the clipboard if the text is longer than 'clipboard_threshold' characters.
# clipboard_threshold: 100
# For a list of all the available options, visit the official docs at: https://espanso.org/docs/