|
|
|
/*
|
|
|
|
* kPPP: A pppd front end for the KDE project
|
|
|
|
*
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Copyright (C) 1997 Bernd Johannes Wuebben
|
|
|
|
* wuebben@math.cornell.edu
|
|
|
|
*
|
|
|
|
* This file was contributed by Mario Weilguni <mweilguni@sime.com>
|
|
|
|
* Thanks Mario !
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Library 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
|
|
|
|
* Library General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library 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 __RULESET__H__
|
|
|
|
#define __RULESET__H__
|
|
|
|
|
|
|
|
#include <tqmemarray.h>
|
|
|
|
#include <tqdatetime.h>
|
|
|
|
#include <tqstring.h>
|
|
|
|
|
|
|
|
// this structure is used to save
|
|
|
|
// accounting rules
|
|
|
|
struct RULE {
|
|
|
|
int type;
|
|
|
|
double costs;
|
|
|
|
double len;
|
|
|
|
double after;
|
|
|
|
TQTime from, until;
|
|
|
|
struct {
|
|
|
|
TQDate from, until;
|
|
|
|
} date;
|
|
|
|
struct {
|
|
|
|
int from, until;
|
|
|
|
} weekday;
|
|
|
|
};
|
|
|
|
|
|
|
|
// this class is used for loading and parsing of rules
|
|
|
|
class RuleSet {
|
|
|
|
public:
|
|
|
|
/// create an empty rule
|
|
|
|
RuleSet();
|
|
|
|
|
|
|
|
/// gcc needs a destructor (otherwise compiler error)
|
|
|
|
~RuleSet() {};
|
|
|
|
|
|
|
|
/// returns the name of the ruleset
|
|
|
|
TQString name() const;
|
|
|
|
|
|
|
|
/** Load a ruleset from a file. If an error occurs,
|
|
|
|
* returns the linenumber the error was in,
|
|
|
|
* otherwise 0. If the file could not be opened,
|
|
|
|
* returns -1
|
|
|
|
*/
|
|
|
|
int load(const TQString &filename);
|
|
|
|
|
|
|
|
/// returns the currency symbol
|
|
|
|
TQString currencySymbol() const;
|
|
|
|
|
|
|
|
/** returns a string representation of the
|
|
|
|
* of a doubleingpoint number using the
|
|
|
|
* currency-settings
|
|
|
|
*/
|
|
|
|
TQString currencyString(double val) const;
|
|
|
|
|
|
|
|
/// sets the start time -- must be called when the connection has bee established
|
|
|
|
void setStartTime(TQDateTime dt);
|
|
|
|
|
|
|
|
/// returns the "per-connection" costs
|
|
|
|
double perConnectionCosts() const;
|
|
|
|
|
|
|
|
/** returns the minimum number of costs (some
|
|
|
|
* phony companies have this
|
|
|
|
*/
|
|
|
|
double minimumCosts() const;
|
|
|
|
|
|
|
|
/// returns the currently valid rule settings
|
|
|
|
void getActiveRule(TQDateTime dt, double connect_time, double &costs, double &len);
|
|
|
|
|
|
|
|
/// checks if a rulefile is ok (no parse errors...)
|
|
|
|
static int checkRuleFile(const TQString &);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
/** converts an english name of a day to integer,
|
|
|
|
* beginning with monday=0 .. sunday=6
|
|
|
|
*/
|
|
|
|
int dayNameToInt(const char *s);
|
|
|
|
|
|
|
|
/// returns the date of easter-sunday for a year
|
|
|
|
static TQDate get_easter(int year);
|
|
|
|
|
|
|
|
/// add a rule to this ruleset
|
|
|
|
void addRule(RULE r);
|
|
|
|
|
|
|
|
/// parses on entry of the "on(...)" fields
|
|
|
|
bool parseEntry(RULE &ret, TQString s, int year);
|
|
|
|
|
|
|
|
/// parses the "on(...)" fields
|
|
|
|
bool parseEntries(TQString s, int year,
|
|
|
|
TQTime t1, TQTime t2,
|
|
|
|
double costs, double len, double after);
|
|
|
|
|
|
|
|
/// parses the "between(...)" time fields
|
|
|
|
bool parseTime(TQTime &t1, TQTime &t2, TQString s);
|
|
|
|
|
|
|
|
/// parses the "use(...)" fields
|
|
|
|
bool parseRate(double &costs, double &len, double &after, TQString s);
|
|
|
|
|
|
|
|
/// parses a whole line
|
|
|
|
bool parseLine(const TQString &line);
|
|
|
|
|
|
|
|
/// returns midnight time (00:00:00.000)
|
|
|
|
TQTime midnight() const;
|
|
|
|
|
|
|
|
/// returns the last valid time BEFORE midnight
|
|
|
|
TQTime beforeMidnight() const;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
TQString _name;
|
|
|
|
TQString _currency_symbol;
|
|
|
|
TQDateTime starttime;
|
|
|
|
int _currency_digits;
|
|
|
|
double default_costs;
|
|
|
|
double _minimum_costs;
|
|
|
|
double default_len;
|
|
|
|
double pcf;
|
|
|
|
bool have_flat_init_costs;
|
|
|
|
double flat_init_duration;
|
|
|
|
double flat_init_costs;
|
|
|
|
|
|
|
|
TQMemArray<RULE> rules;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|