UNIXworkcode

1 /* 2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. 3 * 4 * Copyright 2025 Olaf Wintermann. All rights reserved. 5 * 6 * Redistribution and use in source and binary forms, with or without 7 * modification, are permitted provided that the following conditions are met: 8 * 9 * 1. Redistributions of source code must retain the above copyright 10 * notice, this list of conditions and the following disclaimer. 11 * 12 * 2. Redistributions in binary form must reproduce the above copyright 13 * notice, this list of conditions and the following disclaimer in the 14 * documentation and/or other materials provided with the distribution. 15 * 16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 17 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 20 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 23 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 24 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 25 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 26 * POSSIBILITY OF SUCH DAMAGE. 27 */ 28 29 #include <stdio.h> 30 #include <stdlib.h> 31 32 #include "toolkit.h" 33 34 #include "var.h" 35 36 static uint64_t var_counter = 0; 37 38 char* ui_generate_var_id(const CxAllocator *a) { 39 char id[32]; 40 snprintf(id, 32, "%" PRIx64, var_counter++); 41 return cx_strdup_a(a, id).ptr; 42 } 43 44 cxmutstr ui_server_bind_int(UiContext *ctx, UiInteger *i) { 45 i->obj = ui_generate_var_id(ctx->allocator); 46 i->get = ui_server_int_get; 47 i->set = ui_server_int_set; 48 return cx_mutstr(i->obj); 49 } 50 51 cxmutstr ui_server_bind_double(UiContext *ctx, UiDouble *d) { 52 d->obj = ui_generate_var_id(ctx->allocator); 53 d->get = ui_server_double_get; 54 d->set = ui_server_double_set; 55 return cx_mutstr(d->obj); 56 } 57 58 cxmutstr ui_server_bind_string(UiContext *ctx, UiString *s) { 59 s->obj = ui_generate_var_id(ctx->allocator); 60 s->get = ui_server_string_get; 61 s->set = ui_server_string_set; 62 return cx_mutstr(s->obj); 63 } 64 65 66 int64_t ui_server_int_get(UiInteger *i) { 67 return 0; 68 } 69 70 void ui_server_int_set(UiInteger *i, int64_t value) { 71 72 } 73 74 double ui_server_double_get(UiDouble *d) { 75 return 0; 76 } 77 78 void ui_server_double_set(UiDouble *d, double value) { 79 80 } 81 82 char* ui_server_string_get(UiString *s) { 83 return NULL; 84 } 85 86 void ui_server_string_set(UiString *s, const char *str) { 87 88 } 89