mirror of
https://github.com/GothenburgBitFactory/taskwarrior.git
synced 2025-07-07 20:06:36 +02:00
Config: Migrated to libshared Configuration
This commit is contained in:
parent
00bbca275c
commit
b57a734625
9 changed files with 19 additions and 125 deletions
|
@ -7,7 +7,6 @@ include_directories (${CMAKE_SOURCE_DIR}
|
||||||
${TASK_INCLUDE_DIRS})
|
${TASK_INCLUDE_DIRS})
|
||||||
|
|
||||||
add_library (task CLI2.cpp CLI2.h
|
add_library (task CLI2.cpp CLI2.h
|
||||||
Config.cpp Config.h
|
|
||||||
Context.cpp Context.h
|
Context.cpp Context.h
|
||||||
DOM.cpp DOM.h
|
DOM.cpp DOM.h
|
||||||
Dates.cpp Dates.h
|
Dates.cpp Dates.h
|
||||||
|
@ -32,6 +31,7 @@ add_library (task CLI2.cpp CLI2.h
|
||||||
util.cpp util.h)
|
util.cpp util.h)
|
||||||
|
|
||||||
add_library (libshared libshared/src/Color.cpp libshared/src/Color.h
|
add_library (libshared libshared/src/Color.cpp libshared/src/Color.h
|
||||||
|
libshared/src/Configuration.cpp libshared/src/Configuration.h
|
||||||
libshared/src/Datetime.cpp libshared/src/Datetime.h
|
libshared/src/Datetime.cpp libshared/src/Datetime.h
|
||||||
libshared/src/Duration.cpp libshared/src/Duration.h
|
libshared/src/Duration.cpp libshared/src/Duration.h
|
||||||
libshared/src/FS.cpp libshared/src/FS.h
|
libshared/src/FS.cpp libshared/src/FS.h
|
||||||
|
|
|
@ -1071,9 +1071,7 @@ void Context::staticInitialization ()
|
||||||
Task::urgencyAgeMax = config.getReal ("urgency.age.max");
|
Task::urgencyAgeMax = config.getReal ("urgency.age.max");
|
||||||
|
|
||||||
// Tag- and project-specific coefficients.
|
// Tag- and project-specific coefficients.
|
||||||
std::vector <std::string> all;
|
for (auto& var : config.all ())
|
||||||
config.all (all);
|
|
||||||
for (auto& var : all)
|
|
||||||
if (var.substr (0, 13) == "urgency.user." ||
|
if (var.substr (0, 13) == "urgency.user." ||
|
||||||
var.substr (0, 12) == "urgency.uda.")
|
var.substr (0, 12) == "urgency.uda.")
|
||||||
Task::coefficients[var] = config.getReal (var);
|
Task::coefficients[var] = config.getReal (var);
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
|
|
||||||
#include <Command.h>
|
#include <Command.h>
|
||||||
#include <Column.h>
|
#include <Column.h>
|
||||||
#include <Config.h>
|
#include <Configuration.h>
|
||||||
#include <Task.h>
|
#include <Task.h>
|
||||||
#include <TDB2.h>
|
#include <TDB2.h>
|
||||||
#include <Hooks.h>
|
#include <Hooks.h>
|
||||||
|
@ -81,7 +81,7 @@ public:
|
||||||
std::string home_dir {};
|
std::string home_dir {};
|
||||||
File rc_file {"~/.taskrc"};
|
File rc_file {"~/.taskrc"};
|
||||||
Path data_dir {"~/.task"};
|
Path data_dir {"~/.task"};
|
||||||
Config config {};
|
Configuration config {};
|
||||||
TDB2 tdb2 {};
|
TDB2 tdb2 {};
|
||||||
Hooks hooks {};
|
Hooks hooks {};
|
||||||
bool determine_color_use {true};
|
bool determine_color_use {true};
|
||||||
|
|
|
@ -60,7 +60,7 @@ bool CmdConfig::setConfigVariable (
|
||||||
{
|
{
|
||||||
// Read .taskrc (or equivalent)
|
// Read .taskrc (or equivalent)
|
||||||
std::vector <std::string> contents;
|
std::vector <std::string> contents;
|
||||||
File::read (context.config._original_file, contents);
|
File::read (context.config.file (), contents);
|
||||||
|
|
||||||
auto found = false;
|
auto found = false;
|
||||||
auto change = false;
|
auto change = false;
|
||||||
|
@ -99,7 +99,7 @@ bool CmdConfig::setConfigVariable (
|
||||||
}
|
}
|
||||||
|
|
||||||
if (change)
|
if (change)
|
||||||
File::write (context.config._original_file, contents);
|
File::write (context.config.file (), contents);
|
||||||
|
|
||||||
return change;
|
return change;
|
||||||
}
|
}
|
||||||
|
@ -109,7 +109,7 @@ int CmdConfig::unsetConfigVariable (const std::string& name, bool confirmation /
|
||||||
{
|
{
|
||||||
// Read .taskrc (or equivalent)
|
// Read .taskrc (or equivalent)
|
||||||
std::vector <std::string> contents;
|
std::vector <std::string> contents;
|
||||||
File::read (context.config._original_file, contents);
|
File::read (context.config.file (), contents);
|
||||||
|
|
||||||
auto found = false;
|
auto found = false;
|
||||||
auto change = false;
|
auto change = false;
|
||||||
|
@ -144,7 +144,7 @@ int CmdConfig::unsetConfigVariable (const std::string& name, bool confirmation /
|
||||||
}
|
}
|
||||||
|
|
||||||
if (change)
|
if (change)
|
||||||
File::write (context.config._original_file, contents);
|
File::write (context.config.file (), contents);
|
||||||
|
|
||||||
if (change && found)
|
if (change && found)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -216,7 +216,7 @@ int CmdConfig::execute (std::string& output)
|
||||||
if (change)
|
if (change)
|
||||||
{
|
{
|
||||||
out << format (STRING_CMD_CONFIG_FILE_MOD,
|
out << format (STRING_CMD_CONFIG_FILE_MOD,
|
||||||
context.config._original_file._data)
|
context.config.file ())
|
||||||
<< '\n';
|
<< '\n';
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -252,8 +252,7 @@ CmdCompletionConfig::CmdCompletionConfig ()
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
int CmdCompletionConfig::execute (std::string& output)
|
int CmdCompletionConfig::execute (std::string& output)
|
||||||
{
|
{
|
||||||
std::vector <std::string> configs;
|
auto configs = context.config.all ();
|
||||||
context.config.all (configs);
|
|
||||||
std::sort (configs.begin (), configs.end ());
|
std::sort (configs.begin (), configs.end ());
|
||||||
|
|
||||||
for (const auto& config : configs)
|
for (const auto& config : configs)
|
||||||
|
|
|
@ -163,16 +163,17 @@ int CmdDiagnostics::execute (std::string& output)
|
||||||
<< "\n\n";
|
<< "\n\n";
|
||||||
|
|
||||||
// Config: .taskrc found, readable, writable
|
// Config: .taskrc found, readable, writable
|
||||||
|
File rcFile (context.config.file ());
|
||||||
out << bold.colorize (STRING_CMD_DIAG_CONFIG)
|
out << bold.colorize (STRING_CMD_DIAG_CONFIG)
|
||||||
<< '\n'
|
<< '\n'
|
||||||
<< " File: " << context.config._original_file._data << ' '
|
<< " File: " << rcFile._data << ' '
|
||||||
<< (context.config._original_file.exists ()
|
<< (rcFile.exists ()
|
||||||
? STRING_CMD_DIAG_FOUND
|
? STRING_CMD_DIAG_FOUND
|
||||||
: STRING_CMD_DIAG_MISSING)
|
: STRING_CMD_DIAG_MISSING)
|
||||||
<< ", " << context.config._original_file.size () << ' ' << "bytes"
|
<< ", " << rcFile.size () << ' ' << "bytes"
|
||||||
<< ", mode "
|
<< ", mode "
|
||||||
<< std::setbase (8)
|
<< std::setbase (8)
|
||||||
<< context.config._original_file.mode ()
|
<< rcFile.mode ()
|
||||||
<< '\n';
|
<< '\n';
|
||||||
|
|
||||||
// Config: data.location found, readable, writable
|
// Config: data.location found, readable, writable
|
||||||
|
|
|
@ -253,7 +253,7 @@ int CmdShow::execute (std::string& output)
|
||||||
|
|
||||||
// Find all the values that match the defaults, for highlighting.
|
// Find all the values that match the defaults, for highlighting.
|
||||||
std::vector <std::string> default_values;
|
std::vector <std::string> default_values;
|
||||||
Config default_config;
|
Configuration default_config;
|
||||||
default_config.parse (configurationDefaults);
|
default_config.parse (configurationDefaults);
|
||||||
|
|
||||||
for (auto& i : context.config)
|
for (auto& i : context.config)
|
||||||
|
@ -411,11 +411,8 @@ CmdShowRaw::CmdShowRaw ()
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
int CmdShowRaw::execute (std::string& output)
|
int CmdShowRaw::execute (std::string& output)
|
||||||
{
|
{
|
||||||
// Get all the settings.
|
// Get all the settings and sort alphabetically by name.
|
||||||
std::vector <std::string> all;
|
auto all = context.config.all ();
|
||||||
context.config.all (all);
|
|
||||||
|
|
||||||
// Sort alphabetically by name.
|
|
||||||
std::sort (all.begin (), all.end ());
|
std::sort (all.begin (), all.end ());
|
||||||
|
|
||||||
// Display them all.
|
// Display them all.
|
||||||
|
|
1
test/.gitignore
vendored
1
test/.gitignore
vendored
|
@ -4,7 +4,6 @@
|
||||||
*.log
|
*.log
|
||||||
*.runlog
|
*.runlog
|
||||||
col.t
|
col.t
|
||||||
config.t
|
|
||||||
dates.t
|
dates.t
|
||||||
eval.t
|
eval.t
|
||||||
iso8601d.t
|
iso8601d.t
|
||||||
|
|
|
@ -14,7 +14,7 @@ include_directories (${CMAKE_SOURCE_DIR}
|
||||||
${CMAKE_SOURCE_DIR}/test
|
${CMAKE_SOURCE_DIR}/test
|
||||||
${TASK_INCLUDE_DIRS})
|
${TASK_INCLUDE_DIRS})
|
||||||
|
|
||||||
set (test_SRCS col.t config.t nibbler.t t.t tdb2.t util.t view.t lexer.t iso8601d.t iso8601p.t eval.t dates.t variant_add.t variant_and.t variant_cast.t variant_divide.t variant_equal.t variant_exp.t variant_gt.t variant_gte.t variant_inequal.t variant_lt.t variant_lte.t variant_match.t variant_math.t variant_modulo.t variant_multiply.t variant_nomatch.t variant_not.t variant_or.t variant_partial.t variant_subtract.t variant_xor.t)
|
set (test_SRCS col.t nibbler.t t.t tdb2.t util.t view.t lexer.t iso8601d.t iso8601p.t eval.t dates.t variant_add.t variant_and.t variant_cast.t variant_divide.t variant_equal.t variant_exp.t variant_gt.t variant_gte.t variant_inequal.t variant_lt.t variant_lte.t variant_match.t variant_math.t variant_modulo.t variant_multiply.t variant_nomatch.t variant_not.t variant_or.t variant_partial.t variant_subtract.t variant_xor.t)
|
||||||
|
|
||||||
add_custom_target (test ./run_all --verbose
|
add_custom_target (test ./run_all --verbose
|
||||||
DEPENDS ${test_SRCS} task_executable
|
DEPENDS ${test_SRCS} task_executable
|
||||||
|
|
|
@ -1,100 +0,0 @@
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
//
|
|
||||||
// Copyright 2006 - 2017, Paul Beckingham, Federico Hernandez.
|
|
||||||
//
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
// of this software and associated documentation files (the "Software"), to deal
|
|
||||||
// in the Software without restriction, including without limitation the rights
|
|
||||||
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
// copies of the Software, and to permit persons to whom the Software is
|
|
||||||
// furnished to do so, subject to the following conditions:
|
|
||||||
//
|
|
||||||
// The above copyright notice and this permission notice shall be included
|
|
||||||
// in all copies or substantial portions of the Software.
|
|
||||||
//
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
||||||
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
||||||
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
||||||
// SOFTWARE.
|
|
||||||
//
|
|
||||||
// http://www.opensource.org/licenses/mit-license.php
|
|
||||||
//
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
#include <cmake.h>
|
|
||||||
#include <iostream>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <Context.h>
|
|
||||||
#include <test.h>
|
|
||||||
|
|
||||||
Context context;
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
int main (int, char**)
|
|
||||||
{
|
|
||||||
UnitTest t (11);
|
|
||||||
|
|
||||||
// Ensure environment has no influence.
|
|
||||||
unsetenv ("TASKDATA");
|
|
||||||
unsetenv ("TASKRC");
|
|
||||||
|
|
||||||
Config c;
|
|
||||||
|
|
||||||
// void set (const std::string&, const std::string&);
|
|
||||||
// const std::string get (const std::string&);
|
|
||||||
c.set ("str1", "one");
|
|
||||||
t.is (c.get ("str1"), "one", "Config::set/get std::string");
|
|
||||||
|
|
||||||
c.set ("str1", "");
|
|
||||||
t.is (c.get ("str1"), "", "Config::set/get std::string");
|
|
||||||
|
|
||||||
// void set (const std::string&, const int);
|
|
||||||
// const int getInteger (const std::string&);
|
|
||||||
c.set ("int1", 1);
|
|
||||||
t.is (c.getInteger ("int1"), 1, "Config::set/get int");
|
|
||||||
|
|
||||||
c.set ("int2", 3);
|
|
||||||
t.is (c.getInteger ("int2"), 3, "Config::set/get int");
|
|
||||||
|
|
||||||
c.set ("int3", -9);
|
|
||||||
t.is (c.getInteger ("int3"), -9, "Config::set/get int");
|
|
||||||
|
|
||||||
// void set (const std::string&, const double);
|
|
||||||
// const double getReal (const std::string&);
|
|
||||||
c.set ("double1", 1.0);
|
|
||||||
t.is (c.getReal ("double1"), 1.0, "Config::set/get double");
|
|
||||||
|
|
||||||
c.set ("double2", 3.0);
|
|
||||||
t.is (c.getReal ("double2"), 3.0, "Config::set/get double");
|
|
||||||
|
|
||||||
c.set ("double3", -9.0);
|
|
||||||
t.is (c.getReal ("double3"), -9.0, "Config::set/get double");
|
|
||||||
|
|
||||||
// void set (const std::string&, const bool);
|
|
||||||
// const bool getBoolean (const std::string&);
|
|
||||||
c.set ("bool1", false);
|
|
||||||
t.is (c.getBoolean ("bool1"), false, "Config::set/get bool");
|
|
||||||
|
|
||||||
c.set ("bool1", true);
|
|
||||||
t.is (c.getBoolean ("bool1"), true, "Config::set/get bool");
|
|
||||||
|
|
||||||
// void all (std::vector <std::string>&);
|
|
||||||
std::vector <std::string> all;
|
|
||||||
c.all (all);
|
|
||||||
|
|
||||||
// 8 created in this test program.
|
|
||||||
// 22 default report setting created in Config::Config.
|
|
||||||
t.ok (all.size () >= 8, "Config::all");
|
|
||||||
|
|
||||||
// TODO Test includes
|
|
||||||
// TODO Test included nesting limit
|
|
||||||
// TODO Test included absolute vs relative
|
|
||||||
// TODO Test included missing file
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
Loading…
Add table
Add a link
Reference in a new issue