00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef _CJLS_GEOABS_H_
00021 #define _CJLS_GEOABS_H_ 1
00022
00023 #include <string>
00024 #include "CjLinkSelector.hh"
00025
00026 namespace jmitie {
00027 namespace corelib {
00028 class CjLS_geoabs : public CjLinkSelector {
00029 public:
00030
00031 static std::string getName_static() { return "geoabs"; }
00032 virtual std::string getName() const { return getName_static(); }
00033 std::string getProperty(const std::string & prop) const { return getProperty_static(prop); }
00034 static std::string getProperty_static(const std::string & opt) {
00035 if(opt=="desc") return "Selects the link or node-pair which has the highest, or lowest absolute value for geographic/euclidean distance between them.";
00036 if(opt=="usage") return getProperty_static("desc") + "\n" +
00037 "(min|max)\tSpecify whether the absolute minimum or maximum geographic distance node-pair should be selected.\n" \
00038 "[dupe_ok]\tIf specified a node pairs which are already connected are included in the node-pair selection(only applies when adding links).\n";
00039 throw std::invalid_argument("CjLS_geoabs::getProperty_static(" + opt + "): Unknown property requested.");
00040 }
00041
00042 CjLS_geoabs(std::string args, const ctor_va_t & va );
00043
00044 virtual bool selectLink( select_arg_t &, unsigned int & from, unsigned int & to );
00045 virtual ~CjLS_geoabs() {};
00046
00047 protected:
00048 bool m_add_remove;
00049 bool m_dupe_link_ok;
00050 bool m_min_max;
00051
00052 private:
00053
00054 };
00055 }
00056 }
00057
00058 #endif // _CJLS_GEOABS_H_