forked from stepmania/stepmania
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMsdFile.h
129 lines (117 loc) · 4.24 KB
/
MsdFile.h
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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
#ifndef MSDFILE_H
#define MSDFILE_H
/** @brief The class that reads the various .SSC, .SM, .SMA, .DWI, and .MSD files. */
class MsdFile
{
public:
/**
* @brief The list of params found in the files.
*
* Note that #param:param:param:param; is one whole value. */
struct value_t
{
/** @brief The list of parameters. */
std::vector<std::string> params;
/** @brief Set up the parameters with default values. */
value_t(): params() {}
/**
* @brief Access the proper parameter.
* @param i the index.
* @return the proper parameter.
*/
std::string operator[]( unsigned i ) const { if( i >= params.size() ) return std::string(); return params[i]; }
};
MsdFile(): values(), error("") {}
/** @brief Remove the MSDFile. */
virtual ~MsdFile() { }
/**
* @brief Attempt to read an MSD file.
* @param sFilePath the path to the file.
* @param bUnescape a flag to see if we need to unescape values.
* @return its success or failure.
*/
bool ReadFile( std::string sFilePath, bool bUnescape );
/**
* @brief Attempt to read an MSD file.
* @param sString the path to the file.
* @param bUnescape a flag to see if we need to unescape values.
* @return its success or failure.
*/
void ReadFromString( const std::string &sString, bool bUnescape );
/**
* @brief Should an error take place, have an easy place to get it.
* @return the current error. */
std::string GetError() const { return error; }
/**
* @brief Retrieve the number of values for each tag.
* @return the nmber of values. */
unsigned GetNumValues() const { return values.size(); }
/**
* @brief Get the number of parameters for the current index.
* @param val the current value index.
* @return the number of params.
*/
unsigned GetNumParams( unsigned val ) const { if( val >= GetNumValues() ) return 0; return values[val].params.size(); }
/**
* @brief Get the specified value.
* @param val the current value index.
* @return The specified value.
*/
const value_t &GetValue( unsigned val ) const { ASSERT(val < GetNumValues()); return values[val]; }
/**
* @brief Retrieve the specified parameter.
* @param val the current value index.
* @param par the current parameter index.
* @return the parameter in question.
*/
std::string GetParam( unsigned val, unsigned par ) const;
private:
/**
* @brief Attempt to read an MSD file from the buffer.
* @param buf the buffer containing the MSD file.
* @param len the length of the buffer.
* @param bUnescape a flag to see if we need to unescape values.
*/
void ReadBuf( const char *buf, int len, bool bUnescape );
/**
* @brief Add a new parameter.
* @param buf the new parameter.
* @param len the length of the new parameter.
*/
void AddParam( const char *buf, int len );
/**
* @brief Add a new value.
*/
void AddValue();
/** @brief The list of values. */
std::vector<value_t> values;
/** @brief The error string. */
std::string error;
};
#endif
/**
* @file
* @author Chris Danford, Glenn Maynard (c) 2001-2004
* @section LICENSE
* All rights reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, and/or sell copies of the Software, and to permit persons to
* whom the Software is furnished to do so, provided that the above
* copyright notice(s) and this permission notice appear in all copies of
* the Software and that both the above copyright notice(s) and this
* permission notice appear in supporting documentation.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF
* THIRD PARTY RIGHTS. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS
* INCLUDED IN THIS NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT
* OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS
* OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
* PERFORMANCE OF THIS SOFTWARE.
*/