00001 /* 00002 * mapzone.h 00003 * 00004 * Copyright (C) 2008,2009 Thomas A. Vaughan 00005 * All rights reserved. 00006 * 00007 * 00008 * Redistribution and use in source and binary forms, with or without 00009 * modification, are permitted provided that the following conditions are met: 00010 * * Redistributions of source code must retain the above copyright 00011 * notice, this list of conditions and the following disclaimer. 00012 * * Redistributions in binary form must reproduce the above copyright 00013 * notice, this list of conditions and the following disclaimer in the 00014 * documentation and/or other materials provided with the distribution. 00015 * * Neither the name of the <organization> nor the 00016 * names of its contributors may be used to endorse or promote products 00017 * derived from this software without specific prior written permission. 00018 * 00019 * THIS SOFTWARE IS PROVIDED BY THOMAS A. VAUGHAN ''AS IS'' AND ANY 00020 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 00021 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 00022 * DISCLAIMED. IN NO EVENT SHALL THOMAS A. VAUGHAN BE LIABLE FOR ANY 00023 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 00024 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 00025 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 00026 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 00027 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00028 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00029 * 00030 * 00031 * Entry point for the mapzone library. See the aesop-map headers. 00032 * Basically, this is a particular implementation of maps + zones. 00033 */ 00034 00035 #ifndef AESOP_MAPZONE_H__ 00036 #define AESOP_MAPZONE_H__ 00037 00038 // includes -------------------------------------------------------------------- 00039 #include "aesop-map/map.h" 00040 00041 00042 namespace mapzone { 00043 00071 00075 00076 // 00077 // public API 00078 // 00080 00082 smart_ptr<aesop::MapFormatReader> getMapFormatReader(void); 00083 00084 00085 00087 // 00088 // internals 00089 // 00090 // Don't use these outside of the mapzone library! 00091 // 00093 00095 typedef std::map<std::string, smart_ptr<aesop::Zone> > zone_map_t; 00096 00097 00098 // load maps + zones from streams (don't use these! Use getMapFormatReader() 00099 smart_ptr<aesop::Map> loadMap(IN const char * id, 00100 IN std::istream& stream); 00101 00102 smart_ptr<aesop::Zone> loadZone(IN std::istream& stream, 00103 IN aesop::Zone::eType type); 00104 00105 // again, internal only. After all zones are loaded, zones can resolve IDs 00106 void resolveZoneIds(IN aesop::Zone * zone, 00107 IN zone_map_t& map); 00108 00109 // internal only. third pass of loading! 00110 void calcBoundaries(IN aesop::Zone * zone); 00111 00112 00113 }; // mapzone namespace 00114 00115 #endif // AESOP_MAPZONE_H__ 00116