forked from Miroirs/x49gp
Compare commits
3 commits
58287d660a
...
fffd39029c
Author | SHA1 | Date | |
---|---|---|---|
|
fffd39029c | ||
|
3e3a7a5caa | ||
|
0041e7546c |
5 changed files with 112 additions and 108 deletions
10
src/list.h
10
src/list.h
|
@ -97,8 +97,8 @@ static inline void __list_del( struct list_head* prev, struct list_head* next )
|
|||
static inline void list_del( struct list_head* entry )
|
||||
{
|
||||
__list_del( entry->prev, entry->next );
|
||||
entry->next = LIST_POISON1;
|
||||
entry->prev = LIST_POISON2;
|
||||
entry->next = (struct list_head*)LIST_POISON1;
|
||||
entry->prev = (struct list_head*)LIST_POISON2;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -391,8 +391,8 @@ static inline void __hlist_del( struct hlist_node* n )
|
|||
static inline void hlist_del( struct hlist_node* n )
|
||||
{
|
||||
__hlist_del( n );
|
||||
n->next = LIST_POISON1;
|
||||
n->pprev = LIST_POISON2;
|
||||
n->next = (struct hlist_node*)LIST_POISON1;
|
||||
n->pprev = (struct hlist_node**)LIST_POISON2;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -417,7 +417,7 @@ static inline void hlist_del( struct hlist_node* n )
|
|||
static inline void hlist_del_rcu( struct hlist_node* n )
|
||||
{
|
||||
__hlist_del( n );
|
||||
n->pprev = LIST_POISON2;
|
||||
n->pprev = (struct hlist_node**)LIST_POISON2;
|
||||
}
|
||||
|
||||
static inline void hlist_del_init( struct hlist_node* n )
|
||||
|
|
18
src/module.c
18
src/module.c
|
@ -9,6 +9,7 @@
|
|||
#include <sys/mman.h>
|
||||
#include <errno.h>
|
||||
|
||||
#include "list.h"
|
||||
#include "x49gp.h"
|
||||
|
||||
int x49gp_modules_init( x49gp_t* x49gp )
|
||||
|
@ -25,9 +26,8 @@ int x49gp_modules_init( x49gp_t* x49gp )
|
|||
list_for_each_entry( module, &x49gp->modules, list )
|
||||
{
|
||||
error = module->init( module );
|
||||
if ( error ) {
|
||||
if ( error )
|
||||
return error;
|
||||
}
|
||||
}
|
||||
|
||||
phys_ram_base = mmap( 0, phys_ram_size, PROT_NONE, MAP_SHARED | MAP_ANON, -1, 0 );
|
||||
|
@ -61,9 +61,8 @@ int x49gp_modules_exit( x49gp_t* x49gp )
|
|||
list_for_each_entry_safe_reverse( module, next, &x49gp->modules, list )
|
||||
{
|
||||
error = module->exit( module );
|
||||
if ( error ) {
|
||||
if ( error )
|
||||
return error;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
|
@ -81,9 +80,8 @@ int x49gp_modules_reset( x49gp_t* x49gp, x49gp_reset_t reset )
|
|||
list_for_each_entry( module, &x49gp->modules, list )
|
||||
{
|
||||
error = module->reset( module, reset );
|
||||
if ( error ) {
|
||||
if ( error )
|
||||
return error;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
|
@ -124,11 +122,10 @@ int x49gp_modules_load( x49gp_t* x49gp, const char* filename )
|
|||
{
|
||||
error = module->load( module, x49gp->config );
|
||||
if ( error ) {
|
||||
if ( error == -EAGAIN ) {
|
||||
if ( error == -EAGAIN )
|
||||
result = -EAGAIN;
|
||||
} else {
|
||||
else
|
||||
return error;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -161,9 +158,8 @@ int x49gp_modules_save( x49gp_t* x49gp, const char* filename )
|
|||
list_for_each_entry( module, &x49gp->modules, list )
|
||||
{
|
||||
error = module->save( module, x49gp->config );
|
||||
if ( error ) {
|
||||
if ( error )
|
||||
return error;
|
||||
}
|
||||
}
|
||||
|
||||
data = g_key_file_to_data( x49gp->config, &length, &gerror );
|
||||
|
|
|
@ -318,11 +318,11 @@ void x49gp_lcd_update( x49gp_t* x49gp )
|
|||
|
||||
GdkGC* gc = gdk_gc_new( gtk_widget_get_window( ui->lcd_canvas ) );
|
||||
|
||||
for ( int y = 0; y < ( ui->lcd_height - ui->lcd_top_margin ) / LCD_PIXEL_SCALE; y++ ) {
|
||||
for ( int y = 0; y < ( ui->lcd_height - ui->lcd_annunciators_height ) / LCD_PIXEL_SCALE; y++ ) {
|
||||
for ( int x = 0; x < ui->lcd_width / LCD_PIXEL_SCALE; x++ ) {
|
||||
color = x49gp_get_pixel_color( lcd, x, y );
|
||||
gdk_gc_set_rgb_fg_color( gc, &( ui->colors[ UI_COLOR_GRAYSCALE_0 + color ] ) );
|
||||
gdk_draw_rectangle( ui->lcd_pixmap, gc, true, LCD_PIXEL_SCALE * x, LCD_PIXEL_SCALE * y + ui->lcd_top_margin,
|
||||
gdk_draw_rectangle( ui->lcd_pixmap, gc, true, LCD_PIXEL_SCALE * x, LCD_PIXEL_SCALE * y + ui->lcd_annunciators_height,
|
||||
LCD_PIXEL_SCALE, LCD_PIXEL_SCALE );
|
||||
}
|
||||
}
|
||||
|
|
186
src/ui.c
186
src/ui.c
|
@ -3223,82 +3223,8 @@ static int gui_load( x49gp_module_t* module, GKeyFile* keyfile )
|
|||
{
|
||||
x49gp_t* x49gp = module->x49gp;
|
||||
x49gp_ui_t* ui = module->user_data;
|
||||
x49gp_ui_button_t* button;
|
||||
const x49gp_ui_key_t* key;
|
||||
GtkWidget* screen_box;
|
||||
GtkWidget *menu_mount_folder, *menu_mount_image, *menu_unmount;
|
||||
GtkWidget *menu_debug, *menu_reset, *menu_quit;
|
||||
GdkBitmap* shape;
|
||||
|
||||
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:
|
||||
ui->calculator = UI_CALCULATOR_HP49GP;
|
||||
ui->name = opt.name != NULL ? opt.name : "HP 49g+";
|
||||
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:
|
||||
default:
|
||||
ui->calculator = UI_CALCULATOR_HP50G;
|
||||
ui->name = opt.name != NULL ? opt.name : "HP 50g";
|
||||
break;
|
||||
}
|
||||
|
||||
/* Load faceplate base texture into imagefile */
|
||||
GError* gerror = NULL;
|
||||
char* imagefile;
|
||||
int fd = x49gp_module_open_rodata( module,
|
||||
ui->calculator == UI_CALCULATOR_HP49GP || ui->calculator == UI_CALCULATOR_HP49GP_NEWRPL
|
||||
? "hp49g+-cropped.png"
|
||||
: "hp50g-cropped.png",
|
||||
&imagefile );
|
||||
if ( fd < 0 )
|
||||
return fd;
|
||||
|
||||
ui->bg_pixbuf = gdk_pixbuf_new_from_file( imagefile, &gerror );
|
||||
/* ui->bg_pixbuf = gdk_pixbuf_new_from_file_at_scale( imagefile, 302, 727, true, &gerror ); */
|
||||
|
||||
/* set ui->width and ui->height based on imagefile dimensions */
|
||||
gdk_pixbuf_get_file_info( imagefile, &ui->width, &ui->height );
|
||||
close( fd );
|
||||
|
||||
ui->lcd_width = 131 * LCD_PIXEL_SCALE;
|
||||
ui->lcd_top_margin = 16;
|
||||
ui->lcd_height = 80 * LCD_PIXEL_SCALE + ui->lcd_top_margin;
|
||||
|
||||
ui->lcd_x_offset = ( ui->width - ui->lcd_width ) / 2;
|
||||
ui->lcd_y_offset = 48; // 69;
|
||||
|
||||
ui->kb_x_offset = 10; // 36;
|
||||
ui->kb_y_offset = 280; // 301;
|
||||
|
||||
ui->window = gtk_window_new( GTK_WINDOW_TOPLEVEL );
|
||||
gtk_widget_set( ui->window, "can-focus", true, NULL );
|
||||
gtk_widget_set( ui->window, "accept-focus", true, NULL );
|
||||
gtk_widget_set( ui->window, "focus-on-map", true, NULL );
|
||||
gtk_widget_set( ui->window, "resizable", false, NULL );
|
||||
gtk_window_set_decorated( GTK_WINDOW( ui->window ), true );
|
||||
|
||||
gtk_widget_set_name( ui->window, ui->name );
|
||||
gtk_window_set_title( GTK_WINDOW( ui->window ), ui->name );
|
||||
|
||||
// gtk_window_set_icon(GTK_WINDOW(ui->window), ui->bg_pixbuf);
|
||||
|
||||
gdk_pixbuf_render_pixmap_and_mask( ui->bg_pixbuf, NULL, &shape, 255 );
|
||||
|
||||
gtk_widget_set_size_request( ui->window, ui->width, ui->height );
|
||||
gtk_widget_shape_combine_mask( ui->window, shape, 0, 0 );
|
||||
|
||||
g_object_unref( shape );
|
||||
|
||||
gtk_widget_realize( ui->window );
|
||||
|
||||
/* create all buttons' shapes */
|
||||
ui->shapes[ UI_SHAPE_BUTTON_TINY ] =
|
||||
gdk_bitmap_create_from_data( NULL, ( char* )button_tiny_bits, button_tiny_width, button_tiny_height );
|
||||
ui->shapes[ UI_SHAPE_BUTTON_SMALL ] =
|
||||
|
@ -3310,13 +3236,7 @@ static int gui_load( x49gp_module_t* module, GKeyFile* keyfile )
|
|||
ui->shapes[ UI_SHAPE_BUTTON_ROUND ] =
|
||||
gdk_bitmap_create_from_data( NULL, ( char* )button_round_bits, button_round_width, button_round_height );
|
||||
|
||||
ui->fixed = gtk_fixed_new();
|
||||
gtk_container_add( GTK_CONTAINER( ui->window ), ui->fixed );
|
||||
|
||||
ui->background = gtk_drawing_area_new();
|
||||
gtk_drawing_area_size( GTK_DRAWING_AREA( ui->background ), ui->width, ui->height );
|
||||
x49gp_ui_place_at( x49gp, GTK_FIXED( ui->fixed ), ui->background, 0, 0, ui->width, ui->height );
|
||||
|
||||
/* create all colors */
|
||||
x49gp_ui_color_init( &ui->colors[ UI_COLOR_BLACK ], 0x00, 0x00, 0x00 ); /* #000000 */
|
||||
x49gp_ui_color_init( &ui->colors[ UI_COLOR_WHITE ], 0xff, 0xff, 0xff ); /* #ffffff */
|
||||
x49gp_ui_color_init( &ui->colors[ UI_COLOR_YELLOW ], 0xfa, 0xe8, 0x2c ); /* #fae82c */
|
||||
|
@ -3343,14 +3263,95 @@ static int gui_load( x49gp_module_t* module, GKeyFile* keyfile )
|
|||
x49gp_ui_color_init( &ui->colors[ UI_COLOR_GRAYSCALE_14 ], 0x0b, 0x03, 0x0c ); /* #0b030c */
|
||||
x49gp_ui_color_init( &ui->colors[ UI_COLOR_GRAYSCALE_15 ], 0x00, 0x00, 0x00 ); /* #000000 */
|
||||
|
||||
/* set calculator type and name */
|
||||
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:
|
||||
ui->calculator = UI_CALCULATOR_HP49GP;
|
||||
ui->name = opt.name != NULL ? opt.name : "HP 49g+";
|
||||
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:
|
||||
default:
|
||||
ui->calculator = UI_CALCULATOR_HP50G;
|
||||
ui->name = opt.name != NULL ? opt.name : "HP 50g";
|
||||
break;
|
||||
}
|
||||
|
||||
/* Load faceplate base texture into imagefile */
|
||||
GError* gerror = NULL;
|
||||
char* imagefile;
|
||||
int fd = x49gp_module_open_rodata( module,
|
||||
ui->calculator == UI_CALCULATOR_HP49GP || ui->calculator == UI_CALCULATOR_HP49GP_NEWRPL
|
||||
? "hp49g+-cropped.png"
|
||||
: "hp50g-cropped.png",
|
||||
&imagefile );
|
||||
if ( fd < 0 )
|
||||
return fd;
|
||||
|
||||
ui->bg_pixbuf = gdk_pixbuf_new_from_file( imagefile, &gerror );
|
||||
/* ui->bg_pixbuf = gdk_pixbuf_new_from_file_at_scale( imagefile, 302, 727, true, &gerror ); */
|
||||
|
||||
/* set ui->width and ui->height based on imagefile dimensions */
|
||||
gdk_pixbuf_get_file_info( imagefile, &ui->width, &ui->height );
|
||||
close( fd );
|
||||
|
||||
/* set coordinates of LCD and keyboard */
|
||||
ui->lcd_width = 131 * LCD_PIXEL_SCALE;
|
||||
ui->lcd_annunciators_height = 16;
|
||||
ui->lcd_height = ( 80 * LCD_PIXEL_SCALE ) + ui->lcd_annunciators_height;
|
||||
ui->lcd_x_offset = ( ui->width - ui->lcd_width ) / 2;
|
||||
ui->lcd_y_offset = 48; // 69;
|
||||
|
||||
ui->kb_x_offset = 10; // 36;
|
||||
ui->kb_y_offset = 280; // 301;
|
||||
|
||||
ui->window = gtk_window_new( GTK_WINDOW_TOPLEVEL );
|
||||
gtk_widget_set( ui->window, "can-focus", true, NULL );
|
||||
gtk_widget_set( ui->window, "accept-focus", true, NULL );
|
||||
gtk_widget_set( ui->window, "focus-on-map", true, NULL );
|
||||
gtk_widget_set( ui->window, "resizable", false, NULL );
|
||||
gtk_window_set_decorated( GTK_WINDOW( ui->window ), true );
|
||||
|
||||
gtk_widget_set_name( ui->window, ui->name );
|
||||
gtk_window_set_title( GTK_WINDOW( ui->window ), ui->name );
|
||||
|
||||
// gtk_window_set_icon(GTK_WINDOW(ui->window), ui->bg_pixbuf);
|
||||
|
||||
GdkBitmap* shape;
|
||||
gdk_pixbuf_render_pixmap_and_mask( ui->bg_pixbuf, NULL, &shape, 255 );
|
||||
|
||||
gtk_widget_set_size_request( ui->window, ui->width, ui->height );
|
||||
gtk_widget_shape_combine_mask( ui->window, shape, 0, 0 );
|
||||
|
||||
g_object_unref( shape );
|
||||
|
||||
gtk_widget_realize( ui->window );
|
||||
|
||||
ui->fixed = gtk_fixed_new();
|
||||
gtk_container_add( GTK_CONTAINER( ui->window ), ui->fixed );
|
||||
|
||||
ui->background = gtk_drawing_area_new();
|
||||
gtk_drawing_area_size( GTK_DRAWING_AREA( ui->background ), ui->width, ui->height );
|
||||
x49gp_ui_place_at( x49gp, GTK_FIXED( ui->fixed ), ui->background, 0, 0, ui->width, ui->height );
|
||||
|
||||
ui->lcd_canvas = gtk_drawing_area_new();
|
||||
gtk_drawing_area_size( GTK_DRAWING_AREA( ui->lcd_canvas ), ui->lcd_width, ui->lcd_height );
|
||||
screen_box = gtk_event_box_new();
|
||||
|
||||
GtkWidget* screen_box = gtk_event_box_new();
|
||||
gtk_event_box_set_visible_window( GTK_EVENT_BOX( screen_box ), true );
|
||||
gtk_event_box_set_above_child( GTK_EVENT_BOX( screen_box ), false );
|
||||
gtk_container_add( GTK_CONTAINER( screen_box ), ui->lcd_canvas );
|
||||
x49gp_ui_place_at( x49gp, GTK_FIXED( ui->fixed ), screen_box, ui->lcd_x_offset, ui->lcd_y_offset, ui->lcd_width, ui->lcd_height );
|
||||
|
||||
x49gp_ui_button_t* button;
|
||||
const x49gp_ui_key_t* key;
|
||||
for ( int i = 0; i < ui->nr_buttons; i++ ) {
|
||||
switch ( ui->calculator ) {
|
||||
case UI_CALCULATOR_HP49GP:
|
||||
|
@ -3408,24 +3409,27 @@ static int gui_load( x49gp_module_t* module, GKeyFile* keyfile )
|
|||
gtk_widget_add_events( button->button, GDK_BUTTON_PRESS_MASK | GDK_BUTTON_RELEASE_MASK | GDK_LEAVE_NOTIFY_MASK );
|
||||
}
|
||||
|
||||
// right-click menu
|
||||
// {
|
||||
ui->menu = gtk_menu_new();
|
||||
|
||||
menu_mount_folder = gtk_menu_item_new_with_label( "Mount SD folder ..." );
|
||||
GtkWidget *menu_mount_folder = gtk_menu_item_new_with_label( "Mount SD folder ..." );
|
||||
gtk_menu_shell_append( GTK_MENU_SHELL( ui->menu ), menu_mount_folder );
|
||||
g_signal_connect( G_OBJECT( menu_mount_folder ), "activate", G_CALLBACK( x49gp_ui_mount_sd_folder ), x49gp );
|
||||
|
||||
menu_mount_image = gtk_menu_item_new_with_label( "Mount SD image ..." );
|
||||
GtkWidget *menu_mount_image = gtk_menu_item_new_with_label( "Mount SD image ..." );
|
||||
gtk_menu_shell_append( GTK_MENU_SHELL( ui->menu ), menu_mount_image );
|
||||
g_signal_connect( G_OBJECT( menu_mount_image ), "activate", G_CALLBACK( x49gp_ui_mount_sd_image ), x49gp );
|
||||
|
||||
menu_unmount = gtk_menu_item_new_with_label( "Unmount SD" );
|
||||
GtkWidget *menu_unmount = gtk_menu_item_new_with_label( "Unmount SD" );
|
||||
gtk_menu_shell_append( GTK_MENU_SHELL( ui->menu ), menu_unmount );
|
||||
g_signal_connect_swapped( G_OBJECT( menu_unmount ), "activate", G_CALLBACK( s3c2410_sdi_unmount ), x49gp );
|
||||
ui->menu_unmount = menu_unmount;
|
||||
|
||||
if ( x49gp->debug_port != 0 ) {
|
||||
gtk_menu_shell_append( GTK_MENU_SHELL( ui->menu ), gtk_separator_menu_item_new() );
|
||||
menu_debug = gtk_menu_item_new_with_label( "Start debugger" );
|
||||
|
||||
GtkWidget *menu_debug = gtk_menu_item_new_with_label( "Start debugger" );
|
||||
gtk_menu_shell_append( GTK_MENU_SHELL( ui->menu ), menu_debug );
|
||||
g_signal_connect( G_OBJECT( menu_debug ), "activate", G_CALLBACK( x49gp_ui_debug ), x49gp );
|
||||
ui->menu_debug = menu_debug;
|
||||
|
@ -3433,14 +3437,17 @@ static int gui_load( x49gp_module_t* module, GKeyFile* keyfile )
|
|||
ui->menu_debug = NULL;
|
||||
|
||||
gtk_menu_shell_append( GTK_MENU_SHELL( ui->menu ), gtk_separator_menu_item_new() );
|
||||
menu_reset = gtk_menu_item_new_with_label( "Reset" );
|
||||
|
||||
GtkWidget *menu_reset = gtk_menu_item_new_with_label( "Reset" );
|
||||
gtk_menu_shell_append( GTK_MENU_SHELL( ui->menu ), menu_reset );
|
||||
g_signal_connect( G_OBJECT( menu_reset ), "activate", G_CALLBACK( x49gp_ui_calculator_reset ), x49gp );
|
||||
menu_quit = gtk_menu_item_new_with_label( "Quit" );
|
||||
|
||||
GtkWidget *menu_quit = gtk_menu_item_new_with_label( "Quit" );
|
||||
gtk_menu_shell_append( GTK_MENU_SHELL( ui->menu ), menu_quit );
|
||||
g_signal_connect_swapped( G_OBJECT( menu_quit ), "activate", G_CALLBACK( x49gp_ui_quit ), x49gp );
|
||||
|
||||
gtk_widget_show_all( ui->menu );
|
||||
// }
|
||||
|
||||
g_signal_connect( G_OBJECT( screen_box ), "button-press-event", G_CALLBACK( x49gp_ui_show_menu ), x49gp );
|
||||
|
||||
|
@ -3462,6 +3469,7 @@ static int gui_load( x49gp_module_t* module, GKeyFile* keyfile )
|
|||
gtk_widget_add_events( ui->window, GDK_FOCUS_CHANGE_MASK | GDK_BUTTON_PRESS_MASK | GDK_KEY_PRESS_MASK | GDK_KEY_RELEASE_MASK );
|
||||
|
||||
gtk_widget_show_all( ui->window );
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -137,7 +137,7 @@ struct __x49gp_ui_s__ {
|
|||
gint lcd_y_offset;
|
||||
gint lcd_width;
|
||||
gint lcd_height;
|
||||
gint lcd_top_margin;
|
||||
gint lcd_annunciators_height;
|
||||
};
|
||||
|
||||
int x49gp_ui_init( x49gp_t* x49gp );
|
||||
|
|
Loading…
Add table
Reference in a new issue