Rewritten the event processing, added arrow keys emulation, file name in save snapshot menu

This commit is contained in:
fabio.olimpieri 2012-04-15 18:16:37 +00:00
parent c8973f8493
commit 449ed4a2da
5 changed files with 1676 additions and 1907 deletions

File diff suppressed because it is too large Load Diff

View File

@ -1,217 +1,220 @@
/* /*
* Copyright 2003-2009 (C) Raster Software Vigo (Sergio Costas) * Copyright 2003-2009 (C) Raster Software Vigo (Sergio Costas)
* This file is part of FBZX * This file is part of FBZX
* *
* FBZX is free software; you can redistribute it and/or modify * FBZX is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or * the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* FBZX is distributed in the hope that it will be useful, * FBZX is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>. * along with this program. If not, see <http://www.gnu.org/licenses/>.
* *
*/ */
#ifndef computer_h #ifndef computer_h
#define computer_h #define computer_h
#include <SDL/SDL.h> #include <SDL/SDL.h>
#include <SDL/SDL_thread.h> #include <SDL/SDL_thread.h>
// #define MUT // #define MUT
extern char salir; extern char salir;
enum tapmodes {TAP_GUIDE, TAP_DATA, TAP_PAUSE, TAP_TRASH, TAP_STOP, TAP_PAUSE2, TZX_PURE_TONE, enum tapmodes {TAP_GUIDE, TAP_DATA, TAP_PAUSE, TAP_TRASH, TAP_STOP, TAP_PAUSE2, TZX_PURE_TONE,
TZX_SEQ_PULSES, TAP_FINAL_BIT, TAP_PAUSE3}; TZX_SEQ_PULSES, TAP_FINAL_BIT, TAP_PAUSE3};
enum taptypes {TAP_TAP, TAP_TZX}; enum taptypes {TAP_TAP, TAP_TZX};
struct computer { struct computer {
unsigned int temporal_io; unsigned int temporal_io;
// screen private global variables // screen private global variables
SDL_Surface *screen; SDL_Surface *screen;
unsigned char *screenbuffer; unsigned char *screenbuffer;
unsigned int screen_width; unsigned int screen_width;
unsigned int translate[6144],translate2[6144]; unsigned int translate[6144],translate2[6144];
unsigned char zaurus_mini; unsigned char zaurus_mini;
unsigned char text_mini; unsigned char text_mini;
unsigned char dblscan; unsigned char dblscan;
unsigned char bw; unsigned char bw;
int contador_flash; int contador_flash;
unsigned int *p_translt,*p_translt2; unsigned int *p_translt,*p_translt2;
unsigned char *pixel; // current address unsigned char *pixel; // current address
char border,flash; char border,flash;
int currline,currpix; int currline,currpix;
int tstados_counter; // counts tstates leaved to the next call int tstados_counter; // counts tstates leaved to the next call
int resx,resy,bpp; // screen resolutions int resx,resy,bpp; // screen resolutions
int init_line; // cuantity to add to the base address to start to paint int init_line; // cuantity to add to the base address to start to paint
int next_line; // cuantity to add when we reach the end of line to go to next line int next_line; // cuantity to add when we reach the end of line to go to next line
int next_scanline; // cuantity to add to pass to the next scanline int next_scanline; // cuantity to add to pass to the next scanline
int first_line; // first line to start to paint int first_line; // first line to start to paint
int last_line; // last line to paint int last_line; // last line to paint
int first_pixel; // first pixel of a line to paint int first_pixel; // first pixel of a line to paint
int last_pixel; // last pixel of a line to paint int last_pixel; // last pixel of a line to paint
int next_pixel; // next pixel int next_pixel; // next pixel
int pixancho,pixalto; // maximum pixel value for width and height int pixancho,pixalto; // maximum pixel value for width and height
int jump_pixel; int jump_pixel;
unsigned char screen_snow; // 0-> no emulate snow; 1-> emulate snow unsigned char screen_snow; // 0-> no emulate snow; 1-> emulate snow
unsigned char contended_zone; // 0-> no contention; 1-> contention possible unsigned char contended_zone; // 0-> no contention; 1-> contention possible
int cicles_counter; // counts how many pixel clock cicles passed since las interrupt int cicles_counter; // counts how many pixel clock cicles passed since las interrupt
char ulaplus; // 0 = inactive; 1 = active char ulaplus; // 0 = inactive; 1 = active
unsigned char ulaplus_reg; // contains the last selected register in the ULAPlus unsigned char ulaplus_reg; // contains the last selected register in the ULAPlus
unsigned char ulaplus_palete[64]; // contains the current palete unsigned char ulaplus_palete[64]; // contains the current palete
// keyboard private global variables // keyboard private global variables
unsigned char s8,s9,s10,s11,s12,s13,s14,s15; unsigned char s8,s9,s10,s11,s12,s13,s14,s15;
unsigned char k8,k9,k10,k11,k12,k13,k14,k15; unsigned char k8,k9,k10,k11,k12,k13,k14,k15;
unsigned char readed; unsigned char readed;
unsigned char tab_extended; unsigned char tab_extended;
unsigned char esc_again; unsigned char esc_again;
// kempston joystick private global variables // kempston joystick private global variables
unsigned char js,jk; unsigned char js,jk;
// Linux joystick private global variables // Linux joystick private global variables
unsigned char use_js; unsigned char use_js;
unsigned char updown,leftright; unsigned char updown,leftright;
// sound global variables // sound global variables
int tst_sample; // number of tstates per sample int tst_sample; // number of tstates per sample
int freq; // frequency for reproduction int freq; // frequency for reproduction
int format; // 0: 8 bits, 1: 16 bits LSB, 2: 16 bits MSB int format; // 0: 8 bits, 1: 16 bits LSB, 2: 16 bits MSB
signed char sign; // 0: unsigned; 1: signed signed char sign; // 0: unsigned; 1: signed
int channels; // number of channels int channels; // number of channels
int buffer_len; // sound buffer length (in samples) int buffer_len; // sound buffer length (in samples)
int increment; // cuantity to add to jump to the next sample int increment; // cuantity to add to jump to the next sample
unsigned char volume; // volume unsigned char volume; // volume
unsigned char sample1[4]; // buffer with precalculated sample 1 (for buzzer) unsigned char sample1[4]; // buffer with precalculated sample 1 (for buzzer)
unsigned char sample1b[4]; // buffer with prec. sample 1 (for AY-3-8912) unsigned char sample1b[4]; // buffer with prec. sample 1 (for AY-3-8912)
unsigned char sample0[4]; // buffer with precalculated sample 0 unsigned char sample0[4]; // buffer with precalculated sample 0
unsigned char sound_bit; unsigned char sound_bit;
unsigned int tstados_counter_sound; unsigned int tstados_counter_sound;
unsigned char *current_buffer; unsigned char *current_buffer;
unsigned char num_buff; unsigned char num_buff;
unsigned int sound_cuantity; // counter for the buffer unsigned int sound_cuantity; // counter for the buffer
unsigned char ay_registers[16]; // registers for the AY emulation unsigned char ay_registers[16]; // registers for the AY emulation
unsigned int aych_a,aych_b,aych_c,aych_n,aych_envel; // counters for AY emulation unsigned int aych_a,aych_b,aych_c,aych_n,aych_envel; // counters for AY emulation
unsigned char ayval_a,ayval_b,ayval_c,ayval_n; unsigned char ayval_a,ayval_b,ayval_c,ayval_n;
unsigned char ay_emul; // 0: no AY emulation; 1: AY emulation unsigned char ay_emul; // 0: no AY emulation; 1: AY emulation
unsigned char vol_a,vol_b,vol_c; unsigned char vol_a,vol_b,vol_c;
unsigned int tst_ay; unsigned int tst_ay;
unsigned int tst_ay2; unsigned int tst_ay2;
unsigned int ay_latch; unsigned int ay_latch;
signed char ay_envel_value; signed char ay_envel_value;
unsigned char ay_envel_way; unsigned char ay_envel_way;
unsigned char sound_current_value; unsigned char sound_current_value;
// bus global variables // bus global variables
unsigned char bus_counter; unsigned char bus_counter;
unsigned char bus_value; unsigned char bus_value;
unsigned char issue; // 2= 48K issue 2, 3= 48K issue 3 unsigned char issue; // 2= 48K issue 2, 3= 48K issue 3
unsigned char mode128k; // 0=48K, 1=128K, 2=+2, 3=+3 unsigned char mode128k; // 0=48K, 1=128K, 2=+2, 3=+3
unsigned char joystick; // 0=cursor, 1=kempston, 2=sinclair1, 3=sinclair2 unsigned char joystick; // 0=cursor, 1=kempston, 2=sinclair1, 3=sinclair2
unsigned char port254; unsigned char port254;
// tape global variables // tape global variables
enum tapmodes tape_current_mode; enum tapmodes tape_current_mode;
unsigned char pause; // 1=tape stop unsigned char pause; // 1=tape stop
enum taptypes tape_file_type; enum taptypes tape_file_type;
unsigned int tape_counter0; unsigned int tape_counter0;
unsigned int tape_counter1; unsigned int tape_counter1;
unsigned int tape_counter_rep; unsigned int tape_counter_rep;
unsigned char tape_byte; unsigned char tape_byte;
unsigned char tape_bit; unsigned char tape_bit;
unsigned char tape_readed; unsigned char tape_readed;
unsigned int tape_byte_counter; unsigned int tape_byte_counter;
unsigned int tape_pause_at_end; unsigned int tape_pause_at_end;
FILE *tap_file; FILE *tap_file;
unsigned char tape_fast_load; // 0 normal load; 1 fast load unsigned char tape_fast_load; // 0 normal load; 1 fast load
unsigned char current_tap[2049]; unsigned char current_tap[2049];
unsigned char tape_current_bit; unsigned char tape_current_bit;
unsigned int tape_block_level; unsigned int tape_block_level;
unsigned int tape_sync_level0; unsigned int tape_sync_level0;
unsigned int tape_sync_level1; unsigned int tape_sync_level1;
unsigned int tape_bit0_level; unsigned int tape_bit0_level;
unsigned int tape_bit1_level; unsigned int tape_bit1_level;
unsigned char tape_bits_at_end; unsigned char tape_bits_at_end;
unsigned int tape_loop_counter; unsigned int tape_loop_counter;
long tape_loop_pos; long tape_loop_pos;
unsigned char tape_write; // 0 can't write; 1 can write unsigned char tape_write; // 0 can't write; 1 can write
// Microdrive global variables // Microdrive global variables
FILE *mdr_file; // Current microdrive file FILE *mdr_file; // Current microdrive file
unsigned char mdr_current_mdr[2049]; // current path and name for microdrive file unsigned char mdr_current_mdr[2049]; // current path and name for microdrive file
unsigned char mdr_active; // 0: not installed; 1: installed unsigned char mdr_active; // 0: not installed; 1: installed
unsigned char mdr_paged; // 0: not pagined; 1: pagined unsigned char mdr_paged; // 0: not pagined; 1: pagined
unsigned int mdr_tapehead; // current position in the tape unsigned int mdr_tapehead; // current position in the tape
unsigned int mdr_bytes; // number of bytes read or written in this transfer unsigned int mdr_bytes; // number of bytes read or written in this transfer
unsigned int mdr_maxbytes; // maximum number of bytes to read or write in this transfer unsigned int mdr_maxbytes; // maximum number of bytes to read or write in this transfer
unsigned int mdr_gap; // TSTATEs remaining for GAP end unsigned int mdr_gap; // TSTATEs remaining for GAP end
unsigned int mdr_nogap; // TSTATEs remaining for next GAP unsigned int mdr_nogap; // TSTATEs remaining for next GAP
unsigned char mdr_cartridge[137923]; // current cartridge unsigned char mdr_cartridge[137923]; // current cartridge
unsigned char mdr_drive; // current drive unsigned char mdr_drive; // current drive
byte mdr_old_STATUS; // to detect an edge in COM CLK byte mdr_old_STATUS; // to detect an edge in COM CLK
unsigned char mdr_modified; // if a sector is stored, this change to know that it must be stored in the file unsigned char mdr_modified; // if a sector is stored, this change to know that it must be stored in the file
// OSD global variables // OSD global variables
unsigned char osd_text[200]; unsigned char osd_text[200];
unsigned int osd_time; unsigned int osd_time;
// pagination global variables // pagination global variables
unsigned char mport1,mport2; // ports for memory management (128K and +3) unsigned char mport1,mport2; // ports for memory management (128K and +3)
unsigned int video_offset; // 0 for page 5, and 32768 for page 7 unsigned int video_offset; // 0 for page 5, and 32768 for page 7
unsigned char *block0,*block1,*block2,*block3; // pointers for memory access (one for each 16K block). unsigned char *block0,*block1,*block2,*block3; // pointers for memory access (one for each 16K block).
// public // public
unsigned char memoria[196608]; // memory (12 pages of 16K each one). 4 for ROM, and 8 for RAM unsigned char memoria[196608]; // memory (12 pages of 16K each one). 4 for ROM, and 8 for RAM
unsigned char shadowrom[8192]; // space for Interface I's ROMs unsigned char shadowrom[8192]; // space for Interface I's ROMs
unsigned char interr; unsigned char interr;
unsigned char mustlock; unsigned char mustlock;
unsigned char other_ret; // 0=no change; 1=memory returns RET (201) unsigned char other_ret; // 0=no change; 1=memory returns RET (201)
unsigned char turbo; unsigned char turbo;
SDL_Event keyboard_buffer[10]; unsigned int kbd_buffer_pointer;
unsigned int kbd_buffer_pointer; unsigned char *key;
}; SDL_Joystick *joystick_sdl[2];
int joy_axis_x_state[2];
void computer_init(); int joy_axis_y_state[2];
void register_screen(SDL_Surface *); };
inline void show_screen(int);
inline void paint_pixels(unsigned char, unsigned char, unsigned char); void computer_init();
inline void read_keyboard(); void register_screen(SDL_Surface *);
void fill_audio(void *udata,Uint8 *,int); inline void show_screen(int);
void set_volume(unsigned char); inline void paint_pixels(unsigned char, unsigned char, unsigned char);
inline void play_sound(unsigned int); inline void read_keyboard();
inline void emulate(int); void fill_audio(void *udata,Uint8 *,int);
void ResetComputer(); void set_volume(unsigned char);
inline byte bus_empty(); inline void play_sound(unsigned int);
void set_memory_pointers(); inline void emulate(int);
inline void play_ay(); void ResetComputer();
inline void paint_one_pixel(unsigned char *colour,unsigned char *address); inline byte bus_empty();
void computer_set_palete(); void set_memory_pointers();
void set_palete_entry(unsigned char entry, byte Value); inline void play_ay();
inline void paint_one_pixel(unsigned char *colour,unsigned char *address);
#endif void computer_set_palete();
void set_palete_entry(unsigned char entry, byte Value);
#endif

