File: ArchiveScanner.h

package info (click to toggle)
spring 0.81.2.1%2Bdfsg1-6
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 28,496 kB
  • ctags: 37,096
  • sloc: cpp: 238,659; ansic: 13,784; java: 12,175; awk: 3,428; python: 1,159; xml: 738; perl: 405; sh: 297; makefile: 267; pascal: 228; objc: 192
file content (104 lines) | stat: -rw-r--r-- 3,743 bytes parent folder | download
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
#ifndef __ARCHIVE_SCANNER_H
#define __ARCHIVE_SCANNER_H

#include <string>
#include <vector>
#include <map>

class CArchiveBase;
class IFileFilter;
class LuaParser;
class LuaTable;

/*
 * This class searches through a given directory and its subdirectories looking for archive files.
 * When it finds one, it figures out what kind of archive it is (i.e. if it is a map or a mod currently).
 * This information is cached, so that only modified archives are actually opened. The information can
 * then be retreived by the mod and map selectors.
 *
 * The archive namespace is global, so it is not allowed to have an archive with the same name in more
 * than one folder.
 */

class CArchiveScanner
{
public:
	struct MapData {
		std::string name;
		std::string virtualPath;					// Where in the archive the map can be found
	};

	struct ModData {
		std::string name;							// ex:  Original Total Annihilation v2.3
		std::string shortName;						// ex:  OTA
		std::string version;						// ex:  v2.3
		std::string mutator;						// ex:  deployment
		std::string game;							// ex:  Total Annihilation
		std::string shortGame;						// ex:  TA
		std::string description;					// ex:  Little units blowing up other little units
		int modType;
		std::vector<std::string> dependencies;		// Archives it depends on
		std::vector<std::string> replaces;			// This archive obsoletes these ones
	};

	CArchiveScanner(void);
	virtual ~CArchiveScanner(void);

	std::string GetFilename();

	void ScanDirs(const std::vector<std::string>& dirs, bool checksum = false);

	void ReadCacheData(const std::string& filename);
	void WriteCacheData(const std::string& filename);

	std::vector<ModData> GetPrimaryMods() const;
	std::vector<ModData> GetAllMods() const;
	std::vector<std::string> GetArchives(const std::string& root, int depth = 0) const;
	std::vector<std::string> GetMaps();
	std::vector<std::string> GetArchivesForMap(const std::string& mapName) const;
	unsigned int GetArchiveChecksum(const std::string& name);
	std::string GetArchivePath(const std::string& name) const;
	unsigned int GetModChecksum(const std::string& root);
	unsigned int GetMapChecksum(const std::string& mapName);
	void CheckMod(const std::string& root, unsigned checksum); // these throw a content_error if checksum doesn't match
	void CheckMap(const std::string& mapName, unsigned checksum);
	std::string ModNameToModArchive(const std::string& s) const;
	std::string ModArchiveToModName(const std::string& s) const;
	ModData ModNameToModData(const std::string& s) const;
	ModData ModArchiveToModData(const std::string& s) const;

protected:
	struct ArchiveInfo {
		std::string path;
		std::string origName;					// Could be useful to have the non-lowercased name around
		unsigned int modified;
		std::vector<MapData> mapData;
		ModData modData;
		unsigned int checksum;
		bool updated;
		std::string replaced;					// If not empty, use that archive instead
	};

protected:
	void PreScan(const std::string& curPath);
	void Scan(const std::string& curPath, bool checksum = false);
	void ScanArchive(const std::string& fullName, bool checksum = false);
	bool ScanMap(CArchiveBase* ar, const std::string& fileName, ArchiveInfo& ai);
	bool ScanModLua(CArchiveBase* ar, const std::string& fileName, ArchiveInfo& ai);
	bool ScanModTdf(CArchiveBase* ar, const std::string& fileName, ArchiveInfo& ai);

protected:
	std::map<std::string, ArchiveInfo> archiveInfo;
	ModData GetModData(const LuaTable& modTable);
	IFileFilter* CreateIgnoreFilter(CArchiveBase* ar);
	unsigned int GetCRC(const std::string& filename);
	bool isDirty;
	std::string parse_tdf_path;
	std::string parse_tdf_code;
	std::string scanutils_path;
	std::string scanutils_code;
};

extern CArchiveScanner* archiveScanner;

#endif