Subversion Repositories Kolibri OS

Rev

Rev 6589 | Rev 6612 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
6589 siemargl 1
#ifndef KOLIBRI_TREELIST_H
2
#define KOLIBRI_TREELIST_H
3
 
4
 
6601 siemargl 5
/// константы стиля
6589 siemargl 6
enum tl_style {
7
    TL_KEY_NO_EDIT  = 1,    // элемент нельзя редактировать на клавиатуре (изменять уровни, удалять)
8
    TL_DRAW_PAR_LINE = 2,   // рисовать линии к родительскому узлу
9
    TL_LISTBOX_MODE  = 4    //стиль не отображает уровни (как в ListBox все одного уровня)
10
};
11
 
6601 siemargl 12
/// константы для функций
13
enum tl_err {
14
    TL_ERR_LOAD_CAPTION     = 1, //в памяти нет заголовка 'tree'
15
    TL_ERR_SAVE_MEMOTY_SIZE = 2, //не хватает памяти для сохранения элемента
16
    TL_ERR_LOAD_INFO_SIZE   = 4, //не совпадает размер информационной структуры при открытии
17
};
18
 
6589 siemargl 19
typedef struct __attribute__ ((__packed__)) {
6601 siemargl 20
    uint16_t    type;   //тип элемента, или индекс иконки для узла
21
    uint8_t     lev;    //уровень элемента
22
    uint8_t     clo;    //флаг закрытия, или открытия (имеет смысл для родительского узла)
23
    uint32_t    prev;   //индекс предыдущего элемента
24
    uint32_t    next;   //индекс последующего элемента
25
    uint32_t    tcreat; //врем. создания
26
    uint32_t    tdel;   //врем. удаления
27
} treelist_node;
28
 
29
 
30
typedef struct __attribute__ ((__packed__)) {
6589 siemargl 31
    uint32_t    left;
32
    uint32_t    top;
33
    uint32_t    width;
34
    uint32_t    height;
35
    void       *data_info;  // указатель на основные даные
36
    uint16_t    info_size;  // размер данных выделяемых для каждого узла (пользовательськие данные + текст для подписи)
37
    uint32_t    info_max_count; // максимальное количество узлов, которые можно добавить в элемент
38
    uint32_t    style;      // стили элемента
6601 siemargl 39
    treelist_node *data_nodes; // указатель на структуры узлов
6589 siemargl 40
    void       *data_img;   // указатель на изображения с иконками узлов
41
    uint16_t    img_cx;     // ширина иконок
42
    uint16_t    img_cy;     // высота иконок
43
    void       *data_img_sys;//указатель на системные изображения (стрелки, плюсики)
44
    uint32_t    ch_tim;     // количество изменений в файле
45
    uint32_t    tim_undo;   // количество отмененных действий
46
    uint32_t    cur_pos;    // позиция курсора
47
    color_t     col_bkg;    // цвет фона
6601 siemargl 48
    color_t     col_zag; // цвет заголовка
49
    color_t     col_txt; // цвет текста
6589 siemargl 50
    uint16_t    capt_cy;    // высота подписи
51
    uint16_t    info_capt_offs;//сдвиг для начала текста (подписи узла)
52
    uint16_t    info_capt_len;//длина текста подписи узла (если = 0 то до конца структуры)
53
    void       *el_focus;   // указатель на структуру элемента в фокусе
6601 siemargl 54
    scrollbar  *p_scroll;   // указатель на структуру скроллинга
6589 siemargl 55
    void       *on_press;   // +84 указатель на функцию, которая вызывается при нажатии Enter
56
} treelist;
57
 
6601 siemargl 58
static inline treelist* kolibri_new_treelist( uint32_t x_w, uint32_t y_h, uint16_t capt_cy, uint32_t icon_size_xy, uint16_t info_size, uint32_t info_max_count,
59
                                             uint16_t info_capt_len, uint16_t info_capt_offs, enum tl_style style, void *el_focus, color_t back, color_t title, color_t txt)
