Changeset 983052c in mainline for uspace/app/taskbar/wndlist.c


Ignore:
Timestamp:
2023-10-10T12:30:54Z (15 months ago)
Author:
Jiri Svoboda <jiri@…>
Branches:
master, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
bd2fab5
Parents:
9bec33a
git-author:
Jiri Svoboda <jiri@…> (2023-10-09 18:30:06)
git-committer:
Jiri Svoboda <jiri@…> (2023-10-10 12:30:54)
Message:

Task bar should not crash when starting in terminal

Firstly, we need to make sure we do not paint anything while
UI is suspended. Also, we were missing calls to ui_lock/unlock()
while delivering kbd/pos events from console.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/app/taskbar/wndlist.c

    r9bec33a r983052c  
    254254                wndlist_set_entry_rect(wndlist, entry);
    255255                if (paint)
    256                         return ui_pbutton_paint(entry->button);
     256                        return wndlist_paint_entry(entry);
    257257        }
    258258
     
    320320                        wndlist_set_entry_rect(wndlist, e);
    321321                        if (paint) {
    322                                 rc = ui_pbutton_paint(e->button);
     322                                rc = wndlist_paint_entry(e);
    323323                                if (rc != EOK)
    324324                                        return rc;
     
    402402        ui_pbutton_set_light(entry->button, active);
    403403
    404         rc = ui_pbutton_paint(entry->button);
     404        rc = wndlist_paint_entry(entry);
    405405        if (rc != EOK)
    406406                return rc;
    407407
    408         return wndlist_repaint(wndlist);
     408        return EOK;
    409409}
    410410
     
    470470}
    471471
    472 /** Unpaint window list entry.
     472/** Paint window list entry.
    473473 *
    474474 * @param entry Window list entry
    475475 * @return EOK on success or an error code
    476476 */
     477errno_t wndlist_paint_entry(wndlist_entry_t *entry)
     478{
     479        ui_t *ui;
     480
     481        ui = ui_window_get_ui(entry->wndlist->window);
     482        if (ui_is_suspended(ui))
     483                return EOK;
     484
     485        return ui_pbutton_paint(entry->button);
     486}
     487
     488/** Unpaint window list entry.
     489 *
     490 * @param entry Window list entry
     491 * @return EOK on success or an error code
     492 */
    477493errno_t wndlist_unpaint_entry(wndlist_entry_t *entry)
    478494{
    479495        errno_t rc;
     496        ui_t *ui;
    480497        gfx_context_t *gc;
    481498        ui_resource_t *res;
    482499        gfx_color_t *color;
    483500
     501        ui = ui_window_get_ui(entry->wndlist->window);
    484502        gc = ui_window_get_gc(entry->wndlist->window);
    485503        res = ui_window_get_res(entry->wndlist->window);
    486504        color = ui_resource_get_wnd_face_color(res);
    487505
     506        if (ui_is_suspended(ui))
     507                return EOK;
     508
    488509        rc = gfx_set_color(gc, color);
    489510        if (rc != EOK)
     
    510531        wndlist_t *wndlist = (wndlist_t *)arg;
    511532        wndmgt_window_info_t *winfo = NULL;
     533        ui_t *ui;
    512534        errno_t rc;
     535
     536        ui = ui_window_get_ui(wndlist->window);
     537        ui_lock(ui);
    513538
    514539        rc = wndmgt_get_window_info(wndlist->wndmgt, wnd_id, &winfo);
     
    526551
    527552        wndmgt_free_window_info(winfo);
     553        ui_unlock(ui);
    528554        return;
    529555error:
    530556        if (winfo != NULL)
    531557                wndmgt_free_window_info(winfo);
     558        ui_unlock(ui);
    532559}
    533560
     
    541568        wndlist_t *wndlist = (wndlist_t *)arg;
    542569        wndlist_entry_t *entry;
     570        ui_t *ui;
     571
     572        ui = ui_window_get_ui(wndlist->window);
     573        ui_lock(ui);
    543574
    544575        entry = wndlist_entry_by_id(wndlist, wnd_id);
    545         if (entry == NULL)
     576        if (entry == NULL) {
     577                ui_unlock(ui);
    546578                return;
     579        }
    547580
    548581        (void) wndlist_remove(wndlist, entry, true);
     582        ui_unlock(ui);
    549583}
    550584
     
    559593        wndmgt_window_info_t *winfo = NULL;
    560594        wndlist_entry_t *entry;
     595        ui_t *ui;
    561596        errno_t rc;
    562597
     598        ui = ui_window_get_ui(wndlist->window);
     599        ui_lock(ui);
     600
    563601        entry = wndlist_entry_by_id(wndlist, wnd_id);
    564         if (entry == NULL)
     602        if (entry == NULL) {
     603                ui_unlock(ui);
    565604                return;
     605        }
    566606
    567607        rc = wndmgt_get_window_info(wndlist->wndmgt, wnd_id, &winfo);
    568         if (rc != EOK)
     608        if (rc != EOK) {
     609                ui_unlock(ui);
    569610                return;
     611        }
    570612
    571613        (void) wndlist_update(wndlist, entry, winfo->caption,
    572614            winfo->nfocus != 0);
    573615        wndmgt_free_window_info(winfo);
     616        ui_unlock(ui);
    574617}
    575618
     
    660703errno_t wndlist_repaint(wndlist_t *wndlist)
    661704{
     705        if (ui_is_suspended(ui_window_get_ui(wndlist->window)))
     706                return EOK;
     707
    662708        return ui_window_paint(wndlist->window);
    663709}
Note: See TracChangeset for help on using the changeset viewer.