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
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
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 }