60
{
61
    treelist *tl = (treelist *)calloc(1, sizeof(treelist));
62
    tl->left= x_w >> 16;
63
    tl->width = x_w & 0xFFFF;
64
    tl->top = y_h >> 16;
65
    tl->height = y_h & 0xFFFF;
66
    tl->info_size = info_size;
67
    tl->info_max_count = info_max_count;
68
    tl->style = style;
69
    tl->img_cx = icon_size_xy >> 16;
70
    tl->img_cy = icon_size_xy & 0xFFFF;
71
    tl->col_bkg = back;
72
    tl->col_zag = title;
73
    tl->col_txt = txt;
74
    tl->info_capt_len = info_capt_len;
75
    tl->info_capt_offs = info_capt_offs;
76
    tl->el_focus = el_focus;
77
    tl->p_scroll = kolibri_new_scrollbar_def(X_Y(0, 16), X_Y(70, 30), 100, 30, 0);
78
    return tl;
79
}
6589 siemargl 80
 
6601 siemargl 81
static inline void gui_add_treelist(kolibri_window *wnd, treelist* tl)
82
{
83
    kolibri_window_add_element(wnd, KOLIBRI_TREELIST, tl);
84
}
85
 
86
 
87
///реакция на мышь
88
extern void (*tl_mouse)(treelist *) __attribute__((__stdcall__));
89
 
90
///вывод списка на экран
91
extern void (*tl_draw)(treelist *) __attribute__((__stdcall__));
92
 
93
///перемещаем узел вверх
94
extern void (*tl_node_move_up)(treelist *) __attribute__((__stdcall__));
95
 
96
///перемещаем узел вниз
97
extern void (*tl_node_move_down)(treelist *) __attribute__((__stdcall__));
98
 
99
extern void (*tl_data_init_asm)(treelist *) __attribute__((__stdcall__));
100
///выделение памяти для структур списка и основной информации (конструктор)
101
static inline void treelist_data_init(treelist *tl)
102
{
103
    __asm__ __volatile__ (
104
             "push %%edi \n\t":::);
105
 
106
    (*tl_data_init_asm)(tl);
107
 
108
    __asm__ __volatile__ (
109
             "pop %%edi \n\t":::);
110
}
111
 
112
extern void (*tl_data_clear_asm)(treelist *) __attribute__((__stdcall__));
113
///очистка памяти элемента (деструктор)
114
static inline void treelist_data_clear(treelist *tl)
115
{
116
    __asm__ __volatile__ (
117
             "push %%edi \n\t":::);
118
 
119
    (*tl_data_clear_asm)(tl);
120
 
121
    __asm__ __volatile__ (
122
             "pop %%edi \n\t":::);
123
}
124
 
125
extern void (*tl_info_clear_asm)(treelist *) __attribute__((__stdcall__));
126
///очистка списка (информации)
127
static inline void treelist_info_clear(treelist *tl)
128
{
129
    __asm__ __volatile__ (
130
             "push %%edi \n\t":::);
131
 
132
    (*tl_info_clear_asm)(tl);
133
 
134
    __asm__ __volatile__ (
135
             "pop %%edi \n\t":::);
136
}
137
 
138
extern void (*tl_key_asm)(treelist *) __attribute__((__stdcall__));
139
///реакция на клавиатуру
140
static inline void treelist_key(treelist *tl)
141
{
142
    __asm__ __volatile__ (
143
             "push %%ebx \n\t"
144
             "push %%edi \n\t":::);
145
 
146
    (*tl_key_asm)(tl);
147
 
148
    __asm__ __volatile__ (
149
             "pop %%edi \n\t"
150
             "pop %%ebx \n\t":::);
151
}
152
 
153
extern void (*tl_info_undo_asm)(treelist *) __attribute__((__stdcall__));
154
///отмена действия
155
static inline void treelist_undo(treelist *tl)
156
{
157
    __asm__ __volatile__ (
158
             "push %%edi \n\t":::);
159
 
160
    (*tl_info_undo_asm)(tl);
161
 
162
    __asm__ __volatile__ (
163
             "pop %%edi \n\t":::);
164
}
165
 
