Enhancement - Mod/Att interaction

- New unit tests for Mod object.
- Added new constructors to Mod object for ease of use.
- Added Mod handling in Att object.
- Added more Att unit tests.
This commit is contained in:
Paul Beckingham 2009-05-24 14:45:50 -04:00
parent c860d58641
commit 41a6cdea22
8 changed files with 117 additions and 37 deletions

View file

@ -126,9 +126,9 @@ std::string Att::composeF4 () const
} }
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
void Att::addMod (const std::string&) void Att::addMod (const Mod& mod)
{ {
throw std::string ("unimplemented Att::addMod"); mMods.push_back (mod);
} }
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////

View file

@ -44,7 +44,7 @@ public:
void parse (const std::string&); void parse (const std::string&);
std::string composeF4 () const; std::string composeF4 () const;
void addMod (const std::string&); void addMod (const Mod&);
// TODO Need method to access mods. // TODO Need method to access mods.
std::string name () const; std::string name () const;

View file

@ -29,27 +29,33 @@
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
Mod::Mod () Mod::Mod ()
: std::string ("")
{ {
} }
////////////////////////////////////////////////////////////////////////////////
Mod::Mod (const char* other)
: std::string (other)
{
if (!valid ())
throw std::string ("Unrecognized modifier '") + other + "'";
}
////////////////////////////////////////////////////////////////////////////////
Mod::Mod (const std::string& other)
: std::string (other)
{
if (!valid ())
throw std::string ("Unrecognized modifier '") + other + "'";
}
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
Mod::~Mod () Mod::~Mod ()
{ {
} }
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
// before after bool Mod::valid ()
// not
// none any
// over under
// synth
// first last
// this
// next
// is isnt
// has hasnt
// startswith endswith
bool Mod::isValid ()
{ {
if (*this == "before" || *this == "after" || if (*this == "before" || *this == "after" ||
*this == "not" || *this == "not" ||
@ -70,18 +76,22 @@ bool Mod::isValid ()
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
bool Mod::eval (const Mod& other) bool Mod::eval (const Mod& other)
{ {
// before // No modifier means automatic pass.
// after if (*this == "")
// non return true;
// none
// any // TODO before
// synth // TODO after
// under // TODO not
// over // TODO none
// first // TODO any
// last // TODO synth
// this // TODO under
// next // TODO over
// TODO first
// TODO last
// TODO this
// TODO next
if (*this == ".is") if (*this == ".is")
return *this == other ? true : false; return *this == other ? true : false;
@ -89,10 +99,10 @@ bool Mod::eval (const Mod& other)
if (*this == ".isnt") if (*this == ".isnt")
return *this != other ? true : false; return *this != other ? true : false;
// has // TODO has
// hasnt // TODO hasnt
// startswith // TODO startswith
// endswith // TODO endswith
return false; return false;
} }

View file

@ -34,10 +34,12 @@ class Mod;
class Mod : public std::string class Mod : public std::string
{ {
public: public:
Mod (); // Default constructor Mod (); // Default constructor
~Mod (); // Destructor Mod (const char*); // Copy constructor
Mod (const std::string&); // Copy constructor
~Mod (); // Destructor
bool isValid (); bool valid ();
bool eval (const Mod&); bool eval (const Mod&);
}; };

View file

@ -68,6 +68,10 @@ void Record::parse (const std::string& input)
{ {
if (input[0] == '[' && input[input.length () - 1] == ']') if (input[0] == '[' && input[input.length () - 1] == ']')
{ {
throw std::string ("unimplemented Record:parse"); throw std::string ("unimplemented Record:parse");
} }
else else

View file

@ -1,5 +1,5 @@
PROJECT = t.t tdb.t date.t duration.t t.benchmark.t text.t autocomplete.t \ PROJECT = t.t tdb.t date.t duration.t t.benchmark.t text.t autocomplete.t \
parse.t seq.t att.t # mod.t record.t parse.t seq.t att.t mod.t # record.t
CFLAGS = -I. -I.. -Wall -pedantic -ggdb3 -fno-rtti CFLAGS = -I. -I.. -Wall -pedantic -ggdb3 -fno-rtti
LFLAGS = -L/usr/local/lib LFLAGS = -L/usr/local/lib
OBJECTS = ../TDB.o ../T.o ../parse.o ../text.o ../Date.o ../Duration.o \ OBJECTS = ../TDB.o ../T.o ../parse.o ../text.o ../Date.o ../Duration.o \

View file

@ -30,7 +30,7 @@
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
int main (int argc, char** argv) int main (int argc, char** argv)
{ {
UnitTest t (31); UnitTest t (33);
Att a1 ("name", "value"); Att a1 ("name", "value");
t.is (a1.name (), "name", "Att::Att (name, value), Att.name"); t.is (a1.name (), "name", "Att::Att (name, value), Att.name");
@ -64,7 +64,14 @@ int main (int argc, char** argv)
t.is (a6.value_int (), 7, "Att::value_int set/get"); t.is (a6.value_int (), 7, "Att::value_int set/get");
t.is (a6.value (), "7", "Att::value 7"); t.is (a6.value (), "7", "Att::value 7");
// TODO Att::addMod // Att::addMod
bool good = true;
try {a6.addMod ("is");} catch (...) {t.fail ("Att::addMod (is)"); good = false;}
if (good) t.pass ("Att::addMod (is)");
good = true;
try {a6.addMod (Mod ("fartwizzle"));} catch (...) {t.pass ("Att::addMod (fartwizzle) failed"); good = false;}
if (good) t.fail ("Att::addMod (fartwizzle)");
// Att::parse // Att::parse
Att a7; Att a7;

57
src/tests/mod.t.cpp Normal file
View file

@ -0,0 +1,57 @@
////////////////////////////////////////////////////////////////////////////////
// task - a command line task list manager.
//
// Copyright 2006 - 2009, 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
//
////////////////////////////////////////////////////////////////////////////////
#include <Mod.h>
#include <test.h>
////////////////////////////////////////////////////////////////////////////////
int main (int argc, char** argv)
{
UnitTest t (18);
Mod m = "before"; t.ok (m.valid (), "Mod: before is valid");
m = "after"; t.ok (m.valid (), "Mod: after is valid");
m = "not"; t.ok (m.valid (), "Mod: not is valid");
m = "none"; t.ok (m.valid (), "Mod: none is valid");
m = "any"; t.ok (m.valid (), "Mod: any is valid");
m = "over"; t.ok (m.valid (), "Mod: over is valid");
m = "under"; t.ok (m.valid (), "Mod: under is valid");
m = "synth"; t.ok (m.valid (), "Mod: synth is valid");
m = "first"; t.ok (m.valid (), "Mod: first is valid");
m = "last"; t.ok (m.valid (), "Mod: last is valid");
m = "this"; t.ok (m.valid (), "Mod: this is valid");
m = "next"; t.ok (m.valid (), "Mod: next is valid");
m = "is"; t.ok (m.valid (), "Mod: is is valid");
m = "isnt"; t.ok (m.valid (), "Mod: isnt is valid");
m = "has"; t.ok (m.valid (), "Mod: has is valid");
m = "hasnt"; t.ok (m.valid (), "Mod: hasnt is valid");
m = "startswith"; t.ok (m.valid (), "Mod: startswith is valid");
m = "endswith"; t.ok (m.valid (), "Mod: endswith is valid");
return 0;
}
////////////////////////////////////////////////////////////////////////////////