comparison engine/core/vfs/dat/dat1.h @ 0:4a0efb7baf70

* Datasets becomes the new trunk and retires after that :-)
author mvbarracuda@33b003aa-7bff-0310-803a-e67f0ece8222
date Sun, 29 Jun 2008 18:44:17 +0000
parents
children 90005975cdbb
comparison
equal deleted inserted replaced
-1:000000000000 0:4a0efb7baf70
1 /***************************************************************************
2 * Copyright (C) 2005-2008 by the FIFE team *
3 * http://www.fifengine.de *
4 * This file is part of FIFE. *
5 * *
6 * FIFE is free software; you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License as published by *
8 * the Free Software Foundation; either version 2 of the License, or *
9 * (at your option) any later version. *
10 * *
11 * This program is distributed in the hope that it will be useful, *
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14 * GNU General Public License for more details. *
15 * *
16 * You should have received a copy of the GNU General Public License *
17 * along with this program; if not, write to the *
18 * Free Software Foundation, Inc., *
19 * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA *
20 ***************************************************************************/
21
22 #ifndef FIFE_MAP_LOADERS_FALLOUT_DAT1_H
23 #define FIFE_MAP_LOADERS_FALLOUT_DAT1_H
24
25 // Standard C++ library includes
26 #include <map>
27 #include <boost/scoped_ptr.hpp>
28
29 // 3rd party library includes
30
31 // FIFE includes
32 // These includes are split up in two parts, separated by one empty line
33 // First block: files included from the FIFE root src directory
34 // Second block: files included from the same folder
35 #include "vfs/vfs.h"
36 #include "vfs/vfssource.h"
37
38 #include "rawdatadat1.h"
39
40 namespace FIFE {
41
42 /** VFSource for the Fallout1 DAT file format.
43 */
44 class DAT1 : public VFSSource {
45 public:
46 /** Constructor
47 * Create a VFSSource for a Fallout1 DAT file.
48 * @param file A Fallout1 DAT file - e.g. master.DAT
49 */
50 DAT1(VFS* vfs, const std::string& file);
51
52 bool fileExists(const std::string& name) const;
53 RawData* open(const std::string& file) const;
54
55 /** Get the needed information to unpack and extract a file from the
56 * DAT file.
57 * Retrieves the Information needed to extract a specific file, this
58 * is passed as argument to a mffalloutrawdatadat1 RawMemSource,
59 * which itself fills its memory content with the unpacked file.
60 *
61 * @throw NotFound
62 * @see MFFalloutRawDataDAT1, RawMemSource
63 */
64 const RawDataDAT1::s_info& getInfo(const std::string& name) const;
65
66 std::set<std::string> listFiles(const std::string& pathstr) const;
67 std::set<std::string> listDirectories(const std::string& pathstr) const;
68
69 private:
70 std::string m_datpath;
71 boost::scoped_ptr<RawData> m_data;
72 typedef std::map<std::string, RawDataDAT1::s_info> type_filelist;
73 type_filelist m_filelist;
74
75 std::set<std::string> list(const std::string& pathstr, bool dirs) const;
76 std::string readString();
77
78 void loadFileList(const std::string& dirname);
79
80 // Not copyable
81 DAT1(const DAT1&);
82 DAT1& operator=(const DAT1&);
83 };
84
85 } // FIFE
86
87 #endif