ultimatepp/autotest/SortedAMap/main.cpp
cxl d02fe7d7c7 Creating the *real* autotest nest
git-svn-id: svn://ultimatepp.org/upp/trunk@7141 f0d560ea-af0d-0410-9eb7-867de7ffcac7
2014-04-02 18:36:01 +00:00

221 lines
4.5 KiB
C++

#include <Core/Core.h>
using namespace Upp;
template <class C>
void BenchNTL(const char *file, Stream& out) {
FileIn in(file);
if (!in) {
out << "Cannot open input file.\n";
return;
}
C map;
for(;;) {
int c = in.Get();
if(c < 0) break;
if(IsAlpha(c) || c == '_') {
String id;
id.Cat(c);
c = in.Get();
while(c >= 0 && (IsAlNum(c) || c == '_')) {
id.Cat(c);
c = in.Get();
}
map.GetAdd(id, 0)++;
}
else
if(IsDigit(c))
do c = in.Get();
while(c >= 0 && (IsAlNum(c) || c == '.'));
}
for(int i = 0; i < map.GetCount(); i++)
out << ~map.GetKey(i) << ": " << map[i] << '\n';
}
void BenchNTL2(const char *file, Stream& out) {
FileIn in(file);
if (!in) {
out << "Cannot open input file.\n";
return;
}
VectorMap<String, int> map;
for(;;) {
int c = in.Get();
if(c < 0) break;
if(IsAlpha(c) || c == '_') {
String id;
id.Cat(c);
c = in.Get();
while(c >= 0 && (IsAlNum(c) || c == '_')) {
id.Cat(c);
c = in.Get();
}
map.GetAdd(id, 0)++;
}
else
if(IsDigit(c))
do c = in.Get();
while(c >= 0 && (IsAlNum(c) || c == '.'));
}
Vector<int> order = GetSortOrder(map.GetKeys());
for(int i = 0; i < order.GetCount(); i++)
out << ~map.GetKey(order[i]) << ": " << map[order[i]] << '\n';
}
void BenchmarkMap()
{
String fn;
int argc = CommandLine().GetCount();
const Vector<String>& argv = CommandLine();
if(argc < 1)
#ifdef _DEBUG
fn = GetDataFile("main.cpp");
#else
fn = GetHomeDirFile("test.txt");
#endif
else
fn = argv[0];
{
FileOut out(GetHomeDirFile("ntl1.txt"));
BenchNTL< SortedVectorMap<String, int> >(fn, out);
}
{
FileOut out(GetHomeDirFile("ntl2.txt"));
BenchNTL< SortedArrayMap<String, int> >(fn, out);
}
{
FileOut out(GetHomeDirFile("ntl3.txt"));
BenchNTL2(fn, out);
}
ASSERT(LoadFile(GetHomeDirFile("ntl1.txt")) == LoadFile(GetHomeDirFile("ntl2.txt")) &&
LoadFile(GetHomeDirFile("ntl2.txt")) == LoadFile(GetHomeDirFile("ntl3.txt")));
LOG("MATCH!");
}
template <class T>
void Test(T& map)
{
map.Add(1, 10);
map.Add(20, 20);
map.Add(12, 20);
map.Add(10, 11);
map.Add(12) = 21;
map.Add(1) = 2;
map.GetAdd(12) = 1234;
DUMPM(map);
DUMP(map.FindAdd(4, 2));
DUMPM(map);
map.GetAdd(13) = 1313;
ASSERT(map.Get(13) == 1313);
ASSERT(map.Get(1) == 10);
ASSERT(map.Get(10) == 11);
ASSERT(map.GetAdd(10) == 11);
ASSERT(map.GetAdd(15, 4321) == 4321);
for(int i = 0; i < 1000; i++)
map.Add(i, Random(1000));
for(int i = 0; i < 1000; i++)
map.FindAdd(i, Random(1000));
typename T::Iterator it = map.Begin();
typename T::KeyConstIterator ckit = map.KeyBegin();
typename T::ConstIterator cit = map.Begin();
for(int i = 0; i < map.GetCount(); i++) {
ASSERT(map.GetKey(i) == *ckit++);
ASSERT(map[i] == *it++);
ASSERT(map[i] == *cit++);
typename T::Iterator q = map.GetIter(i);
ASSERT(map[i] == *q);
typename T::KeyConstIterator kq = map.KeyGetIter(i);
ASSERT(map.GetKey(i) == *kq);
}
}
struct Foo : Moveable<Foo> {
Vector<int> a;
};
CONSOLE_APP_MAIN
{
StdLogSetup(LOG_COUT|LOG_FILE);
BenchmarkMap();
LOG("===========================");
LOG("VectorMap");
SortedVectorMap<int, int> map;
Test(map);
LOG("===========================");
LOG("ArrayMap");
SortedArrayMap<int, int> amap;
Test(amap);
LOG("------------");
SortedArrayMap<int, int, StdGreater<int> > am;
am.Add(1, 11);
am.Add(2) = 12;
am.Add(3, new int(13));
am.Create<int>(4) = 14;
am.GetAdd(5) = 15;
am.GetAdd(6, 0);
am.GetAdd(6, 1) = 16;
am.GetAdd(7, 17);
DDUMPM(am);
ASSERT(am.GetCount() == 7);
for(int i = 0; i < am.GetCount(); i++) {
ASSERT(am.GetKey(i) == am[i] - 10);
}
am.Remove(0);
DDUMPM(am);
ASSERT(am.GetCount() == 6);
for(int i = 0; i < am.GetCount(); i++)
ASSERT(am.GetKey(i) + 1 == am[i] - 10 + 1);
delete am.Detach(0);
DDUMPM(am);
ASSERT(am.GetCount() == 5);
for(int i = 0; i < am.GetCount(); i++)
ASSERT(am.GetKey(i) + 2 == am[i] - 10 + 2);
RDUMP(sizeof(Vector<int>));
RDUMP(sizeof(Array<int>));
RDUMP(sizeof(Index<int>));
RDUMP(sizeof(VectorMap<int, int>));
RDUMP(sizeof(InVector<int>));
RDUMP(sizeof(InArray<int>));
RDUMP(sizeof(SortedIndex<int>));
RDUMP(sizeof(SortedVectorMap<int, int>));
{ // Test that this compiles
SortedVectorMap<int, Foo> mm;
Foo& x = mm.Add(1);
x.a.Add(12);
}
}