[Liblas-commits] hg-main-tree: removed static getDefaultOptions();
cleaned up imp...
liblas-commits at liblas.org
liblas-commits at liblas.org
Fri Aug 12 17:44:33 EDT 2011
details: http://hg.libpc.orghg-main-tree/rev/910748f21b3f
changeset: 1076:910748f21b3f
user: Michael P. Gerlek <mpg at flaxen.com>
date: Fri Aug 12 14:27:42 2011 -0700
description:
removed static getDefaultOptions(); cleaned up impl of getName() nd getDescription()
Subject: hg-main-tree: merge
details: http://hg.libpc.orghg-main-tree/rev/b0db3059a611
changeset: 1077:b0db3059a611
user: Michael P. Gerlek <mpg at flaxen.com>
date: Fri Aug 12 14:44:07 2011 -0700
description:
merge
diffstat:
include/pdal/StageBase.hpp | 42 ++++++++++------------------
include/pdal/drivers/faux/Reader.hpp | 7 ++--
include/pdal/drivers/faux/Writer.hpp | 7 ++--
include/pdal/drivers/las/Reader.hpp | 7 ++--
include/pdal/drivers/las/Writer.hpp | 5 ++-
include/pdal/drivers/liblas/Reader.hpp | 5 ++-
include/pdal/drivers/liblas/Writer.hpp | 5 ++-
include/pdal/drivers/oci/Reader.hpp | 6 ++-
include/pdal/drivers/oci/Writer.hpp | 8 +++--
include/pdal/drivers/qfit/Reader.hpp | 6 ++--
include/pdal/drivers/terrasolid/Reader.hpp | 6 ++--
include/pdal/filters/ByteSwapFilter.hpp | 5 ++-
include/pdal/filters/CacheFilter.hpp | 5 ++-
include/pdal/filters/Chipper.hpp | 5 ++-
include/pdal/filters/ColorFilter.hpp | 6 ++-
include/pdal/filters/CropFilter.hpp | 5 ++-
include/pdal/filters/DecimationFilter.hpp | 6 ++-
include/pdal/filters/MosaicFilter.hpp | 6 ++-
include/pdal/filters/ReprojectionFilter.hpp | 6 ++-
include/pdal/filters/ScalingFilter.hpp | 10 +++++-
src/drivers/faux/Reader.cpp | 6 +--
src/drivers/faux/Writer.cpp | 7 +---
src/drivers/las/Reader.cpp | 9 ++----
src/drivers/las/Writer.cpp | 7 +---
src/drivers/liblas/Reader.cpp | 7 +---
src/drivers/liblas/Writer.cpp | 7 +---
src/drivers/oci/Reader.cpp | 6 +--
src/drivers/oci/Writer.cpp | 19 ++++++++++--
src/drivers/qfit/Reader.cpp | 7 +---
src/drivers/terrasolid/Reader.cpp | 6 +--
src/filters/ByteSwapFilter.cpp | 7 +---
src/filters/CacheFilter.cpp | 5 +--
src/filters/Chipper.cpp | 6 +--
src/filters/ColorFilter.cpp | 7 +---
src/filters/CropFilter.cpp | 7 +---
src/filters/DecimationFilter.cpp | 7 +---
src/filters/MosaicFilter.cpp | 6 +--
src/filters/ReprojectionFilter.cpp | 6 +--
src/filters/ScalingFilter.cpp | 11 ++-----
test/unit/MosaicFilterTest.cpp | 2 +-
test/unit/OptionsTest.cpp | 5 ++-
41 files changed, 144 insertions(+), 164 deletions(-)
diffs (truncated from 1039 to 300 lines):
diff -r f2459a56b514 -r b0db3059a611 include/pdal/StageBase.hpp
--- a/include/pdal/StageBase.hpp Fri Aug 12 14:14:56 2011 -0500
+++ b/include/pdal/StageBase.hpp Fri Aug 12 14:44:07 2011 -0700
@@ -84,39 +84,27 @@
bool isVerbose() const; // true iff verbosity>0
boost::uint8_t getVerboseLevel() const;
- // For Name, Description, and DefaultOptions:
- // each concrete class should provide a static function s_getX() which returns a static object
- // each concrete class should provide a virtual getX() which returns s_getX()
- // This is automated via the GenerateStatics() macro below.
+ // Everyone must implement this. If you want to access the list of
+ // options "statically", you are free to construct the stage with no
+ // arguments and cal getDefaultOptions() on it -- there is no need
+ // to call initialize(), so it should be a fast/safe operation.
+ virtual const Options getDefaultOptions() const = 0;
// Use a dotted, XPath-style name for your
// stage. For example, 'drivers.las.reader' or 'filters.crop'. This
// XPath-style name will also correspond to an entry in the pdal::Options
// tree for the given stage.
+ virtual std::string getName() const = 0;
+ virtual std::string getDescription() const = 0;
- virtual const Options& getDefaultOptions() const = 0; // { return s_getDefaultOptions(); }
- virtual const std::string& getName() const = 0; // { return s_getName(); }
- virtual const std::string& getDescription() const = 0; // { return s_getDescription(); }
- //static const Options& s_getDefaultOptions();
- //static const std::string& s_getName();
- //static const std::string& s_getDescription();
-
-#define DECLARE_STATICS \
- public: \
- static const Options& s_getDefaultOptions(); \
- virtual const Options& getDefaultOptions() const; \
- static const std::string& s_getName(); \
- virtual const std::string& getName() const; \
- static const std::string& s_getDescription(); \
- virtual const std::string& getDescription() const; \
- private:
-
-#define IMPLEMENT_STATICS(T, name, description) \
- const Options& T::getDefaultOptions() const { return s_getDefaultOptions(); } \
- const std::string& T::s_getName() { static std::string s(name); return s; } \
- const std::string& T::getName() const { return s_getName(); } \
- const std::string& T::s_getDescription() { static std::string s(description); return s; } \
- const std::string& T::getDescription() const { return s_getDescription(); }
+ // For getName() and getDescription(), each stage provides a static and
+ // a dynamic version of the function. Each (concrete) stage should call
+ // the following macro to create the functions for you.
+#define SET_STAGE_NAME(name, description) \
+ static std::string s_getName() { return name; } \
+ std::string getName() const { return name; } \
+ static std::string s_getDescription() { return description; } \
+ std::string getDescription() const { return description; }
protected:
Options& getOptions();
diff -r f2459a56b514 -r b0db3059a611 include/pdal/drivers/faux/Reader.hpp
--- a/include/pdal/drivers/faux/Reader.hpp Fri Aug 12 14:14:56 2011 -0500
+++ b/include/pdal/drivers/faux/Reader.hpp Fri Aug 12 14:44:07 2011 -0700
@@ -65,8 +65,6 @@
//
class PDAL_DLL Reader : public pdal::Reader
{
- DECLARE_STATICS
-
public:
enum Mode
{
@@ -76,11 +74,14 @@
};
public:
+ SET_STAGE_NAME("drivers.faux.reader", "Faux Reader")
+
Reader(const Options& options);
Reader(const Bounds<double>&, boost::uint64_t numPoints, Mode mode);
Reader(const Bounds<double>&, boost::uint64_t numPoints, Mode mode, const std::vector<Dimension>& dimensions);
-
+
virtual void initialize();
+ virtual const Options getDefaultOptions() const;
Mode getMode() const;
diff -r f2459a56b514 -r b0db3059a611 include/pdal/drivers/faux/Writer.hpp
--- a/include/pdal/drivers/faux/Writer.hpp Fri Aug 12 14:14:56 2011 -0500
+++ b/include/pdal/drivers/faux/Writer.hpp Fri Aug 12 14:44:07 2011 -0700
@@ -51,12 +51,13 @@
//
class PDAL_DLL Writer : public pdal::Writer
{
- DECLARE_STATICS
+public:
+ SET_STAGE_NAME("drivers.faux.writer", "Faux Writer")
-public:
Writer(Stage& prevStage, const Options&);
-
+
virtual void initialize();
+ virtual const Options getDefaultOptions() const;
// retrieve the summary info
double getMinX() const { return m_minimumX; }
diff -r f2459a56b514 -r b0db3059a611 include/pdal/drivers/las/Reader.hpp
--- a/include/pdal/drivers/las/Reader.hpp Fri Aug 12 14:14:56 2011 -0500
+++ b/include/pdal/drivers/las/Reader.hpp Fri Aug 12 14:44:07 2011 -0700
@@ -55,13 +55,14 @@
class PDAL_DLL LasReader : public LasReaderBase
{
- DECLARE_STATICS
+public:
+ SET_STAGE_NAME("drivers.las.reader", "Las Reader")
-public:
LasReader(const Options&);
LasReader(const std::string& filename);
-
+
virtual void initialize();
+ virtual const Options getDefaultOptions() const;
const std::string& getFileName() const;
diff -r f2459a56b514 -r b0db3059a611 include/pdal/drivers/las/Writer.hpp
--- a/include/pdal/drivers/las/Writer.hpp Fri Aug 12 14:14:56 2011 -0500
+++ b/include/pdal/drivers/las/Writer.hpp Fri Aug 12 14:44:07 2011 -0700
@@ -53,14 +53,15 @@
class PDAL_DLL LasWriter : public Writer
{
- DECLARE_STATICS
+public:
+ SET_STAGE_NAME("drivers.las.writer", "Las Writer")
-public:
LasWriter(Stage& prevStage, const Options&);
LasWriter(Stage& prevStage, std::ostream*);
~LasWriter();
virtual void initialize();
+ virtual const Options getDefaultOptions() const;
void setFormatVersion(boost::uint8_t majorVersion, boost::uint8_t minorVersion);
void setPointFormat(PointFormat);
diff -r f2459a56b514 -r b0db3059a611 include/pdal/drivers/liblas/Reader.hpp
--- a/include/pdal/drivers/liblas/Reader.hpp Fri Aug 12 14:14:56 2011 -0500
+++ b/include/pdal/drivers/liblas/Reader.hpp Fri Aug 12 14:44:07 2011 -0700
@@ -55,14 +55,15 @@
class PDAL_DLL LiblasReader : public pdal::drivers::las::LasReaderBase
{
- DECLARE_STATICS
+public:
+ SET_STAGE_NAME("drivers.liblas.reader", "Liblas Reader")
-public:
LiblasReader(const Options&);
LiblasReader(const std::string& filename);
~LiblasReader();
virtual void initialize();
+ virtual const Options getDefaultOptions() const;
const std::string& getFileName() const;
diff -r f2459a56b514 -r b0db3059a611 include/pdal/drivers/liblas/Writer.hpp
--- a/include/pdal/drivers/liblas/Writer.hpp Fri Aug 12 14:14:56 2011 -0500
+++ b/include/pdal/drivers/liblas/Writer.hpp Fri Aug 12 14:44:07 2011 -0700
@@ -53,14 +53,15 @@
// we default to LAS 1.2, point format 0
class PDAL_DLL LiblasWriter : public Writer
{
- DECLARE_STATICS
+public:
+ SET_STAGE_NAME("drivers.liblas.writer", "Liblas Writer")
-public:
LiblasWriter(Stage& prevStage, const Options&);
LiblasWriter(Stage& prevStage, std::ostream*);
~LiblasWriter();
virtual void initialize();
+ virtual const Options getDefaultOptions() const;
void setFormatVersion(boost::uint8_t majorVersion, boost::uint8_t minorVersion);
void setPointFormat(::pdal::drivers::las::PointFormat);
diff -r f2459a56b514 -r b0db3059a611 include/pdal/drivers/oci/Reader.hpp
--- a/include/pdal/drivers/oci/Reader.hpp Fri Aug 12 14:14:56 2011 -0500
+++ b/include/pdal/drivers/oci/Reader.hpp Fri Aug 12 14:44:07 2011 -0700
@@ -51,12 +51,14 @@
class PDAL_DLL Reader : public pdal::Reader
{
- DECLARE_STATICS
+public:
+ SET_STAGE_NAME("drivers.oci.reader", "OCI Reader")
-public:
Reader(const Options&);
~Reader();
+
virtual void initialize();
+ virtual const Options getDefaultOptions() const;
bool supportsIterator (StageIteratorType t) const
{
diff -r f2459a56b514 -r b0db3059a611 include/pdal/drivers/oci/Writer.hpp
--- a/include/pdal/drivers/oci/Writer.hpp Fri Aug 12 14:14:56 2011 -0500
+++ b/include/pdal/drivers/oci/Writer.hpp Fri Aug 12 14:44:07 2011 -0700
@@ -49,12 +49,14 @@
class PDAL_DLL Writer : public pdal::Writer
{
- DECLARE_STATICS
+public:
+ SET_STAGE_NAME("drivers.oci.writer", "OCI Writer")
-public:
Writer(Stage& prevStage, const Options&);
~Writer();
+
virtual void initialize();
+ virtual const Options getDefaultOptions() const;
void run(std::ostringstream const& command);
inline void setBounds(pdal::Bounds<double> bounds) {m_bounds = bounds; }
@@ -101,7 +103,7 @@
template<typename T> T getDefaultedOption(std::string const& option_name) const
{
- T default_value = Writer::s_getDefaultOptions().getOption<T>(option_name).getValue();
+ T default_value = getDefaultOptions().getOption<T>(option_name).getValue();
return getOptions().getValueOrDefault<T>(option_name, default_value);
}
diff -r f2459a56b514 -r b0db3059a611 include/pdal/drivers/qfit/Reader.hpp
--- a/include/pdal/drivers/qfit/Reader.hpp Fri Aug 12 14:14:56 2011 -0500
+++ b/include/pdal/drivers/qfit/Reader.hpp Fri Aug 12 14:44:07 2011 -0700
@@ -119,17 +119,17 @@
class PDAL_DLL Reader : public pdal::Reader
{
- DECLARE_STATICS
+public:
+ SET_STAGE_NAME("drivers.qfit.reader", "QFIT Reader")
-public:
Reader(const Options& options);
~Reader();
virtual void initialize();
+ virtual const Options getDefaultOptions() const;
std::string getFileName() const;
-
bool supportsIterator (StageIteratorType t) const
{
if (t == StageIterator_Sequential ) return true;
diff -r f2459a56b514 -r b0db3059a611 include/pdal/drivers/terrasolid/Reader.hpp
--- a/include/pdal/drivers/terrasolid/Reader.hpp Fri Aug 12 14:14:56 2011 -0500
+++ b/include/pdal/drivers/terrasolid/Reader.hpp Fri Aug 12 14:44:07 2011 -0700
@@ -127,18 +127,18 @@
class PDAL_DLL Reader : public pdal::Reader
{
- DECLARE_STATICS
+public:
+ SET_STAGE_NAME("drivers.terrasolid.reader", "TerraSolid Reader")
-public:
Reader(const Options&);
Reader(OptionsOld& options);
~Reader();
virtual void initialize();
+ virtual const Options getDefaultOptions() const;
std::string getFileName() const;
-
bool supportsIterator (StageIteratorType t) const
{
if (t == StageIterator_Sequential ) return true;
diff -r f2459a56b514 -r b0db3059a611 include/pdal/filters/ByteSwapFilter.hpp
--- a/include/pdal/filters/ByteSwapFilter.hpp Fri Aug 12 14:14:56 2011 -0500
+++ b/include/pdal/filters/ByteSwapFilter.hpp Fri Aug 12 14:44:07 2011 -0700
@@ -54,13 +54,14 @@
// updates the header accordingly
class PDAL_DLL ByteSwapFilter : public Filter
{
- DECLARE_STATICS
+public:
+ SET_STAGE_NAME("filters.byteswap", "Crop Filter")
-public:
More information about the Liblas-commits
mailing list