pns_logger.h 1.59 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
/*
 * 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;

35 36
class PNS_LOGGER
{
37 38 39 40
public:
	PNS_LOGGER();
	~PNS_LOGGER();

41
	void Save( const std::string& aFilename );
42
	void Clear();
43 44

	void NewGroup( const std::string& aName, int aIter = 0 );
45
	void EndGroup();
46 47 48 49 50

	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() );
51 52

private:
53
	void dumpShape ( const SHAPE* aSh );
54 55 56 57 58 59

	bool m_groupOpened;
	std::stringstream m_theLog;
};

#endif