View File

@ -219,7 +219,7 @@ void load_rom(char type) {
void init_screen(int resx,int resy,int depth,int fullscreen,int dblbuffer,int hwsurface) { void init_screen(int resx,int resy,int depth,int fullscreen,int dblbuffer,int hwsurface) {
int retorno,bucle,bucle2,valores,ret2; int retorno,bucle,bucle2,valores,ret2,joystick_number;
unsigned char value; unsigned char value;
//if (sound_type!=3) //if (sound_type!=3)
@ -239,8 +239,11 @@ void init_screen(int resx,int resy,int depth,int fullscreen,int dblbuffer,int hw
ordenador.use_js=1; ordenador.use_js=1;
if(SDL_NumJoysticks()>0){ if(SDL_NumJoysticks()>0){
// Open joystick // Open joystick
for (bucle=0;bucle<SDL_NumJoysticks();bucle++) { joystick_number = SDL_NumJoysticks();
if (NULL==SDL_JoystickOpen(bucle)) { if (joystick_number>2) joystick_number = 2; //Open max 2 joysticks
for (bucle=0;bucle<joystick_number;bucle++) {
ordenador.joystick_sdl [bucle] = SDL_JoystickOpen(bucle);
if (NULL==ordenador.joystick_sdl [bucle]) {
printf("Can't open joystick %d\n",bucle); printf("Can't open joystick %d\n",bucle);
} }
} }
@ -704,11 +707,11 @@ int main(int argc,char *argv[]) {
SDL_EventState(SDL_MOUSEMOTION,SDL_IGNORE); SDL_EventState(SDL_MOUSEMOTION,SDL_IGNORE);
SDL_EventState(SDL_MOUSEBUTTONDOWN,SDL_IGNORE); SDL_EventState(SDL_MOUSEBUTTONDOWN,SDL_IGNORE);
SDL_EventState(SDL_MOUSEBUTTONUP,SDL_IGNORE); SDL_EventState(SDL_MOUSEBUTTONUP,SDL_IGNORE);
SDL_EventState(SDL_JOYAXISMOTION,SDL_ENABLE); SDL_EventState(SDL_JOYAXISMOTION,SDL_IGNORE);
SDL_EventState(SDL_JOYBALLMOTION,SDL_ENABLE); SDL_EventState(SDL_JOYBALLMOTION,SDL_IGNORE);
SDL_EventState(SDL_JOYHATMOTION,SDL_ENABLE); SDL_EventState(SDL_JOYHATMOTION,SDL_IGNORE);
SDL_EventState(SDL_JOYBUTTONDOWN,SDL_ENABLE); SDL_EventState(SDL_JOYBUTTONDOWN,SDL_IGNORE);
SDL_EventState(SDL_JOYBUTTONUP,SDL_ENABLE); SDL_EventState(SDL_JOYBUTTONUP,SDL_IGNORE);
SDL_EventState(SDL_QUIT,SDL_ENABLE); SDL_EventState(SDL_QUIT,SDL_ENABLE);
SDL_EventState(SDL_SYSWMEVENT,SDL_IGNORE); SDL_EventState(SDL_SYSWMEVENT,SDL_IGNORE);
SDL_EventState(SDL_VIDEORESIZE,SDL_IGNORE); SDL_EventState(SDL_VIDEORESIZE,SDL_IGNORE);
@ -798,7 +801,7 @@ int main(int argc,char *argv[]) {
ordenador.mdr_paged = 2; ordenador.mdr_paged = 2;
if(ordenador.interr==1) { if(ordenador.interr==1) {
read_keyboard (NULL); // read the physical keyboard read_keyboard (); // read the physical keyboard
Z80free_INT(&procesador,bus_empty()); Z80free_INT(&procesador,bus_empty());
ordenador.interr=0; ordenador.interr=0;
} }

View File

@ -286,7 +286,7 @@ void settings_menu() {
ordenador.turbo = 0; ordenador.turbo = 0;
jump_frames=0; jump_frames=0;
} else { } else {
ordenador.tst_sample=12000000/ordenador.freq; //5,0 MHz max emulation speed for wii ordenador.tst_sample=12000000/ordenador.freq; //5,0 MHz max emulation speed for wii at full frames
ordenador.turbo = 1; ordenador.turbo = 1;
jump_frames=3; jump_frames=3;
} }
@ -308,7 +308,7 @@ void help_menu() {
clean_screen(); clean_screen();
print_string(fbuffer,"FBZX (2.7.0)",-1,20,15,0,ancho); print_string(fbuffer,"FBZX Wii (1.0)",-1,20,15,0,ancho);
print_string(fbuffer,"Available keys",-1,50,14,0,ancho); print_string(fbuffer,"Available keys",-1,50,14,0,ancho);
print_string(fbuffer,"Shift:Caps Shift Ctrl:Symbol Shift",-1,95,11,0,ancho); print_string(fbuffer,"Shift:Caps Shift Ctrl:Symbol Shift",-1,95,11,0,ancho);
@ -351,7 +351,7 @@ void help_menu() {
print_string(fbuffer,"ESC:",184,400,12,0,ancho); print_string(fbuffer,"ESC:",184,400,12,0,ancho);
print_string(fbuffer,"exit emulator",248,400,15,0,ancho); print_string(fbuffer,"exit emulator",248,400,15,0,ancho);
print_copy(fbuffer,ancho); //print_copy(fbuffer,ancho);
fin=1; fin=1;
do { do {
@ -484,7 +484,7 @@ void tools_menu() {
print_string(fbuffer,"ESC:",14,250,12,0,ancho); print_string(fbuffer,"ESC:",14,250,12,0,ancho);
print_string(fbuffer,"return emulator",78,250,15,0,ancho); print_string(fbuffer,"return emulator",78,250,15,0,ancho);
print_copy(fbuffer,ancho); //print_copy(fbuffer,ancho);
switch(wait_key()) { switch(wait_key()) {
case SDLK_ESCAPE: // to exit the help case SDLK_ESCAPE: // to exit the help
@ -539,7 +539,7 @@ void snapshots_menu() {
print_string(fbuffer,"ESC: \001\017return to emulator",-1,400,12,0,ancho); print_string(fbuffer,"ESC: \001\017return to emulator",-1,400,12,0,ancho);
print_copy(fbuffer,ancho); //print_copy(fbuffer,ancho);
fin=1; fin=1;
do { do {
@ -609,7 +609,7 @@ void taps_menu() {
print_string(fbuffer,"Current TAP/TZX file is:",-1,310,12,0,ancho); print_string(fbuffer,"Current TAP/TZX file is:",-1,310,12,0,ancho);
print_string(fbuffer,ordenador.current_tap,-1,330,12,0,ancho); print_string(fbuffer,ordenador.current_tap,-1,330,12,0,ancho);
print_copy(fbuffer,ancho); //print_copy(fbuffer,ancho);
if(ordenador.tape_fast_load) if(ordenador.tape_fast_load)
print_string(fbuffer,"Fast load enabled ",10,420,14,0,ancho); print_string(fbuffer,"Fast load enabled ",10,420,14,0,ancho);
@ -748,7 +748,7 @@ void create_tapfile() {
print_string(videomem,path_taps,0,152,12,0,ancho); print_string(videomem,path_taps,0,152,12,0,ancho);
retorno=ask_filename(nombre2,84,"tap",path_taps); retorno=ask_filename(nombre2,84,"tap",path_taps,NULL);
clean_screen(); clean_screen();
@ -821,7 +821,7 @@ void microdrive_menu() {
print_string(fbuffer,"Current MDR file is:",-1,300,12,0,ancho); print_string(fbuffer,"Current MDR file is:",-1,300,12,0,ancho);
print_string(fbuffer,ordenador.mdr_current_mdr,-1,320,12,0,ancho); print_string(fbuffer,ordenador.mdr_current_mdr,-1,320,12,0,ancho);
print_copy(fbuffer,ancho); //print_copy(fbuffer,ancho);
if(!ordenador.mdr_cartridge[137922]) if(!ordenador.mdr_cartridge[137922])
print_string(fbuffer,"Write enabled",-1,420,14,0,ancho); print_string(fbuffer,"Write enabled",-1,420,14,0,ancho);
@ -931,7 +931,7 @@ void create_mdrfile() {
print_string(videomem,"MDR file will be saved in:",-1,132,12,0,ancho); print_string(videomem,"MDR file will be saved in:",-1,132,12,0,ancho);
print_string(videomem,path_mdrs,0,152,12,0,ancho); print_string(videomem,path_mdrs,0,152,12,0,ancho);
retorno=ask_filename(nombre2,84,"mdr",path_mdrs); retorno=ask_filename(nombre2,84,"mdr",path_mdrs, NULL);
clean_screen(); clean_screen();
@ -984,6 +984,7 @@ void create_scrfile() {
int ancho,retorno,retval; int ancho,retorno,retval;
unsigned char nombre2[1024]; unsigned char nombre2[1024];
FILE *fichero; FILE *fichero;
char *name;
videomem=screen->pixels; videomem=screen->pixels;
ancho=screen->w; ancho=screen->w;
@ -996,7 +997,15 @@ void create_scrfile() {
print_string(videomem,"SCR file will be saved in:",-1,132,12,0,ancho); print_string(videomem,"SCR file will be saved in:",-1,132,12,0,ancho);
print_string(videomem,path_snaps,0,152,12,0,ancho); print_string(videomem,path_snaps,0,152,12,0,ancho);
retorno=ask_filename(nombre2,84,"scr",path_snaps); if (strlen(ordenador.current_tap))
{
name=strrchr(ordenador.current_tap,'/');
if (name) name++; else name = ordenador.current_tap;
}
else
name=NULL;
retorno=ask_filename(nombre2,84,"scr",path_snaps, name);
clean_screen(); clean_screen();
@ -1041,10 +1050,11 @@ void create_scrfile() {
} }
int ask_filename(char *nombre_final,int y_coord,char *extension, char *path) { int ask_filename(char *nombre_final,int y_coord,char *extension, char *path, char *name) {
int longitud,retorno; int longitud,retorno;
unsigned char nombre[37],nombre2[38]; unsigned char nombre[37],nombre2[38];
char *ptr;
unsigned char *videomem; unsigned char *videomem;
int ancho; int ancho;
@ -1052,10 +1062,29 @@ int ask_filename(char *nombre_final,int y_coord,char *extension, char *path) {
videomem=screen->pixels; videomem=screen->pixels;
ancho=screen->w; ancho=screen->w;
nombre[0]=127;
nombre[1]=0;
longitud=0;
retorno=0; retorno=0;
if (!name||(strlen(name)>36))
{
nombre[0]=127;
nombre[1]=0;
}
else
{
strcpy(nombre,name);
ptr = strrchr (nombre, '.');
if (ptr) //remove the extension
{
*ptr = 127;
*(ptr+1) = 0;
}
else
nombre[strlen(nombre)-1]=127;
nombre[strlen(nombre)]=0;
}
longitud=strlen(nombre)-1;
do { do {
sprintf (nombre2, " %s.%s ", nombre,extension); sprintf (nombre2, " %s.%s ", nombre,extension);
@ -1452,6 +1481,7 @@ void save_z80file() {
unsigned char *videomem; unsigned char *videomem;
int ancho,retorno; int ancho,retorno;
unsigned char nombre2[1024]; unsigned char nombre2[1024];
char *name;
videomem=screen->pixels; videomem=screen->pixels;
ancho=screen->w; ancho=screen->w;
@ -1464,8 +1494,15 @@ void save_z80file() {
print_string(videomem,"Snapshot will be saved in:",-1,132,12,0,ancho); print_string(videomem,"Snapshot will be saved in:",-1,132,12,0,ancho);
print_string(videomem,path_snaps,0,152,12,0,ancho); print_string(videomem,path_snaps,0,152,12,0,ancho);
if (strlen(ordenador.current_tap))
retorno=ask_filename(nombre2,84,"z80", path_snaps); {
name=strrchr(ordenador.current_tap,'/');
if (name) name++; else name = ordenador.current_tap;
}
else
name=NULL;
retorno=ask_filename(nombre2,84,"z80", path_snaps, name);
clean_screen(); clean_screen();
@ -1845,7 +1882,7 @@ void keyboard_menu() {
buffer=buffer2-ordenador.bpp; buffer=buffer2-ordenador.bpp;
} }
} }
print_copy(screen->pixels,screen->w); //print_copy(screen->pixels,screen->w);
wait_key(); wait_key();
clean_screen(); clean_screen();
} }

View File

@ -45,7 +45,7 @@ void create_mdrfile();
void microdrive_menu(); void microdrive_menu();
void keyboard_menu(); void keyboard_menu();
void load_scrfile(); void load_scrfile();
int ask_filename(char *nombre,int y_coord,char *extension, char *path); int ask_filename(char *nombre,int y_coord,char *extension, char *path, char *name);
void create_scrfile(); void create_scrfile();
void do_poke(); void do_poke();
int ask_value(int *final_value,int y_coord,int max_value); int ask_value(int *final_value,int y_coord,int max_value);