summaryrefslogtreecommitdiff
path: root/pcbnew/router/pns_logger.h
diff options
context:
space:
mode:
Diffstat (limited to 'pcbnew/router/pns_logger.h')
-rw-r--r--pcbnew/router/pns_logger.h59
1 files changed, 59 insertions, 0 deletions
diff --git a/pcbnew/router/pns_logger.h b/pcbnew/router/pns_logger.h
new file mode 100644
index 0000000..b38fd42
--- /dev/null
+++ b/pcbnew/router/pns_logger.h
@@ -0,0 +1,59 @@
+/*
+ * KiRouter - a push-and-(sometimes-)shove PCB router
+ *
+ * Copyright (C) 2013-2014 CERN
+ * Author: Tomasz Wlostowski <tomasz.wlostowski@cern.ch>
+ *
+ * This program 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 3 of the License, or (at your
+ * option) any later version.
+ *
+ * This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef __PNS_LOGGER_H
+#define __PNS_LOGGER_H
+
+#include <cstdio>
+#include <vector>
+#include <string>
+#include <sstream>
+
+#include <math/vector2d.h>
+
+class PNS_ITEM;
+class SHAPE_LINE_CHAIN;
+class SHAPE;
+
+class PNS_LOGGER
+{
+public:
+ PNS_LOGGER();
+ ~PNS_LOGGER();
+
+ void Save( const std::string& aFilename );
+ void Clear();
+
+ void NewGroup( const std::string& aName, int aIter = 0 );
+ void EndGroup();
+
+ void Log( const PNS_ITEM* aItem, int aKind = 0, const std::string aName = std::string() );
+ void Log( const SHAPE_LINE_CHAIN *aL, int aKind = 0, const std::string aName = std::string() );
+ void Log( const VECTOR2I& aStart, const VECTOR2I& aEnd, int aKind = 0,
+ const std::string aName = std::string() );
+
+private:
+ void dumpShape( const SHAPE* aSh );
+
+ bool m_groupOpened;
+ std::stringstream m_theLog;
+};
+
+#endif