Mercurial > audlegacy
annotate Plugins/Input/console/Spc_Emu.cpp @ 477:8fc500c08b61 trunk
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
author | nenolod |
---|---|
date | Thu, 19 Jan 2006 19:31:32 -0800 |
parents | 252843aac42f |
children | 0b9507985f0d |
rev | line source |
---|---|
90
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
1 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
2 // Game_Music_Emu 0.2.4. http://www.slack.net/~ant/libs/ |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
3 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
4 #include "Spc_Emu.h" |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
5 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
6 #include <string.h> |
477
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
7 #include "abstract_file.h" |
90
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
8 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
9 /* Copyright (C) 2004-2005 Shay Green. This module is free software; you |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
10 can redistribute it and/or modify it under the terms of the GNU Lesser |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
11 General Public License as published by the Free Software Foundation; either |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
12 version 2.1 of the License, or (at your option) any later version. This |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
13 module is distributed in the hope that it will be useful, but WITHOUT ANY |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
15 FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
16 more details. You should have received a copy of the GNU Lesser General |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
17 Public License along with this module; if not, write to the Free Software |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
19 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
20 #include BLARGG_SOURCE_BEGIN |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
21 |
477
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
22 #ifndef RAISE_ERROR |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
23 #define RAISE_ERROR( str ) return str |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
24 #endif |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
25 |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
26 typedef Spc_Reader::error_t error_t; |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
27 |
90
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
28 Spc_Emu::Spc_Emu() |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
29 { |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
30 resample_ratio = 1.0; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
31 use_resampler = false; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
32 track_count_ = 0; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
33 } |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
34 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
35 Spc_Emu::~Spc_Emu() |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
36 { |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
37 } |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
38 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
39 const char** Spc_Emu::voice_names() const |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
40 { |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
41 static const char* names [] = { |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
42 "DSP 1", "DSP 2", "DSP 3", "DSP 4", "DSP 5", "DSP 6", "DSP 7", "DSP 8" |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
43 }; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
44 return names; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
45 } |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
46 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
47 blargg_err_t Spc_Emu::init( long sample_rate, double gain ) |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
48 { |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
49 apu.set_gain( gain ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
50 use_resampler = false; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
51 resample_ratio = (double) native_sample_rate / sample_rate; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
52 if ( sample_rate != native_sample_rate ) |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
53 { |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
54 BLARGG_RETURN_ERR( resampler.buffer_size( native_sample_rate / 20 * 2 ) ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
55 resampler.time_ratio( resample_ratio, 0.9965 ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
56 use_resampler = true; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
57 } |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
58 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
59 return blargg_success; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
60 } |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
61 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
62 blargg_err_t Spc_Emu::load( const header_t& h, Emu_Reader& in ) |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
63 { |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
64 if ( in.remain() < sizeof file.data ) |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
65 return "Not an SPC file"; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
66 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
67 if ( strncmp( h.tag, "SNES-SPC700 Sound File Data", 27 ) != 0 ) |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
68 return "Not an SPC file"; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
69 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
70 track_count_ = 1; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
71 voice_count_ = Snes_Spc::voice_count; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
72 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
73 memcpy( &file.header, &h, sizeof file.header ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
74 return in.read( file.data, sizeof file.data ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
75 } |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
76 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
77 blargg_err_t Spc_Emu::start_track( int ) |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
78 { |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
79 resampler.clear(); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
80 return apu.load_spc( &file, sizeof file ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
81 } |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
82 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
83 blargg_err_t Spc_Emu::skip( long count ) |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
84 { |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
85 count = long (count * resample_ratio) & ~1; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
86 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
87 count -= resampler.skip_input( count ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
88 if ( count > 0 ) |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
89 BLARGG_RETURN_ERR( apu.skip( count ) ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
90 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
91 // eliminate pop due to resampler |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
92 const int resampler_latency = 64; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
93 sample_t buf [resampler_latency]; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
94 return play( resampler_latency, buf ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
95 } |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
96 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
97 blargg_err_t Spc_Emu::play( long count, sample_t* out ) |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
98 { |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
99 require( track_count_ ); // file must be loaded |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
100 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
101 if ( !use_resampler ) |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
102 return apu.play( count, out ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
103 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
104 long remain = count; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
105 while ( remain > 0 ) |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
106 { |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
107 remain -= resampler.read( &out [count - remain], remain ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
108 if ( remain > 0 ) |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
109 { |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
110 long n = resampler.max_write(); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
111 BLARGG_RETURN_ERR( apu.play( n, resampler.buffer() ) ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
112 resampler.write( n ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
113 } |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
114 } |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
115 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
116 assert( remain == 0 ); |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
117 |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
118 return blargg_success; |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
119 } |
252843aac42f
[svn] Import the initial sources for console music support.
nenolod
parents:
diff
changeset
|
120 |
477
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
121 Spc_Reader::Spc_Reader() : file( NULL ) { |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
122 } |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
123 |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
124 Spc_Reader::~Spc_Reader() { |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
125 close(); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
126 } |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
127 |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
128 error_t Spc_Reader::open( const char* path ) |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
129 { |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
130 file = fopen( path, "rb" ); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
131 if ( !file ) |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
132 RAISE_ERROR( "Couldn't open file" ); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
133 return NULL; |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
134 } |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
135 |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
136 blargg_err_t Spc_Reader::read_head(Spc_Emu::header_t *header) { |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
137 fread(&header->tag, 1,35,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
138 fread(&header->format, 1, 1,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
139 fread(&header->version, 1, 1,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
140 fread(&header->pc, 1, 2,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
141 fread(&header->a, 1, 1,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
142 fread(&header->x, 1, 1,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
143 fread(&header->y, 1, 1,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
144 fread(&header->psw, 1, 1,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
145 fread(&header->sp, 1, 1,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
146 fread(&header->unused, 1, 2,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
147 fread(&header->song, 1,32,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
148 fread(&header->game, 1,32,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
149 fread(&header->dumper, 1,16,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
150 fread(&header->comment, 1,32,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
151 fread(&header->date, 1,11,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
152 fread(&header->len_secs,1, 3,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
153 fread(&header->fade_msec,1,5,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
154 fread(&header->author, 1,32,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
155 fread(&header->mute_mask,1,1,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
156 fread(&header->emulator,1, 1,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
157 fread(&header->unused2, 1,45,file); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
158 } |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
159 |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
160 long Spc_Reader::size() const |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
161 { |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
162 long pos = tell(); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
163 fseek( file, 0, SEEK_END ); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
164 long result = tell(); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
165 fseek( file, pos, SEEK_SET ); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
166 return result; |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
167 } |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
168 |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
169 long Spc_Reader::read_avail( void* p, long s ) { |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
170 return fread( p, 1, s, file ); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
171 } |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
172 |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
173 long Spc_Reader::tell() const { |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
174 return ftell( file ); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
175 } |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
176 |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
177 error_t Spc_Reader::seek( long n ) |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
178 { |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
179 if ( fseek( file, n, SEEK_SET ) != 0 ) |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
180 RAISE_ERROR( "Error seeking in file" ); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
181 return NULL; |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
182 } |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
183 |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
184 void Spc_Reader::close() |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
185 { |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
186 if ( file ) { |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
187 fclose( file ); |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
188 file = NULL; |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
189 } |
8fc500c08b61
[svn] SPC length detection c/o Kiyoshi Aman <kiyoshi.aman -at- gmail.com>
nenolod
parents:
90
diff
changeset
|
190 } |