% notcurses_reel(3) % nick black % v1.5.0 # NAME notcurses_reel - high-level widget for hierarchical data # SYNOPSIS **#include ** ```c #define NCREEL_OPTION_INFINITESCROLL 0x0001 #define NCREEL_OPTION_CIRCULAR 0x0002 typedef struct ncreel_options { // require this many rows and columns (including borders). // otherwise, a message will be displayed stating that a // larger terminal is necessary, and input will be queued. // if 0, no minimum will be enforced. may not be negative. // note that ncreel_create() does not return error if // given a WINDOW smaller than these minima; it instead // patiently waits for the screen to get bigger. int min_supported_cols; int min_supported_rows; // use no more than this many rows and columns (including // borders). may not be less than the corresponding minimum. // 0 means no maximum. int max_supported_cols; int max_supported_rows; // desired offsets within the surrounding WINDOW (top right // bottom left) upon creation / resize. an ncreel_move() // operation updates these. int toff, roff, boff, loff; // notcurses can draw a border around the ncreel, and also // around the component tablets. inhibit borders by setting all // valid bits in the masks. partially inhibit borders by setting // individual bits in the masks. the appropriate attr and pair // values will be used to style the borders. focused and // non-focused tablets can have different styles. you can instead // draw your own borders, or forgo borders entirely. unsigned bordermask; // bitfield; 1s will not be drawn uint64_t borderchan; // attributes used for ncreel border unsigned tabletmask; // bitfield for tablet borders uint64_t tabletchan; // tablet border styling channel uint64_t focusedchan;// focused tablet border styling channel uint64_t bgchannel; // background colors unsigned flags; // bitfield over NCREEL_OPTION_* } ncreel_options; ``` **struct ncreel* ncreel_create(struct ncplane* nc, const ncreel_options* popts, int efd);** **struct ncplane* ncreel_plane(struct ncreel* nr);** **typedef int (*tabletcb)(struct nctablet* t, int begx, int begy, int maxx, int maxy, bool cliptop);** **struct nctablet* ncreel_add(struct ncreel* nr, struct nctablet* after, struct nctablet* before, tabletcb cb, void* opaque);** **int ncreel_tabletcount(const struct ncreel* nr);** **int ncreel_touch(struct ncreel* nr, struct nctablet* t);** **int ncreel_del(struct ncreel* nr, struct nctablet* t);** **int ncreel_del_focused(struct ncreel* nr);** **int ncreel_move(struct ncreel* nr, int y, int x);** **int ncreel_redraw(struct ncreel* nr);** **struct nctablet* ncreel_focused(struct ncreel* nr);** **struct nctablet* ncreel_next(struct ncreel* nr);** **struct nctablet* ncreel_prev(struct ncreel* nr);** **int ncreel_destroy(struct ncreel* nr);** **void* nctablet_userptr(struct nctablet* t);** **struct ncplane* nctablet_ncplane(struct nctablet* t);** # DESCRIPTION # RETURN VALUES # SEE ALSO **notcurses(3)**, **notcurses_plane(3)**