mirror of
https://github.com/Oibaf66/fbzx-wii.git
synced 2025-01-13 09:09:09 +01:00
Jump to block, linear interpolation anti aliasing filter, fixed bug in file list creation (hopefully), fixed bug in block selection
This commit is contained in:
parent
b17bd01131
commit
0dafc20545
@ -1713,7 +1713,7 @@ void ResetComputer () {
|
|||||||
|
|
||||||
ordenador.last_selected_poke_file[0]='\0';
|
ordenador.last_selected_poke_file[0]='\0';
|
||||||
|
|
||||||
ordenador.tst_sample=(ordenador.cpufreq + ordenador.freq/2)/ordenador.freq;
|
ordenador.tst_sample=(ordenador.cpufreq + (ordenador.freq*N_SAMPLES/2))/(ordenador.freq*N_SAMPLES);
|
||||||
|
|
||||||
microdrive_reset();
|
microdrive_reset();
|
||||||
|
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
|
|
||||||
#define KB_BUFFER_LENGHT 10
|
#define KB_BUFFER_LENGHT 10
|
||||||
#define MAX_PATH_LENGTH 256
|
#define MAX_PATH_LENGTH 256
|
||||||
|
#define N_SAMPLES 4
|
||||||
|
|
||||||
extern char salir;
|
extern char salir;
|
||||||
|
|
||||||
|
@ -584,7 +584,7 @@ int bucle, bucle2,ret2;
|
|||||||
}
|
}
|
||||||
|
|
||||||
printf("Init sound 2\n");
|
printf("Init sound 2\n");
|
||||||
ordenador.tst_sample=(ordenador.cpufreq + ordenador.freq/2)/ordenador.freq;
|
ordenador.tst_sample=(ordenador.cpufreq + (ordenador.freq*N_SAMPLES/2))/(ordenador.freq*N_SAMPLES);
|
||||||
}
|
}
|
||||||
|
|
||||||
void end_system() {
|
void end_system() {
|
||||||
|
@ -344,7 +344,6 @@ static const char **get_file_list(const char *base_dir)
|
|||||||
int cur = 0;
|
int cur = 0;
|
||||||
struct dirent *de;
|
struct dirent *de;
|
||||||
int cnt = 16;
|
int cnt = 16;
|
||||||
int i;
|
|
||||||
|
|
||||||
if (!d)
|
if (!d)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -371,6 +370,7 @@ static const char **get_file_list(const char *base_dir)
|
|||||||
size_t len = strlen(de->d_name) + 4;
|
size_t len = strlen(de->d_name) + 4;
|
||||||
|
|
||||||
p = (char*)malloc( len );
|
p = (char*)malloc( len );
|
||||||
|
if (p==NULL) break; //Terminate the list
|
||||||
snprintf(p, len, "[%s]", de->d_name);
|
snprintf(p, len, "[%s]", de->d_name);
|
||||||
file_list[cur++] = p;
|
file_list[cur++] = p;
|
||||||
file_list[cur] = NULL;
|
file_list[cur] = NULL;
|
||||||
@ -380,6 +380,7 @@ static const char **get_file_list(const char *base_dir)
|
|||||||
char *p;
|
char *p;
|
||||||
|
|
||||||
p = strdup(de->d_name);
|
p = strdup(de->d_name);
|
||||||
|
if (p==NULL) break; //Terminate the list
|
||||||
file_list[cur++] = p;
|
file_list[cur++] = p;
|
||||||
file_list[cur] = NULL;
|
file_list[cur] = NULL;
|
||||||
}
|
}
|
||||||
@ -388,15 +389,8 @@ static const char **get_file_list(const char *base_dir)
|
|||||||
{
|
{
|
||||||
cnt = cnt + 32;
|
cnt = cnt + 32;
|
||||||
realloc_file_list = (const char**)realloc(file_list, cnt * sizeof(char*));
|
realloc_file_list = (const char**)realloc(file_list, cnt * sizeof(char*));
|
||||||
if (realloc_file_list) file_list = realloc_file_list; else
|
if (realloc_file_list) file_list = realloc_file_list; else break;
|
||||||
{
|
|
||||||
/* Cleanup everything - file_list is NULL-terminated */
|
|
||||||
for ( i = 0; file_list[i]; i++ )
|
|
||||||
free((void*)file_list[i]);
|
|
||||||
free(file_list);
|
|
||||||
closedir(d);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
closedir(d);
|
closedir(d);
|
||||||
|
@ -1747,7 +1747,7 @@ char *select_file(char *path,enum LOAD_FILE_TYPES kind) {
|
|||||||
unsigned char fin,read,*salida;
|
unsigned char fin,read,*salida;
|
||||||
int bucle,ancho,numitems,selected,from,longitud;
|
int bucle,ancho,numitems,selected,from,longitud;
|
||||||
|
|
||||||
salida=(unsigned char *)malloc(2049);
|
salida=(unsigned char *)malloc(MAX_PATH_LENGTH);
|
||||||
salida[0]=0;
|
salida[0]=0;
|
||||||
|
|
||||||
ancho=screen->w;
|
ancho=screen->w;
|
||||||
@ -2018,6 +2018,6 @@ if (freq == 0)
|
|||||||
}
|
}
|
||||||
else ordenador.cpufreq = freq;
|
else ordenador.cpufreq = freq;
|
||||||
|
|
||||||
ordenador.tst_sample=(ordenador.cpufreq + ordenador.freq/2)/ordenador.freq;
|
ordenador.tst_sample=(ordenador.cpufreq + (ordenador.freq*N_SAMPLES/2))/(ordenador.freq*N_SAMPLES);
|
||||||
|
|
||||||
}
|
}
|
61
src/spk_ay.c
61
src/spk_ay.c
@ -24,7 +24,8 @@
|
|||||||
#include "sound.h"
|
#include "sound.h"
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
unsigned int beeper = 0;
|
unsigned int beeper = 0, lvalue_sum=0, rvalue_sum=0 ;
|
||||||
|
unsigned char sample_count = 0;
|
||||||
|
|
||||||
/* emulates the AY-3-8912 during TSTADOS tstates */
|
/* emulates the AY-3-8912 during TSTADOS tstates */
|
||||||
|
|
||||||
@ -314,23 +315,12 @@ inline void play_ay (unsigned int tstados) {
|
|||||||
|
|
||||||
inline void play_sound (unsigned int tstados) {
|
inline void play_sound (unsigned int tstados) {
|
||||||
|
|
||||||
int lvalue, rvalue;
|
|
||||||
|
|
||||||
ordenador.tstados_counter_sound += tstados;
|
ordenador.tstados_counter_sound += tstados;
|
||||||
|
|
||||||
while (ordenador.tstados_counter_sound >= ordenador.tst_sample) {
|
while (ordenador.tstados_counter_sound >= ordenador.tst_sample) {
|
||||||
|
|
||||||
ordenador.tstados_counter_sound -= ordenador.tst_sample;
|
ordenador.tstados_counter_sound -= ordenador.tst_sample;
|
||||||
|
|
||||||
/*
|
|
||||||
//Low pass filter
|
|
||||||
if (ordenador.sound_bit)
|
|
||||||
{
|
|
||||||
if (beeper<480) beeper = beeper + ordenador.low_filter; //Sound bit volume max 480*vol
|
|
||||||
}
|
|
||||||
else if (beeper>0) beeper = beeper - ordenador.low_filter;
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (ordenador.sound_bit)
|
if (ordenador.sound_bit)
|
||||||
{
|
{
|
||||||
if (ordenador.sound_bit_mic) beeper = 544; //480 + 64 - MIC is audible only if EAR is on
|
if (ordenador.sound_bit_mic) beeper = 544; //480 + 64 - MIC is audible only if EAR is on
|
||||||
@ -340,46 +330,55 @@ inline void play_sound (unsigned int tstados) {
|
|||||||
|
|
||||||
//Each channel max 256*vol
|
//Each channel max 256*vol
|
||||||
|
|
||||||
if (ordenador.ay_emul)
|
if ((ordenador.ay_emul)&&(!ordenador.turbo_state))
|
||||||
{
|
{
|
||||||
switch (ordenador.audio_mode)
|
switch (ordenador.audio_mode)
|
||||||
{
|
{
|
||||||
case 0: //Mono
|
case 0: //Mono
|
||||||
lvalue = (beeper + ordenador.vol_a + ordenador.vol_b +ordenador.vol_c)*ordenador.volume;
|
lvalue_sum = lvalue_sum + (beeper + ordenador.vol_a + ordenador.vol_b +ordenador.vol_c)*ordenador.volume;
|
||||||
rvalue = (beeper + ordenador.vol_a + ordenador.vol_b +ordenador.vol_c)*ordenador.volume;
|
rvalue_sum = rvalue_sum + (beeper + ordenador.vol_a + ordenador.vol_b +ordenador.vol_c)*ordenador.volume;
|
||||||
break;
|
break;
|
||||||
case 1: //ABC
|
case 1: //ABC
|
||||||
lvalue = (beeper + ordenador.vol_a*2 + ordenador.vol_b)*ordenador.volume;
|
lvalue_sum = lvalue_sum + (beeper + ordenador.vol_a*2 + ordenador.vol_b)*ordenador.volume;
|
||||||
rvalue = (beeper + ordenador.vol_b + ordenador.vol_c*2)*ordenador.volume;
|
rvalue_sum = rvalue_sum + (beeper + ordenador.vol_b + ordenador.vol_c*2)*ordenador.volume;
|
||||||
break;
|
break;
|
||||||
case 2: //ACB
|
case 2: //ACB
|
||||||
lvalue = (beeper + ordenador.vol_a*2 + ordenador.vol_c)*ordenador.volume;
|
lvalue_sum = lvalue_sum + (beeper + ordenador.vol_a*2 + ordenador.vol_c)*ordenador.volume;
|
||||||
rvalue = (beeper + ordenador.vol_c + ordenador.vol_b*2)*ordenador.volume;
|
rvalue_sum = rvalue_sum + (beeper + ordenador.vol_c + ordenador.vol_b*2)*ordenador.volume;
|
||||||
break;
|
break;
|
||||||
case 3: //BAC
|
case 3: //BAC
|
||||||
lvalue = (beeper + ordenador.vol_b*2 + ordenador.vol_a)*ordenador.volume;
|
lvalue_sum = lvalue_sum + (beeper + ordenador.vol_b*2 + ordenador.vol_a)*ordenador.volume;
|
||||||
rvalue = (beeper + ordenador.vol_a + ordenador.vol_c*2)*ordenador.volume;
|
rvalue_sum = rvalue_sum + (beeper + ordenador.vol_a + ordenador.vol_c*2)*ordenador.volume;
|
||||||
break;
|
break;
|
||||||
default: //No emulation
|
default: //No emulation
|
||||||
rvalue = beeper*ordenador.volume;
|
lvalue_sum = lvalue_sum + beeper*ordenador.volume;
|
||||||
lvalue = beeper*ordenador.volume;
|
rvalue_sum = rvalue_sum + beeper*ordenador.volume;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
rvalue = beeper*ordenador.volume;
|
lvalue_sum = lvalue_sum + beeper*ordenador.volume;
|
||||||
lvalue = beeper*ordenador.volume;
|
rvalue_sum = rvalue_sum + beeper*ordenador.volume;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
*ordenador.current_buffer = (rvalue<<16)|(lvalue);
|
if (sample_count==(N_SAMPLES-1))
|
||||||
ordenador.current_buffer++;
|
{
|
||||||
|
|
||||||
ordenador.sound_cuantity++;
|
*ordenador.current_buffer = ((rvalue_sum/N_SAMPLES)<<16)|(lvalue_sum/N_SAMPLES);
|
||||||
|
ordenador.current_buffer++;
|
||||||
|
|
||||||
|
ordenador.sound_cuantity++;
|
||||||
|
|
||||||
if (ordenador.sound_cuantity == ordenador.buffer_len) { // buffer filled
|
if (ordenador.sound_cuantity == ordenador.buffer_len) { // buffer filled
|
||||||
sound_play();
|
sound_play();
|
||||||
ordenador.sound_cuantity = 0;
|
ordenador.sound_cuantity = 0;
|
||||||
|
}
|
||||||
|
sample_count=0;
|
||||||
|
lvalue_sum=0;
|
||||||
|
rvalue_sum=0;
|
||||||
}
|
}
|
||||||
|
else sample_count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
23
src/tape.c
23
src/tape.c
@ -57,8 +57,8 @@ inline void tape_read(FILE *fichero, int tstados) {
|
|||||||
//Auto ultra fast mode
|
//Auto ultra fast mode
|
||||||
if ((ordenador.turbo_state != 1)&&(ordenador.turbo==1))
|
if ((ordenador.turbo_state != 1)&&(ordenador.turbo==1))
|
||||||
{
|
{
|
||||||
if (ordenador.tape_file_type==TAP_TAP) update_frequency(13000000);
|
if (ordenador.tape_file_type==TAP_TAP) update_frequency(12500000);
|
||||||
else update_frequency(11000000);
|
else update_frequency(10500000);
|
||||||
jump_frames=7;
|
jump_frames=7;
|
||||||
ordenador.precision_old=ordenador.precision;
|
ordenador.precision_old=ordenador.precision;
|
||||||
ordenador.precision =0;
|
ordenador.precision =0;
|
||||||
@ -207,6 +207,7 @@ inline void tape_read_tzx (FILE * fichero, int tstados) {
|
|||||||
static unsigned char value, value2,value3,value4,done;
|
static unsigned char value, value2,value3,value4,done;
|
||||||
static unsigned int bucle,bucle2, byte_position;
|
static unsigned int bucle,bucle2, byte_position;
|
||||||
int retval;
|
int retval;
|
||||||
|
char block_jump[2];
|
||||||
|
|
||||||
if (fichero == NULL)
|
if (fichero == NULL)
|
||||||
{
|
{
|
||||||
@ -423,6 +424,11 @@ inline void tape_read_tzx (FILE * fichero, int tstados) {
|
|||||||
|
|
||||||
case 0x22: // group end
|
case 0x22: // group end
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 0x23: // jump to block
|
||||||
|
retval=fread(block_jump,1,2,fichero);
|
||||||
|
jump_to_block(fichero, (int) block_jump[0] + 256*((int) block_jump[1]));
|
||||||
|
break;
|
||||||
|
|
||||||
case 0x24: // loop start
|
case 0x24: // loop start
|
||||||
retval=fread(&value2,1,1,fichero);
|
retval=fread(&value2,1,1,fichero);
|
||||||
@ -938,6 +944,7 @@ void fastload_block_tzx (FILE * fichero) {
|
|||||||
unsigned int longitud, len, bucle, number_bytes, byte_position, byte_position2, retorno;
|
unsigned int longitud, len, bucle, number_bytes, byte_position, byte_position2, retorno;
|
||||||
unsigned char value[65536], empty, blockid, parity, pause[2],flag_byte;
|
unsigned char value[65536], empty, blockid, parity, pause[2],flag_byte;
|
||||||
int retval;
|
int retval;
|
||||||
|
char block_jump[2];
|
||||||
|
|
||||||
longitud =0;
|
longitud =0;
|
||||||
pause[0]=pause[1]=0;
|
pause[0]=pause[1]=0;
|
||||||
@ -1039,11 +1046,19 @@ void fastload_block_tzx (FILE * fichero) {
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x21: // group start
|
case 0x21: // group start
|
||||||
retorno=2;
|
retval=fread(value,1,1,fichero);
|
||||||
|
if (retval!=1) {procesador.Rm.br.F &= (~F_C);return;}
|
||||||
|
len = (unsigned int) value[0];
|
||||||
|
retval=fread(value,1,len,fichero);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x22: // group end
|
case 0x22: // group end
|
||||||
retorno=2;
|
break;
|
||||||
|
|
||||||
|
case 0x23: // jump to block
|
||||||
|
retval=fread(block_jump,1,2,fichero);
|
||||||
|
if (retval!=2) {procesador.Rm.br.F &= (~F_C);return;}
|
||||||
|
jump_to_block(fichero, (int) block_jump[0] + 256*((int) block_jump[1]));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x24: // loop start
|
case 0x24: // loop start
|
||||||
|
@ -40,7 +40,8 @@ struct tape_select *block_select_list[MAX_SELECT_ITEM+1];
|
|||||||
void browser_tzx (FILE * fichero) {
|
void browser_tzx (FILE * fichero) {
|
||||||
|
|
||||||
unsigned int longitud, len, bucle, byte_position, retorno, block_number;
|
unsigned int longitud, len, bucle, byte_position, retorno, block_number;
|
||||||
unsigned char value[65536], empty, blockid, pause[2], flag_byte;
|
unsigned char value[65536], empty, blockid, pause[2], flag_byte;
|
||||||
|
char block_jump[2];
|
||||||
int retval, retval2;
|
int retval, retval2;
|
||||||
|
|
||||||
longitud =0;
|
longitud =0;
|
||||||
@ -196,7 +197,7 @@ void browser_tzx (FILE * fichero) {
|
|||||||
if (longitud==0) strcpy(browser_list[block_number]->block_type,"Stop the Tape ");
|
if (longitud==0) strcpy(browser_list[block_number]->block_type,"Stop the Tape ");
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
strcpy(browser_list[block_number]->block_type,"Pause: ");
|
strcpy(browser_list[block_number]->block_type,"Pause ");
|
||||||
sprintf(browser_list[block_number]->info,"%d ms", longitud);
|
sprintf(browser_list[block_number]->info,"%d ms", longitud);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -216,6 +217,13 @@ void browser_tzx (FILE * fichero) {
|
|||||||
strcpy(browser_list[block_number]->block_type,"Group end ");
|
strcpy(browser_list[block_number]->block_type,"Group end ");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 0x23: // jump to block
|
||||||
|
strcpy(browser_list[block_number]->block_type,"Jump to block ");
|
||||||
|
retval=fread(block_jump,1,2,fichero);
|
||||||
|
if (retval!=2) {retorno=1;break;}
|
||||||
|
sprintf(browser_list[block_number]->info,"Block: %d", ((int) block_jump[0]) + 256*((int) block_jump[1]) + ((int) block_number));
|
||||||
|
break;
|
||||||
|
|
||||||
case 0x24: // loop start
|
case 0x24: // loop start
|
||||||
strcpy(browser_list[block_number]->block_type,"Loop start ");
|
strcpy(browser_list[block_number]->block_type,"Loop start ");
|
||||||
retval=fread(value,1,2, fichero);
|
retval=fread(value,1,2, fichero);
|
||||||
@ -302,7 +310,7 @@ void browser_tzx (FILE * fichero) {
|
|||||||
|
|
||||||
default: // not supported
|
default: // not supported
|
||||||
strcpy(browser_list[block_number]->block_type,"Not supported");
|
strcpy(browser_list[block_number]->block_type,"Not supported");
|
||||||
retorno=1; //Tape error
|
retorno=1; //Error
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
block_number++;
|
block_number++;
|
||||||
@ -421,7 +429,7 @@ browser_list[block_number]=NULL;
|
|||||||
|
|
||||||
int select_block(FILE * fichero)
|
int select_block(FILE * fichero)
|
||||||
{
|
{
|
||||||
unsigned int longitud, bucle, byte_position, block_number,nblocks,offset, blk_sel_pos;
|
unsigned int longitud, bucle, block_number,nblocks,offset, blk_sel_pos;
|
||||||
unsigned char value[64], len_text;
|
unsigned char value[64], len_text;
|
||||||
int retval;
|
int retval;
|
||||||
|
|
||||||
@ -434,14 +442,14 @@ int select_block(FILE * fichero)
|
|||||||
block_select_list[bucle]=NULL;
|
block_select_list[bucle]=NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
byte_position=ftell(fichero)-1;
|
//search for select block position
|
||||||
|
|
||||||
//search for select block
|
|
||||||
for(blk_sel_pos=0;
|
for(blk_sel_pos=0;
|
||||||
((browser_list[blk_sel_pos]!=NULL)&&(blk_sel_pos<MAX_BROWSER_ITEM)&&(browser_list[blk_sel_pos]->position!=byte_position));
|
((blk_sel_pos<MAX_BROWSER_ITEM)&&(browser_list[blk_sel_pos]!=NULL)&&(browser_list[blk_sel_pos]->position!=ordenador.tape_position));
|
||||||
blk_sel_pos++);
|
blk_sel_pos++);
|
||||||
|
|
||||||
if (browser_list[blk_sel_pos]->position!=byte_position) return -1;
|
if (browser_list[blk_sel_pos]==NULL) return -1;
|
||||||
|
|
||||||
|
if (browser_list[blk_sel_pos]->position!=ordenador.tape_position) return -1;
|
||||||
|
|
||||||
retval=fread(value,1,3,fichero);
|
retval=fread(value,1,3,fichero);
|
||||||
if (retval!=3) {return -1;}
|
if (retval!=3) {return -1;}
|
||||||
@ -473,7 +481,7 @@ int select_block(FILE * fichero)
|
|||||||
block_select_list[block_number]=NULL;
|
block_select_list[block_number]=NULL;
|
||||||
if (feof(fichero)) return -1;
|
if (feof(fichero)) return -1;
|
||||||
|
|
||||||
unsigned int tape_position, block_n_int;
|
unsigned int block_n_int;
|
||||||
const char *row_selected;
|
const char *row_selected;
|
||||||
char block_n[3];
|
char block_n[3];
|
||||||
|
|
||||||
@ -488,23 +496,52 @@ int select_block(FILE * fichero)
|
|||||||
|
|
||||||
block_n_int=atoi(block_n);
|
block_n_int=atoi(block_n);
|
||||||
|
|
||||||
if ((block_n_int<0)||(block_n_int >(MAX_SELECT_ITEM-1))) return -1;
|
if ((block_n_int<0)||(block_n_int >(MAX_SELECT_ITEM-1))||block_select_list[block_n_int]==NULL) return -1;
|
||||||
|
|
||||||
if ((block_select_list[block_n_int]->offset+blk_sel_pos) > (MAX_BROWSER_ITEM-1)) return -1;
|
if ((block_select_list[block_n_int]->offset+blk_sel_pos) > (MAX_BROWSER_ITEM-1)) return -1;
|
||||||
|
|
||||||
tape_position=browser_list[block_select_list[block_n_int]->offset+blk_sel_pos]->position;
|
if (browser_list[block_select_list[block_n_int]->offset+blk_sel_pos]==NULL) return -1;
|
||||||
|
|
||||||
|
ordenador.tape_position=browser_list[block_select_list[block_n_int]->offset+blk_sel_pos]->position;
|
||||||
|
|
||||||
ordenador.tape_current_bit=0;
|
ordenador.tape_current_bit=0;
|
||||||
ordenador.tape_current_mode=TAP_TRASH;
|
ordenador.tape_current_mode=TAP_TRASH;
|
||||||
ordenador.next_block= NOBLOCK;
|
ordenador.next_block= NOBLOCK;
|
||||||
|
|
||||||
fseek(ordenador.tap_file, tape_position, SEEK_SET);
|
fseek(ordenador.tap_file, ordenador.tape_position, SEEK_SET);
|
||||||
ordenador.tape_position = tape_position;
|
|
||||||
free((void*)row_selected);
|
free((void*)row_selected);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int jump_to_block(FILE * fichero, int blocks_to_jump)
|
||||||
|
{
|
||||||
|
|
||||||
|
int blk_sel_pos, dest_block;
|
||||||
|
|
||||||
|
|
||||||
|
//search for block position
|
||||||
|
for(blk_sel_pos=0;
|
||||||
|
((blk_sel_pos<MAX_BROWSER_ITEM)&&(browser_list[blk_sel_pos]!=NULL)&&(browser_list[blk_sel_pos]->position!=ordenador.tape_position));
|
||||||
|
blk_sel_pos++);
|
||||||
|
|
||||||
|
if (browser_list[blk_sel_pos]==NULL) return -1;
|
||||||
|
|
||||||
|
if (browser_list[blk_sel_pos]->position!=ordenador.tape_position) return -1;
|
||||||
|
|
||||||
|
dest_block=blk_sel_pos+blocks_to_jump;
|
||||||
|
|
||||||
|
if ((dest_block<0)||(dest_block>MAX_BROWSER_ITEM)) return -1;
|
||||||
|
|
||||||
|
if (browser_list[dest_block]==NULL) return -1;
|
||||||
|
|
||||||
|
fseek(fichero, browser_list[dest_block]->position, SEEK_SET);
|
||||||
|
|
||||||
|
ordenador.tape_position = browser_list[dest_block]->position;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
void free_browser()
|
void free_browser()
|
||||||
{
|
{
|
||||||
unsigned int bucle;
|
unsigned int bucle;
|
||||||
|
@ -40,6 +40,7 @@ extern struct browser *browser_list[MAX_BROWSER_ITEM+1];
|
|||||||
void browser_tap (FILE *);
|
void browser_tap (FILE *);
|
||||||
void browser_tzx (FILE *);
|
void browser_tzx (FILE *);
|
||||||
int select_block(FILE * fichero);
|
int select_block(FILE * fichero);
|
||||||
|
int jump_to_block(FILE * fichero, int blocks_to_jump);
|
||||||
void free_browser();
|
void free_browser();
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user