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 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
|
/***************************************************************************
* Copyright (C) 2006-2011 by the FIFE team *
* http://www.fifengine.net *
* This file is part of FIFE. *
* *
* FIFE is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Lesser General Public *
* License as published by the Free Software Foundation; either *
* version 2.1 of the License, or (at your option) any later version. *
* *
* This library 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 *
* Lesser General Public License for more details. *
* *
* You should have received a copy of the GNU Lesser General Public *
* License along with this library; if not, write to the *
* Free Software Foundation, Inc., *
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
***************************************************************************/
%module fife
%{
#include "model/model.h"
%}
namespace FIFE {
class Map;
class Object;
}
namespace std {
%template(StringList) list<std::string>;
%template(ObjectList) list<FIFE::Object*>;
%template(MapList) list<FIFE::Map*>;
}
namespace FIFE {
class IPather;
class Model: public FifeClass {
public:
Model(RenderBackend* renderbackend, const std::vector<RendererBase*>& renderers);
~Model();
Map* createMap(const std::string& identifier);
void deleteMap(Map*);
const std::list<Map*>& getMaps() const;
Map* getMap(const std::string& id) const;
std::list<std::string> getNamespaces() const;
Object* createObject(const std::string& identifier, const std::string& name_space, Object* parent=0);
bool deleteObject(Object*);
bool deleteObjects();
Object* getObject(const std::string& id, const std::string& name_space);
std::list<Object*> getObjects(const std::string& name_space) const;
uint32_t getMapCount() const;
void deleteMaps();
void adoptPather(IPather* pather);
IPather* getPather(const std::string& pathername);
CellGrid* getCellGrid(const std::string& gridtype);
void setTimeMultiplier(float multip);
double getTimeMultiplier() const;
};
}
|