The configure method takes test_only flag so we can avoid
[metaproxy-moved-to-github.git] / src / ex_router_flexml.cpp
index 3793ea2..b8ec894 100644 (file)
@@ -1,13 +1,27 @@
-/* $Id: ex_router_flexml.cpp,v 1.6 2006-01-09 13:43:59 adam Exp $
-   Copyright (c) 2005, Index Data.
+/* $Id: ex_router_flexml.cpp,v 1.13 2008-02-20 15:07:51 adam Exp $
+   Copyright (c) 2005-2007, Index Data.
 
-%LICENSE%
+This file is part of Metaproxy.
+
+Metaproxy 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, or (at your option) any later
+version.
+
+Metaproxy 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 Metaproxy; see the file LICENSE.  If not, write to the
+Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
+02111-1307, USA.
  */
 
 #include "config.hpp"
 
-#include <boost/program_options.hpp>
-namespace po = boost::program_options;
+#include <yaz/options.h>
 
 #include <iostream>
 #include <stdexcept>
@@ -17,43 +31,38 @@ namespace po = boost::program_options;
 #include "router_flexml.hpp"
 #include "factory_static.hpp"
 
+namespace mp = metaproxy_1;
+
 int main(int argc, char **argv)
 {
     try 
     {
+        int ret;
+        char *arg;
+        char *fname = 0;
 
-        po::options_description desc("Allowed options");
-        desc.add_options()
-            ("help", "produce help message")
-            ("config", po::value< std::vector<std::string> >(), "xml config")
-            ;
-        
-        po::positional_options_description p;
-        p.add("config", -1);
-        
-        po::variables_map vm;        
-        po::store(po::command_line_parser(argc, argv).
-                  options(desc).positional(p).run(), vm);
-        po::notify(vm);    
-        
-        if (vm.count("help")) {
-            std::cout << desc << "\n";
-            return 1;
-        }
-        
-        xmlDocPtr doc = 0;
-        if (vm.count("config"))
+        while ((ret = options("h{help}c{config}:", 
+                              argv, argc, &arg)) != -2)
         {
-            std::vector<std::string> config_fnames = 
-                vm["config"].as< std::vector<std::string> >();
-
-            if (config_fnames.size() != 1)
+            switch(ret)
             {
-                std::cerr << "Only one configuration must be given\n";
+            case -1:
+                std::cerr << "bad option " << arg << std::endl;
+            case 'h':
+                std::cerr << "ex_router_flexml\n"
+                    " -h|--help         help\n"
+                    " -c|--config fname configuation\n"
+                          << std::endl;
                 std::exit(1);
+            case 'c':
+                fname = arg;
             }
-            
-            doc = xmlParseFile(config_fnames[0].c_str());
+        }
+
+        xmlDocPtr doc = 0;
+        if (fname)
+        {
+            doc = xmlParseFile(fname);
             if (!doc)
             {
                 std::cerr << "xmlParseFile failed\n";
@@ -67,10 +76,10 @@ int main(int argc, char **argv)
         }
         if (doc)
         {
-            yp2::FactoryStatic factory;
-            yp2::RouterFleXML router(doc, factory);
+            mp::FactoryStatic factory;
+            mp::RouterFleXML router(doc, factory, false);
 
-           yp2::Package pack;
+           mp::Package pack;
         
             pack.router(router).move();
 
@@ -86,8 +95,6 @@ int main(int argc, char **argv)
 }
 
 
-
-
 /*
  * Local variables:
  * c-basic-offset: 4