-
-
Notifications
You must be signed in to change notification settings - Fork 493
/
Copy pathasset_archive.cpp
110 lines (80 loc) · 2.66 KB
/
asset_archive.cpp
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
/*
* This program source code file is part of KiCad, a free EDA CAD application.
*
* Copyright The KiCad Developers, see AUTHORS.txt for contributors.
*
* This program is free software: you can redistribute it and/or modify it
* under the terms of the GNU 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
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include <wx/tarstrm.h>
#include <wx/wfstream.h>
#include <wx/zstream.h>
#include <asset_archive.h>
ASSET_ARCHIVE::ASSET_ARCHIVE( const wxString& aFilePath, bool aLoadNow ) :
m_filePath( aFilePath )
{
if( aLoadNow )
Load();
}
bool ASSET_ARCHIVE::Load()
{
// We don't support hot-reloading yet
if( !m_fileInfoCache.empty() )
return false;
wxFFileInputStream zipFile( m_filePath );
if( !zipFile.IsOk() )
return false;
wxZlibInputStream stream( zipFile, wxZLIB_GZIP );
wxTarInputStream tarStream( stream );
wxTarEntry* entry;
// Avoid realloc while reading: we're not going to get better than 2:1 compression
m_cache.resize( 2 * zipFile.GetLength() );
size_t offset = 0;
while( ( entry = tarStream.GetNextEntry() ) != nullptr )
{
if( entry->IsDir() )
{
delete entry;
continue;
}
size_t length = entry->GetSize();
FILE_INFO fi;
fi.offset = offset;
fi.length = length;
if( offset + length > m_cache.size() )
m_cache.resize( m_cache.size() * 2 );
tarStream.Read( &m_cache[offset], length );
m_fileInfoCache[entry->GetName()] = fi;
offset += length;
delete entry;
}
m_cache.resize( offset );
return true;
}
long ASSET_ARCHIVE::GetFileContents( const wxString& aFilePath, const unsigned char* aDest,
size_t aMaxLen )
{
wxFAIL_MSG( wxS( "Unimplemented" ) );
return 0;
}
long ASSET_ARCHIVE::GetFilePointer( const wxString& aFilePath, const unsigned char** aDest )
{
if( aFilePath.IsEmpty() )
return -1;
wxASSERT( aDest );
if( !m_fileInfoCache.count( aFilePath ) )
return -1;
const FILE_INFO& fi = m_fileInfoCache.at( aFilePath );
*aDest = &m_cache[fi.offset];
return fi.length;
}