166
extern void (*tl_info_redo_asm)(treelist *) __attribute__((__stdcall__));
167
///повтор действия
168
static inline void treelist_redo(treelist *tl)
169
{
170
    __asm__ __volatile__ (
171
             "push %%edi \n\t":::);
172
 
173
    (*tl_info_redo_asm)(tl);
174
 
175
    __asm__ __volatile__ (
176
             "pop %%edi \n\t":::);
177
}
178
 
179
extern void (*tl_node_add_asm)(treelist *, uint32_t n_opt, void *n_info) __attribute__((__stdcall__));
180
///добавить узел
181
///input:
182
/// tlist - указатель на структуру листа
183
/// n_opt - опции добавления
184
/// n_info - указатель на добавляемые данные
185
static inline void treelist_node_add(treelist *tl, void *n_info, uint16_t type, uint8_t clos, uint8_t lev)
186
{
187
    __asm__ __volatile__ (
188
             "push %%ebx \n\t"
189
             "push %%edi \n\t":::);
190
 
191
    uint32_t    n_opt = (type << 16) | (clos << 8) | lev;
192
    (*tl_node_add_asm)(tl, n_opt, n_info);
193
 
194
    __asm__ __volatile__ (
195
             "pop %%edi \n\t"
196
             "pop %%ebx \n\t":::);
197
}
198
 
199
extern void (*tl_node_set_data_asm)(treelist *, void *n_info) __attribute__((__stdcall__));
200
///записать в текущий узел
201
///input:
202
/// tlist - указатель на структуру листа
203
/// n_info - указатель на данные
204
static inline void treelist_node_setdata(treelist *tl, void *n_info)
205
{
206
    __asm__ __volatile__ (
207
             "push %%esi \n\t"
208
             "push %%edi \n\t":::);
209
 
210
    (*tl_node_set_data_asm)(tl, n_info);
211
 
212
    __asm__ __volatile__ (
213
             "pop %%edi \n\t"
214
             "pop %%esi \n\t":::);
215
}
216
 
217
extern void* (*tl_node_get_data_asm)(treelist *) __attribute__((__stdcall__));
218
///взять указатель на данные узла под курсором
219
static inline void* treelist_getdata(treelist *tl)
220
{
221
    __asm__ __volatile__ (
222
             "push %%edi \n\t":::);
223
 
224
    void *res =
225
    (*tl_node_get_data_asm)(tl);
226
 
227
    __asm__ __volatile__ (
228
             "pop %%edi \n\t":::);
229
    return res;
230
}
231
 
232
extern void (*tl_node_delete_asm)(treelist *) __attribute__((__stdcall__));
233
///удалить узел под курсором
234
static inline void treelist_node_delete(treelist *tl)
235
{
236
    __asm__ __volatile__ (
237
             "push %%edi \n\t":::);
238
 
239
    (*tl_node_delete_asm)(tl);
240
 
241
    __asm__ __volatile__ (
242
             "pop %%edi \n\t":::);
243
}
244
 
245
extern void (*tl_cur_beg_asm)(treelist *) __attribute__((__stdcall__));
246
///поставить курсор на первый узел
247
static inline void treelist_cursor_begin(treelist *tl)
248
{
249
    __asm__ __volatile__ (
250
             "push %%edi \n\t":::);
251
 
252
    (*tl_cur_beg_asm)(tl);
253
 
254
    __asm__ __volatile__ (
255
             "pop %%edi \n\t":::);
256
}
257
 
258
extern void (*tl_cur_next_asm)(treelist *) __attribute__((__stdcall__));
259
///перенести курсор на 1 позицию ниже
260
static inline void treelist_cursor_next(treelist *tl)
261
{
262
    __asm__ __volatile__ (
263
             "push %%ebx \n\t"
264
             "push %%esi \n\t"
265
             "push %%edi \n\t":::);
266
 
267
    (*tl_cur_next_asm)(tl);
268
 
269
    __asm__ __volatile__ (
270
             "pop %%edi \n\t"
271
             "pop %%esi \n\t"
272
             "pop %%ebx \n\t":::);
273
}
274
 
