GstPipelineStudio/src/settings.rs
Stéphane Cerveau 8c6cda2e92 player: feed the app with gst logs
Get the debug callback to retrieve the gst logs
and display it in the debug tab.
2023-11-30 11:54:15 +01:00

160 lines
4.6 KiB
Rust

// settings.rs
//
// Copyright 2022 Stéphane Cerveau <scerveau@collabora.com>
//
// This file is part of GstPipelineStudio
//
// SPDX-License-Identifier: GPL-3.0-only
use gtk::glib;
use std::collections::HashMap;
use std::fs::create_dir_all;
use std::path::PathBuf;
use serde::{Deserialize, Serialize};
use crate::config;
use crate::logger;
#[derive(Debug, Serialize, Deserialize, Default)]
#[serde(default)]
pub struct Settings {
pub app_maximized: bool,
pub app_width: i32,
pub app_height: i32,
pub recent_pipeline: String,
// values must be emitted before tables
pub favorites: Vec<String>,
pub paned_positions: HashMap<String, i32>,
pub preferences: HashMap<String, String>,
}
impl Settings {
fn create_path_if_not(s: &PathBuf) {
if !s.exists() {
if let Err(e) = create_dir_all(s) {
GPS_ERROR!(
"Error while trying to build settings snapshot_directory '{}': {}",
s.display(),
e
);
}
}
}
fn default_app_folder() -> PathBuf {
let mut path = glib::user_config_dir();
path.push(config::APP_ID);
path
}
fn settings_file_path() -> PathBuf {
let mut path = Settings::default_app_folder();
Settings::create_path_if_not(&path);
path.push("settings.toml");
path
}
// Public methods
pub fn graph_file_path() -> PathBuf {
let mut path = Settings::default_app_folder();
Settings::create_path_if_not(&path);
path.push("default_graph.toml");
path
}
pub fn log_file_path() -> PathBuf {
let mut path = Settings::default_app_folder();
Settings::create_path_if_not(&path);
path.push("gstpipelinestudio.log");
path
}
pub fn gst_log_level() -> String {
let settings = Settings::load_settings();
let binding = "0".to_string();
let level = settings
.preferences
.get("gst_log_level")
.unwrap_or(&binding);
level.clone()
}
pub fn set_recent_pipeline_description(pipeline: &str) {
let mut settings = Settings::load_settings();
settings.recent_pipeline = pipeline.to_string();
Settings::save_settings(&settings);
}
pub fn recent_pipeline_description() -> String {
let settings = Settings::load_settings();
settings.recent_pipeline
}
pub fn add_favorite(favorite: &str) {
let mut settings = Settings::load_settings();
settings.favorites.sort();
settings.favorites.push(String::from(favorite));
Settings::save_settings(&settings);
}
pub fn remove_favorite(favorite: &str) {
let mut settings = Settings::load_settings();
settings.favorites.retain(|x| x != favorite);
Settings::save_settings(&settings);
}
pub fn favorites_list() -> Vec<String> {
let mut favorites = Vec::new();
let settings = Settings::load_settings();
for fav in settings.favorites {
favorites.push(fav);
}
favorites
}
// Save the provided settings to the settings path
pub fn save_settings(settings: &Settings) {
let s = Settings::settings_file_path();
if let Err(e) = serde_any::to_file(&s, settings) {
GPS_ERROR!("Error while trying to save file: {} {}", s.display(), e);
}
}
// Load the current settings
pub fn load_settings() -> Settings {
let s = Settings::settings_file_path();
if s.exists() && s.is_file() {
match serde_any::from_file::<Settings, _>(&s) {
Ok(s) => s,
Err(e) => {
GPS_ERROR!("Error while opening '{}': {}", s.display(), e);
Settings::default()
}
}
} else {
let mut settings = Settings {
app_width: 800,
app_height: 600,
..Default::default()
};
settings
.paned_positions
.insert(String::from("graph_dashboard-paned"), 600);
settings
.paned_positions
.insert(String::from("graph_logs-paned"), 400);
settings
.paned_positions
.insert(String::from("elements_preview-paned"), 300);
settings
.paned_positions
.insert(String::from("elements_properties-paned"), 150);
settings
.paned_positions
.insert(String::from("playcontrols_position-paned"), 400);
settings
}
}
}