-
Notifications
You must be signed in to change notification settings - Fork 6
/
file.hpp
86 lines (74 loc) · 3.18 KB
/
file.hpp
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
//////////////////////////////////////////////////////////////////////////////
// NoLifeNx - Part of the NoLifeStory project //
// Copyright © 2013 Peter Atashian //
// //
// This program is free software: you can redistribute it and/or modify //
// it under the terms of the GNU Affero General Public License as //
// published by the Free Software Foundation, either version 3 of the //
// License, or (at your option) any later version. //
// //
// This program 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 Affero General Public License for more details. //
// //
// You should have received a copy of the GNU Affero General Public License //
// along with this program. If not, see <http://www.gnu.org/licenses/>. //
//////////////////////////////////////////////////////////////////////////////
#pragma once
#include "nxfwd.hpp"
#include <cstdint>
#include <string>
namespace nl
{
struct _file_data;
class file
{
public:
typedef _file_data data;
struct header;
//! Creates a null file object.
//! Nothing can really be done until you call `open()`.
file() = default;
//! Used to construct an NX file from a filename.
//! Multiple file objects can be created from the same filename
//! and the resulting nodes are interchangeable.
file(std::string name);
//! Destructor calls `close()`.
~file();
//! Files cannot be copied.
file(file const&) = delete;
//! Files cannot be copied.
file& operator=(file const&) = delete;
//! Transfers ownership of the file handle to another file.
file(file&&);
//! Transfers ownership of the file handle to another file.
file& operator=(file&&);
//! Opens the file with the given name.
void open(std::string name);
//! Closes the given file.
//! Any nodes derived from this file become invalid after closing it.
//! Any attempts to use invalid nodes will result in undefined behavior.
void close();
//! Obtains the root node from which all other nodes may be accessed.
//! If the file is not open, a null node is returned.
node root() const;
//! Effectively calls `root()`.
operator node() const;
//! Returns the number of strings in the file.
uint32_t string_count() const;
//! Returns the number of bitmaps in the file.
uint32_t bitmap_count() const;
//! Returns the number of audios in the file.
uint32_t audio_count() const;
//! Returns the number of nodes in the file.
uint32_t node_count() const;
//! Returns the string with a given ID number.
std::string get_string(uint32_t) const;
private:
data* m_data = nullptr;
friend node;
friend bitmap;
friend audio;
};
} // namespace nl