Changeset e63e74a in mainline for uspace/app
- Timestamp:
- 2024-02-21T20:26:35Z (20 months ago)
- Branches:
- master
- Children:
- 95e2967
- Parents:
- 5f3188b8
- Location:
- uspace/app
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/app/taskbar-cfg/startmenu.c
r5f3188b8 re63e74a 54 54 static void startmenu_delete_entry_clicked(ui_pbutton_t *, void *); 55 55 static void startmenu_edit_entry_clicked(ui_pbutton_t *, void *); 56 static void startmenu_sep_entry_clicked(ui_pbutton_t *, void *); 56 57 static void startmenu_up_entry_clicked(ui_pbutton_t *, void *); 57 58 static void startmenu_down_entry_clicked(ui_pbutton_t *, void *); … … 75 76 ui_pbutton_cb_t startmenu_edit_entry_button_cb = { 76 77 .clicked = startmenu_edit_entry_clicked 78 }; 79 80 /** Separator entry button callbacks */ 81 ui_pbutton_cb_t startmenu_sep_entry_button_cb = { 82 .clicked = startmenu_sep_entry_clicked 77 83 }; 78 84 … … 275 281 &startmenu_edit_entry_button_cb, (void *)smenu); 276 282 277 /* Move entry upbutton */278 279 rc = ui_pbutton_create(ui_res, " Up", &smenu->up_entry);283 /* Separator entry button */ 284 285 rc = ui_pbutton_create(ui_res, "Separator", &smenu->sep_entry); 280 286 if (rc != EOK) { 281 287 printf("Error creating button.\n"); … … 285 291 if (ui_resource_is_textmode(ui_res)) { 286 292 rect.p0.x = 58; 287 rect.p0.y = 1 2;293 rect.p0.y = 11; 288 294 rect.p1.x = 68; 289 rect.p1.y = 1 3;295 rect.p1.y = 12; 290 296 } else { 291 297 rect.p0.x = 370; 292 rect.p0.y = 1 90;298 rect.p0.y = 170; 293 299 rect.p1.x = 450; 294 rect.p1.y = 215;295 } 296 297 ui_pbutton_set_rect(smenu-> up_entry, &rect);298 299 rc = ui_fixed_add(smenu->fixed, ui_pbutton_ctl(smenu-> up_entry));300 rect.p1.y = 195; 301 } 302 303 ui_pbutton_set_rect(smenu->sep_entry, &rect); 304 305 rc = ui_fixed_add(smenu->fixed, ui_pbutton_ctl(smenu->sep_entry)); 300 306 if (rc != EOK) { 301 307 printf("Error adding control to layout.\n"); … … 303 309 } 304 310 305 ui_pbutton_set_cb(smenu-> up_entry,306 &startmenu_ up_entry_button_cb, (void *)smenu);307 308 /* Move entry downbutton */309 310 rc = ui_pbutton_create(ui_res, " Down", &smenu->down_entry);311 ui_pbutton_set_cb(smenu->sep_entry, 312 &startmenu_sep_entry_button_cb, (void *)smenu); 313 314 /* Move entry up button */ 315 316 rc = ui_pbutton_create(ui_res, "Up", &smenu->up_entry); 311 317 if (rc != EOK) { 312 318 printf("Error creating button.\n"); … … 316 322 if (ui_resource_is_textmode(ui_res)) { 317 323 rect.p0.x = 58; 318 rect.p0.y = 1 4;324 rect.p0.y = 13; 319 325 rect.p1.x = 68; 320 rect.p1.y = 1 5;326 rect.p1.y = 14; 321 327 } else { 322 328 rect.p0.x = 370; … … 324 330 rect.p1.x = 450; 325 331 rect.p1.y = 245; 332 } 333 334 ui_pbutton_set_rect(smenu->up_entry, &rect); 335 336 rc = ui_fixed_add(smenu->fixed, ui_pbutton_ctl(smenu->up_entry)); 337 if (rc != EOK) { 338 printf("Error adding control to layout.\n"); 339 goto error; 340 } 341 342 ui_pbutton_set_cb(smenu->up_entry, 343 &startmenu_up_entry_button_cb, (void *)smenu); 344 345 /* Move entry down button */ 346 347 rc = ui_pbutton_create(ui_res, "Down", &smenu->down_entry); 348 if (rc != EOK) { 349 printf("Error creating button.\n"); 350 goto error; 351 } 352 353 if (ui_resource_is_textmode(ui_res)) { 354 rect.p0.x = 58; 355 rect.p0.y = 15; 356 rect.p1.x = 68; 357 rect.p1.y = 16; 358 } else { 359 rect.p0.x = 370; 360 rect.p0.y = 250; 361 rect.p1.x = 450; 362 rect.p1.y = 275; 326 363 } 327 364 … … 418 455 startmenu_entry_t *smentry; 419 456 ui_list_entry_attr_t attr; 457 bool separator; 420 458 errno_t rc; 421 459 … … 428 466 429 467 ui_list_entry_attr_init(&attr); 430 attr.caption = smenu_entry_get_caption(entry); 468 separator = smenu_entry_get_separator(entry); 469 if (separator) 470 attr.caption = "-- Separator --"; 471 else 472 attr.caption = smenu_entry_get_caption(entry); 473 431 474 attr.arg = (void *)smentry; 475 432 476 rc = ui_list_entry_append(smenu->entries_list, &attr, &smentry->lentry); 433 477 if (rc != EOK) { … … 473 517 } 474 518 519 /** Create new separator menu entry. 520 * 521 * @param smenu Start menu 522 */ 523 void startmenu_sep_entry(startmenu_t *smenu) 524 { 525 startmenu_entry_t *smentry = NULL; 526 smenu_entry_t *entry; 527 errno_t rc; 528 529 rc = smenu_entry_sep_create(smenu->tbarcfg->tbarcfg, &entry); 530 if (rc != EOK) 531 return; 532 533 (void)startmenu_insert(smenu, entry, &smentry); 534 (void)ui_control_paint(ui_list_ctl(smenu->entries_list)); 535 } 536 475 537 /** Edit selected menu entry. 476 538 * … … 485 547 smentry = startmenu_get_selected(smenu); 486 548 if (smentry == NULL) 549 return; 550 551 /* Do not edit separator entries */ 552 if (smenu_entry_get_separator(smentry->entry)) 487 553 return; 488 554 … … 582 648 } 583 649 584 /** Upentry button clicked.650 /** Separator entry button clicked. 585 651 * 586 652 * @param pbutton Push button 587 653 * @param arg Argument (startmenu_t *) 588 654 */ 655 static void startmenu_sep_entry_clicked(ui_pbutton_t *pbutton, void *arg) 656 { 657 startmenu_t *smenu = (startmenu_t *)arg; 658 659 (void)pbutton; 660 startmenu_sep_entry(smenu); 661 } 662 663 /** Up entry button clicked. 664 * 665 * @param pbutton Push button 666 * @param arg Argument (startmenu_t *) 667 */ 589 668 static void startmenu_up_entry_clicked(ui_pbutton_t *pbutton, void *arg) 590 669 { -
uspace/app/taskbar-cfg/startmenu.h
r5f3188b8 re63e74a 1 1 /* 2 * Copyright (c) 202 3Jiri Svoboda2 * Copyright (c) 2024 Jiri Svoboda 3 3 * All rights reserved. 4 4 * … … 48 48 extern startmenu_entry_t *startmenu_get_selected(startmenu_t *); 49 49 extern void startmenu_new_entry(startmenu_t *); 50 extern void startmenu_sep_entry(startmenu_t *); 50 51 extern void startmenu_edit(startmenu_t *); 51 52 extern errno_t startmenu_entry_update(startmenu_entry_t *); -
uspace/app/taskbar-cfg/types/startmenu.h
r5f3188b8 re63e74a 62 62 /** Edit entry button */ 63 63 ui_pbutton_t *edit_entry; 64 /** Separator entry button */ 65 ui_pbutton_t *sep_entry; 64 66 /** Move entry up button */ 65 67 ui_pbutton_t *up_entry; -
uspace/app/taskbar/tbsmenu.c
r5f3188b8 re63e74a 129 129 tbarcfg_t *tbcfg = NULL; 130 130 smenu_entry_t *sme; 131 bool separator; 131 132 const char *caption; 132 133 const char *cmd; … … 140 141 sme = tbarcfg_smenu_first(tbcfg); 141 142 while (sme != NULL) { 142 caption = smenu_entry_get_caption(sme); 143 cmd = smenu_entry_get_cmd(sme); 144 terminal = smenu_entry_get_terminal(sme); 145 146 rc = tbsmenu_add(tbsmenu, caption, cmd, terminal, &tentry); 147 if (rc != EOK) 148 goto error; 143 separator = smenu_entry_get_separator(sme); 144 if (separator == false) { 145 caption = smenu_entry_get_caption(sme); 146 cmd = smenu_entry_get_cmd(sme); 147 terminal = smenu_entry_get_terminal(sme); 148 149 rc = tbsmenu_add(tbsmenu, caption, cmd, terminal, 150 &tentry); 151 if (rc != EOK) 152 goto error; 153 } else { 154 rc = tbsmenu_add_sep(tbsmenu, &tentry); 155 if (rc != EOK) 156 goto error; 157 } 149 158 150 159 (void)tentry; … … 272 281 if (entry->cmd != NULL) 273 282 free(entry->cmd); 283 free(entry); 284 return rc; 285 } 286 287 /** Add separator entry to start menu. 288 * 289 * @param tbsmenu Start menu 290 * @param entry Start menu entry 291 * @return @c EOK on success or an error code 292 */ 293 errno_t tbsmenu_add_sep(tbsmenu_t *tbsmenu, tbsmenu_entry_t **rentry) 294 { 295 errno_t rc; 296 tbsmenu_entry_t *entry; 297 298 entry = calloc(1, sizeof(tbsmenu_entry_t)); 299 if (entry == NULL) 300 return ENOMEM; 301 302 rc = ui_menu_entry_sep_create(tbsmenu->smenu, &entry->mentry); 303 if (rc != EOK) 304 goto error; 305 306 ui_menu_entry_set_cb(entry->mentry, tbsmenu_smenu_entry_cb, 307 (void *)entry); 308 309 entry->tbsmenu = tbsmenu; 310 list_append(&entry->lentries, &tbsmenu->entries); 311 *rentry = entry; 312 return EOK; 313 error: 274 314 free(entry); 275 315 return rc; -
uspace/app/taskbar/tbsmenu.h
r5f3188b8 re63e74a 55 55 extern errno_t tbsmenu_add(tbsmenu_t *, const char *, const char *, bool, 56 56 tbsmenu_entry_t **); 57 extern errno_t tbsmenu_add_sep(tbsmenu_t *, tbsmenu_entry_t **); 57 58 extern void tbsmenu_remove(tbsmenu_t *, tbsmenu_entry_t *, bool); 58 59 extern tbsmenu_entry_t *tbsmenu_first(tbsmenu_t *);
Note:
See TracChangeset
for help on using the changeset viewer.