1
0
Fork 0
forked from Miroirs/x49gp

make --newrpl-keyboard a distinct option; make --text-scale steps finer (defaults at 2)

This commit is contained in:
Gwenhael Le Moine 2024-11-10 22:10:45 +01:00
parent 62458e2b11
commit ed48563f14
No known key found for this signature in database
GPG key ID: FDFE3669426707A7
4 changed files with 35 additions and 62 deletions

View file

@ -442,11 +442,8 @@ static int flash_load( x49gp_module_t* module, GKeyFile* key )
if ( x49gp->startup_reinit == X49GP_REINIT_FLASH_FULL ) if ( x49gp->startup_reinit == X49GP_REINIT_FLASH_FULL )
memset( phys_ram_base + flash->offset, 0xff, flash->size - st.st_size ); memset( phys_ram_base + flash->offset, 0xff, flash->size - st.st_size );
bootfd = x49gp_module_open_rodata( module, bootfd = x49gp_module_open_rodata(
ui->calculator == UI_CALCULATOR_HP49GP || ui->calculator == UI_CALCULATOR_HP49GP_NEWRPL module, ui->calculator == UI_CALCULATOR_HP49GP ? "firmware/boot-49g+.bin" : "firmware/boot-50g.bin", &bootfile );
? "firmware/boot-49g+.bin"
: "firmware/boot-50g.bin",
&bootfile );
if ( bootfd < 0 ) { if ( bootfd < 0 ) {
g_free( filename ); g_free( filename );

View file

@ -20,8 +20,9 @@ struct options opt = {
.reinit = X49GP_REINIT_NONE, .reinit = X49GP_REINIT_NONE,
.firmware = NULL, .firmware = NULL,
.model = MODEL_50G, .model = MODEL_50G,
.newrpl = false,
.name = NULL, .name = NULL,
.text_scale = 1, .text_scale = 2,
.display_scale = 2, .display_scale = 2,
#if defined( __linux__ ) #if defined( __linux__ )
.font = "urw gothic l", .font = "urw gothic l",
@ -94,24 +95,22 @@ static void print_config( void )
fprintf( stdout, "-- Configuration file for x49gpng\n" ); fprintf( stdout, "-- Configuration file for x49gpng\n" );
fprintf( stdout, "-- This is a comment\n" ); fprintf( stdout, "-- This is a comment\n" );
fprintf( stdout, "name = \"%s\"\n", opt.name ); fprintf( stdout, "name = \"%s\"", opt.name );
fprintf( stdout, " -- this customize the title of the window\n" );
fprintf( stdout, "model = \"" ); fprintf( stdout, "model = \"" );
switch ( opt.model ) { switch ( opt.model ) {
case MODEL_49GP: case MODEL_49GP:
fprintf( stdout, "49gp" ); fprintf( stdout, "49gp" );
break; break;
case MODEL_49GP_NEWRPL: default:
fprintf( stdout, "49gp-newrpl" );
break;
case MODEL_50G: case MODEL_50G:
fprintf( stdout, "50g" ); fprintf( stdout, "50g" );
break; break;
case MODEL_50G_NEWRPL:
fprintf( stdout, "50g-newrpl" );
break;
} }
fprintf( stdout, "\" -- possible values: \"49gp\", \"50g\", \"49gp-newrpl\", \"50g-newrpl\"\n" ); fprintf( stdout, "\" -- possible values: \"49gp\", \"50g\". Changes the colors and the bootloader looked for when (re-)flashing\n" );
fprintf( stdout, "newrpl_keyboard = %s", opt.newrpl ? "true" : "false" );
fprintf( stdout, " -- when true this makes the keyboard labels more suited to newRPL use\n" );
fprintf( stdout, "font = \"%s\"\n", opt.font ); fprintf( stdout, "font = \"%s\"\n", opt.font );
fprintf( stdout, "text_scale = %i\n", opt.text_scale ); fprintf( stdout, "text_scale = %i\n", opt.text_scale );
fprintf( stdout, "display_scale = %i\n", opt.display_scale ); fprintf( stdout, "display_scale = %i\n", opt.display_scale );
@ -134,6 +133,7 @@ void config_init( char* progname, int argc, char* argv[] )
char* clopt_name = NULL; char* clopt_name = NULL;
char* clopt_font = NULL; char* clopt_font = NULL;
int clopt_model = -1; int clopt_model = -1;
int clopt_newrpl = -1;
int clopt_text_scale = -1; int clopt_text_scale = -1;
int clopt_display_scale = -1; int clopt_display_scale = -1;
@ -155,9 +155,8 @@ void config_init( char* progname, int argc, char* argv[] )
{"reboot", no_argument, NULL, 'r' }, {"reboot", no_argument, NULL, 'r' },
{"50g", no_argument, NULL, 506 }, {"50g", no_argument, NULL, 506 },
{"50g-newrpl", no_argument, NULL, 507 },
{"49gp", no_argument, NULL, 496 }, {"49gp", no_argument, NULL, 496 },
{"49gp-newrpl", no_argument, NULL, 497 }, {"newrpl-keyboard", no_argument, &clopt_newrpl, true},
{"name", required_argument, NULL, 'n' }, {"name", required_argument, NULL, 'n' },
{"text-scale", required_argument, NULL, 's' }, {"text-scale", required_argument, NULL, 's' },
{"display-scale", required_argument, NULL, 'S' }, {"display-scale", required_argument, NULL, 'S' },
@ -178,13 +177,12 @@ void config_init( char* progname, int argc, char* argv[] )
"Valid options:\n" "Valid options:\n"
" -h --help print this message and exit\n" " -h --help print this message and exit\n"
" --state[=<filename>] alternate config file\n" " --state[=<filename>] alternate config file\n"
" --50g show HP 50g faceplate (default)\n" " --50g emulate an HP 50g (default)\n"
" --50g-newrpl show HP 50g faceplate with newRPL labels\n" " --49gp emulate an HP 49g+\n"
" --49gp show HP 49g+ faceplate\n" " --newrpl-keyboard label keyboard for newRPL\n"
" --49gp-newrpl show HP 49g+ faceplate with newRPL labels\n"
" -n --name[=<name>] set alternate UI name\n" " -n --name[=<name>] set alternate UI name\n"
" -t --font[=<fontname>] set alternate UI font\n" " -t --font[=<fontname>] set alternate UI font\n"
" -s --text-scale[=<X>] scale text by X (default: 1)\n" " -s --text-scale[=<X>] scale text by X (default: 2)\n"
" -S --display-scale[=<X>] scale LCD by X (default: 2)\n" " -S --display-scale[=<X>] scale LCD by X (default: 2)\n"
" -D --enable-debug[=<port>] enable the debugger interface\n" " -D --enable-debug[=<port>] enable the debugger interface\n"
" (default port: %u)\n" " (default port: %u)\n"
@ -228,21 +226,11 @@ void config_init( char* progname, int argc, char* argv[] )
if ( clopt_name == NULL ) if ( clopt_name == NULL )
clopt_name = "HP 49g+"; clopt_name = "HP 49g+";
break; break;
case 497:
clopt_model = MODEL_49GP_NEWRPL;
if ( clopt_name == NULL )
clopt_name = "HP 49g+ / newRPL";
break;
case 506: case 506:
clopt_model = MODEL_50G; clopt_model = MODEL_50G;
if ( clopt_name == NULL ) if ( clopt_name == NULL )
clopt_name = "HP 50g"; clopt_name = "HP 50g";
break; break;
case 507:
clopt_model = MODEL_50G_NEWRPL;
if ( clopt_name == NULL )
clopt_name = "HP 50g / newRPL";
break;
case 'n': case 'n':
clopt_name = strdup( optarg ); clopt_name = strdup( optarg );
break; break;
@ -271,31 +259,24 @@ void config_init( char* progname, int argc, char* argv[] )
/**********************/ /**********************/
bool haz_config_file = config_read( opt.config_lua_filename ); bool haz_config_file = config_read( opt.config_lua_filename );
if ( haz_config_file ) { if ( haz_config_file ) {
lua_getglobal( config_lua_values, "newrpl_keyboard" );
opt.newrpl = lua_toboolean( config_lua_values, -1 );
lua_getglobal( config_lua_values, "model" ); lua_getglobal( config_lua_values, "model" );
const char* svalue_model = luaL_optstring( config_lua_values, -1, "50g" ); const char* svalue_model = luaL_optstring( config_lua_values, -1, "50g" );
if ( svalue_model != NULL ) { if ( svalue_model != NULL ) {
if ( strcmp( svalue_model, "50g" ) == 0 ) if ( strcmp( svalue_model, "50g" ) == 0 )
opt.model = MODEL_50G; opt.model = MODEL_50G;
if ( strcmp( svalue_model, "50g-newrpl" ) == 0 )
opt.model = MODEL_50G_NEWRPL;
if ( strcmp( svalue_model, "49gp" ) == 0 ) if ( strcmp( svalue_model, "49gp" ) == 0 )
opt.model = MODEL_49GP; opt.model = MODEL_49GP;
if ( strcmp( svalue_model, "49gp-newrpl" ) == 0 )
opt.model = MODEL_49GP_NEWRPL;
switch ( opt.model ) { switch ( opt.model ) {
case MODEL_50G_NEWRPL:
opt.name = "HP 50g / newRPL";
break;
case MODEL_49GP: case MODEL_49GP:
opt.name = "HP 49g+"; opt.name = opt.newrpl ? "HP 49g+ / newRPL" : "HP 49g+";
break;
case MODEL_49GP_NEWRPL:
opt.name = "HP 49g+ / newRPL";
break; break;
case MODEL_50G: case MODEL_50G:
default: default:
opt.name = "HP 50g"; opt.name = opt.newrpl ? "HP 50g / newRPL" : "HP 50g";
break; break;
} }
} }
@ -322,6 +303,8 @@ void config_init( char* progname, int argc, char* argv[] )
opt.font = strdup( clopt_font ); opt.font = strdup( clopt_font );
if ( clopt_model != -1 ) if ( clopt_model != -1 )
opt.model = clopt_model; opt.model = clopt_model;
if ( clopt_newrpl != -1 )
opt.newrpl = clopt_newrpl;
if ( clopt_text_scale != -1 ) if ( clopt_text_scale != -1 )
opt.text_scale = clopt_text_scale; opt.text_scale = clopt_text_scale;
if ( clopt_display_scale != -1 ) if ( clopt_display_scale != -1 )

View file

@ -13,7 +13,7 @@
# define PATCHLEVEL 0 # define PATCHLEVEL 0
#endif #endif
typedef enum { MODEL_49GP = 0, MODEL_49GP_NEWRPL, MODEL_50G, MODEL_50G_NEWRPL } x49gpng_model_t; typedef enum { MODEL_49GP = 0, MODEL_50G } x49gpng_model_t;
struct options { struct options {
char* state_filename; char* state_filename;
@ -23,6 +23,7 @@ struct options {
x49gp_reinit_t reinit; x49gp_reinit_t reinit;
x49gpng_model_t model; x49gpng_model_t model;
bool newrpl;
char* name; char* name;
char* font; char* font;

View file

@ -24,10 +24,10 @@
#define NB_KEYS 51 #define NB_KEYS 51
#define FONT_SIZE_SYMBOL ( 28 * opt.text_scale ) #define FONT_SIZE_SYMBOL ( 14 * opt.text_scale )
#define FONT_SIZE_NUMBER ( 20 * opt.text_scale ) #define FONT_SIZE_NUMBER ( 10 * opt.text_scale )
#define FONT_SIZE_KEY ( 12 * opt.text_scale ) #define FONT_SIZE_KEY ( 7 * opt.text_scale )
#define FONT_SIZE_TINY ( 10 * opt.text_scale ) #define FONT_SIZE_TINY ( 6 * opt.text_scale )
#define TINY_TEXT_HEIGHT ( FONT_SIZE_TINY + 2 ) #define TINY_TEXT_HEIGHT ( FONT_SIZE_TINY + 2 )
#define TINY_TEXT_WIDTH ( TINY_TEXT_HEIGHT / 2 ) #define TINY_TEXT_WIDTH ( TINY_TEXT_HEIGHT / 2 )
@ -39,9 +39,9 @@
#define KB_WIDTH_6_KEYS ( 36 * opt.text_scale ) #define KB_WIDTH_6_KEYS ( 36 * opt.text_scale )
#define KB_WIDTH_5_KEYS ( 46 * opt.text_scale ) #define KB_WIDTH_5_KEYS ( 46 * opt.text_scale )
#define KB_HEIGHT_MENU_KEYS ( 22 * opt.text_scale ) #define KB_HEIGHT_MENU_KEYS ( 11 * opt.text_scale )
#define KB_HEIGHT_SMALL_KEYS ( 28 * opt.text_scale ) #define KB_HEIGHT_SMALL_KEYS ( 14 * opt.text_scale )
#define KB_HEIGHT_BIG_KEYS ( 32 * opt.text_scale ) #define KB_HEIGHT_BIG_KEYS ( 16 * opt.text_scale )
#define KB_LINE_HEIGHT ( KB_HEIGHT_BIG_KEYS + ( 1.5 * ( TINY_TEXT_HEIGHT + 2 ) ) ) #define KB_LINE_HEIGHT ( KB_HEIGHT_BIG_KEYS + ( 1.5 * ( TINY_TEXT_HEIGHT + 2 ) ) )
#define KB_SPACING_KEYS TINY_TEXT_WIDTH #define KB_SPACING_KEYS TINY_TEXT_WIDTH
@ -1439,18 +1439,10 @@ static int ui_load( x49gp_module_t* module, GKeyFile* keyfile )
/* set calculator type and name */ /* set calculator type and name */
switch ( opt.model ) { switch ( opt.model ) {
case MODEL_50G_NEWRPL:
ui->calculator = UI_CALCULATOR_HP50G_NEWRPL;
ui->name = opt.name != NULL ? opt.name : "HP 50g / newRPL";
break;
case MODEL_49GP: case MODEL_49GP:
ui->calculator = UI_CALCULATOR_HP49GP; ui->calculator = UI_CALCULATOR_HP49GP;
ui->name = opt.name != NULL ? opt.name : "HP 49g+"; ui->name = opt.name != NULL ? opt.name : "HP 49g+";
break; break;
case MODEL_49GP_NEWRPL:
ui->calculator = UI_CALCULATOR_HP49GP_NEWRPL;
ui->name = opt.name != NULL ? opt.name : "HP 49g+ / newRPL";
break;
case MODEL_50G: case MODEL_50G:
default: default:
ui->calculator = UI_CALCULATOR_HP50G; ui->calculator = UI_CALCULATOR_HP50G;
@ -1529,7 +1521,7 @@ static int ui_load( x49gp_module_t* module, GKeyFile* keyfile )
x49gp_ui_button_t* button; x49gp_ui_button_t* button;
if ( ui->calculator == UI_CALCULATOR_HP49GP_NEWRPL || ui->calculator == UI_CALCULATOR_HP50G_NEWRPL ) if ( opt.newrpl )
_ui_load__newrplify_ui_keys(); _ui_load__newrplify_ui_keys();
GtkWidget* rows_containers[ KB_NB_ROWS ]; GtkWidget* rows_containers[ KB_NB_ROWS ];
@ -1635,7 +1627,7 @@ static int ui_load( x49gp_module_t* module, GKeyFile* keyfile )
char* color_bg_50g = "#272727"; char* color_bg_50g = "#272727";
char* color_shift_left_49gp = "#4060a4"; char* color_shift_left_49gp = "#4060a4";
char* color_shift_left_50g = "#f5f5f5"; char* color_shift_left_50g = "#f5f5f5";
bool is_50g = ( ui->calculator == UI_CALCULATOR_HP50G || ui->calculator == UI_CALCULATOR_HP50G_NEWRPL ); bool is_50g = ( ui->calculator == UI_CALCULATOR_HP50G );
char* css; char* css;
asprintf( &css, css_global, is_50g ? color_bg_50g : color_bg_49gp, is_50g ? color_shift_left_50g : color_shift_left_49gp, asprintf( &css, css_global, is_50g ? color_bg_50g : color_bg_49gp, is_50g ? color_shift_left_50g : color_shift_left_49gp,