forked from Miroirs/x49gp
[3298 - patch 34] When loading a firmware during flash initialization, check for the KINPOUPDATEIMAGE signature, and fail if it's missing
[3298 - patch 35] When selecting a firmware interactively, show errors in a message window and retry The user may not even have a terminal open to catch the error message, so the previous behavior was basically a silent failure to them. [3298 - patch 36] Add newRPL keyboard layouts via new calculator types "hp49gp/newrpl" and "hp50g/newrpl" Also fixes an old bug causing only a single keyboard layout to be used, regardless of selected calculator type. It appears nobody noticed this bug because the only two layouts present before this commit were almost identical.
This commit is contained in:
parent
48d0c97490
commit
0df95a3dfd
3 changed files with 823 additions and 31 deletions
108
flash.c
108
flash.c
|
@ -454,6 +454,7 @@ flash_load(x49gp_module_t *module, GKeyFile *key)
|
||||||
int error;
|
int error;
|
||||||
int i;
|
int i;
|
||||||
char bank_marker[5] = {0xf0, 0x02, 0x00, 0x00, 0x00};
|
char bank_marker[5] = {0xf0, 0x02, 0x00, 0x00, 0x00};
|
||||||
|
int bytes_read;
|
||||||
|
|
||||||
#ifdef DEBUG_X49GP_MODULES
|
#ifdef DEBUG_X49GP_MODULES
|
||||||
printf("%s: %s:%u\n", module->name, __FUNCTION__, __LINE__);
|
printf("%s: %s:%u\n", module->name, __FUNCTION__, __LINE__);
|
||||||
|
@ -521,7 +522,8 @@ flash_load(x49gp_module_t *module, GKeyFile *key)
|
||||||
flash->size - st.st_size);
|
flash->size - st.st_size);
|
||||||
|
|
||||||
bootfd = x49gp_module_open_rodata(module,
|
bootfd = x49gp_module_open_rodata(module,
|
||||||
calc == UI_CALCULATOR_HP49GP ?
|
calc == UI_CALCULATOR_HP49GP ||
|
||||||
|
calc == UI_CALCULATOR_HP49GP_NEWRPL ?
|
||||||
"boot-49g+.bin" :
|
"boot-49g+.bin" :
|
||||||
"boot-50g.bin",
|
"boot-50g.bin",
|
||||||
&bootfile);
|
&bootfile);
|
||||||
|
@ -568,6 +570,7 @@ flash_load(x49gp_module_t *module, GKeyFile *key)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
retry:
|
||||||
filename = NULL;
|
filename = NULL;
|
||||||
if (x49gp->firmware != NULL) {
|
if (x49gp->firmware != NULL) {
|
||||||
filename = g_strdup(x49gp->firmware);
|
filename = g_strdup(x49gp->firmware);
|
||||||
|
@ -580,35 +583,106 @@ flash_load(x49gp_module_t *module, GKeyFile *key)
|
||||||
fprintf(stderr, "%s: %s:%u: open %s: %s\n",
|
fprintf(stderr, "%s: %s:%u: open %s: %s\n",
|
||||||
module->name, __FUNCTION__, __LINE__,
|
module->name, __FUNCTION__, __LINE__,
|
||||||
filename, strerror(errno));
|
filename, strerror(errno));
|
||||||
fprintf(stderr, "Warning: Could not open "
|
|
||||||
"selected firmware, falling back to "
|
|
||||||
"bootloader recovery tools\n");
|
|
||||||
/* Mark firmware as invalid if there is one */
|
/* Mark firmware as invalid if there is one */
|
||||||
memset(phys_ram_base + flash->offset +
|
memset(phys_ram_base + flash->offset +
|
||||||
BOOT_SIZE, 0, 16);
|
BOOT_SIZE, 0, 16);
|
||||||
|
if (x49gp->firmware != NULL) {
|
||||||
|
fprintf(stderr, "Warning: Could not "
|
||||||
|
"open selected firmware, "
|
||||||
|
"falling back to bootloader "
|
||||||
|
"recovery tools\n");
|
||||||
} else {
|
} else {
|
||||||
/* The firmware may be shorter than
|
x49gp_ui_show_error(x49gp,
|
||||||
SST29VF160_SIZE - BOOT_SIZE, but if so,
|
"Could not open "
|
||||||
read will just give us what it sees.
|
"selected "
|
||||||
The space after that will remain empty. */
|
"firmware!");
|
||||||
if (read(fwfd, phys_ram_base + flash->offset +
|
goto retry;
|
||||||
BOOT_SIZE,
|
}
|
||||||
SST29VF160_SIZE - BOOT_SIZE) < 0) {
|
} else {
|
||||||
|
bytes_read = read(fwfd, phys_ram_base +
|
||||||
|
flash->offset + BOOT_SIZE,
|
||||||
|
16);
|
||||||
|
if (bytes_read < 0) {
|
||||||
fprintf(stderr, "%s: %s:%u: read %s: %s\n",
|
fprintf(stderr, "%s: %s:%u: read %s: %s\n",
|
||||||
module->name, __FUNCTION__,
|
module->name, __FUNCTION__,
|
||||||
__LINE__, filename,
|
__LINE__, filename,
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
fprintf(stderr, "Warning: Could not "
|
|
||||||
"read selected firmware, "
|
|
||||||
"falling back to bootloader "
|
|
||||||
"recovery tools\n");
|
|
||||||
/* Mark firmware as invalid
|
/* Mark firmware as invalid
|
||||||
if there is one */
|
if there is one */
|
||||||
memset(phys_ram_base + flash->offset +
|
memset(phys_ram_base + flash->offset +
|
||||||
BOOT_SIZE, 0, 16);
|
BOOT_SIZE, 0, 16);
|
||||||
|
if (x49gp->firmware != NULL) {
|
||||||
|
fprintf(stderr, "Warning: "
|
||||||
|
"Could not read "
|
||||||
|
"selected firmware, "
|
||||||
|
"falling back to "
|
||||||
|
"bootloader recovery "
|
||||||
|
"tools\n");
|
||||||
} else {
|
} else {
|
||||||
/* Mark the firmware as valid in the
|
x49gp_ui_show_error(x49gp,
|
||||||
same way the bootloader does */
|
"Could not "
|
||||||
|
"read "
|
||||||
|
"selected "
|
||||||
|
"firmware!");
|
||||||
|
goto retry;
|
||||||
|
}
|
||||||
|
} else if (bytes_read < 16 ||
|
||||||
|
memcmp(phys_ram_base +
|
||||||
|
flash->offset + BOOT_SIZE,
|
||||||
|
"KINPOUPDATEIMAGE", 16)
|
||||||
|
!= 0) {
|
||||||
|
/* Mark firmware as invalid */
|
||||||
|
memset(phys_ram_base + flash->offset +
|
||||||
|
BOOT_SIZE, 0, 16);
|
||||||
|
if (x49gp->firmware != NULL) {
|
||||||
|
fprintf(stderr, "Warning: "
|
||||||
|
"Firmware is invalid, "
|
||||||
|
"falling back to "
|
||||||
|
"bootloader recovery "
|
||||||
|
"tools\n");
|
||||||
|
} else {
|
||||||
|
x49gp_ui_show_error(x49gp,
|
||||||
|
"Selected "
|
||||||
|
"firmware "
|
||||||
|
"is "
|
||||||
|
"invalid!");
|
||||||
|
goto retry;
|
||||||
|
}
|
||||||
|
/* The firmware may be shorter than
|
||||||
|
SST29VF160_SIZE - BOOT_SIZE, but if so,
|
||||||
|
read will just give us what it sees.
|
||||||
|
The space after that will remain empty. */
|
||||||
|
} else if (read(fwfd, phys_ram_base +
|
||||||
|
flash->offset + BOOT_SIZE + 16,
|
||||||
|
SST29VF160_SIZE -
|
||||||
|
(BOOT_SIZE + 16))
|
||||||
|
< 0) {
|
||||||
|
fprintf(stderr, "%s: %s:%u: read %s: %s\n",
|
||||||
|
module->name, __FUNCTION__,
|
||||||
|
__LINE__, filename,
|
||||||
|
strerror(errno));
|
||||||
|
/* Mark firmware as invalid
|
||||||
|
if there is one */
|
||||||
|
memset(phys_ram_base + flash->offset +
|
||||||
|
BOOT_SIZE, 0, 16);
|
||||||
|
if (x49gp->firmware != NULL) {
|
||||||
|
fprintf(stderr, "Warning: "
|
||||||
|
"Could not read "
|
||||||
|
"selected firmware, "
|
||||||
|
"falling back to "
|
||||||
|
"bootloader recovery "
|
||||||
|
"tools\n");
|
||||||
|
} else {
|
||||||
|
x49gp_ui_show_error(x49gp,
|
||||||
|
"Could not "
|
||||||
|
"read "
|
||||||
|
"selected "
|
||||||
|
"firmware!");
|
||||||
|
goto retry;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Mark firmware as valid in the same
|
||||||
|
way the bootloader does */
|
||||||
memcpy(phys_ram_base + flash->offset +
|
memcpy(phys_ram_base + flash->offset +
|
||||||
BOOT_SIZE, "Kinposhcopyright",
|
BOOT_SIZE, "Kinposhcopyright",
|
||||||
16);
|
16);
|
||||||
|
|
|
@ -52,7 +52,9 @@ typedef enum {
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
UI_CALCULATOR_HP49GP = 0,
|
UI_CALCULATOR_HP49GP = 0,
|
||||||
UI_CALCULATOR_HP50G
|
UI_CALCULATOR_HP49GP_NEWRPL,
|
||||||
|
UI_CALCULATOR_HP50G,
|
||||||
|
UI_CALCULATOR_HP50G_NEWRPL
|
||||||
} x49gp_ui_calculator_t;
|
} x49gp_ui_calculator_t;
|
||||||
|
|
||||||
|
|
||||||
|
@ -143,6 +145,7 @@ struct __x49gp_ui_s__ {
|
||||||
};
|
};
|
||||||
|
|
||||||
int x49gp_ui_init(x49gp_t *x49gp);
|
int x49gp_ui_init(x49gp_t *x49gp);
|
||||||
|
void x49gp_ui_show_error(x49gp_t *x49gp, const char *text);
|
||||||
void x49gp_ui_open_firmware(x49gp_t *x49gp, char **filename);
|
void x49gp_ui_open_firmware(x49gp_t *x49gp, char **filename);
|
||||||
|
|
||||||
#endif /* !(_X49GP_UI_H) */
|
#endif /* !(_X49GP_UI_H) */
|
||||||
|
|
733
ui.c
733
ui.c
|
@ -371,6 +371,341 @@ static const x49gp_ui_key_t x49gp_ui_keys[] =
|
||||||
};
|
};
|
||||||
#define X49GP_UI_NR_KEYS (sizeof(x49gp_ui_keys) / sizeof(x49gp_ui_keys[0]))
|
#define X49GP_UI_NR_KEYS (sizeof(x49gp_ui_keys) / sizeof(x49gp_ui_keys[0]))
|
||||||
|
|
||||||
|
static const x49gp_ui_key_t x49gp_newrpl_ui_keys[] =
|
||||||
|
{
|
||||||
|
{
|
||||||
|
"F1", "A", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_TINY, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
0, 0, 36, 22, 5, 1, (1 << 5), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"F2", "B", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_TINY, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
50, 0, 36, 22, 5, 2, (1 << 5), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"F3", "C", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_TINY, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
99, 0, 36, 22, 5, 3, (1 << 5), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"F4", "D", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_TINY, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
149, 0, 36, 22, 5, 4, (1 << 5), (1 << 4), 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"F5", "E", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_TINY, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
198, 0, 36, 22, 5, 5, (1 << 5), (1 << 5), 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"F6", "F", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_TINY, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
247, 0, 36, 22, 5, 6, (1 << 5), (1 << 6), 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"", "G", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 10.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_SMALL, 10.0, UI_LAYOUT_BELOW,
|
||||||
|
0, 44, 36, 28, 5, 7, (1 << 5), (1 << 7), 7
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"", "H", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 10.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_SMALL, 10.0, UI_LAYOUT_BELOW,
|
||||||
|
50, 44, 36, 28, 6, 5, (1 << 6), (1 << 5), 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"", "I", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 10.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_SMALL, 10.0, UI_LAYOUT_BELOW,
|
||||||
|
99, 44, 36, 28, 6, 6, (1 << 6), (1 << 6), 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"", "J", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 10.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_SMALL, 10.0, UI_LAYOUT_BELOW,
|
||||||
|
0, 92, 36, 28, 6, 7, (1 << 6), (1 << 7), 7
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"", "K", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 10.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_SMALL, 10.0, UI_LAYOUT_BELOW,
|
||||||
|
50, 92, 36, 28, 7, 1, (1 << 7), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"", "L", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 10.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_SMALL, 10.0, UI_LAYOUT_BELOW,
|
||||||
|
99, 92, 36, 28, 7, 2, (1 << 7), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
NULL, NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_SILVER, 0.0, 0,
|
||||||
|
UI_SHAPE_BUTTON_ROUND, 0.0, 0,
|
||||||
|
200, 38, 33, 33, 6, 1, (1 << 6), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
NULL, NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_SILVER, 0.0, 0,
|
||||||
|
UI_SHAPE_BUTTON_ROUND, 0.0, 0,
|
||||||
|
164, 66, 33, 33, 6, 2, (1 << 6), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
NULL, NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_SILVER, 0.0, 0,
|
||||||
|
UI_SHAPE_BUTTON_ROUND, 0.0, 0,
|
||||||
|
200, 94, 33, 33, 6, 3, (1 << 6), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
NULL, NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_SILVER, 0.0, 0,
|
||||||
|
UI_SHAPE_BUTTON_ROUND, 0.0, 0,
|
||||||
|
236, 66, 33, 33, 6, 4, (1 << 6), (1 << 4), 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"S\\kern-1 T\\kern-1 O\\kern-1\\triangleright", "M", "RCL", NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
0, 141, 46, 28, 4, 1, (1 << 4), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"EV\\kern-1 AL", "N", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
59, 141, 46, 28, 3, 1, (1 << 3), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\tick", "O", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
119, 141, 46, 28, 2, 1, (1 << 2), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"M\\kern-1 A\\kern-1 I\\kern-1 N", "P", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
179, 141, 46, 28, 1, 1, (1 << 1), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\arrowleftdblfull", NULL, NULL, "CLEAR", NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 0.0, 0,
|
||||||
|
238, 141, 46, 28, 0, 1, (1 << 0), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Y\\super x\\/super", "Q", "\\math_e\\xsuperior", "LN", NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
0, 183, 46, 28, 4, 2, (1 << 4), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\radical\\overscore\\kern-7 X", "R",
|
||||||
|
"\\math_x\\twosuperior",
|
||||||
|
"\\xsuperior\\kern-4\\math_radical\\overscore\\kern-5\\math_y",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
59, 183, 46, 28, 3, 2, (1 << 3), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"SIN", "S", "ASIN", NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
119, 183, 46, 28, 2, 2, (1 << 2), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"COS", "T", "ACOS", NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
179, 183, 46, 28, 1, 2, (1 << 1), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"TAN", "U", "ATAN", NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
238, 183, 46, 28, 0, 2, (1 << 0), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"EEX", "V", "10\\xsuperior", "LOG", NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
0, 225, 46, 28, 4, 3, (1 << 4), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"+\\divisionslash\\minus", "W",
|
||||||
|
"\\math_notequal",
|
||||||
|
"\\math_equal",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
59, 225, 46, 28, 3, 3, (1 << 3), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"X", "X",
|
||||||
|
"\\math_lessequal",
|
||||||
|
"\\math_less",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
119, 225, 46, 28, 2, 3, (1 << 2), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"1/X", "Y",
|
||||||
|
"\\math_greaterequal",
|
||||||
|
"\\math_greater",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
179, 225, 46, 28, 1, 3, (1 << 1), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\divide", "Z", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT_NO_SPACE,
|
||||||
|
238, 225, 46, 28, 0, 3, (1 << 0), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"ALPHA", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
0, 267, 46, 32, 0, 0, 0, 0, 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"7", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
59, 267, 46, 32, 3, 4, (1 << 3), (1 << 4), 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"8", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
119, 267, 46, 32, 2, 4, (1 << 2), (1 << 4), 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"9", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
179, 267, 46, 32, 1, 4, (1 << 1), (1 << 4), 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\multiply", NULL, "[ ]", "\" \"", NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
238, 267, 46, 32, 0, 4, (1 << 0), (1 << 4), 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\uparrowleft", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
0, 313, 46, 32, 0, 0, 0, 0, 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"4", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
59, 313, 46, 32, 3, 5, (1 << 3), (1 << 5), 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"5", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
119, 313, 46, 32, 2, 5, (1 << 2), (1 << 5), 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"6", NULL, NULL, "UNITS", NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
179, 313, 46, 32, 1, 5, (1 << 1), (1 << 5), 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\minus", NULL, "( )", "_", NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
238, 313, 46, 32, 0, 5, (1 << 0), (1 << 5), 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\uparrowright", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
0, 359, 46, 32, 0, 0, 0, 0, 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"1", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
59, 359, 46, 32, 3, 6, (1 << 3), (1 << 6), 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"2", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
119, 359, 46, 32, 2, 6, (1 << 2), (1 << 6), 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"3", NULL, "\\math_numbersign", NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
179, 359, 46, 32, 1, 6, (1 << 1), (1 << 6), 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"+", NULL,
|
||||||
|
"{ }",
|
||||||
|
"\\guillemotleft\\ \\guillemotright",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
238, 359, 46, 32, 0, 6, (1 << 0), (1 << 6), 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"ON", NULL, NULL, "OFF", NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
0, 405, 46, 32, 0, 0, 0, 0, 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"0", NULL,
|
||||||
|
"\\math_infinity",
|
||||||
|
"\\math_arrowright",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
59, 405, 46, 32, 3, 7, (1 << 3), (1 << 7), 7
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\bullet", NULL,
|
||||||
|
": :",
|
||||||
|
"\\math_downarrowleft",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
119, 405, 46, 32, 2, 7, (1 << 2), (1 << 7), 7
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"SPC", NULL,
|
||||||
|
"\\math_pi",
|
||||||
|
"\\large_comma",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
179, 405, 46, 32, 1, 7, (1 << 1), (1 << 7), 7
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"ENTER", NULL, NULL, "\\arrowright NUM", NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
238, 405, 46, 32, 0, 7, (1 << 0), (1 << 7), 7
|
||||||
|
},
|
||||||
|
};
|
||||||
|
#define X49GP_NEWRPL_UI_NR_KEYS (sizeof(x49gp_newrpl_ui_keys) / sizeof(x49gp_newrpl_ui_keys[0]))
|
||||||
|
|
||||||
static const x49gp_ui_key_t x50g_ui_keys[] =
|
static const x49gp_ui_key_t x50g_ui_keys[] =
|
||||||
{
|
{
|
||||||
{
|
{
|
||||||
|
@ -706,6 +1041,341 @@ static const x49gp_ui_key_t x50g_ui_keys[] =
|
||||||
};
|
};
|
||||||
#define X50G_UI_NR_KEYS (sizeof(x50g_ui_keys) / sizeof(x50g_ui_keys[0]))
|
#define X50G_UI_NR_KEYS (sizeof(x50g_ui_keys) / sizeof(x50g_ui_keys[0]))
|
||||||
|
|
||||||
|
static const x49gp_ui_key_t x50g_newrpl_ui_keys[] =
|
||||||
|
{
|
||||||
|
{
|
||||||
|
"F1", "A", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_TINY, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
0, 0, 36, 22, 5, 1, (1 << 5), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"F2", "B", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_TINY, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
50, 0, 36, 22, 5, 2, (1 << 5), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"F3", "C", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_TINY, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
99, 0, 36, 22, 5, 3, (1 << 5), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"F4", "D", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_TINY, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
149, 0, 36, 22, 5, 4, (1 << 5), (1 << 4), 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"F5", "E", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_TINY, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
198, 0, 36, 22, 5, 5, (1 << 5), (1 << 5), 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"F6", "F", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_TINY, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
247, 0, 36, 22, 5, 6, (1 << 5), (1 << 6), 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"", "G", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 10.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_SMALL, 10.0, UI_LAYOUT_BELOW,
|
||||||
|
0, 44, 36, 28, 5, 7, (1 << 5), (1 << 7), 7
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"", "H", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 10.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_SMALL, 10.0, UI_LAYOUT_BELOW,
|
||||||
|
50, 44, 36, 28, 6, 5, (1 << 6), (1 << 5), 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"", "I", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 10.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_SMALL, 10.0, UI_LAYOUT_BELOW,
|
||||||
|
99, 44, 36, 28, 6, 6, (1 << 6), (1 << 6), 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"", "J", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 10.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_SMALL, 10.0, UI_LAYOUT_BELOW,
|
||||||
|
0, 92, 36, 28, 6, 7, (1 << 6), (1 << 7), 7
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"", "K", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 10.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_SMALL, 10.0, UI_LAYOUT_BELOW,
|
||||||
|
50, 92, 36, 28, 7, 1, (1 << 7), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"", "L", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 10.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_SMALL, 10.0, UI_LAYOUT_BELOW,
|
||||||
|
99, 92, 36, 28, 7, 2, (1 << 7), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
NULL, NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_SILVER, 0.0, 0,
|
||||||
|
UI_SHAPE_BUTTON_ROUND, 0.0, 0,
|
||||||
|
200, 38, 33, 33, 6, 1, (1 << 6), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
NULL, NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_SILVER, 0.0, 0,
|
||||||
|
UI_SHAPE_BUTTON_ROUND, 0.0, 0,
|
||||||
|
164, 66, 33, 33, 6, 2, (1 << 6), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
NULL, NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_SILVER, 0.0, 0,
|
||||||
|
UI_SHAPE_BUTTON_ROUND, 0.0, 0,
|
||||||
|
200, 94, 33, 33, 6, 3, (1 << 6), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
NULL, NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_SILVER, 0.0, 0,
|
||||||
|
UI_SHAPE_BUTTON_ROUND, 0.0, 0,
|
||||||
|
236, 66, 33, 33, 6, 4, (1 << 6), (1 << 4), 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"S\\kern-1 T\\kern-1 O\\kern-1\\triangleright", "M", "RCL", NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
0, 141, 46, 28, 4, 1, (1 << 4), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"EV\\kern-1 AL", "N", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
59, 141, 46, 28, 3, 1, (1 << 3), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\tick", "O", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
119, 141, 46, 28, 2, 1, (1 << 2), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"M\\kern-1 A\\kern-1 I\\kern-1 N", "P", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
179, 141, 46, 28, 1, 1, (1 << 1), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\arrowleftdblfull", NULL, NULL, "CLEAR", NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 0.0, 0,
|
||||||
|
238, 141, 46, 28, 0, 1, (1 << 0), (1 << 1), 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Y\\super x\\/super", "Q", "\\math_e\\xsuperior", "LN", NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
0, 183, 46, 28, 4, 2, (1 << 4), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\radical\\overscore\\kern-7 X", "R",
|
||||||
|
"\\math_x\\twosuperior",
|
||||||
|
"\\xsuperior\\kern-4\\math_radical\\overscore\\kern-5\\math_y",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
59, 183, 46, 28, 3, 2, (1 << 3), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"SIN", "S", "ASIN", NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
119, 183, 46, 28, 2, 2, (1 << 2), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"COS", "T", "ACOS", NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
179, 183, 46, 28, 1, 2, (1 << 1), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"TAN", "U", "ATAN", NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
238, 183, 46, 28, 0, 2, (1 << 0), (1 << 2), 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"EEX", "V", "10\\xsuperior", "LOG", NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
0, 225, 46, 28, 4, 3, (1 << 4), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"+\\divisionslash\\minus", "W",
|
||||||
|
"\\math_notequal",
|
||||||
|
"\\math_equal",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
59, 225, 46, 28, 3, 3, (1 << 3), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"X", "X",
|
||||||
|
"\\math_lessequal",
|
||||||
|
"\\math_less",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
119, 225, 46, 28, 2, 3, (1 << 2), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"1/X", "Y",
|
||||||
|
"\\math_greaterequal",
|
||||||
|
"\\math_greater",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT,
|
||||||
|
179, 225, 46, 28, 1, 3, (1 << 1), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\divide", "Z", NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_NORMAL, 12.0, UI_LAYOUT_LEFT_NO_SPACE,
|
||||||
|
238, 225, 46, 28, 0, 3, (1 << 0), (1 << 3), 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"ALPHA", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
0, 267, 46, 32, 0, 0, 0, 0, 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"7", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
59, 267, 46, 32, 3, 4, (1 << 3), (1 << 4), 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"8", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
119, 267, 46, 32, 2, 4, (1 << 2), (1 << 4), 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"9", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
179, 267, 46, 32, 1, 4, (1 << 1), (1 << 4), 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\multiply", NULL, "[ ]", "\" \"", NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
238, 267, 46, 32, 0, 4, (1 << 0), (1 << 4), 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\uparrowleft", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
0, 313, 46, 32, 0, 0, 0, 0, 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"4", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
59, 313, 46, 32, 3, 5, (1 << 3), (1 << 5), 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"5", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
119, 313, 46, 32, 2, 5, (1 << 2), (1 << 5), 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"6", NULL, NULL, "UNITS", NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
179, 313, 46, 32, 1, 5, (1 << 1), (1 << 5), 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\minus", NULL, "( )", "_", NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
238, 313, 46, 32, 0, 5, (1 << 0), (1 << 5), 5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\uparrowright", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_BLACK, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
0, 359, 46, 32, 0, 0, 0, 0, 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"1", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
59, 359, 46, 32, 3, 6, (1 << 3), (1 << 6), 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"2", NULL, NULL, NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
119, 359, 46, 32, 2, 6, (1 << 2), (1 << 6), 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"3", NULL, "\\math_numbersign", NULL, NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
179, 359, 46, 32, 1, 6, (1 << 1), (1 << 6), 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"+", NULL,
|
||||||
|
"{ }",
|
||||||
|
"\\guillemotleft\\ \\guillemotright",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
238, 359, 46, 32, 0, 6, (1 << 0), (1 << 6), 6
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"ON", NULL, NULL, "OFF", NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
0, 405, 46, 32, 0, 0, 0, 0, 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"0", NULL,
|
||||||
|
"\\math_infinity",
|
||||||
|
"\\math_arrowright",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
59, 405, 46, 32, 3, 7, (1 << 3), (1 << 7), 7
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"\\bullet", NULL,
|
||||||
|
": :",
|
||||||
|
"\\math_downarrowleft",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 19.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
119, 405, 46, 32, 2, 7, (1 << 2), (1 << 7), 7
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"SPC", NULL,
|
||||||
|
"\\math_pi",
|
||||||
|
"\\large_comma",
|
||||||
|
NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
179, 405, 46, 32, 1, 7, (1 << 1), (1 << 7), 7
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"ENTER", NULL, NULL, "\\arrowright NUM", NULL,
|
||||||
|
UI_COLOR_WHITE, 12.0, CAIRO_FONT_WEIGHT_BOLD,
|
||||||
|
UI_SHAPE_BUTTON_LARGE, 0.0, 0,
|
||||||
|
238, 405, 46, 32, 0, 7, (1 << 0), (1 << 7), 7
|
||||||
|
},
|
||||||
|
};
|
||||||
|
#define X50G_NEWRPL_UI_NR_KEYS (sizeof(x50g_newrpl_ui_keys) / sizeof(x50g_newrpl_ui_keys[0]))
|
||||||
|
|
||||||
static void
|
static void
|
||||||
x49gp_ui_color_init(GdkColor *color, u8 red, u8 green, u8 blue)
|
x49gp_ui_color_init(GdkColor *color, u8 red, u8 green, u8 blue)
|
||||||
{
|
{
|
||||||
|
@ -1505,6 +2175,22 @@ bitmap_font_draw_text(GdkDrawable *drawable, GdkColor *color,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
x49gp_ui_show_error(x49gp_t *x49gp, const char *text)
|
||||||
|
{
|
||||||
|
GtkWidget *dialog;
|
||||||
|
x49gp_ui_t *ui = x49gp->ui;
|
||||||
|
|
||||||
|
dialog = gtk_message_dialog_new(GTK_WINDOW(ui->window),
|
||||||
|
GTK_DIALOG_DESTROY_WITH_PARENT,
|
||||||
|
GTK_MESSAGE_ERROR,
|
||||||
|
GTK_BUTTONS_OK,
|
||||||
|
"%s", text);
|
||||||
|
|
||||||
|
gtk_dialog_run(GTK_DIALOG(dialog));
|
||||||
|
gtk_widget_destroy(dialog);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
x49gp_ui_choose_file(x49gp_t *x49gp, const char *prompt,
|
x49gp_ui_choose_file(x49gp_t *x49gp, const char *prompt,
|
||||||
GtkFileChooserAction action, char **filename)
|
GtkFileChooserAction action, char **filename)
|
||||||
|
@ -2205,11 +2891,8 @@ x49gp_window_configure_event(GtkWidget *widget, GdkEventConfigure *event,
|
||||||
cairo_set_line_join(cr, CAIRO_LINE_JOIN_MITER);
|
cairo_set_line_join(cr, CAIRO_LINE_JOIN_MITER);
|
||||||
|
|
||||||
switch (ui->calculator) {
|
switch (ui->calculator) {
|
||||||
default:
|
|
||||||
ui->calculator = UI_CALCULATOR_HP49GP;
|
|
||||||
/* fall through */
|
|
||||||
|
|
||||||
case UI_CALCULATOR_HP49GP:
|
case UI_CALCULATOR_HP49GP:
|
||||||
|
case UI_CALCULATOR_HP49GP_NEWRPL:
|
||||||
x49gp_ui_draw_text(cr, &widget->style->black,
|
x49gp_ui_draw_text(cr, &widget->style->black,
|
||||||
X49GP_UI_NORMAL_FONT, 15.0, 0.0,
|
X49GP_UI_NORMAL_FONT, 15.0, 0.0,
|
||||||
38, 42, 2,
|
38, 42, 2,
|
||||||
|
@ -2235,7 +2918,12 @@ x49gp_window_configure_event(GtkWidget *widget, GdkEventConfigure *event,
|
||||||
below_color = UI_COLOR_BLACK;
|
below_color = UI_COLOR_BLACK;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
ui->calculator = UI_CALCULATOR_HP50G;
|
||||||
|
/* fall through */
|
||||||
|
|
||||||
case UI_CALCULATOR_HP50G:
|
case UI_CALCULATOR_HP50G:
|
||||||
|
case UI_CALCULATOR_HP50G_NEWRPL:
|
||||||
x49gp_ui_draw_text(cr, &widget->style->white,
|
x49gp_ui_draw_text(cr, &widget->style->white,
|
||||||
X49GP_UI_NORMAL_FONT, 15.0, 0.0,
|
X49GP_UI_NORMAL_FONT, 15.0, 0.0,
|
||||||
38, 42, 2,
|
38, 42, 2,
|
||||||
|
@ -2265,8 +2953,7 @@ x49gp_window_configure_event(GtkWidget *widget, GdkEventConfigure *event,
|
||||||
cairo_destroy(cr);
|
cairo_destroy(cr);
|
||||||
|
|
||||||
for (i = 0; i < ui->nr_buttons; i++) {
|
for (i = 0; i < ui->nr_buttons; i++) {
|
||||||
key = &x49gp_ui_keys[i];
|
key = ui->buttons[i].key;
|
||||||
key = &x50g_ui_keys[i];
|
|
||||||
|
|
||||||
if (key->left) {
|
if (key->left) {
|
||||||
bitmap_font_text_size(&tiny_font, key->left, &wl, &hl, &a, &dl);
|
bitmap_font_text_size(&tiny_font, key->left, &wl, &hl, &a, &dl);
|
||||||
|
@ -2446,8 +3133,12 @@ gui_load(x49gp_module_t *module, GKeyFile *keyfile)
|
||||||
x49gp_module_get_string(module, keyfile, "type", "hp50g", &typestr);
|
x49gp_module_get_string(module, keyfile, "type", "hp50g", &typestr);
|
||||||
if (!strcmp(typestr, "hp49g+")) {
|
if (!strcmp(typestr, "hp49g+")) {
|
||||||
ui->calculator = UI_CALCULATOR_HP49GP;
|
ui->calculator = UI_CALCULATOR_HP49GP;
|
||||||
|
} else if (!strcmp(typestr, "hp49g+/newrpl")) {
|
||||||
|
ui->calculator = UI_CALCULATOR_HP49GP_NEWRPL;
|
||||||
} else if (!strcmp(typestr, "hp50g")) {
|
} else if (!strcmp(typestr, "hp50g")) {
|
||||||
ui->calculator = UI_CALCULATOR_HP50G;
|
ui->calculator = UI_CALCULATOR_HP50G;
|
||||||
|
} else if (!strcmp(typestr, "hp50g/newrpl")) {
|
||||||
|
ui->calculator = UI_CALCULATOR_HP50G_NEWRPL;
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "Invalid calculator type, reverting to default\n");
|
fprintf(stderr, "Invalid calculator type, reverting to default\n");
|
||||||
ui->calculator = UI_CALCULATOR_HP50G;
|
ui->calculator = UI_CALCULATOR_HP50G;
|
||||||
|
@ -2455,11 +3146,16 @@ gui_load(x49gp_module_t *module, GKeyFile *keyfile)
|
||||||
|
|
||||||
x49gp_module_get_string(module, keyfile, "name",
|
x49gp_module_get_string(module, keyfile, "name",
|
||||||
ui->calculator == UI_CALCULATOR_HP49GP ?
|
ui->calculator == UI_CALCULATOR_HP49GP ?
|
||||||
"HP 49g+" : "HP 50g",
|
"HP 49g+" :
|
||||||
|
ui->calculator == UI_CALCULATOR_HP49GP_NEWRPL ?
|
||||||
|
"HP 49g+ / newRPL" :
|
||||||
|
ui->calculator == UI_CALCULATOR_HP50G ?
|
||||||
|
"HP 50g" : "HP 50g / newRPL",
|
||||||
&(ui->name));
|
&(ui->name));
|
||||||
|
|
||||||
fd = x49gp_module_open_rodata(module,
|
fd = x49gp_module_open_rodata(module,
|
||||||
ui->calculator == UI_CALCULATOR_HP49GP ?
|
ui->calculator == UI_CALCULATOR_HP49GP ||
|
||||||
|
ui->calculator == UI_CALCULATOR_HP49GP_NEWRPL ?
|
||||||
"hp49g+.png" : "hp50g.png",
|
"hp49g+.png" : "hp50g.png",
|
||||||
&imagefile);
|
&imagefile);
|
||||||
if (fd < 0) return fd;
|
if (fd < 0) return fd;
|
||||||
|
@ -2574,8 +3270,23 @@ gui_load(x49gp_module_t *module, GKeyFile *keyfile)
|
||||||
|
|
||||||
|
|
||||||
for (i = 0; i < ui->nr_buttons; i++) {
|
for (i = 0; i < ui->nr_buttons; i++) {
|
||||||
|
switch (ui->calculator) {
|
||||||
|
case UI_CALCULATOR_HP49GP:
|
||||||
key = &x49gp_ui_keys[i];
|
key = &x49gp_ui_keys[i];
|
||||||
|
break;
|
||||||
|
case UI_CALCULATOR_HP49GP_NEWRPL:
|
||||||
|
key = &x49gp_newrpl_ui_keys[i];
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
ui->calculator = UI_CALCULATOR_HP50G;
|
||||||
|
/* fall through */
|
||||||
|
case UI_CALCULATOR_HP50G:
|
||||||
key = &x50g_ui_keys[i];
|
key = &x50g_ui_keys[i];
|
||||||
|
break;
|
||||||
|
case UI_CALCULATOR_HP50G_NEWRPL:
|
||||||
|
key = &x50g_newrpl_ui_keys[i];
|
||||||
|
break;
|
||||||
|
}
|
||||||
button = &ui->buttons[i];
|
button = &ui->buttons[i];
|
||||||
|
|
||||||
button->x49gp = x49gp;
|
button->x49gp = x49gp;
|
||||||
|
@ -2723,7 +3434,11 @@ gui_save(x49gp_module_t *module, GKeyFile *keyfile)
|
||||||
|
|
||||||
x49gp_module_set_string(module, keyfile, "type",
|
x49gp_module_set_string(module, keyfile, "type",
|
||||||
ui->calculator == UI_CALCULATOR_HP49GP ?
|
ui->calculator == UI_CALCULATOR_HP49GP ?
|
||||||
"hp49g+" : "hp50g");
|
"hp49g+" :
|
||||||
|
ui->calculator == UI_CALCULATOR_HP49GP_NEWRPL ?
|
||||||
|
"hp49g+/newrpl" :
|
||||||
|
ui->calculator == UI_CALCULATOR_HP50G ?
|
||||||
|
"hp50g" : "hp50g/newrpl");
|
||||||
x49gp_module_set_string(module, keyfile, "name", ui->name);
|
x49gp_module_set_string(module, keyfile, "name", ui->name);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Loading…
Reference in a new issue