275
extern void (*tl_cur_perv_asm)(treelist *) __attribute__((__stdcall__));
276
///перенести курсор на 1 позицию выше
277
static inline void treelist_cursor_prev(treelist *tl)
278
{
279
    __asm__ __volatile__ (
280
             "push %%ebx \n\t"
281
             "push %%esi \n\t"
282
             "push %%edi \n\t":::);
283
 
284
    (*tl_cur_perv_asm)(tl);
285
 
286
    __asm__ __volatile__ (
287
             "pop %%edi \n\t"
288
             "pop %%esi \n\t"
289
             "pop %%ebx \n\t":::);
290
}
291
 
292
extern void (*tl_node_close_open_asm)(treelist *) __attribute__((__stdcall__));
293
///открыть/закрыть узел (работает с узлами которые имеют дочерние узлы)
294
static inline void treelist_close_open(treelist *tl)
295
{
296
    __asm__ __volatile__ (
297
             "push %%edi \n\t":::);
298
 
299
    (*tl_node_close_open_asm)(tl);
300
 
301
    __asm__ __volatile__ (
302
             "pop %%edi \n\t":::);
303
}
304
 
305
extern void (*tl_node_lev_inc_asm)(treelist *) __attribute__((__stdcall__));
306
///увеличить уровень
307
static inline void treelist_level_inc(treelist *tl)
308
{
309
    __asm__ __volatile__ (
310
             "push %%edi \n\t":::);
311
 
312
    (*tl_node_lev_inc_asm)(tl);
313
 
314
    __asm__ __volatile__ (
315
             "pop %%edi \n\t":::);
316
}
317
 
318
extern void (*tl_node_lev_dec_asm)(treelist *) __attribute__((__stdcall__));
319
///уменьшить уровень
320
static inline void treelist_level_dec(treelist *tl)
321
{
322
    __asm__ __volatile__ (
323
             "push %%edi \n\t":::);
324
 
325
    (*tl_node_lev_dec_asm)(tl);
326
 
327
    __asm__ __volatile__ (
328
             "pop %%edi \n\t":::);
329
}
330
 
331
extern treelist_node* (*tl_node_poi_get_info_asm)(treelist *, int node_ind) __attribute__((__stdcall__));
332
///взять указатель на структуру узла в указанной позиции
333
///input:
334
/// tlist - pointer to 'TreeList' struct
335
/// node_ind - node index
336
///output - pointer to node info or NULL
337
static inline treelist_node* treelist_getnode(treelist *tl, int node_ind)
338
{
339
    __asm__ __volatile__ (
340
             "push %%ebx \n\t"
341
             "push %%edi \n\t":::);
342
 
343
    treelist_node *ret =
344
    (*tl_node_poi_get_info_asm)(tl, node_ind);
345
 
346
    __asm__ __volatile__ (
347
             "pop %%edi \n\t"
348
             "pop %%ebx \n\t":::);
349
    return ret;
350
}
351
 
352
extern treelist_node* (*tl_node_poi_get_next_info_asm)(treelist *, treelist_node*) __attribute__((__stdcall__));
353
///взять указатель на следущую структуру узла
354
///input:
355
/// tlist - pointer to 'TreeList' struct
356
/// node_p - node param struct
357
///output - pointer to next node struct or NULL
358
static inline treelist_node* treelist_getnode_next(treelist *tl, treelist_node* node)
359
{
360
    __asm__ __volatile__ (
361
             "push %%ebx \n\t"
362
             "push %%edi \n\t":::);
363
 
364
    treelist_node *ret =
365
    (*tl_node_poi_get_next_info_asm)(tl, node);
366
 
367
    __asm__ __volatile__ (
368
             "pop %%edi \n\t"
369
             "pop %%ebx \n\t":::);
370
    return ret;
371
}
372
 
