summaryrefslogtreecommitdiff
path: root/server/src/macrotool
diff options
context:
space:
mode:
authordeva <deva>2011-02-17 11:00:14 +0000
committerdeva <deva>2011-02-17 11:00:14 +0000
commitdb144840aba95affb3a6b5b2536059f49f0677ff (patch)
tree1c397a20aa5745c6bbb5dee6a4409f58c4542e87 /server/src/macrotool
parentc8651b8c89673300477ab86962640c93216ea306 (diff)
Rewrite of all old tests to new unittest framework. Also some work on testdb; more to come...
Diffstat (limited to 'server/src/macrotool')
-rw-r--r--server/src/macrotool/Makefile.am8
-rw-r--r--server/src/macrotool/fieldnamescanner.cc158
-rw-r--r--server/src/macrotool/fieldnamescanner.h44
-rw-r--r--server/src/macrotool/util.cc77
-rw-r--r--server/src/macrotool/util.h39
5 files changed, 3 insertions, 323 deletions
diff --git a/server/src/macrotool/Makefile.am b/server/src/macrotool/Makefile.am
index edd8f4a..f35dae9 100644
--- a/server/src/macrotool/Makefile.am
+++ b/server/src/macrotool/Makefile.am
@@ -12,16 +12,15 @@ macrotool_SOURCES = \
dump.cc \
export.cc \
fieldnames.cc \
- fieldnamescanner.cc \
filehandler.cc \
sunlock.cc \
- util.cc \
../debug.cc \
../configuration.cc \
../configurationparser.cc \
../database.cc \
../entitylist.cc \
../exception.cc \
+ ../fieldnamescanner.cc \
../inotify.cc \
../log.cc \
../macroheaderparser.cc \
@@ -33,16 +32,15 @@ macrotool_SOURCES = \
../pracrodaotest.cc \
../saxparser.cc \
../templateparser.cc \
+ ../util.cc \
../versionstr.cc
EXTRA_DIST = \
dump.h \
export.h \
fieldnames.h \
- fieldnamescanner.h \
filehandler.h \
- sunlock.h \
- util.h
+ sunlock.h
################
# Test Section #
diff --git a/server/src/macrotool/fieldnamescanner.cc b/server/src/macrotool/fieldnamescanner.cc
deleted file mode 100644
index 9c436fb..0000000
--- a/server/src/macrotool/fieldnamescanner.cc
+++ /dev/null
@@ -1,158 +0,0 @@
-/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
-/* vim: set et sw=2 ts=2: */
-/***************************************************************************
- * fieldnamescanner.cc
- *
- * Wed Jan 26 09:21:58 CET 2011
- * Copyright 2011 Bent Bisballe Nyeng
- * deva@aasimon.org
- ****************************************************************************/
-
-/*
- * This file is part of Pracro.
- *
- * Pracro 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.
- *
- * Pracro 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 Pracro; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
- */
-#include "fieldnamescanner.h"
-
-#include <stdio.h>
-
-#include "util.h"
-
-#include "macroparser.h"
-#include "templateparser.h"
-#include "configuration.h"
-#include "exception.h"
-#include "macrolist.h"
-
-#include "debug.h"
-
-fieldnames_t getFields(Widget &widget)
-{
- fieldnames_t fieldnames;
-
- if(widget.attributes.find("name") != widget.attributes.end()) {
- fieldnames.push_back(widget.attributes["name"]);
- //printf("\t\t%s\n", widget.attributes["name"].c_str());
- }
-
- std::vector< Widget >::iterator i = widget.widgets.begin();
- while(i != widget.widgets.end()) {
- fieldnames_t f = getFields(*i);
- fieldnames.insert(fieldnames.end(), f.begin(), f.end());
- i++;
- }
-
- return fieldnames;
-}
-
-templates_t scanfieldnames(std::set<std::string> &filter)
-{
- templates_t templates;
-
- // TemplateList templatelist(Conf::xml_basedir + "/templates");
- MacroList macrolist(Conf::xml_basedir + "/macros");
-
- // Iterate templates:
- std::vector<std::string> templatefiles = getTemplates();
- std::vector<std::string>::iterator tfs = templatefiles.begin();
- while(tfs != templatefiles.end()) {
- std::string templ = tfs->substr(0, tfs->length() - 4);
- fieldnames_t fieldnames;
- DEBUG(scanner, "%s:\n", tfs->c_str());
- TemplateParser parser(Conf::xml_basedir + "/templates/" + *tfs);
- try {
- parser.parse();
- Template *t = parser.getTemplate();
- if(!t) ERR(scanner, "Missing template!\n");
- // Iterate macros:
- std::vector<Macro>::iterator ms = t->macros.begin();
- while(ms != t->macros.end()) {
- if(ms->isHeader == false) {
- std::string macro = ms->attributes["name"];
- DEBUG(scanner, "Name '%s'\n", macro.c_str());
- std::string macrofile = macrolist.getLatestVersion(macro);
- DEBUG(scanner, "File '%s'\n", macrofile.c_str());
-
- // Iterate fields:
- MacroParser parser(macrofile);
- try {
- parser.parse();
- Macro *m = parser.getMacro();
- fieldnames_t f = getFields(m->widgets);
- fieldnames.insert(fieldnames.end(), f.begin(), f.end());
- } catch( Exception &e ) {
- ERR(scanner, "Error reading macro: %s: %s\n",
- macrofile.c_str(), e.what());
- }
- }
-
- ms++;
- }
- } catch( Exception &e ) {
- ERR(scanner, "Error reading template: %s: %s\n", tfs->c_str(), e.what());
- }
-
- fieldnames_t nodubs;
- fieldnames_t::iterator fi = fieldnames.begin();
- while(fi != fieldnames.end()) {
- bool hasdub = false;
- fieldnames_t::iterator di = nodubs.begin();
- while(di != nodubs.end()) {
- if(*di == *fi) {
- hasdub = true;
- break;
- }
- di++;
- }
-
- if(!hasdub && filter.find(*fi) != filter.end()) nodubs.push_back(*fi);
- fi++;
- }
-
- templates[templ] = nodubs;
- tfs++;
- }
-
- return templates;
-}
-
-#ifdef TEST_FIELDNAMESCANNER
-//deps: util.cc ../configuration.cc ../debug.cc ../log.cc ../templateparser.cc ../exception.cc ../saxparser.cc ../macrolist.cc ../entitylist.cc ../inotify.cc ../mutex.cc ../macroheaderparser.cc ../versionstr.cc ../macroparser.cc
-//cflags: -I.. -I../.. $(EXPAT_CFLAGS) $(PTHREAD_CFLAGS)
-//libs: $(EXPAT_LIBS) $(PTHREAD_LIBS)
-#include "test.h"
-
-TEST_BEGIN;
-Conf::xml_basedir = "../../xml";
-std::set<std::string> filter;
-filter.insert("dims");
-filter.insert("test1");
-templates_t t = scanfieldnames(filter);
-
-templates_t::iterator ti = t.begin();
-while(ti != t.end()) {
- printf("%s\n", ti->first.c_str());
- fieldnames_t::iterator fi = ti->second.begin();
- while(fi != ti->second.end()) {
- printf("\t%s\n", (*fi).c_str());
- fi++;
- }
- ti++;
-}
-
-TEST_END;
-
-#endif/*TEST_FIELDNAMESCANNER*/
diff --git a/server/src/macrotool/fieldnamescanner.h b/server/src/macrotool/fieldnamescanner.h
deleted file mode 100644
index c766ba1..0000000
--- a/server/src/macrotool/fieldnamescanner.h
+++ /dev/null
@@ -1,44 +0,0 @@
-/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
-/* vim: set et sw=2 ts=2: */
-/***************************************************************************
- * fieldnamescanner.h
- *
- * Wed Jan 26 09:21:58 CET 2011
- * Copyright 2011 Bent Bisballe Nyeng
- * deva@aasimon.org
- ****************************************************************************/
-
-/*
- * This file is part of Pracro.
- *
- * Pracro 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.
- *
- * Pracro 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 Pracro; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
- */
-#ifndef __PRACRO_FIELDNAMESCANNER_H__
-#define __PRACRO_FIELDNAMESCANNER_H__
-
-#include <map>
-#include <vector>
-#include <string>
-#include <set>
-
-typedef std::string fieldname_t;
-typedef std::vector< fieldname_t > fieldnames_t;
-
-typedef std::string template_name_t;
-typedef std::map< template_name_t, fieldnames_t > templates_t;
-
-templates_t scanfieldnames(std::set<std::string> &filter);
-
-#endif/*__PRACRO_FIELDNAMESCANNER_H__*/
diff --git a/server/src/macrotool/util.cc b/server/src/macrotool/util.cc
deleted file mode 100644
index 8be5435..0000000
--- a/server/src/macrotool/util.cc
+++ /dev/null
@@ -1,77 +0,0 @@
-/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
-/* vim: set et sw=2 ts=2: */
-/***************************************************************************
- * macrotool_util.cc
- *
- * Fri Jul 10 09:11:28 CEST 2009
- * Copyright 2009 Bent Bisballe Nyeng
- * deva@aasimon.org
- ****************************************************************************/
-
-/*
- * This file is part of Pracro.
- *
- * Pracro 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.
- *
- * Pracro 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 Pracro; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
- */
-#include "util.h"
-
-#include <stdio.h>
-#include <sys/types.h>
-#include <dirent.h>
-
-#include "debug.h"
-#include "configuration.h"
-
-static std::vector<std::string> listdir(std::string path)
-{
- std::vector<std::string> files;
-
- DIR* dir = opendir(path.c_str());
- if(!dir) {
- ERR(dump, "Could not open directory: %s\n", path.c_str());
- return files;
- }
-
- struct dirent *d;
- while((d = readdir(dir)) != 0) {
- //if(d->d_type == DT_DIR) {
- std::string name = d->d_name;
- if(name.length() >= 4 && name.substr(name.length() - 4) == ".xml")
- files.push_back(name);
- //}
- }
- closedir(dir);
-
- return files;
-}
-
-std::vector<std::string> getMacros()
-{
- std::vector<std::string> macros = listdir(Conf::xml_basedir + "/macros");
- return macros;
-}
-
-std::vector<std::string> getTemplates()
-{
- std::vector<std::string> templates = listdir(Conf::xml_basedir + "/templates");
- return templates;
-}
-
-void printcolumn(std::string text, size_t width)
-{
- printf("%s", text.c_str());
- for(size_t i = text.length(); i < width; i++) printf(" ");
- printf("\t");
-}
diff --git a/server/src/macrotool/util.h b/server/src/macrotool/util.h
deleted file mode 100644
index 2e41f6b..0000000
--- a/server/src/macrotool/util.h
+++ /dev/null
@@ -1,39 +0,0 @@
-/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
-/* vim: set et sw=2 ts=2: */
-/***************************************************************************
- * macrotool_util.h
- *
- * Fri Jul 10 09:11:28 CEST 2009
- * Copyright 2009 Bent Bisballe Nyeng
- * deva@aasimon.org
- ****************************************************************************/
-
-/*
- * This file is part of Pracro.
- *
- * Pracro 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.
- *
- * Pracro 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 Pracro; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
- */
-#ifndef __PRACRO_MACROTOOL_UTIL_H__
-#define __PRACRO_MACROTOOL_UTIL_H__
-
-#include <vector>
-#include <string>
-
-std::vector<std::string> getMacros();
-std::vector<std::string> getTemplates();
-
-void printcolumn(std::string text, size_t width);
-
-#endif/*__PRACRO_MACROTOOL_UTIL_H__*/