Changes in / [34aad53d:e4cc266] in mainline


Ignore:
Files:
5 added
36 deleted
49 edited

Legend:

Unmodified
Added
Removed
  • README.md

    r34aad53d re4cc266  
    1010extensible, fault tolerant and easy to understand.
    1111
    12 ![screenshot](http://www.helenos.org/raw-attachment/wiki/Screenshots/gui-14.1-aio.png "Screenshot")
     12![screenshot](http://www.helenos.org/raw-attachment/wiki/Screenshots/newgui-aio.png "Screenshot")
    1313
    1414HelenOS aims to be compatible with the C11 and C++14 standards, but does not
  • abi/include/abi/ipc/interfaces.h

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * Copyright (c) 2014 Martin Decky
    44 * All rights reserved.
     
    201201        INTERFACE_WNDMGT_CB =
    202202            FOURCC_COMPACT('w', 'm', 'g', 't') | IFACE_EXCHANGE_SERIALIZE | IFACE_MOD_CALLBACK,
    203         INTERFACE_TBARCFG_NOTIFY =
    204             FOURCC_COMPACT('t', 'b', 'c', 'f') | IFACE_EXCHANGE_SERIALIZE,
    205203        INTERFACE_PCAP_CONTROL =
    206204            FOURCC_COMPACT('p', 'c', 't', 'l') | IFACE_EXCHANGE_SERIALIZE,
  • defaults/ia64/Makefile.config

    r34aad53d re4cc266  
    5151
    5252# Optimization level
    53 OPTIMIZATION = 2
     53OPTIMIZATION = 3
  • meson/part/initrd_manifest/meson.build

    r34aad53d re4cc266  
    6868if CONFIG_FB
    6969        rd_essential += [
    70                 'app/taskbar',
     70                'app/launcher',
    7171                'app/terminal',
    7272
  • tools/export.sh

    r34aad53d re4cc266  
    4343        uspace/lib/libc.a \
    4444        uspace/lib/libcongfx.a \
    45         uspace/lib/libconsole.a \
    4645        uspace/lib/libcpp.a \
    4746        uspace/lib/libdisplay.a \
     
    4948        uspace/lib/libgfxfont.a \
    5049        uspace/lib/libgfximage.a \
    51         uspace/lib/libinput.a \
    5250        uspace/lib/libhound.a \
    5351        uspace/lib/libipcgfx.a \
    5452        uspace/lib/libmath.a \
    5553        uspace/lib/libmemgfx.a \
    56         uspace/lib/liboutput.a \
    5754        uspace/lib/libpcm.a \
    5855        uspace/lib/libpixconv.a \
  • tools/mkarray.py

    r34aad53d re4cc266  
    3939def usage(prname):
    4040        "Print usage syntax"
    41         print("%s [--deflate] <DESTINATION> <TYPENAME> <LABEL> <AS_PROLOG> <SECTION> [SOURCE ...]" % prname)
     41        print("%s [--deflate] <DESTINATION> <LABEL> <AS_PROLOG> <SECTION> [SOURCE ...]" % prname)
    4242
    4343def arg_check():
    44         if (len(sys.argv) < 6):
     44        if (len(sys.argv) < 5):
    4545                usage(sys.argv[0])
    4646                sys.exit()
     
    6666
    6767        dest = sys.argv[1]
    68         typename = sys.argv[2]
    69         label = sys.argv[3]
    70         as_prolog = sys.argv[4]
    71         section = sys.argv[5]
     68        label = sys.argv[2]
     69        as_prolog = sys.argv[3]
     70        section = sys.argv[4]
    7271
    7372        timestamp = (1980, 1, 1, 0, 0, 0)
     
    8281        archive = zipfile.ZipFile("%s.zip" % dest, "w", zipfile.ZIP_STORED)
    8382
    84         for src in sys.argv[6:]:
     83        for src in sys.argv[5:]:
    8584                basename = os.path.basename(src)
    8685                plainname = os.path.splitext(basename)[0]
     
    148147        data += "#include <stdbool.h>\n\n"
    149148        data += "#define %sS  %u\n\n" % (label.upper(), src_cnt)
    150         data += "#ifndef %sS_T_\n" % typename.upper()
    151         data += "#define %sS_T_\n\n" % typename.upper()
    152149        data += "typedef struct {\n"
    153150        data += "\tconst char *name;\n"
     
    156153        data += "\tsize_t inflated;\n"
    157154        data += "\tbool compressed;\n"
    158         data += "} %s_t;\n\n" % typename
    159         data += "#endif\n"
    160         data += "extern %s_t %ss[];\n\n" % (typename, label)
     155        data += "} %s_t;\n\n" % label
     156        data += "extern %s_t %ss[];\n\n" % (label, label)
    161157        data += "\n".join(header_ctx)
    162158        data += "\n\n"
     
    183179        data += ' */\n\n'
    184180        data += "#include \"%s.h\"\n\n" % dest
    185         data += "%s_t %ss[] = {\n" % (typename, label)
     181        data += "%s_t %ss[] = {\n" % (label, label)
    186182        data += ",\n".join(desc_ctx)
    187183        data += "\n"
  • tools/mkarray_for_meson.sh

    r34aad53d re4cc266  
    4242_arg3="$4"
    4343_arg4="$5"
    44 _arg5="$6"
    4544_inputs=""
    4645
    47 shift 6
     46shift 5
    4847
    4948for file in "$@"; do
     
    5251
    5352cd $_outdir
    54 $TOOLS_DIR/mkarray.py "$_arg1" "$_arg2" "$_arg3" "$_arg4" "$_arg5" $_inputs > /dev/null
     53$TOOLS_DIR/mkarray.py "$_arg1" "$_arg2" "$_arg3" "$_arg4" $_inputs > /dev/null
  • tools/xcw/bin/helenos-pkg-config

    r34aad53d re4cc266  
    9393    config = args.parse_args()
    9494
    95     export_dir = os.getenv('EXPORT_DIR', get_build_root() + '/export')
     95    export_dir = os.getenv('EXPORT_DIR', get_build_root())
    9696
    9797    result = []
  • uspace/app/barber/barber.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2020 Jiri Svoboda
    33 * Copyright (c) 2014 Martin Decky
    44 * All rights reserved.
     
    5050#include <ui/image.h>
    5151#include "images.h"
    52 #include "images_tiny.h"
    5352
    5453#define NAME  "barber"
     
    6160#define MIN_LOAD  (LOAD_UNIT / 4)
    6261#define MAX_LOAD  (LOAD_UNIT / 3)
     62
     63#define FRAME_WIDTH   59
     64#define FRAME_HEIGHT  192
    6365
    6466#define LED_PERIOD  1000000
     
    9597static unsigned int frame = 0;
    9698static unsigned int fps = MIN_FPS;
    97 static gfx_coord_t frame_width;
    98 static gfx_coord_t frame_height;
    9999
    100100static void led_timer_callback(void *);
     
    102102
    103103static void wnd_close(ui_window_t *, void *);
    104 static void wnd_kbd_event(ui_window_t *, void *, kbd_event_t *);
    105104
    106105static ui_window_cb_t window_cb = {
    107         .close = wnd_close,
    108         .kbd = wnd_kbd_event
     106        .close = wnd_close
    109107};
    110108
     
    112110 *
    113111 * @param window Window
    114  * @param arg Argument (barber)
     112 * @param arg Argument (launcher)
    115113 */
    116114static void wnd_close(ui_window_t *window, void *arg)
     
    121119}
    122120
    123 /** Barber unmodified key press.
    124  *
    125  * @param barber Barber
    126  * @param event Keyboard event
    127  */
    128 static void barber_kbd_event_unmod(barber_t *barber, kbd_event_t *event)
    129 {
    130         if (event->key == KC_ESCAPE)
    131                 ui_quit(barber->ui);
    132 }
    133 
    134 /** Barber ctrl-key key press.
    135  *
    136  * @param barber Barber
    137  * @param event Keyboard event
    138  */
    139 static void barber_kbd_event_ctrl(barber_t *barber, kbd_event_t *event)
    140 {
    141         if (event->key == KC_Q)
    142                 ui_quit(barber->ui);
    143 }
    144 
    145 /** Barber window keyboard event.
    146  *
    147  * @param window UI window
    148  * @param arg Argument (barber_t *)
    149  * @param event Keyboard event
    150  */
    151 static void wnd_kbd_event(ui_window_t *window, void *arg, kbd_event_t *event)
    152 {
    153         barber_t *barber = (barber_t *)arg;
    154 
    155         if (event->type != KEY_PRESS)
    156                 return;
    157 
    158         if ((event->mods & (KM_CTRL | KM_ALT | KM_SHIFT)) == 0)
    159                 barber_kbd_event_unmod(barber, event);
    160 
    161         if ((event->mods & KM_CTRL) != 0 &&
    162             (event->mods & (KM_ALT | KM_SHIFT)) == 0)
    163                 barber_kbd_event_ctrl(barber, event);
    164 
    165         ui_window_def_kbd(window, event);
    166 }
    167 
    168 static bool decode_frames(gfx_context_t *gc, image_t *img)
     121static bool decode_frames(gfx_context_t *gc)
    169122{
    170123        gfx_rect_t rect;
     
    172125
    173126        for (unsigned int i = 0; i < FRAMES; i++) {
    174                 rc = decode_tga_gz(gc, img[i].addr, img[i].size,
     127                rc = decode_tga_gz(gc, images[i].addr, images[i].size,
    175128                    &frame_bmp[i], &rect);
    176129                if (rc != EOK) {
     
    179132                }
    180133
    181                 (void)rect;
     134                (void) rect;
    182135        }
    183136
     
    285238        rect.p0.x = 0;
    286239        rect.p0.y = 0;
    287         rect.p1.x = frame_width;
    288         rect.p1.y = frame_height;
     240        rect.p1.x = FRAME_WIDTH;
     241        rect.p1.y = FRAME_HEIGHT;
    289242
    290243        ui_image_set_bmp(frame_img, frame_bmp[frame], &rect);
     
    346299int main(int argc, char *argv[])
    347300{
    348         const char *display_spec = UI_ANY_DEFAULT;
     301        const char *display_spec = UI_DISPLAY_DEFAULT;
    349302        barber_t barber;
    350303        ui_t *ui;
     
    357310        gfx_context_t *gc;
    358311        gfx_coord2_t off;
    359         image_t *img;
    360312        int i;
    361313
     
    403355        }
    404356
    405         if (ui_is_textmode(ui)) {
    406                 frame_width = 10;
    407                 frame_height = 16;
    408         } else {
    409                 frame_width = 59;
    410                 frame_height = 192;
    411         }
    412 
    413357        rect.p0.x = 0;
    414358        rect.p0.y = 0;
    415         rect.p1.x = frame_width;
    416         rect.p1.y = frame_height;
     359        rect.p1.x = FRAME_WIDTH;
     360        rect.p1.y = FRAME_HEIGHT;
    417361
    418362        ui_wnd_params_init(&params);
     
    423367         * to rect
    424368         */
    425         ui_wdecor_rect_from_app(ui, params.style, &rect, &wrect);
     369        ui_wdecor_rect_from_app(params.style, &rect, &wrect);
    426370        off = wrect.p0;
    427371        gfx_rect_rtranslate(&off, &wrect, &params.rect);
     
    440384        ui_window_set_cb(window, &window_cb, (void *) &barber);
    441385
    442         img = ui_is_textmode(ui) ? image_tinys : images;
    443 
    444         if (!decode_frames(gc, img))
     386        if (!decode_frames(gc))
    445387                return 1;
    446388
  • uspace/app/barber/meson.build

    r34aad53d re4cc266  
    6262)
    6363
    64 _images_tiny = files(
    65         'gfx-tiny/frame01t.tga.gz',
    66         'gfx-tiny/frame02t.tga.gz',
    67         'gfx-tiny/frame03t.tga.gz',
    68         'gfx-tiny/frame04t.tga.gz',
    69         'gfx-tiny/frame05t.tga.gz',
    70         'gfx-tiny/frame06t.tga.gz',
    71         'gfx-tiny/frame07t.tga.gz',
    72         'gfx-tiny/frame08t.tga.gz',
    73         'gfx-tiny/frame09t.tga.gz',
    74         'gfx-tiny/frame10t.tga.gz',
    75         'gfx-tiny/frame11t.tga.gz',
    76         'gfx-tiny/frame12t.tga.gz',
    77         'gfx-tiny/frame13t.tga.gz',
    78         'gfx-tiny/frame14t.tga.gz',
    79         'gfx-tiny/frame15t.tga.gz',
    80         'gfx-tiny/frame16t.tga.gz',
    81         'gfx-tiny/frame17t.tga.gz',
    82         'gfx-tiny/frame18t.tga.gz',
    83         'gfx-tiny/frame19t.tga.gz',
    84         'gfx-tiny/frame20t.tga.gz',
    85         'gfx-tiny/frame21t.tga.gz',
    86         'gfx-tiny/frame22t.tga.gz',
    87         'gfx-tiny/frame23t.tga.gz',
    88         'gfx-tiny/frame24t.tga.gz',
    89         'gfx-tiny/frame25t.tga.gz',
    90         'gfx-tiny/frame26t.tga.gz',
    91         'gfx-tiny/frame27t.tga.gz',
    92         'gfx-tiny/frame28t.tga.gz',
    93         'gfx-tiny/frame29t.tga.gz',
    94         'gfx-tiny/frame30t.tga.gz',
    95 )
    96 
    9764_tarball = custom_target('barber_images.tar',
    9865        input: _images,
     
    10370# TODO
    10471
    105 # Normal images
    106 
    10772_images_zip = custom_target('barber_images.zip',
    10873        input : _images,
    10974        output : [ 'images.zip' ],
    110         command : [ mkarray, '@OUTDIR@', 'images', 'image', 'image', uspace_as_prolog, '.data', '@INPUT@' ],
     75        command : [ mkarray, '@OUTDIR@', 'images', 'image', uspace_as_prolog, '.data', '@INPUT@' ],
    11176)
    11277_imgs_s = custom_target('barber_images.s',
     
    12994)
    13095
    131 # Tiny images
    132 
    133 _images_tiny_zip = custom_target('barber_images_tiny.zip',
    134         input : _images_tiny,
    135         output : [ 'images_tiny.zip' ],
    136         command : [ mkarray, '@OUTDIR@', 'images_tiny', 'image', 'image_tiny', uspace_as_prolog, '.data', '@INPUT@' ],
    137 )
    138 _imgs_tiny_s = custom_target('barber_images_tiny.s',
    139         input : _images_tiny_zip,
    140         output : [ 'images_tiny.s' ],
    141         command : [ unzip, '-p', '@INPUT@', 'images_tiny.s' ],
    142         capture : true,
    143 )
    144 _imgs_tiny_h = custom_target('barber_images_tiny.h',
    145         input : _images_tiny_zip,
    146         output : [ 'images_tiny.h' ],
    147         command : [ unzip, '-p', '@INPUT@', 'images_tiny.h' ],
    148         capture : true,
    149 )
    150 _imgs_tiny_desc_c = custom_target('barber_images_tiny_desc.c',
    151         input : _images_tiny_zip,
    152         output : [ 'images_tiny_desc.c' ],
    153         command : [ unzip, '-p', '@INPUT@', 'images_tiny_desc.c' ],
    154         capture : true,
    155 )
    156 
    157 src = [ files('barber.c'), _imgs_s, _imgs_h, _imgs_desc_c,
    158     _imgs_tiny_s, _imgs_tiny_h, _imgs_tiny_desc_c ]
     96src = [ files('barber.c'), _imgs_s, _imgs_h, _imgs_desc_c ]
  • uspace/app/fontedit/fontedit.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2022 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    787787         * to rect
    788788         */
    789         ui_wdecor_rect_from_app(ui, params.style, &rect, &wrect);
     789        ui_wdecor_rect_from_app(params.style, &rect, &wrect);
    790790        off = wrect.p0;
    791791        gfx_rect_rtranslate(&off, &wrect, &params.rect);
  • uspace/app/gfxdemo/gfxdemo.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    393393                for (j = 0; j < h; j++) {
    394394                        pixelmap_put_pixel(&pixelmap, i, j,
    395                             PIXEL(255, (i % 30) < 3 ? 255 : 0,
     395                            PIXEL(0, (i % 30) < 3 ? 255 : 0,
    396396                            (j % 30) < 3 ? 255 : 0, i / 2));
    397397                }
     
    429429                        k = i * i + j * j;
    430430                        pixelmap_put_pixel(&pixelmap, i, j,
    431                             PIXEL(255, k, k, k));
     431                            PIXEL(0, k, k, k));
    432432                }
    433433        }
     
    464464                        k = i * i + j * j;
    465465                        pixelmap_put_pixel(&pixelmap, i, j,
    466                             k < w * w / 2 ? PIXEL(255, 0, 255, 0) :
    467                             PIXEL(255, 255, 0, 255));
     466                            k < w * w / 2 ? PIXEL(0, 0, 255, 0) :
     467                            PIXEL(0, 255, 0, 255));
    468468                }
    469469        }
     
    621621        params.rect.p1.y = 40;
    622622        params.flags = bmpf_color_key;
    623         params.key_color = PIXEL(255, 255, 0, 255);
     623        params.key_color = PIXEL(0, 255, 0, 255);
    624624
    625625        rc = gfx_bitmap_create(gc, &params, NULL, &bitmap);
     
    11601160         * to rect
    11611161         */
    1162         ui_wdecor_rect_from_app(ui, params.style, &rect, &wrect);
     1162        ui_wdecor_rect_from_app(params.style, &rect, &wrect);
    11631163        off = wrect.p0;
    11641164        gfx_rect_rtranslate(&off, &wrect, &params.rect);
  • uspace/app/init/init.c

    r34aad53d re4cc266  
    476476                rc = display_server();
    477477                if (rc == EOK) {
     478                        app_start("/app/launcher", NULL);
    478479                        app_start("/app/taskbar", NULL);
    479480                        app_start("/app/terminal", "-topleft");
  • uspace/app/meson.build

    r34aad53d re4cc266  
    2828
    2929apps = [
    30         'aboutos',
    3130        'barber',
    3231        'bdsh',
     
    5857        'killall',
    5958        'kio',
     59        'launcher',
    6060        'loc',
    6161        'logset',
  • uspace/app/nav/test/panel.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2022 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    5555PCUT_TEST(create_destroy)
    5656{
     57        panel_t *panel;
     58        errno_t rc;
     59
     60        rc = panel_create(NULL, true, &panel);
     61        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     62
     63        panel_destroy(panel);
     64}
     65
     66/** panel_set_cb() sets callback */
     67PCUT_TEST(set_cb)
     68{
     69        panel_t *panel;
     70        errno_t rc;
     71        test_resp_t resp;
     72
     73        rc = panel_create(NULL, true, &panel);
     74        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     75
     76        panel_set_cb(panel, &test_cb, &resp);
     77        PCUT_ASSERT_EQUALS(&test_cb, panel->cb);
     78        PCUT_ASSERT_EQUALS(&resp, panel->cb_arg);
     79
     80        panel_destroy(panel);
     81}
     82
     83/** Test panel_paint() */
     84PCUT_TEST(paint)
     85{
    5786        ui_t *ui;
    5887        ui_window_t *window;
     
    73102        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    74103
     104        rc = panel_paint(panel);
     105        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     106
    75107        panel_destroy(panel);
    76108        ui_window_destroy(window);
     
    78110}
    79111
    80 /** panel_set_cb() sets callback */
    81 PCUT_TEST(set_cb)
    82 {
    83         ui_t *ui;
    84         ui_window_t *window;
    85         ui_wnd_params_t params;
    86         panel_t *panel;
    87         errno_t rc;
    88         test_resp_t resp;
    89 
    90         rc = ui_create_disp(NULL, &ui);
    91         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    92 
    93         ui_wnd_params_init(&params);
    94         params.caption = "Test";
    95 
    96         rc = ui_window_create(ui, &params, &window);
    97         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    98 
    99         rc = panel_create(window, true, &panel);
    100         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    101 
    102         panel_set_cb(panel, &test_cb, &resp);
    103         PCUT_ASSERT_EQUALS(&test_cb, panel->cb);
    104         PCUT_ASSERT_EQUALS(&resp, panel->cb_arg);
    105 
    106         panel_destroy(panel);
    107         ui_window_destroy(window);
    108         ui_destroy(ui);
    109 }
    110 
    111 /** Test panel_paint() */
    112 PCUT_TEST(paint)
    113 {
    114         ui_t *ui;
    115         ui_window_t *window;
    116         ui_wnd_params_t params;
    117         panel_t *panel;
    118         errno_t rc;
    119 
    120         rc = ui_create_disp(NULL, &ui);
    121         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    122 
    123         ui_wnd_params_init(&params);
    124         params.caption = "Test";
    125 
    126         rc = ui_window_create(ui, &params, &window);
    127         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    128 
    129         rc = panel_create(window, true, &panel);
    130         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    131 
    132         rc = panel_paint(panel);
    133         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    134 
    135         panel_destroy(panel);
    136         ui_window_destroy(window);
    137         ui_destroy(ui);
    138 }
    139 
    140112/** panel_ctl() returns a valid UI control */
    141113PCUT_TEST(ctl)
    142114{
    143         ui_t *ui;
    144         ui_window_t *window;
    145         ui_wnd_params_t params;
    146115        panel_t *panel;
    147116        ui_control_t *control;
    148117        errno_t rc;
    149118
    150         rc = ui_create_disp(NULL, &ui);
    151         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    152 
    153         ui_wnd_params_init(&params);
    154         params.caption = "Test";
    155 
    156         rc = ui_window_create(ui, &params, &window);
    157         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    158 
    159         rc = panel_create(window, true, &panel);
     119        rc = panel_create(NULL, true, &panel);
    160120        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    161121
     
    164124
    165125        panel_destroy(panel);
    166         ui_window_destroy(window);
    167         ui_destroy(ui);
    168126}
    169127
     
    171129PCUT_TEST(kbd_event)
    172130{
    173         ui_t *ui;
    174         ui_window_t *window;
    175         ui_wnd_params_t params;
    176131        panel_t *panel;
    177132        ui_evclaim_t claimed;
     
    181136        /* Active panel should claim events */
    182137
    183         rc = ui_create_disp(NULL, &ui);
    184         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    185 
    186         ui_wnd_params_init(&params);
    187         params.caption = "Test";
    188 
    189         rc = ui_window_create(ui, &params, &window);
    190         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    191 
    192         rc = panel_create(window, true, &panel);
     138        rc = panel_create(NULL, true, &panel);
    193139        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    194140
     
    205151        /* Inactive panel should not claim events */
    206152
    207         rc = panel_create(window, false, &panel);
     153        rc = panel_create(NULL, false, &panel);
    208154        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    209155
     
    217163
    218164        panel_destroy(panel);
    219         ui_window_destroy(window);
    220         ui_destroy(ui);
    221165}
    222166
     
    229173PCUT_TEST(set_rect)
    230174{
    231         ui_t *ui;
    232         ui_window_t *window;
    233         ui_wnd_params_t params;
    234175        panel_t *panel;
    235176        gfx_rect_t rect;
    236177        errno_t rc;
    237178
    238         rc = ui_create_disp(NULL, &ui);
    239         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    240 
    241         ui_wnd_params_init(&params);
    242         params.caption = "Test";
    243 
    244         rc = ui_window_create(ui, &params, &window);
    245         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    246 
    247         rc = panel_create(window, true, &panel);
     179        rc = panel_create(NULL, true, &panel);
    248180        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    249181
     
    260192
    261193        panel_destroy(panel);
    262         ui_window_destroy(window);
    263         ui_destroy(ui);
    264194}
    265195
    266196/** panel_is_active() returns panel activity state */
    267197PCUT_TEST(is_active)
     198{
     199        panel_t *panel;
     200        errno_t rc;
     201
     202        rc = panel_create(NULL, true, &panel);
     203        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     204        PCUT_ASSERT_TRUE(panel_is_active(panel));
     205        panel_destroy(panel);
     206
     207        rc = panel_create(NULL, false, &panel);
     208        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     209        PCUT_ASSERT_FALSE(panel_is_active(panel));
     210        panel_destroy(panel);
     211}
     212
     213/** panel_activate() activates panel */
     214PCUT_TEST(activate)
    268215{
    269216        ui_t *ui;
     
    282229        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    283230
    284         rc = panel_create(window, true, &panel);
     231        rc = panel_create(window, false, &panel);
     232        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     233
     234        PCUT_ASSERT_FALSE(panel_is_active(panel));
     235        rc = panel_activate(panel);
    285236        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    286237        PCUT_ASSERT_TRUE(panel_is_active(panel));
    287         panel_destroy(panel);
    288 
    289         rc = panel_create(window, false, &panel);
    290         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    291         PCUT_ASSERT_FALSE(panel_is_active(panel));
     238
    292239        panel_destroy(panel);
    293240        ui_window_destroy(window);
     
    295242}
    296243
    297 /** panel_activate() activates panel */
    298 PCUT_TEST(activate)
     244/** panel_deactivate() deactivates panel */
     245PCUT_TEST(deactivate)
    299246{
    300247        ui_t *ui;
     
    313260        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    314261
    315         rc = panel_create(window, false, &panel);
    316         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    317 
    318         PCUT_ASSERT_FALSE(panel_is_active(panel));
    319         rc = panel_activate(panel);
    320         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    321         PCUT_ASSERT_TRUE(panel_is_active(panel));
    322 
    323         panel_destroy(panel);
    324         ui_window_destroy(window);
    325         ui_destroy(ui);
    326 }
    327 
    328 /** panel_deactivate() deactivates panel */
    329 PCUT_TEST(deactivate)
    330 {
    331         ui_t *ui;
    332         ui_window_t *window;
    333         ui_wnd_params_t params;
    334         panel_t *panel;
    335         errno_t rc;
    336 
    337         rc = ui_create_disp(NULL, &ui);
    338         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    339 
    340         ui_wnd_params_init(&params);
    341         params.caption = "Test";
    342 
    343         rc = ui_window_create(ui, &params, &window);
    344         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    345 
    346262        rc = panel_create(window, true, &panel);
    347263        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
     
    359275PCUT_TEST(activate_req)
    360276{
    361         ui_t *ui;
    362         ui_window_t *window;
    363         ui_wnd_params_t params;
    364277        panel_t *panel;
    365278        errno_t rc;
    366279        test_resp_t resp;
    367280
    368         rc = ui_create_disp(NULL, &ui);
    369         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    370 
    371         ui_wnd_params_init(&params);
    372         params.caption = "Test";
    373 
    374         rc = ui_window_create(ui, &params, &window);
    375         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    376 
    377         rc = panel_create(window, true, &panel);
     281        rc = panel_create(NULL, true, &panel);
    378282        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    379283
     
    388292
    389293        panel_destroy(panel);
    390         ui_window_destroy(window);
    391         ui_destroy(ui);
    392294}
    393295
  • uspace/app/taskbar-cfg/smeedit.c

    r34aad53d re4cc266  
    403403
    404404                startmenu_repaint(smee->startmenu);
    405                 (void)tbarcfg_notify(TBARCFG_NOTIFY_DEFAULT);
    406405        } else {
    407406                /* Edit existing entry */
     
    420419                (void)smenu_entry_save(smee->smentry->entry);
    421420                startmenu_entry_update(smee->smentry);
    422                 (void)tbarcfg_notify(TBARCFG_NOTIFY_DEFAULT);
    423421        }
    424422
  • uspace/app/taskbar-cfg/startmenu.c

    r34aad53d re4cc266  
    515515
    516516        (void)smee;
    517         (void)tbarcfg_notify(TBARCFG_NOTIFY_DEFAULT);
    518517}
    519518
     
    534533        (void)startmenu_insert(smenu, entry, &smentry);
    535534        (void)ui_control_paint(ui_list_ctl(smenu->entries_list));
    536         (void)tbarcfg_notify(TBARCFG_NOTIFY_DEFAULT);
    537535}
    538536
     
    635633        free(smentry);
    636634        (void)ui_control_paint(ui_list_ctl(smenu->entries_list));
    637         (void)tbarcfg_notify(TBARCFG_NOTIFY_DEFAULT);
    638635}
    639636
     
    688685
    689686        (void)ui_control_paint(ui_list_ctl(smenu->entries_list));
    690         (void)tbarcfg_notify(TBARCFG_NOTIFY_DEFAULT);
    691687}
    692688
     
    708704                return;
    709705
    710         rc = smenu_entry_move_down(smentry->entry);
     706        rc = smenu_entry_move_up(smentry->entry);
    711707        if (rc != EOK)
    712708                return;
     
    715711
    716712        (void)ui_control_paint(ui_list_ctl(smenu->entries_list));
    717         (void)tbarcfg_notify(TBARCFG_NOTIFY_DEFAULT);
    718713}
    719714
  • uspace/app/taskbar/meson.build

    r34aad53d re4cc266  
    4848)
    4949
    50 installed_data += { 'name': 'taskbar.sif', 'dir': '/cfg' }
     50if install_nonessential_data
     51        installed_data += { 'name': 'taskbar.sif', 'dir': '/cfg' }
     52endif
  • uspace/app/taskbar/taskbar.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    4848#include "wndlist.h"
    4949
    50 #define TASKBAR_CONFIG_FILE "/cfg/taskbar.sif"
    51 
    5250static void taskbar_wnd_close(ui_window_t *, void *);
    5351static void taskbar_wnd_kbd(ui_window_t *, void *, kbd_event_t *);
    5452static void taskbar_wnd_pos(ui_window_t *, void *, pos_event_t *);
    55 static void taskbar_notif_cb(void *);
    5653
    5754static ui_window_cb_t window_cb = {
     
    131128        gfx_rect_t scr_rect;
    132129        gfx_rect_t rect;
    133         char *dspec = NULL;
    134         char *qmark;
    135130        errno_t rc;
    136131
    137132        taskbar = calloc(1, sizeof(taskbar_t));
    138133        if (taskbar == NULL) {
    139                 printf("Out of memory.\n");
    140134                rc = ENOMEM;
    141135                goto error;
    142136        }
    143 
    144         dspec = str_dup(display_spec);
    145         if (dspec == NULL) {
    146                 printf("Out of memory.\n");
    147                 rc = ENOMEM;
    148                 goto error;
    149         }
    150 
    151         /* Remove additional arguments */
    152         qmark = str_chr(dspec, '?');
    153         if (qmark != NULL)
    154                 *qmark = '\0';
    155137
    156138        rc = ui_create(display_spec, &taskbar->ui);
     
    213195        }
    214196
    215         rc = tbsmenu_create(taskbar->window, taskbar->fixed, dspec,
    216             &taskbar->tbsmenu);
     197        rc = tbsmenu_create(taskbar->window, taskbar->fixed, &taskbar->tbsmenu);
    217198        if (rc != EOK) {
    218199                printf("Error creating start menu.\n");
     
    220201        }
    221202
    222         rc = tbsmenu_load(taskbar->tbsmenu, TASKBAR_CONFIG_FILE);
     203        rc = tbsmenu_load(taskbar->tbsmenu, "/cfg/taskbar.sif");
    223204        if (rc != EOK) {
    224205                printf("Error loading start menu from '%s'.\n",
    225                     TASKBAR_CONFIG_FILE);
    226         }
    227 
    228         rc = tbarcfg_listener_create(TBARCFG_NOTIFY_DEFAULT,
    229             taskbar_notif_cb, (void *)taskbar, &taskbar->lst);
    230         if (rc != EOK) {
    231                 printf("Error listening for configuration changes.\n");
     206                    "/cfg/taskbar.sif");
    232207        }
    233208
     
    309284        }
    310285
    311         free(dspec);
    312286        *rtaskbar = taskbar;
    313287        return EOK;
    314288error:
    315         if (dspec != NULL)
    316                 free(dspec);
    317         if (taskbar->lst != NULL)
    318                 tbarcfg_listener_destroy(taskbar->lst);
    319289        if (taskbar->clock != NULL)
    320290                taskbar_clock_destroy(taskbar->clock);
     
    327297        if (taskbar->ui != NULL)
    328298                ui_destroy(taskbar->ui);
    329         free(taskbar);
    330299        return rc;
    331300
     
    335304void taskbar_destroy(taskbar_t *taskbar)
    336305{
    337         if (taskbar->lst != NULL)
    338                 tbarcfg_listener_destroy(taskbar->lst);
    339306        ui_fixed_remove(taskbar->fixed, taskbar_clock_ctl(taskbar->clock));
    340307        taskbar_clock_destroy(taskbar->clock);
     
    345312}
    346313
    347 /** Configuration change notification callback.
    348  *
    349  * Called when configuration changed.
    350  *
    351  * @param arg Argument (taskbar_t *)
    352  */
    353 static void taskbar_notif_cb(void *arg)
    354 {
    355         taskbar_t *taskbar = (taskbar_t *)arg;
    356 
    357         ui_lock(taskbar->ui);
    358         tbsmenu_reload(taskbar->tbsmenu);
    359         ui_unlock(taskbar->ui);
    360 }
    361 
    362314/** @}
    363315 */
  • uspace/app/taskbar/taskbar.sif

    r34aad53d re4cc266  
    1 [sif](){[entries](){[entry]([caption]=[~N~avigator][cmd]=[/app/nav][terminal]=[y]){}[entry]([caption]=[Text ~E~ditor][cmd]=[/app/edit][terminal]=[y]){}[entry]([caption]=[Co~m~mand Line][cmd]=[/app/bdsh][terminal]=[y]){}[entry]([caption]=[~C~alculator][cmd]=[/app/calculator -d %d][terminal]=[n]){}[entry]([caption]=[~I~mage Viewer][cmd]=[/app/viewer -d %d][terminal]=[n]){}[entry]([separator]=[y]){}[entry]([caption]=[~U~I Demo][cmd]=[/app/uidemo -d %d][terminal]=[n]){}[entry]([caption]=[~G~FX Demo][cmd]=[/app/gfxdemo -d %d ui][terminal]=[n]){}[entry]([caption]=[~B~arber Pole][cmd]=[/app/barber -d %d][terminal]=[n]){}[entry]([caption]=[~T~etris][cmd]=[/app/tetris][terminal]=[y]){}[entry]([separator]=[y]){}[entry]([caption]=[~D~isplay Configuration][cmd]=[/app/display-cfg -d %d][terminal]=[n]){}[entry]([caption]=[Ta~s~kbar Configuration][cmd]=[/app/taskbar-cfg -d %d][terminal]=[n]){}[entry]([separator]=[y]){}[entry]([caption]=[Tas~k~ Monitor (top)][cmd]=[/app/top][terminal]=[y]){}[entry]([caption]=[~F~disk Disk Editor][cmd]=[/app/fdisk][terminal]=[y]){}[entry]([separator]=[y]){}[entry]([caption]=[~A~bout HelenOS][cmd]=[/app/aboutos -d %d][terminal]=[n]){}}}
     1[sif](){[entries](){[entry]([caption]=[~N~avigator][cmd]=[/app/nav][terminal]=[y]){}[entry]([caption]=[Text ~E~ditor][cmd]=[/app/edit][terminal]=[y]){}[entry]([caption]=[Co~m~mand Line][cmd]=[/app/bdsh][terminal]=[y]){}[entry]([caption]=[~C~alculator][cmd]=[/app/calculator][terminal]=[n]){}[entry]([separator]=[y]){}[entry]([caption]=[~U~I Demo][cmd]=[/app/uidemo][terminal]=[n]){}[entry]([caption]=[~G~FX Demo][cmd]=[/app/gfxdemo ui][terminal]=[n]){}[entry]([caption]=[~B~arber Pole][cmd]=[/app/barber][terminal]=[n]){}[entry]([caption]=[~T~etris][cmd]=[/app/tetris][terminal]=[y]){}[entry]([separator]=[y]){}[entry]([caption]=[~D~isplay Configuration][cmd]=[/app/display-cfg][terminal]=[n]){}[entry]([caption]=[Ta~s~kbar Configuration][cmd]=[/app/taskbar-cfg][terminal]=[n]){}[entry]([separator]=[y]){}[entry]([caption]=[Tas~k~ Monitor (top)][cmd]=[/app/top][terminal]=[y]){}[entry]([caption]=[~F~disk Disk Editor][cmd]=[/app/fdisk][terminal]=[y]){}}}
  • uspace/app/taskbar/tbsmenu.c

    r34aad53d re4cc266  
    6464static void tbsmenu_smenu_entry_cb(ui_menu_entry_t *, void *);
    6565static errno_t tbsmenu_entry_start(tbsmenu_entry_t *);
    66 static void tbsmenu_cmd_fini(tbsmenu_cmd_t *);
    6766
    6867/** Create taskbar start menu.
     
    7069 * @param window Containing window
    7170 * @param fixed Fixed layout to which start button will be added
    72  * @param dspec Display specification (for passing to applications)
    7371 * @param rtbsmenu Place to store pointer to new start menu
    7472 * @return @c EOK on success or an error code
    7573 */
    7674errno_t tbsmenu_create(ui_window_t *window, ui_fixed_t *fixed,
    77     const char *dspec, tbsmenu_t **rtbsmenu)
     75    tbsmenu_t **rtbsmenu)
    7876{
    7977        ui_resource_t *res = ui_window_get_res(window);
     
    8785        }
    8886
    89         tbsmenu->display_spec = str_dup(dspec);
    90         if (tbsmenu->display_spec == NULL) {
    91                 rc = ENOMEM;
    92                 goto error;
    93         }
    94 
    9587        rc = ui_pbutton_create(res, "Start", &tbsmenu->sbutton);
    9688        if (rc != EOK)
     
    119111        return EOK;
    120112error:
    121         if (tbsmenu != NULL && tbsmenu->display_spec != NULL)
    122                 free(tbsmenu->display_spec);
    123113        if (tbsmenu != NULL)
    124114                ui_pbutton_destroy(tbsmenu->sbutton);
     
    144134        bool terminal;
    145135        errno_t rc;
    146 
    147         if (tbsmenu->repopath != NULL)
    148                 free(tbsmenu->repopath);
    149 
    150         tbsmenu->repopath = str_dup(repopath);
    151         if (tbsmenu->repopath == NULL)
    152                 return ENOMEM;
    153 
    154         /* Remove existing entries */
    155         tentry = tbsmenu_first(tbsmenu);
    156         while (tentry != NULL) {
    157                 tbsmenu_remove(tbsmenu, tentry, false);
    158                 tentry = tbsmenu_first(tbsmenu);
    159         }
    160136
    161137        rc = tbarcfg_open(repopath, &tbcfg);
     
    194170}
    195171
    196 /** Reload start menu from repository (or schedule reload).
    197  *
    198  * @param tbsmenu Start menu
    199  */
    200 void tbsmenu_reload(tbsmenu_t *tbsmenu)
    201 {
    202         if (!tbsmenu_is_open(tbsmenu))
    203                 (void) tbsmenu_load(tbsmenu, tbsmenu->repopath);
    204         else
    205                 tbsmenu->needs_reload = true;
    206 }
    207 
    208172/** Set start menu rectangle.
    209173 *
     
    234198{
    235199        ui_menu_close(tbsmenu->smenu);
    236 
    237         if (tbsmenu->needs_reload)
    238                 (void) tbsmenu_load(tbsmenu, tbsmenu->repopath);
    239200}
    240201
     
    486447static errno_t tbsmenu_cmd_split(const char *str, tbsmenu_cmd_t *cmd)
    487448{
    488         char *buf;
    489449        char *arg;
    490450        char *next;
    491451        size_t cnt;
    492452
    493         buf = str_dup(str);
    494         if (buf == NULL)
     453        cmd->buf = str_dup(str);
     454        if (cmd->buf == NULL)
    495455                return ENOMEM;
    496456
    497457        /* Count the entries */
    498458        cnt = 0;
    499         arg = str_tok(buf, " ", &next);
     459        arg = str_tok(cmd->buf, " ", &next);
    500460        while (arg != NULL) {
    501461                ++cnt;
     
    504464
    505465        /* Need to copy again as buf was mangled */
    506         free(buf);
    507         buf = str_dup(str);
    508         if (buf == NULL)
     466        free(cmd->buf);
     467        cmd->buf = str_dup(str);
     468        if (cmd->buf == NULL)
    509469                return ENOMEM;
    510470
    511471        cmd->argv = calloc(cnt + 1, sizeof(char *));
    512472        if (cmd->argv == NULL) {
    513                 free(buf);
     473                free(cmd->buf);
    514474                return ENOMEM;
    515475        }
    516476
    517         /* Copy individual arguments */
     477        /* Fill in pointers */
    518478        cnt = 0;
    519         arg = str_tok(buf, " ", &next);
     479        arg = str_tok(cmd->buf, " ", &next);
    520480        while (arg != NULL) {
    521                 cmd->argv[cnt] = str_dup(arg);
    522                 if (cmd->argv[cnt] == NULL) {
    523                         tbsmenu_cmd_fini(cmd);
    524                         return ENOMEM;
    525                 }
    526                 ++cnt;
    527 
     481                cmd->argv[cnt++] = arg;
    528482                arg = str_tok(next, " ", &next);
    529483        }
     
    540494static void tbsmenu_cmd_fini(tbsmenu_cmd_t *cmd)
    541495{
    542         char **cp;
    543 
    544         /* Free all pointers in NULL-terminated list */
    545         cp = cmd->argv;
    546         while (*cp != NULL) {
    547                 free(*cp);
    548                 ++cp;
    549         }
    550 
    551         /* Free the array of pointers */
    552496        free(cmd->argv);
    553 }
    554 
    555 /** Free command structure.
    556  *
    557  * @param cmd Command
    558  * @param entry Start menu entry
    559  * @param dspec Display specification
    560  * @return EOK on success or an error code
    561  */
    562 static errno_t tbsmenu_cmd_subst(tbsmenu_cmd_t *cmd, tbsmenu_entry_t *entry,
    563     const char *dspec)
    564 {
    565         char **cp;
    566 
    567         (void)entry;
    568 
    569         /* Walk NULL-terminated list of arguments */
    570         cp = cmd->argv;
    571         while (*cp != NULL) {
    572                 if (str_cmp(*cp, "%d") == 0) {
    573                         /* Display specification */
    574                         free(*cp);
    575                         *cp = str_dup(dspec);
    576                         if (*cp == NULL)
    577                                 return ENOMEM;
    578                 }
    579                 ++cp;
    580         }
    581 
    582         return EOK;
     497        free(cmd->buf);
    583498}
    584499
     
    601516        char **cp;
    602517        const char **targv = NULL;
    603         char *dspec = NULL;
    604         sysarg_t idev_id;
    605         int rv;
    606518        errno_t rc;
    607519        ui_t *ui;
     
    610522        suspended = false;
    611523
    612         idev_id = ui_menu_get_idev_id(entry->tbsmenu->smenu);
    613 
    614         rv = asprintf(&dspec, "%s?idev=%zu",
    615             entry->tbsmenu->display_spec, (size_t)idev_id);
    616         if (rv < 0)
    617                 return ENOMEM;
    618 
    619         /* Split command string into individual arguments */
    620524        rc = tbsmenu_cmd_split(entry->cmd, &cmd);
    621         if (rc != EOK) {
    622                 free(dspec);
     525        if (rc != EOK)
    623526                return rc;
    624         }
    625 
    626         /* Substitute metacharacters in command */
    627         rc = tbsmenu_cmd_subst(&cmd, entry, dspec);
    628         if (rc != EOK)
    629                 goto error;
    630527
    631528        /* Free up and clean console for the child task. */
     
    645542                }
    646543
    647                 targv = calloc(cnt + 5, sizeof(char **));
     544                targv = calloc(cnt + 3, sizeof(char **));
    648545                if (targv == NULL)
    649546                        goto error;
    650547
    651548                targv[0] = "/app/terminal";
    652                 targv[1] = "-d";
    653                 targv[2] = dspec;
    654                 targv[3] = "-c";
     549                targv[1] = "-c";
    655550
    656551                for (i = 0; i <= cnt; i++) {
    657                         targv[4 + i] = cmd.argv[i];
     552                        targv[2 + i] = cmd.argv[i];
    658553                }
    659554
     
    683578        return EOK;
    684579error:
    685         free(dspec);
    686580        if (targv != NULL)
    687581                free(targv);
  • uspace/app/taskbar/tbsmenu.h

    r34aad53d re4cc266  
    4646#include "types/tbsmenu.h"
    4747
    48 extern errno_t tbsmenu_create(ui_window_t *, ui_fixed_t *, const char *,
    49     tbsmenu_t **);
     48extern errno_t tbsmenu_create(ui_window_t *, ui_fixed_t *, tbsmenu_t **);
    5049extern errno_t tbsmenu_load(tbsmenu_t *, const char *);
    51 extern void tbsmenu_reload(tbsmenu_t *);
    5250extern void tbsmenu_set_rect(tbsmenu_t *, gfx_rect_t *);
    5351extern void tbsmenu_open(tbsmenu_t *);
  • uspace/app/taskbar/test/tbsmenu.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    6161        ui_window_add(window, ui_fixed_ctl(fixed));
    6262
    63         rc = tbsmenu_create(window, fixed, UI_DISPLAY_DEFAULT, &tbsmenu);
     63        rc = tbsmenu_create(window, fixed, &tbsmenu);
    6464        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    6565
     
    9292        ui_window_add(window, ui_fixed_ctl(fixed));
    9393
    94         rc = tbsmenu_create(window, fixed, UI_DISPLAY_DEFAULT, &tbsmenu);
     94        rc = tbsmenu_create(window, fixed, &tbsmenu);
    9595        PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    9696
  • uspace/app/taskbar/types/taskbar.h

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    6060        /** Clock */
    6161        taskbar_clock_t *clock;
    62         /** Configuration change listener */
    63         tbarcfg_listener_t *lst;
    6462} taskbar_t;
    6563
  • uspace/app/taskbar/types/tbsmenu.h

    r34aad53d re4cc266  
    4040#include <gfx/coord.h>
    4141#include <stdbool.h>
    42 #include <tbarcfg/tbarcfg.h>
    4342#include <ui/pbutton.h>
    4443#include <ui/fixed.h>
     
    8584        /** Device ID of last input event */
    8685        sysarg_t ev_idev_id;
    87 
    88         /** Repository path name */
    89         char *repopath;
    90 
    91         /** Need to reload menu when possible */
    92         bool needs_reload;
    93 
    94         /** Display specification */
    95         char *display_spec;
    9686} tbsmenu_t;
    9787
    9888/** Command split into individual parts */
    9989typedef struct {
     90        /** Buffer holding broken down command */
     91        char *buf;
    10092        /** NULL-terminated array of string pointers */
    10193        char **argv;
  • uspace/app/terminal/terminal.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * Copyright (c) 2012 Petr Koupy
    44 * All rights reserved.
     
    974974                wparams.placement = ui_wnd_place_top_left;
    975975
     976        /*
     977         * Compute window rectangle such that application area corresponds
     978         * to rect
     979         */
     980        ui_wdecor_rect_from_app(wparams.style, &rect, &wrect);
     981        off = wrect.p0;
     982        gfx_rect_rtranslate(&off, &wrect, &wparams.rect);
     983
     984        term->off = off;
     985
    976986        rc = ui_create(display_spec, &term->ui);
    977987        if (rc != EOK) {
     
    979989                goto error;
    980990        }
    981 
    982         /*
    983          * Compute window rectangle such that application area corresponds
    984          * to rect
    985          */
    986         ui_wdecor_rect_from_app(term->ui, wparams.style, &rect, &wrect);
    987         off = wrect.p0;
    988         gfx_rect_rtranslate(&off, &wrect, &wparams.rect);
    989 
    990         term->off = off;
    991991
    992992        rc = ui_window_create(term->ui, &wparams, &term->window);
  • uspace/app/viewer/viewer.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2020 Jiri Svoboda
    33 * Copyright (c) 2013 Martin Decky
    44 * All rights reserved.
     
    4040#include <stdlib.h>
    4141#include <str.h>
    42 #include <ui/filedialog.h>
    4342#include <ui/image.h>
    4443#include <ui/ui.h>
     
    5150typedef struct {
    5251        ui_t *ui;
    53 
    54         size_t imgs_count;
    55         size_t imgs_current;
    56         char **imgs;
    57 
    58         bool fullscreen;
    59         ui_window_t *window;
    60         gfx_bitmap_t *bitmap;
    61         ui_image_t *image;
    62         gfx_context_t *window_gc;
    63         ui_file_dialog_t *dialog;
    64 
    65         gfx_rect_t img_rect;
    6652} viewer_t;
    6753
    68 static bool viewer_img_load(viewer_t *, const char *, gfx_bitmap_t **,
     54static size_t imgs_count;
     55static size_t imgs_current = 0;
     56static char **imgs;
     57
     58static ui_window_t *window;
     59static gfx_bitmap_t *bitmap = NULL;
     60static ui_image_t *image = NULL;
     61static gfx_context_t *window_gc;
     62
     63static gfx_rect_t img_rect;
     64
     65static bool img_load(gfx_context_t *gc, const char *, gfx_bitmap_t **,
    6966    gfx_rect_t *);
    70 static bool viewer_img_setup(viewer_t *, gfx_bitmap_t *, gfx_rect_t *);
    71 static errno_t viewer_window_create(viewer_t *);
    72 static void viewer_window_destroy(viewer_t *);
     67static bool img_setup(gfx_context_t *, gfx_bitmap_t *, gfx_rect_t *);
    7368
    7469static void wnd_close(ui_window_t *, void *);
     
    8075};
    8176
    82 static void file_dialog_bok(ui_file_dialog_t *, void *, const char *);
    83 static void file_dialog_bcancel(ui_file_dialog_t *, void *);
    84 static void file_dialog_close(ui_file_dialog_t *, void *);
    85 
    86 static ui_file_dialog_cb_t file_dialog_cb = {
    87         .bok = file_dialog_bok,
    88         .bcancel = file_dialog_bcancel,
    89         .close = file_dialog_close
    90 };
    91 
    9277/** Window close request
    9378 *
     
    10287}
    10388
    104 /** Viewer unmodified key press.
    105  *
    106  * @param viewer Viewer
    107  * @param event Keyboard event
    108  */
    109 static void viewer_kbd_event_unmod(viewer_t *viewer, kbd_event_t *event)
     89static void wnd_kbd_event(ui_window_t *window, void *arg,
     90    kbd_event_t *event)
    11091{
    11192        bool update = false;
    11293
    113         if (event->key == KC_Q || event->key == KC_ESCAPE)
    114                 ui_quit(viewer->ui);
    115 
    116         if (event->key == KC_PAGE_DOWN) {
    117                 if (viewer->imgs_current == viewer->imgs_count - 1)
    118                         viewer->imgs_current = 0;
     94        if ((event->type == KEY_PRESS) && (event->c == 'q'))
     95                exit(0);
     96
     97        if ((event->type == KEY_PRESS) && (event->key == KC_PAGE_DOWN)) {
     98                if (imgs_current == imgs_count - 1)
     99                        imgs_current = 0;
    119100                else
    120                         viewer->imgs_current++;
     101                        imgs_current++;
    121102
    122103                update = true;
    123104        }
    124105
    125         if (event->key == KC_PAGE_UP) {
    126                 if (viewer->imgs_current == 0)
    127                         viewer->imgs_current = viewer->imgs_count - 1;
     106        if ((event->type == KEY_PRESS) && (event->key == KC_PAGE_UP)) {
     107                if (imgs_current == 0)
     108                        imgs_current = imgs_count - 1;
    128109                else
    129                         viewer->imgs_current--;
     110                        imgs_current--;
    130111
    131112                update = true;
     
    136117                gfx_rect_t lrect;
    137118
    138                 if (!viewer_img_load(viewer, viewer->imgs[viewer->imgs_current],
    139                     &lbitmap, &lrect)) {
    140                         printf("Cannot load image \"%s\".\n",
    141                             viewer->imgs[viewer->imgs_current]);
     119                if (!img_load(window_gc, imgs[imgs_current], &lbitmap, &lrect)) {
     120                        printf("Cannot load image \"%s\".\n", imgs[imgs_current]);
    142121                        exit(4);
    143122                }
    144                 if (!viewer_img_setup(viewer, lbitmap, &lrect)) {
    145                         printf("Cannot setup image \"%s\".\n",
    146                             viewer->imgs[viewer->imgs_current]);
     123                if (!img_setup(window_gc, lbitmap, &lrect)) {
     124                        printf("Cannot setup image \"%s\".\n", imgs[imgs_current]);
    147125                        exit(6);
    148126                }
     
    150128}
    151129
    152 /** Viewer ctrl-key key press.
    153  *
    154  * @param viewer Viewer
    155  * @param event Keyboard event
    156  */
    157 static void viewer_kbd_event_ctrl(viewer_t *viewer, kbd_event_t *event)
    158 {
    159         if (event->key == KC_Q)
    160                 ui_quit(viewer->ui);
    161 }
    162 
    163 /** Viewer window keyboard event.
    164  *
    165  * @param window UI window
    166  * @param arg Argument (viewer_t *)
    167  * @param event Keyboard event
    168  */
    169 static void wnd_kbd_event(ui_window_t *window, void *arg,
    170     kbd_event_t *event)
    171 {
    172         viewer_t *viewer = (viewer_t *)arg;
    173 
    174         if (event->type != KEY_PRESS)
    175                 return;
    176 
    177         if ((event->mods & (KM_CTRL | KM_ALT | KM_SHIFT)) == 0)
    178                 viewer_kbd_event_unmod(viewer, event);
    179 
    180         if ((event->mods & KM_CTRL) != 0 &&
    181             (event->mods & (KM_ALT | KM_SHIFT)) == 0)
    182                 viewer_kbd_event_ctrl(viewer, event);
    183 
    184         ui_window_def_kbd(window, event);
    185 }
    186 
    187 /** File dialog OK button press.
    188  *
    189  * @param dialog File dialog
    190  * @param arg Argument (viewer_t *)
    191  * @param fname File name
    192  */
    193 static void file_dialog_bok(ui_file_dialog_t *dialog, void *arg,
    194     const char *fname)
    195 {
    196         viewer_t *viewer = (viewer_t *) arg;
    197         errno_t rc;
    198 
    199         viewer->imgs_count = 1;
    200         viewer->imgs = calloc(viewer->imgs_count, sizeof(char *));
    201         if (viewer->imgs == NULL) {
    202                 printf("Out of memory.\n");
    203                 ui_quit(viewer->ui);
    204                 return;
    205         }
    206 
    207         viewer->imgs[0] = str_dup(fname);
    208         if (viewer->imgs[0] == NULL) {
    209                 printf("Out of memory.\n");
    210                 ui_quit(viewer->ui);
    211                 return;
    212         }
    213 
    214         rc = viewer_window_create(viewer);
    215         if (rc != EOK)
    216                 ui_quit(viewer->ui);
    217 
    218         ui_file_dialog_destroy(dialog);
    219         viewer->dialog = NULL;
    220 }
    221 
    222 /** File dialog cancel button press.
    223  *
    224  * @param dialog File dialog
    225  * @param arg Argument (viewer_t *)
    226  */
    227 static void file_dialog_bcancel(ui_file_dialog_t *dialog, void *arg)
    228 {
    229         viewer_t *viewer = (viewer_t *) arg;
    230 
    231         ui_file_dialog_destroy(dialog);
    232         ui_quit(viewer->ui);
    233 }
    234 
    235 /** File dialog close request.
    236  *
    237  * @param dialog File dialog
    238  * @param arg Argument (viewer_t *)
    239  */
    240 static void file_dialog_close(ui_file_dialog_t *dialog, void *arg)
    241 {
    242         viewer_t *viewer = (viewer_t *) arg;
    243 
    244         ui_file_dialog_destroy(dialog);
    245         ui_quit(viewer->ui);
    246 }
    247 
    248 static bool viewer_img_load(viewer_t *viewer, const char *fname,
     130static bool img_load(gfx_context_t *gc, const char *fname,
    249131    gfx_bitmap_t **rbitmap, gfx_rect_t *rect)
    250132{
     
    277159        vfs_put(fd);
    278160
    279         rc = decode_tga(viewer->window_gc, tga, stat.size, rbitmap, rect);
     161        rc = decode_tga(gc, tga, stat.size, rbitmap, rect);
    280162        if (rc != EOK) {
    281163                free(tga);
     
    285167        free(tga);
    286168
    287         viewer->img_rect = *rect;
     169        img_rect = *rect;
    288170        return true;
    289171}
    290172
    291 static bool viewer_img_setup(viewer_t *viewer, gfx_bitmap_t *bmp,
    292     gfx_rect_t *rect)
     173static bool img_setup(gfx_context_t *gc, gfx_bitmap_t *bmp, gfx_rect_t *rect)
    293174{
    294175        gfx_rect_t arect;
     
    297178        errno_t rc;
    298179
    299         ui_res = ui_window_get_res(viewer->window);
    300 
    301         ui_window_get_app_rect(viewer->window, &arect);
     180        ui_res = ui_window_get_res(window);
     181
     182        ui_window_get_app_rect(window, &arect);
    302183
    303184        /* Center image on application area */
    304185        gfx_rect_ctr_on_rect(rect, &arect, &irect);
    305186
    306         if (viewer->image != NULL) {
    307                 ui_image_set_bmp(viewer->image, bmp, rect);
    308                 (void) ui_image_paint(viewer->image);
    309                 ui_image_set_rect(viewer->image, &irect);
     187        if (image != NULL) {
     188                ui_image_set_bmp(image, bmp, rect);
     189                (void) ui_image_paint(image);
     190                ui_image_set_rect(image, &irect);
    310191        } else {
    311                 rc = ui_image_create(ui_res, bmp, rect, &viewer->image);
     192                rc = ui_image_create(ui_res, bmp, rect, &image);
    312193                if (rc != EOK) {
    313194                        gfx_bitmap_destroy(bmp);
     
    315196                }
    316197
    317                 ui_image_set_rect(viewer->image, &irect);
    318                 ui_window_add(viewer->window, ui_image_ctl(viewer->image));
    319         }
    320 
    321         if (viewer->bitmap != NULL)
    322                 gfx_bitmap_destroy(viewer->bitmap);
    323 
    324         viewer->bitmap = bmp;
     198                ui_image_set_rect(image, &irect);
     199                ui_window_add(window, ui_image_ctl(image));
     200        }
     201
     202        if (bitmap != NULL)
     203                gfx_bitmap_destroy(bitmap);
     204
     205        bitmap = bmp;
    325206        return true;
    326207}
     
    333214}
    334215
    335 static errno_t viewer_window_create(viewer_t *viewer)
    336 {
    337         ui_wnd_params_t params;
     216int main(int argc, char *argv[])
     217{
     218        const char *display_spec = UI_DISPLAY_DEFAULT;
    338219        gfx_bitmap_t *lbitmap;
    339220        gfx_rect_t lrect;
     221        bool fullscreen = false;
     222        gfx_rect_t rect;
    340223        gfx_rect_t wrect;
    341224        gfx_coord2_t off;
    342         gfx_rect_t rect;
     225        ui_t *ui;
     226        ui_wnd_params_t params;
     227        viewer_t viewer;
    343228        errno_t rc;
     229        int i;
     230
     231        i = 1;
     232        while (i < argc && argv[i][0] == '-') {
     233                if (str_cmp(argv[i], "-d") == 0) {
     234                        ++i;
     235                        if (i >= argc) {
     236                                printf("Argument missing.\n");
     237                                print_syntax();
     238                                return 1;
     239                        }
     240
     241                        display_spec = argv[i++];
     242                } else if (str_cmp(argv[i], "-f") == 0) {
     243                        ++i;
     244                        fullscreen = true;
     245                } else {
     246                        printf("Invalid option '%s'.\n", argv[i]);
     247                        print_syntax();
     248                        return 1;
     249                }
     250        }
     251
     252        if (i >= argc) {
     253                printf("No image files specified.\n");
     254                print_syntax();
     255                return 1;
     256        }
     257
     258        imgs_count = argc - i;
     259        imgs = calloc(imgs_count, sizeof(char *));
     260        if (imgs == NULL) {
     261                printf("Out of memory.\n");
     262                return 1;
     263        }
     264
     265        for (int j = 0; j < argc - i; j++) {
     266                imgs[j] = str_dup(argv[i + j]);
     267                if (imgs[j] == NULL) {
     268                        printf("Out of memory.\n");
     269                        return 3;
     270                }
     271        }
     272
     273        rc = ui_create(display_spec, &ui);
     274        if (rc != EOK) {
     275                printf("Error creating UI on display %s.\n", display_spec);
     276                return 1;
     277        }
     278
     279        viewer.ui = ui;
    344280
    345281        /*
     
    354290        params.rect.p1.y = 1;
    355291
    356         if (viewer->fullscreen) {
     292        if (fullscreen) {
    357293                params.style &= ~ui_wds_decorated;
    358294                params.placement = ui_wnd_place_full_screen;
    359295        }
    360296
    361         rc = ui_window_create(viewer->ui, &params, &viewer->window);
     297        rc = ui_window_create(ui, &params, &window);
    362298        if (rc != EOK) {
    363299                printf("Error creating window.\n");
    364                 goto error;
    365         }
    366 
    367         viewer->window_gc = ui_window_get_gc(viewer->window);
    368 
    369         ui_window_set_cb(viewer->window, &window_cb, (void *)viewer);
    370 
    371         if (!viewer_img_load(viewer, viewer->imgs[viewer->imgs_current],
    372             &lbitmap, &lrect)) {
    373                 printf("Cannot load image \"%s\".\n",
    374                     viewer->imgs[viewer->imgs_current]);
    375                 goto error;
     300                return 1;
     301        }
     302
     303        window_gc = ui_window_get_gc(window);
     304
     305        ui_window_set_cb(window, &window_cb, (void *) &viewer);
     306
     307        if (!img_load(window_gc, imgs[imgs_current], &lbitmap, &lrect)) {
     308                printf("Cannot load image \"%s\".\n", imgs[imgs_current]);
     309                return 1;
    376310        }
    377311
     
    380314         * to rect
    381315         */
    382         ui_wdecor_rect_from_app(viewer->ui, params.style, &lrect, &wrect);
     316        ui_wdecor_rect_from_app(params.style, &lrect, &wrect);
    383317        off = wrect.p0;
    384318        gfx_rect_rtranslate(&off, &wrect, &rect);
    385319
    386         if (!viewer->fullscreen) {
    387                 rc = ui_window_resize(viewer->window, &rect);
     320        if (!fullscreen) {
     321                rc = ui_window_resize(window, &rect);
    388322                if (rc != EOK) {
    389323                        printf("Error resizing window.\n");
    390                         goto error;
    391                 }
    392         }
    393 
    394         if (!viewer_img_setup(viewer, lbitmap, &lrect)) {
    395                 printf("Cannot setup image \"%s\".\n",
    396                     viewer->imgs[viewer->imgs_current]);
    397                 goto error;
    398         }
    399 
    400         rc = ui_window_paint(viewer->window);
     324                        return 1;
     325                }
     326        }
     327
     328        if (!img_setup(window_gc, lbitmap, &lrect)) {
     329                printf("Cannot setup image \"%s\".\n", imgs[imgs_current]);
     330                return 1;
     331        }
     332
     333        rc = ui_window_paint(window);
    401334        if (rc != EOK) {
    402335                printf("Error painting window.\n");
    403                 goto error;
    404         }
    405 
    406         return EOK;
    407 error:
    408         viewer_window_destroy(viewer);
    409         ui_quit(viewer->ui);
    410         return rc;
    411 }
    412 
    413 static void viewer_window_destroy(viewer_t *viewer)
    414 {
    415         if (viewer->window != NULL)
    416                 ui_window_destroy(viewer->window);
    417         viewer->window = NULL;
    418 }
    419 
    420 int main(int argc, char *argv[])
    421 {
    422         const char *display_spec = UI_ANY_DEFAULT;
    423         ui_t *ui = NULL;
    424         viewer_t *viewer;
    425         errno_t rc;
    426         int i;
    427         unsigned u;
    428         ui_file_dialog_params_t fdparams;
    429 
    430         viewer = calloc(1, sizeof(viewer_t));
    431         if (viewer == NULL) {
    432                 printf("Out of memory.\n");
    433                 goto error;
    434         }
    435 
    436         i = 1;
    437         while (i < argc && argv[i][0] == '-') {
    438                 if (str_cmp(argv[i], "-d") == 0) {
    439                         ++i;
    440                         if (i >= argc) {
    441                                 printf("Argument missing.\n");
    442                                 print_syntax();
    443                                 goto error;
    444                         }
    445 
    446                         display_spec = argv[i++];
    447                 } else if (str_cmp(argv[i], "-f") == 0) {
    448                         ++i;
    449                         viewer->fullscreen = true;
    450                 } else {
    451                         printf("Invalid option '%s'.\n", argv[i]);
    452                         print_syntax();
    453                         goto error;
    454                 }
    455         }
    456 
    457         /* Images specified? */
    458         if (i < argc) {
    459                 viewer->imgs_count = argc - i;
    460                 viewer->imgs = calloc(viewer->imgs_count, sizeof(char *));
    461                 if (viewer->imgs == NULL) {
    462                         printf("Out of memory.\n");
    463                         goto error;
    464                 }
    465 
    466                 for (int j = 0; j < argc - i; j++) {
    467                         viewer->imgs[j] = str_dup(argv[i + j]);
    468                         if (viewer->imgs[j] == NULL) {
    469                                 printf("Out of memory.\n");
    470                                 goto error;
    471                         }
    472                 }
    473         }
    474 
    475         rc = ui_create(display_spec, &ui);
    476         if (rc != EOK) {
    477                 printf("Error creating UI on display %s.\n", display_spec);
    478                 goto error;
    479         }
    480 
    481         if (ui_is_fullscreen(ui))
    482                 viewer->fullscreen = true;
    483 
    484         viewer->ui = ui;
    485 
    486         if (viewer->imgs != NULL) {
    487                 /* We have images, create viewer window. */
    488                 rc = viewer_window_create(viewer);
    489                 if (rc != EOK)
    490                         goto error;
    491         } else {
    492                 /* No images specified, browse for one. */
    493                 ui_file_dialog_params_init(&fdparams);
    494                 fdparams.caption = "Open Image";
    495 
    496                 rc = ui_file_dialog_create(viewer->ui, &fdparams,
    497                     &viewer->dialog);
    498                 if (rc != EOK) {
    499                         printf("Error creating file dialog.\n");
    500                         goto error;
    501                 }
    502 
    503                 ui_file_dialog_set_cb(viewer->dialog, &file_dialog_cb,
    504                     (void *)viewer);
     336                return 1;
    505337        }
    506338
    507339        ui_run(ui);
    508340
    509         ui_window_destroy(viewer->window);
    510         ui_destroy(ui);
    511         free(viewer);
    512 
    513341        return 0;
    514 error:
    515         if (viewer != NULL && viewer->dialog != NULL)
    516                 ui_file_dialog_destroy(viewer->dialog);
    517         if (viewer != NULL && viewer->imgs != NULL) {
    518                 for (u = 0; u < viewer->imgs_count; u++) {
    519                         if (viewer->imgs[i] != NULL)
    520                                 free(viewer->imgs[i]);
    521                 }
    522                 free(viewer->imgs);
    523         }
    524         if (viewer != NULL)
    525                 viewer_window_destroy(viewer);
    526         if (ui != NULL)
    527                 ui_destroy(ui);
    528         if (viewer != NULL)
    529                 free(viewer);
    530         return 1;
    531342}
    532343
  • uspace/lib/congfx/src/console.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2021 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    9191        uint8_t attr;
    9292
    93         if ((clr >> 24) == 0xff) {
     93        if ((clr >> 24) == 0) {
    9494                /* RGB (no text) */
    9595                ch->ch = 0;
    9696                ch->flags = CHAR_FLAG_DIRTY;
    9797                ch->attrs.type = CHAR_ATTR_RGB;
    98                 ch->attrs.val.rgb.fgcolor = clr;
     98                ch->attrs.val.rgb.fgcolor = clr ^ 0xffffff;
    9999                ch->attrs.val.rgb.bgcolor = clr;
    100100        } else {
  • uspace/lib/gfx/src/color.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2021 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    6464        color->g = g;
    6565        color->b = b;
    66         color->attr = 0xff;
    6766
    6867        *rcolor = color;
  • uspace/lib/meson.build

    r34aad53d re4cc266  
    3333        'c',
    3434        'math',
    35         'console',
    3635        'display',
    37         'input',
    38         'output',
    3936        'pixconv',
    4037        'posix',
  • uspace/lib/tbarcfg/include/tbarcfg/tbarcfg.h

    r34aad53d re4cc266  
    4242#include <types/tbarcfg/tbarcfg.h>
    4343
    44 #define TBARCFG_NOTIFY_DEFAULT "tbarcfg-notif"
    45 
    4644extern errno_t tbarcfg_create(const char *, tbarcfg_t **);
    4745extern errno_t tbarcfg_open(const char *, tbarcfg_t **);
     
    6563extern errno_t smenu_entry_move_up(smenu_entry_t *);
    6664extern errno_t smenu_entry_move_down(smenu_entry_t *);
    67 extern errno_t tbarcfg_listener_create(const char *, void (*)(void *),
    68     void *, tbarcfg_listener_t **);
    69 extern void tbarcfg_listener_destroy(tbarcfg_listener_t *);
    70 extern errno_t tbarcfg_notify(const char *);
    7165
    7266#endif
  • uspace/lib/tbarcfg/include/types/tbarcfg/tbarcfg.h

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    4343typedef struct smenu_entry smenu_entry_t;
    4444
    45 struct tbarcfg_listener;
    46 typedef struct tbarcfg_listener tbarcfg_listener_t;
    47 
    4845#endif
    4946
  • uspace/lib/tbarcfg/private/tbarcfg.h

    r34aad53d re4cc266  
    7171};
    7272
    73 /** Taskbar configuration listener */
    74 typedef struct tbarcfg_listener {
    75         /** Notification callback */
    76         void (*cb)(void *);
    77         /** Callback argument */
    78         void *arg;
    79 } tbarcfg_listener_t;
    80 
    8173extern errno_t smenu_entry_new(tbarcfg_t *, sif_node_t *, const char *,
    8274    const char *, bool, smenu_entry_t **);
  • uspace/lib/tbarcfg/src/tbarcfg.c

    r34aad53d re4cc266  
    3434 */
    3535
    36 #include <async.h>
    3736#include <errno.h>
    3837#include <sif.h>
    39 #include <ipc/tbarcfg.h>
    40 #include <loc.h>
    41 #include <task.h>
    4238#include <tbarcfg/tbarcfg.h>
    43 #include <stdio.h>
    4439#include <stdlib.h>
    4540#include <str.h>
    4641#include "../private/tbarcfg.h"
    47 
    48 static void tbarcfg_notify_conn(ipc_call_t *, void *);
    4942
    5043/** Create taskbar configuration.
     
    791784}
    792785
    793 /** Create taskbar configuration listener.
    794  *
    795  * Listens for taskbar configuration change notifications.
    796  *
    797  * @param nchan Notification channel (TBARCFG_NOTIFY_DEFAULT)
    798  * @param rlst Place to store pointer to new listener
    799  * @return EOK on success or an error code
    800  */
    801 errno_t tbarcfg_listener_create(const char *nchan, void (*cb)(void *),
    802     void *arg, tbarcfg_listener_t **rlst)
    803 {
    804         tbarcfg_listener_t *lst;
    805         service_id_t svcid = 0;
    806         loc_srv_t *srv = NULL;
    807         task_id_t taskid;
    808         char *svcname = NULL;
    809         category_id_t catid;
    810         port_id_t port;
    811         int rv;
    812         errno_t rc;
    813 
    814         lst = calloc(1, sizeof(tbarcfg_listener_t));
    815         if (lst == NULL)
    816                 return ENOMEM;
    817 
    818         lst->cb = cb;
    819         lst->arg = arg;
    820 
    821         rc = async_create_port(INTERFACE_TBARCFG_NOTIFY,
    822             tbarcfg_notify_conn, (void *)lst, &port);
    823         if (rc != EOK)
    824                 goto error;
    825 
    826         rc = loc_server_register("tbarcfg-listener", &srv);
    827         if (rc != EOK)
    828                 goto error;
    829 
    830         taskid = task_get_id();
    831 
    832         rv = asprintf(&svcname, "tbarcfg/%u", (unsigned)taskid);
    833         if (rv < 0) {
    834                 rc = ENOMEM;
    835                 goto error;
    836         }
    837 
    838         rc = loc_service_register(srv, svcname, &svcid);
    839         if (rc != EOK)
    840                 goto error;
    841 
    842         rc = loc_category_get_id(nchan, &catid, 0);
    843         if (rc != EOK)
    844                 goto error;
    845 
    846         rc = loc_service_add_to_cat(srv, svcid, catid);
    847         if (rc != EOK)
    848                 goto error;
    849 
    850         *rlst = lst;
    851         return EOK;
    852 error:
    853         if (svcid != 0)
    854                 loc_service_unregister(srv, svcid);
    855         if (srv != NULL)
    856                 loc_server_unregister(srv);
    857         if (svcname != NULL)
    858                 free(svcname);
    859         return rc;
    860 }
    861 
    862 /** Destroy taskbar configuration listener.
    863  *
    864  * @param lst Listener
    865  */
    866 void tbarcfg_listener_destroy(tbarcfg_listener_t *lst)
    867 {
    868         free(lst);
    869 }
    870 
    871 /** Send taskbar configuration notification to a particular service ID.
    872  *
    873  * @param svcid Service ID
    874  * @return EOK on success or an error code
    875  */
    876 static errno_t tbarcfg_notify_svc(service_id_t svcid)
    877 {
    878         async_sess_t *sess;
    879         async_exch_t *exch;
    880         errno_t rc;
    881 
    882         sess = loc_service_connect(svcid, INTERFACE_TBARCFG_NOTIFY, 0);
    883         if (sess == NULL)
    884                 return EIO;
    885 
    886         exch = async_exchange_begin(sess);
    887         rc = async_req_0_0(exch, TBARCFG_NOTIFY_NOTIFY);
    888         if (rc != EOK) {
    889                 async_exchange_end(exch);
    890                 async_hangup(sess);
    891                 return rc;
    892         }
    893 
    894         async_exchange_end(exch);
    895         async_hangup(sess);
    896         return EOK;
    897 }
    898 
    899 /** Send taskbar configuration change notification.
    900  *
    901  * @param nchan Notification channel (TBARCFG_NOTIFY_DEFAULT)
    902  */
    903 errno_t tbarcfg_notify(const char *nchan)
    904 {
    905         errno_t rc;
    906         category_id_t catid;
    907         service_id_t *svcs = NULL;
    908         size_t count, i;
    909 
    910         rc = loc_category_get_id(nchan, &catid, 0);
    911         if (rc != EOK)
    912                 return rc;
    913 
    914         rc = loc_category_get_svcs(catid, &svcs, &count);
    915         if (rc != EOK)
    916                 return rc;
    917 
    918         for (i = 0; i < count; i++) {
    919                 rc = tbarcfg_notify_svc(svcs[i]);
    920                 if (rc != EOK)
    921                         goto error;
    922         }
    923 
    924         free(svcs);
    925         return EOK;
    926 error:
    927         free(svcs);
    928         return rc;
    929 }
    930 
    931 /** Taskbar configuration connection handler.
    932  *
    933  * @param icall Initial call
    934  * @param arg Argument (tbarcfg_listener_t *)
    935  */
    936 static void tbarcfg_notify_conn(ipc_call_t *icall, void *arg)
    937 {
    938         tbarcfg_listener_t *lst = (tbarcfg_listener_t *)arg;
    939 
    940         /* Accept the connection */
    941         async_accept_0(icall);
    942 
    943         while (true) {
    944                 ipc_call_t call;
    945                 async_get_call(&call);
    946                 sysarg_t method = ipc_get_imethod(&call);
    947 
    948                 if (!method) {
    949                         /* The other side has hung up */
    950                         async_answer_0(&call, EOK);
    951                         return;
    952                 }
    953 
    954                 switch (method) {
    955                 case TBARCFG_NOTIFY_NOTIFY:
    956                         lst->cb(lst->arg);
    957                         async_answer_0(&call, EOK);
    958                         break;
    959                 default:
    960                         async_answer_0(&call, EINVAL);
    961                 }
    962         }
    963 }
    964 
    965786/** @}
    966787 */
  • uspace/lib/tbarcfg/test/tbarcfg.c

    r34aad53d re4cc266  
    3030#include <pcut/pcut.h>
    3131#include <tbarcfg/tbarcfg.h>
    32 #include <stdbool.h>
    3332#include <stdio.h>
    3433
     
    3635
    3736PCUT_TEST_SUITE(tbarcfg);
    38 
    39 typedef struct {
    40         bool notified;
    41 } tbarcfg_test_resp_t;
    42 
    43 static void test_cb(void *);
    4437
    4538/** Creating, opening and closing taskbar configuration */
     
    561554}
    562555
    563 /** Notifications can be delivered from tbarcfg_notify() to a listener. */
    564 PCUT_TEST(notify)
    565 {
    566         errno_t rc;
    567         tbarcfg_listener_t *lst;
    568         tbarcfg_test_resp_t test_resp;
    569 
    570         test_resp.notified = false;
    571 
    572         printf("create listener resp=%p\n", (void *)&test_resp);
    573         rc = tbarcfg_listener_create(TBARCFG_NOTIFY_DEFAULT,
    574             test_cb, &test_resp, &lst);
    575         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    576 
    577         rc = tbarcfg_notify(TBARCFG_NOTIFY_DEFAULT);
    578         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    579 
    580         PCUT_ASSERT_TRUE(test_resp.notified);
    581         tbarcfg_listener_destroy(lst);
    582 }
    583 
    584 static void test_cb(void *arg)
    585 {
    586         tbarcfg_test_resp_t *resp = (tbarcfg_test_resp_t *)arg;
    587 
    588         printf("test_cb: executing resp=%p\n", (void *)resp);
    589         resp->notified = true;
    590 }
    591 
    592556PCUT_EXPORT(tbarcfg);
  • uspace/lib/ui/include/ui/menu.h

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    5959extern ui_evclaim_t ui_menu_pos_event(ui_menu_t *, gfx_coord2_t *,
    6060    pos_event_t *);
    61 extern sysarg_t ui_menu_get_idev_id(ui_menu_t *);
    6261
    6362#endif
  • uspace/lib/ui/include/ui/popup.h

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2021 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    5454extern ui_resource_t *ui_popup_get_res(ui_popup_t *);
    5555extern gfx_context_t *ui_popup_get_gc(ui_popup_t *);
    56 extern sysarg_t ui_popup_get_idev_id(ui_popup_t *);
    5756
    5857#endif
  • uspace/lib/ui/include/ui/wdecor.h

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    4444#include <types/ui/event.h>
    4545#include <types/ui/resource.h>
    46 #include <types/ui/ui.h>
    4746#include <types/ui/wdecor.h>
    4847
     
    5958extern ui_evclaim_t ui_wdecor_kbd_event(ui_wdecor_t *, kbd_event_t *);
    6059extern ui_evclaim_t ui_wdecor_pos_event(ui_wdecor_t *, pos_event_t *);
    61 extern void ui_wdecor_rect_from_app(ui_t *, ui_wdecor_style_t, gfx_rect_t *,
     60extern void ui_wdecor_rect_from_app(ui_wdecor_style_t, gfx_rect_t *,
    6261    gfx_rect_t *);
    6362extern void ui_wdecor_app_from_rect(ui_wdecor_style_t, gfx_rect_t *,
  • uspace/lib/ui/private/menu.h

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    7070        /** Callback argument */
    7171        void *arg;
    72         /** ID of device that activated entry */
    73         sysarg_t idev_id;
    7472};
    7573
  • uspace/lib/ui/private/popup.h

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2021 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    5858        /** Placement rectangle */
    5959        gfx_rect_t place;
    60         /** ID of device that sent input event */
    61         sysarg_t idev_id;
    6260};
    6361
  • uspace/lib/ui/src/menu.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    578578        ui_menu_t *menu = (ui_menu_t *)arg;
    579579
    580         menu->idev_id = ui_popup_get_idev_id(menu->popup);
    581580        ui_menu_kbd_event(menu, event);
    582581}
     
    593592        gfx_coord2_t spos;
    594593
    595         menu->idev_id = ui_popup_get_idev_id(menu->popup);
    596 
    597594        spos.x = 0;
    598595        spos.y = 0;
     
    644641}
    645642
    646 /** Get ID of last device that input event.
    647  *
    648  * @param menu Menu
    649  * @return Input device ID
    650  */
    651 sysarg_t ui_menu_get_idev_id(ui_menu_t *menu)
    652 {
    653         return menu->idev_id;
    654 }
    655 
    656643/** @}
    657644 */
  • uspace/lib/ui/src/menuentry.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    145145                return;
    146146
    147         mentry->menu->total_h -= ui_menu_entry_height(mentry);
    148         /* NOTE: max_caption_w/max_shortcut_w not updated (speed) */
    149 
    150147        list_remove(&mentry->lentries);
    151 
    152         /*
    153          * If we emptied the menu, reset accumulated dims so they
    154          * can be correctly calculated when (if) the menu is
    155          * re-populated.
    156          */
    157         if (list_empty(&mentry->menu->entries)) {
    158                 mentry->menu->total_h = 0;
    159                 mentry->menu->max_caption_w = 0;
    160                 mentry->menu->max_shortcut_w = 0;
    161         }
    162 
    163148        free(mentry->caption);
    164149        free(mentry);
  • uspace/lib/ui/src/popup.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    190190}
    191191
    192 /** Get ID of device that sent the last position event.
    193  *
    194  * @param popup Popup window
    195  * @return Input device ID
    196  */
    197 sysarg_t ui_popup_get_idev_id(ui_popup_t *popup)
    198 {
    199         return popup->idev_id;
    200 }
    201 
    202192/** Handle close event in popup window.
    203193 *
     
    224214        ui_popup_t *popup = (ui_popup_t *)arg;
    225215
    226         /* Remember ID of device that sent the last event */
    227         popup->idev_id = event->kbd_id;
    228 
    229216        if (popup->cb != NULL && popup->cb->kbd != NULL)
    230217                popup->cb->kbd(popup, popup->arg, event);
     
    242229        ui_popup_t *popup = (ui_popup_t *)arg;
    243230
    244         /* Remember ID of device that sent the last event */
    245         popup->idev_id = event->pos_id;
    246 
    247231        if (popup->cb != NULL && popup->cb->pos != NULL)
    248232                popup->cb->pos(popup, popup->arg, event);
  • uspace/lib/ui/src/wdecor.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    4545#include <ui/paint.h>
    4646#include <ui/pbutton.h>
    47 #include <ui/ui.h>
    4847#include <ui/wdecor.h>
    4948#include "../private/resource.h"
     
    9594        /** Window resizing edge height */
    9695        wdecor_edge_h = 4,
    97         /** Window resizing edge witdth */
    98         wdecor_edge_w_text = 1,
    99         /** Window resizing edge height */
    100         wdecor_edge_h_text = 1,
    10196        /** Title bar height */
    10297        wdecor_tbar_h = 22,
     
    865860 * and its decoration.
    866861 *
    867  * @param ui UI
    868862 * @param style Decoration style
    869863 * @param app Application area rectangle
    870864 * @param rect Place to store (outer) window decoration rectangle
    871865 */
    872 void ui_wdecor_rect_from_app(ui_t *ui, ui_wdecor_style_t style,
    873     gfx_rect_t *app, gfx_rect_t *rect)
    874 {
    875         bool textmode;
    876         gfx_coord_t edge_w, edge_h;
     866void ui_wdecor_rect_from_app(ui_wdecor_style_t style, gfx_rect_t *app,
     867    gfx_rect_t *rect)
     868{
    877869        *rect = *app;
    878870
    879         textmode = ui_is_textmode(ui);
    880         if (textmode) {
    881                 edge_w = wdecor_edge_w_text;
    882                 edge_h = wdecor_edge_h_text;
    883         } else {
    884                 edge_w = wdecor_edge_w;
    885                 edge_h = wdecor_edge_h;
    886         }
    887 
    888871        if ((style & ui_wds_frame) != 0) {
    889                 rect->p0.x -= edge_w;
    890                 rect->p0.y -= edge_h;
    891                 rect->p1.x += edge_w;
    892                 rect->p1.y += edge_h;
    893         }
    894 
    895         if ((style & ui_wds_titlebar) != 0 && !textmode)
    896                 rect->p0.y -= wdecor_tbar_h;
     872                rect->p0.x -= wdecor_edge_w;
     873                rect->p0.y -= wdecor_edge_h;
     874                rect->p1.x += wdecor_edge_w;
     875                rect->p1.y += wdecor_edge_h;
     876        }
     877
     878        if ((style & ui_wds_titlebar) != 0)
     879                rect->p0.y -= 22;
    897880}
    898881
  • uspace/lib/ui/test/wdecor.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2023 Jiri Svoboda
    33 * All rights reserved.
    44 *
     
    3434#include <ui/pbutton.h>
    3535#include <ui/resource.h>
    36 #include <ui/ui.h>
    3736#include <ui/wdecor.h>
    3837#include "../private/wdecor.h"
     
    13231322PCUT_TEST(rect_from_app)
    13241323{
    1325         errno_t rc;
    1326         ui_t *ui = NULL;
    13271324        gfx_rect_t arect;
    13281325        gfx_rect_t rect;
    1329 
    1330         rc = ui_create_disp(NULL, &ui);
    1331         PCUT_ASSERT_ERRNO_VAL(EOK, rc);
    13321326
    13331327        arect.p0.x = 14;
     
    13361330        arect.p1.y = 196;
    13371331
    1338         ui_wdecor_rect_from_app(ui, ui_wds_none, &arect, &rect);
     1332        ui_wdecor_rect_from_app(ui_wds_none, &arect, &rect);
    13391333
    13401334        PCUT_ASSERT_INT_EQUALS(14, rect.p0.x);
     
    13431337        PCUT_ASSERT_INT_EQUALS(196, rect.p1.y);
    13441338
    1345         ui_wdecor_rect_from_app(ui, ui_wds_frame, &arect, &rect);
     1339        ui_wdecor_rect_from_app(ui_wds_frame, &arect, &rect);
    13461340
    13471341        PCUT_ASSERT_INT_EQUALS(10, rect.p0.x);
     
    13501344        PCUT_ASSERT_INT_EQUALS(200, rect.p1.y);
    13511345
    1352         ui_wdecor_rect_from_app(ui, ui_wds_decorated, &arect, &rect);
     1346        ui_wdecor_rect_from_app(ui_wds_decorated, &arect, &rect);
    13531347
    13541348        PCUT_ASSERT_INT_EQUALS(10, rect.p0.x);
     
    13571351        PCUT_ASSERT_INT_EQUALS(200, rect.p1.y);
    13581352
    1359         ui_destroy(ui);
    13601353}
    13611354
  • uspace/lib/usbhid/src/hidparser.c

    r34aad53d re4cc266  
    225225        /* Than we take the higher bits from the LSB */
    226226        const unsigned bit_offset = item->offset % 8;
    227         const int lsb_bits = min((unsigned)bits, 8 - bit_offset);
     227        const int lsb_bits = min(bits, 8);
    228228
    229229        value |= (*data >> bit_offset) & BIT_RRANGE(uint8_t, lsb_bits);
  • uspace/srv/hid/output/port/ega.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
     2 * Copyright (c) 2021 Jiri Svoboda
    33 * Copyright (c) 2011 Martin Decky
    44 * All rights reserved.
     
    9090                break;
    9191        case CHAR_ATTR_RGB:
    92                 attr =
    93                     ((RED(attrs.val.rgb.fgcolor) >= 0x80) ? 0x40 : 0) |
    94                     ((GREEN(attrs.val.rgb.fgcolor) >= 0x80) ? 0x20 : 0) |
    95                     ((BLUE(attrs.val.rgb.fgcolor) >= 0x80) ? 0x10 : 0) |
    96                     ((RED(attrs.val.rgb.bgcolor) >= 0x80) ? 0x04 : 0) |
    97                     ((GREEN(attrs.val.rgb.bgcolor) >= 0x80) ? 0x02 : 0) |
    98                     ((BLUE(attrs.val.rgb.bgcolor) >= 0x80) ? 0x01 : 0);
     92                attr = (attrs.val.rgb.bgcolor < attrs.val.rgb.fgcolor) ?
     93                    ega.style_inverted : ega.style_normal;
    9994                break;
    10095        }
  • uspace/srv/locsrv/locsrv.c

    r34aad53d re4cc266  
    11/*
    2  * Copyright (c) 2024 Jiri Svoboda
    32 * Copyright (c) 2007 Josef Cejka
     3 * Copyright (c) 2011 Jiri Svoboda
    44 * All rights reserved.
    55 *
     
    13541354        categ_dir_add_cat(&cdir, cat);
    13551355
    1356         cat = category_new("tbarcfg-notif");
    1357         categ_dir_add_cat(&cdir, cat);
    1358 
    13591356        cat = category_new("test3");
    13601357        categ_dir_add_cat(&cdir, cat);
  • version

    r34aad53d re4cc266  
    2828
    2929
    30 HELENOS_RELEASE = 0.14.1
    31 HELENOS_CODENAME = Aladar
    32 HELENOS_COPYRIGHT = Copyright (c) 2001-2024 HelenOS project
     30HELENOS_RELEASE = 0.12.1
     31HELENOS_CODENAME = Cathode
     32HELENOS_COPYRIGHT = Copyright (c) 2001-2022 HelenOS project
Note: See TracChangeset for help on using the changeset viewer.