373
extern void* (*_tl_node_poi_get_data_asm)(treelist *, treelist_node*) __attribute__((__stdcall__));
374
///;взять указатель на данные узла
375
///input:
376
/// tlist - pointer to 'TreeList' struct
377
/// node_p - node param struct
378
///output - pointer
379
static inline void* treelist_getnode_data(treelist *tl, treelist_node *node)
380
{
381
    __asm__ __volatile__ (
382
             "push %%edi \n\t":::);
383
 
384
    void *ret =
385
    (*_tl_node_poi_get_data_asm)(tl, node);
386
 
387
    __asm__ __volatile__ (
388
             "pop %%edi \n\t":::);
389
    return ret;
390
}
391
 
392
extern int (*tl_save_mem_asm)(treelist *, int opt, void *h_mem, int mem_size) __attribute__((__stdcall__));
393
/// tlist - pointer to 'TreeList' struct
394
/// opt - options: 0 - first element, 1 - add next element
395
/// h_mem - pointer to memory
396
/// mem_size - memory size
397
///output - error code
398
static inline int treelist_save2mem(treelist *tl, int opt, void *h_mem, int mem_size)
399
{
400
    __asm__ __volatile__ (
401
             "push %%ebx \n\t"
402
             "push %%esi \n\t"
403
             "push %%edi \n\t":::);
404
 
405
    int ret =
406
    (*tl_save_mem_asm)(tl, opt, h_mem, mem_size);
407
 
408
    __asm__ __volatile__ (
409
             "pop %%edi \n\t"
410
             "pop %%esi \n\t"
411
             "pop %%ebx \n\t":::);
412
    return ret;
413
}
414
 
415
extern int (*_tl_load_mem_asm)(treelist *, int opt, void *h_mem, int mem_size) __attribute__((__stdcall__));
416
/**input:
417
; tlist - pointer to 'TreeList' struct
418
; opt   - options: element index + (2*(add mode)+(init mode)) shl 16, tl_load_mode_add        equ 0x20000 ;опция считывания в режиме добавления информации
419
; h_mem - pointer to memory
420
; mem_size - memory size
421
;   размер памяти, пока не используется (назначался для контроля)
422
;   для его использования нужно доработать функцию
423
;output:
424
; eax - error code
425
;memory header format:
426
;  +0 - (4) 'tree'
427
;  +4 - (2) info size
428
;  +6 - (4) count nodes
429
; +10 - (4) tlist style
430
; +14 - (4) cursor pos
431
; +18 - (2) info capt offs
432
; +20 - (2) info capt len
433
; +22 - (4) scroll pos
434
;memory data format:
435
; +26 - (info size + 8) * count nodes */
436
static inline int treelist_load4mem(treelist *tl, int opt, void *h_mem, int mem_size)
437
{
438
    __asm__ __volatile__ (
439
             "push %%ebx \n\t"
440
             "push %%esi \n\t"
441
             "push %%edi \n\t":::);
442
 
443
    int ret =
444
    (*_tl_load_mem_asm)(tl, opt, h_mem, mem_size);
445
 
446
    __asm__ __volatile__ (
447
             "pop %%edi \n\t"
448
             "pop %%esi \n\t"
449
             "pop %%ebx \n\t":::);
450
    return ret;
451
}
452
 
453
extern int (*tl_get_mem_size_asm)(treelist *, void *h_mem) __attribute__((__stdcall__));
454
/// ;берет размер памяти занятой функцией tl_save_mem при сохранении элементов
455
/// tlist - pointer to 'TreeList' struct
456
/// h_mem - pointer to saved memory
457
static inline int treelist_get_memsize(treelist *tl, void *h_mem)
458
{
459
    __asm__ __volatile__ (
460
             "push %%ebx \n\t"
461
             "push %%edi \n\t":::);
462
 
463
    int ret =
464
    (*tl_get_mem_size_asm)(tl, h_mem);
465
 
466
    __asm__ __volatile__ (
467
             "pop %%edi \n\t"
468
             "pop %%ebx \n\t":::);
469
    return ret;
470
}
471
 
6589 siemargl 472
#endif //KOLIBRI_TREELIST_H