summaryrefslogtreecommitdiff
path: root/apps/plugins/euroconverter.c
diff options
context:
space:
mode:
authorThomas Martitz <kugel@rockbox.org>2010-08-23 16:56:49 +0000
committerThomas Martitz <kugel@rockbox.org>2010-08-23 16:56:49 +0000
commitabdc5935beb7dc3fa63bffeec584921ad2a4c8bd (patch)
tree3eb3ca86063d0fff58ca8ed2c49dbb0af0792570 /apps/plugins/euroconverter.c
parent8106c9dc646bbb26131896eb12d23edb26cba476 (diff)
downloadrockbox-abdc5935beb7dc3fa63bffeec584921ad2a4c8bd.tar.gz
rockbox-abdc5935beb7dc3fa63bffeec584921ad2a4c8bd.zip
Introduce plugin_crt0.c that every plugin links.
It handles exit() properly, calling the handler also when the plugin returns normally (also it makes exit() more standard compliant while at it). It also holds PLUGIN_HEADER, so that it doesn't need to be in each plugin anymore. To work better together with callbacks passed to rb->default_event_handler_ex introduce exit_on_usb() which will call the exit handler before showing the usb screen and exit() after it. In most cases it was passed a callback which was manually called at all other return points. This can now be done via atexit(). In future plugin_crt0.c could also handle clearing bss, initializing iram and more. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@27862 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'apps/plugins/euroconverter.c')
-rw-r--r--apps/plugins/euroconverter.c12
1 files changed, 4 insertions, 8 deletions
diff --git a/apps/plugins/euroconverter.c b/apps/plugins/euroconverter.c
index f85ee798c4..24cebe69d1 100644
--- a/apps/plugins/euroconverter.c
+++ b/apps/plugins/euroconverter.c
@@ -45,7 +45,7 @@ To do:
45- The Irish currency needs 6 digits after the . to have sufficient precision on big number 45- The Irish currency needs 6 digits after the . to have sufficient precision on big number
46*/ 46*/
47 47
48PLUGIN_HEADER 48
49 49
50/* Name and path of the config file*/ 50/* Name and path of the config file*/
51static const char cfg_filename[] = "euroconverter.cfg"; 51static const char cfg_filename[] = "euroconverter.cfg";
@@ -387,10 +387,8 @@ static int euro_menu(void)
387 387
388 388
389/* Call when the program end */ 389/* Call when the program end */
390static void euro_exit(void *parameter) 390static void euro_exit(void)
391{ 391{
392 (void)parameter;
393
394 //Restore the old pattern (i don't find another way to do this. An idea?) 392 //Restore the old pattern (i don't find another way to do this. An idea?)
395 rb->lcd_unlock_pattern(heuro); 393 rb->lcd_unlock_pattern(heuro);
396 rb->lcd_unlock_pattern(hhome); 394 rb->lcd_unlock_pattern(hhome);
@@ -411,6 +409,7 @@ enum plugin_status plugin_start(const void* parameter)
411 /* if you don't use the parameter, you can do like 409 /* if you don't use the parameter, you can do like
412 this to avoid the compiler warning about it */ 410 this to avoid the compiler warning about it */
413 (void)parameter; 411 (void)parameter;
412 atexit(euro_exit);
414 413
415 /*Get the pattern handle*/ 414 /*Get the pattern handle*/
416 heuro=rb->lcd_get_locked_pattern(); 415 heuro=rb->lcd_get_locked_pattern();
@@ -587,9 +586,7 @@ enum plugin_status plugin_start(const void* parameter)
587 break; 586 break;
588 587
589 default: 588 default:
590 if (rb->default_event_handler_ex(button, euro_exit, NULL) 589 exit_on_usb(button);
591 == SYS_USB_CONNECTED)
592 return PLUGIN_USB_CONNECTED;
593 break; 590 break;
594 } 591 }
595 /*Display*/ 592 /*Display*/
@@ -599,7 +596,6 @@ enum plugin_status plugin_start(const void* parameter)
599 e=mydiv(h,currency[country]); 596 e=mydiv(h,currency[country]);
600 display(e,h,pos); 597 display(e,h,pos);
601 } 598 }
602 euro_exit(NULL);
603 return PLUGIN_OK; 599 return PLUGIN_OK;
604} 600}
605 601