- Fixed bug #438, correcting the sorting of the entry_time, start_time and end_time columns (thanks to Michelle Crane). - Reordered ChangeLog so that bugs, features are in sequence. Don't know why I did this. Some inner compulsion. - Deprecated silly start_time, end_time and entry_time columns, which are now (and were) superseded by start, end and entry columns with time formats. - Config.cpp now detects use of these deprecated fields and complains to the show command. - Date.cpp now uses the variable 'input' instead of 'mdy', which was confusing and implied that it contained a date without a time. - Obsoleted and removed Date::toStringWithTime, which ignored requested formats. - When checking for an epoch, Date::isEpoch just looked for strings of more than 8 digits. The additional restriction of less than or equal to 10 digits was added. This was breaking unit tests using the dateformat YMDHNS, which is reasonable. - Removed the obsolete field format hooks format-entry_time, format-start_time and format-end_time - Removed the obsolete field format hook unit tests hook.format-entry_time.t, hook.format-start_time.t and hook.format-end_time.t. - Removed use of deprecated field in hook.format-countdown_compact.t. - Added missing shortcut comparisons in Table::sort that was causing an unnecessary full parse of dates even if they were identical as strings. - Coded entry_time as a synonym for entry. Ditto for start_time and end_time. - Marked the new synonyms as deprecated. - Added bug.438.t unit test. - Added deprecated fields to the NEWS file.
75 lines
2.2 KiB
C++
75 lines
2.2 KiB
C++
////////////////////////////////////////////////////////////////////////////////
|
|
// task - a command line task list manager.
|
|
//
|
|
// Copyright 2006 - 2010, Paul Beckingham.
|
|
// All rights reserved.
|
|
//
|
|
// This program 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 2 of the License, or (at your option) any later
|
|
// version.
|
|
//
|
|
// This program 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
|
|
// this program; if not, write to the
|
|
//
|
|
// Free Software Foundation, Inc.,
|
|
// 51 Franklin Street, Fifth Floor,
|
|
// Boston, MA
|
|
// 02110-1301
|
|
// USA
|
|
//
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
#ifndef INCLUDED_CONFIG
|
|
#define INCLUDED_CONFIG
|
|
|
|
#include <map>
|
|
#include <vector>
|
|
#include <string>
|
|
#include "File.h"
|
|
|
|
class Config : public std::map <std::string, std::string>
|
|
{
|
|
public:
|
|
Config ();
|
|
Config (const std::string&);
|
|
|
|
Config (const Config&);
|
|
Config& operator= (const Config&);
|
|
|
|
void load (const std::string&, int nest = 1);
|
|
void parse (const std::string&, int nest = 1);
|
|
|
|
void createDefaultRC (const std::string&, const std::string&);
|
|
void createDefaultData (const std::string&);
|
|
void setDefaults ();
|
|
void clear ();
|
|
|
|
const std::string get (const std::string&);
|
|
const int getInteger (const std::string&);
|
|
const double getReal (const std::string&);
|
|
const bool getBoolean (const std::string&);
|
|
|
|
void set (const std::string&, const int);
|
|
void set (const std::string&, const double);
|
|
void set (const std::string&, const std::string&);
|
|
void all (std::vector <std::string>&);
|
|
|
|
std::string checkForDeprecatedColor ();
|
|
std::string checkForDeprecatedColumns ();
|
|
|
|
public:
|
|
File original_file;
|
|
|
|
private:
|
|
static std::string defaults;
|
|
};
|
|
|
|
#endif
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|