Blame
Date:
Thu May 5 08:54:29 2022 UTC
Message:
reset all the state functions regardless of MB_READ vs. MB_COMPLREAD must_select otherwise is set when MB_COMPREAD but not cleared on MB_READ, yielding funny errors. While here, move also the other parts of the state out of the if (MB_COMPLREAD) to avoid this kind of issues in the future.
001
2021-07-12
op
/*
002
2021-07-12
op
* Copyright (c) 2021 Omar Polo <op@omarpolo.com>
003
2021-07-12
op
*
004
2021-07-12
op
* Permission to use, copy, modify, and distribute this software for any
005
2021-07-12
op
* purpose with or without fee is hereby granted, provided that the above
006
2021-07-12
op
* copyright notice and this permission notice appear in all copies.
007
2021-07-12
op
*
008
2021-07-12
op
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
009
2021-07-12
op
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
010
2021-07-12
op
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
011
2021-07-12
op
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
012
2021-07-12
op
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
013
2021-07-12
op
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
014
2021-07-12
op
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
015
2021-07-12
op
*/
016
2021-07-12
op
017
2021-07-21
op
#include "compat.h"
018
2021-07-21
op
019
2022-04-24
op
#include <errno.h>
020
2022-04-24
op
#include <limits.h>
021
2021-07-21
op
#include <stdio.h>
022
2021-07-12
op
#include <stdlib.h>
023
2021-07-12
op
#include <string.h>
024
2021-07-12
op
025
2022-04-24
op
#include "fs.h"
026
2021-07-12
op
#include "minibuffer.h"
027
2021-08-14
op
#include "session.h"
028
2021-07-12
op
#include "ui.h"
029
2021-07-12
op
#include "utf8.h"
030
2022-01-11
op
#include "utils.h"
031
2021-07-12
op
032
2022-02-26
op
#define nitems(x) (sizeof(x)/sizeof(x[0]))
033
2022-02-26
op
034
2021-07-15
op
static void *minibuffer_metadata(void);
035
2022-04-13
op
static const char *minibuffer_compl_text(void);
036
2021-07-12
op
static void minibuffer_hist_save_entry(void);
037
2021-07-12
op
static void yornp_self_insert(void);
038
2021-07-12
op
static void yornp_abort(void);
039
2021-07-12
op
static void read_self_insert(void);
040
2021-07-12
op
static void read_abort(void);
041
2021-07-12
op
static void read_select(void);
042
2021-07-21
op
static void handle_clear_echoarea(int, short, void *);
043
2021-07-21
op
044
2021-07-21
op
static struct event clechoev;
045
2021-07-21
op
static struct timeval clechoev_timer = { 5, 0 };
046
2021-07-12
op
047
2021-07-12
op
static void (*yornp_cb)(int, struct tab *);
048
2021-07-12
op
static struct tab *yornp_data;
049
2021-07-12
op
050
2021-07-13
op
static void (*read_cb)(const char*, struct tab *);
051
2021-07-13
op
static struct tab *read_data;
052
2021-07-12
op
053
2021-08-12
op
/* XXX: don't forget to init these in minibuffer_init */
054
2021-07-12
op
struct histhead eecmd_history,
055
2021-07-12
op
ir_history,
056
2021-07-12
op
lu_history,
057
2021-07-12
op
read_history;
058
2021-07-12
op
059
2021-07-12
op
struct ministate ministate;
060
2021-07-12
op
061
2021-07-14
op
struct buffer minibufferwin;
062
2021-07-21
op
063
2021-07-21
op
int in_minibuffer;
064
2022-02-26
op
065
2022-02-26
op
static inline int
066
2022-02-26
op
matches(char **words, size_t len, struct line *l)
067
2022-02-26
op
{
068
2022-02-26
op
size_t i;
069
2022-02-26
op
int lm, am;
070
2022-02-26
op
071
2022-02-26
op
for (i = 0; i < len; ++i) {
072
2022-02-26
op
lm = am = 0;
073
2022-02-26
op
074
2022-02-26
op
if (strcasestr(l->line, words[i]) != NULL)
075
2022-02-26
op
lm = 1;
076
2022-02-26
op
if (l->alt != NULL &&
077
2022-02-26
op
strcasestr(l->alt, words[i]) != NULL)
078
2022-02-26
op
am = 1;
079
2022-02-26
op
080
2022-02-26
op
if (!lm && !am)
081
2022-02-26
op
return 0;
082
2022-02-26
op
}
083
2021-07-14
op
084
2022-02-26
op
return 1;
085
2022-02-26
op
}
086
2022-02-26
op
087
2021-07-14
op
/*
088
2021-07-14
op
* Recompute the visible completions. If add is 1, don't consider the
089
2021-07-14
op
* ones already hidden.
090
2021-07-14
op
*/
091
2021-07-14
op
void
092
2021-07-14
op
recompute_completions(int add)
093
2021-07-14
op
{
094
2022-02-26
op
static char buf[GEMINI_URL_LEN];
095
2022-04-15
op
const char *text;
096
2022-02-26
op
char *input, **ap, *words[10];
097
2022-02-26
op
size_t len = 0;
098
2021-07-14
op
struct line *l;
099
2022-04-13
op
struct vline *vl;
100
2021-07-14
op
struct buffer *b;
101
2021-07-14
op
102
2021-07-14
op
if (in_minibuffer != MB_COMPREAD)
103
2021-07-14
op
return;
104
2021-07-14
op
105
2022-04-15
op
if (ministate.hist_cur != NULL)
106
2022-04-15
op
text = ministate.hist_cur->h;
107
2022-04-15
op
else
108
2022-04-15
op
text = ministate.buf;
109
2022-04-15
op
110
2022-04-15
op
strlcpy(buf, text, sizeof(buf));
111
2022-02-26
op
input = buf;
112
2022-02-26
op
113
2022-02-26
op
/* tokenize the input */
114
2022-02-26
op
for (ap = words; ap < words + nitems(words) &&
115
2022-02-26
op
(*ap = strsep(&input, " ")) != NULL;) {
116
2022-02-26
op
if (**ap != '\0')
117
2022-02-26
op
ap++, len++;
118
2022-02-26
op
}
119
2022-02-26
op
120
2021-07-14
op
b = &ministate.compl.buffer;
121
2021-07-14
op
TAILQ_FOREACH(l, &b->page.head, lines) {
122
2021-07-14
op
l->type = LINE_COMPL;
123
2021-07-14
op
if (add && l->flags & L_HIDDEN)
124
2021-07-14
op
continue;
125
2022-02-26
op
if (matches(words, len, l)) {
126
2021-07-15
op
if (l->flags & L_HIDDEN)
127
2021-07-15
op
b->line_max++;
128
2021-07-14
op
l->flags &= ~L_HIDDEN;
129
2021-07-15
op
} else {
130
2021-07-15
op
if (!(l->flags & L_HIDDEN))
131
2021-07-15
op
b->line_max--;
132
2021-07-14
op
l->flags |= L_HIDDEN;
133
2021-07-15
op
}
134
2021-07-14
op
}
135
2021-07-14
op
136
2021-07-14
op
if (b->current_line == NULL)
137
2021-07-14
op
b->current_line = TAILQ_FIRST(&b->head);
138
2021-07-14
op
b->current_line = adjust_line(b->current_line, b);
139
2022-04-13
op
vl = b->current_line;
140
2022-04-14
op
if (ministate.compl.must_select && vl != NULL)
141
2022-04-13
op
vl->parent->type = LINE_COMPL_CURRENT;
142
2021-07-14
op
}
143
2021-07-14
op
144
2021-01-02
op
int
145
2021-01-02
op
minibuffer_insert_current_candidate(void)
146
2021-01-02
op
{
147
2021-01-02
op
struct vline *vl;
148
2021-01-02
op
149
2021-01-02
op
vl = ministate.compl.buffer.current_line;
150
2021-01-02
op
if (vl == NULL || vl->parent->flags & L_HIDDEN)
151
2021-01-02
op
return -1;
152
2021-01-02
op
153
2021-01-02
op
minibuffer_taint_hist();
154
2021-01-02
op
strlcpy(ministate.buf, vl->parent->line, sizeof(ministate.buf));
155
2021-01-02
op
ministate.buffer.cpoff = utf8_cplen(ministate.buf);
156
2021-01-02
op
157
2021-01-02
op
return 0;
158
2021-01-02
op
}
159
2021-01-02
op
160
2021-07-15
op
static void *
161
2021-07-15
op
minibuffer_metadata(void)
162
2021-07-15
op
{
163
2021-07-15
op
struct vline *vl;
164
2021-07-15
op
165
2021-07-15
op
vl = ministate.compl.buffer.current_line;
166
2021-07-15
op
167
2021-07-15
op
if (vl == NULL || vl->parent->flags & L_HIDDEN)
168
2021-07-15
op
return NULL;
169
2021-07-15
op
170
2021-07-16
op
return vl->parent->data;
171
2021-07-15
op
}
172
2021-07-15
op
173
2022-04-13
op
static const char *
174
2022-04-13
op
minibuffer_compl_text(void)
175
2022-04-13
op
{
176
2022-04-13
op
struct vline *vl;
177
2022-04-13
op
178
2022-04-15
op
if (ministate.hist_cur != NULL)
179
2022-04-15
op
return ministate.hist_cur->h;
180
2022-04-15
op
181
2022-04-13
op
vl = ministate.compl.buffer.current_line;
182
2022-04-13
op
if (vl == NULL || vl->parent->flags & L_HIDDEN ||
183
2022-04-13
op
vl->parent->type == LINE_COMPL || vl->parent->line == NULL)
184
2022-04-13
op
return ministate.buf;
185
2022-04-13
op
return vl->parent->line;
186
2022-04-13
op
}
187
2022-04-13
op
188
2021-07-12
op
static void
189
2021-07-12
op
minibuffer_hist_save_entry(void)
190
2021-07-12
op
{
191
2021-07-12
op
struct hist *hist;
192
2022-04-13
op
const char *t;
193
2021-07-12
op
194
2021-07-12
op
if (ministate.history == NULL)
195
2021-07-12
op
return;
196
2021-07-12
op
197
2021-07-12
op
if ((hist = calloc(1, sizeof(*hist))) == NULL)
198
2021-07-12
op
abort();
199
2021-07-12
op
200
2022-04-13
op
t = minibuffer_compl_text();
201
2022-04-13
op
strlcpy(hist->h, t, sizeof(hist->h));
202
2021-07-12
op
203
2021-08-12
op
TAILQ_INSERT_TAIL(&ministate.history->head, hist, entries);
204
2021-07-12
op
ministate.history->len++;
205
2021-07-12
op
}
206
2021-07-12
op
207
2021-07-12
op
/*
208
2021-07-12
op
* taint the minibuffer cache: if we're currently showing a history
209
2021-07-12
op
* element, copy that to the current buf and reset the "history
210
2021-07-12
op
* navigation" thing.
211
2021-07-12
op
*/
212
2021-07-12
op
void
213
2021-07-12
op
minibuffer_taint_hist(void)
214
2021-07-12
op
{
215
2021-07-12
op
if (ministate.hist_cur == NULL)
216
2021-07-12
op
return;
217
2021-07-12
op
218
2021-07-12
op
strlcpy(ministate.buf, ministate.hist_cur->h, sizeof(ministate.buf));
219
2021-07-12
op
ministate.hist_cur = NULL;
220
2021-07-12
op
ministate.buffer.current_line->line = ministate.buf;
221
2021-07-12
op
}
222
2021-07-12
op
223
2021-07-14
op
void
224
2021-07-12
op
minibuffer_self_insert(void)
225
2021-07-12
op
{
226
2021-07-12
op
char *c, tmp[5] = {0};
227
2021-07-12
op
size_t len;
228
2021-07-12
op
229
2021-07-12
op
minibuffer_taint_hist();
230
2021-07-12
op
231
2021-07-12
op
if (thiskey.cp == 0)
232
2021-07-12
op
return;
233
2021-07-12
op
234
2021-07-12
op
len = utf8_encode(thiskey.cp, tmp);
235
2021-07-12
op
c = utf8_nth(ministate.buffer.current_line->line, ministate.buffer.cpoff);
236
2021-07-12
op
if (c + len > ministate.buf + sizeof(ministate.buf) - 1)
237
2021-07-12
op
return;
238
2021-07-12
op
239
2021-07-12
op
memmove(c + len, c, strlen(c)+1);
240
2021-07-12
op
memcpy(c, tmp, len);
241
2021-07-12
op
ministate.buffer.cpoff++;
242
2021-07-14
op
243
2021-07-14
op
recompute_completions(1);
244
2021-07-14
op
}
245
2021-07-14
op
246
2021-07-14
op
void
247
2021-07-14
op
sensible_self_insert(void)
248
2021-07-14
op
{
249
2021-07-20
op
if (thiskey.meta ||
250
2021-07-24
op
(!unicode_isgraph(thiskey.key) && thiskey.key != ' ')) {
251
2021-07-12
op
global_key_unbound();
252
2021-07-12
op
return;
253
2021-07-12
op
}
254
2021-07-12
op
255
2021-07-12
op
minibuffer_self_insert();
256
2021-07-12
op
}
257
2021-07-12
op
258
2021-07-12
op
void
259
2021-07-12
op
eecmd_select(void)
260
2021-07-12
op
{
261
2021-01-02
op
struct cmd *cmd;
262
2021-01-02
op
const char *t;
263
2021-01-02
op
264
2022-04-13
op
t = minibuffer_compl_text();
265
2021-07-12
op
for (cmd = cmds; cmd->cmd != NULL; ++cmd) {
266
2021-01-02
op
if (!strcmp(cmd->cmd, t)) {
267
2021-07-12
op
minibuffer_hist_save_entry();
268
2022-04-13
op
exit_minibuffer();
269
2021-07-12
op
cmd->fn(current_buffer());
270
2021-07-12
op
return;
271
2021-07-12
op
}
272
2021-07-12
op
}
273
2021-07-12
op
274
2021-07-12
op
message("No match");
275
2021-07-12
op
}
276
2021-07-12
op
277
2021-07-12
op
void
278
2021-08-03
op
ir_select_gemini(void)
279
2021-07-12
op
{
280
2021-07-12
op
char buf[1025] = {0};
281
2021-07-12
op
struct phos_uri uri;
282
2021-07-17
op
struct tab *tab = current_tab;
283
2021-07-12
op
284
2021-07-12
op
minibuffer_hist_save_entry();
285
2021-07-12
op
286
2021-07-12
op
/* a bit ugly but... */
287
2021-07-12
op
memcpy(&uri, &tab->uri, sizeof(tab->uri));
288
2022-04-13
op
phos_uri_set_query(&uri, minibuffer_compl_text());
289
2022-02-07
op
phos_serialize_uri(&uri, buf, sizeof(buf));
290
2022-04-13
op
291
2022-04-13
op
exit_minibuffer();
292
2022-02-07
op
load_url_in_tab(tab, buf, NULL, LU_MODE_NOCACHE);
293
2022-02-07
op
}
294
2022-02-07
op
295
2022-02-07
op
void
296
2022-02-07
op
ir_select_reply(void)
297
2022-02-07
op
{
298
2022-02-07
op
char buf[1025] = {0};
299
2022-02-07
op
struct phos_uri uri;
300
2022-02-07
op
struct tab *tab = current_tab;
301
2022-02-07
op
302
2022-02-07
op
minibuffer_hist_save_entry();
303
2022-02-07
op
304
2022-02-07
op
/* a bit ugly but... */
305
2022-02-07
op
strlcpy(buf, tab->last_input_url, sizeof(buf));
306
2022-02-07
op
phos_parse_absolute_uri(buf, &uri);
307
2022-04-13
op
phos_uri_set_query(&uri, minibuffer_compl_text());
308
2021-07-12
op
phos_serialize_uri(&uri, buf, sizeof(buf));
309
2022-04-13
op
310
2022-04-13
op
exit_minibuffer();
311
2022-01-11
op
load_url_in_tab(tab, buf, NULL, LU_MODE_NOCACHE);
312
2021-07-12
op
}
313
2021-07-12
op
314
2021-07-12
op
void
315
2021-08-03
op
ir_select_gopher(void)
316
2021-08-03
op
{
317
2021-08-03
op
minibuffer_hist_save_entry();
318
2022-04-13
op
gopher_send_search_req(current_tab, minibuffer_compl_text());
319
2022-04-13
op
exit_minibuffer();
320
2021-08-03
op
}
321
2021-08-03
op
322
2021-08-03
op
void
323
2021-07-12
op
lu_select(void)
324
2021-07-12
op
{
325
2021-08-16
op
char url[GEMINI_URL_LEN+1];
326
2021-08-16
op
327
2021-07-12
op
minibuffer_hist_save_entry();
328
2022-04-13
op
humanify_url(minibuffer_compl_text(), url, sizeof(url));
329
2022-04-13
op
exit_minibuffer();
330
2022-01-11
op
load_url_in_tab(current_tab, url, NULL, LU_MODE_NOCACHE);
331
2021-07-12
op
}
332
2021-07-12
op
333
2021-07-12
op
void
334
2021-07-12
op
bp_select(void)
335
2021-07-12
op
{
336
2021-07-12
op
exit_minibuffer();
337
2022-04-24
op
if (*ministate.buf != '\0') {
338
2022-04-24
op
if (!bookmark_page(ministate.buf))
339
2022-04-24
op
message("failed to bookmark page: %s",
340
2022-04-24
op
strerror(errno));
341
2022-04-24
op
} else
342
2021-07-12
op
message("Abort.");
343
2021-07-12
op
}
344
2021-07-12
op
345
2021-07-14
op
void
346
2021-07-14
op
ts_select(void)
347
2021-07-14
op
{
348
2021-07-14
op
struct tab *tab;
349
2021-07-14
op
350
2021-07-15
op
if ((tab = minibuffer_metadata()) == NULL) {
351
2021-07-14
op
message("No tab selected");
352
2021-07-14
op
return;
353
2021-07-14
op
}
354
2021-07-14
op
355
2021-07-14
op
exit_minibuffer();
356
2021-07-14
op
switch_to_tab(tab);
357
2021-07-14
op
}
358
2021-07-14
op
359
2021-07-14
op
void
360
2021-07-14
op
ls_select(void)
361
2021-07-14
op
{
362
2021-07-14
op
struct line *l;
363
2021-07-14
op
364
2021-07-15
op
if ((l = minibuffer_metadata()) == NULL) {
365
2021-07-14
op
message("No link selected");
366
2021-07-14
op
return;
367
2021-07-14
op
}
368
2021-07-14
op
369
2021-07-14
op
exit_minibuffer();
370
2022-01-11
op
load_url_in_tab(current_tab, l->alt, NULL, LU_MODE_NOCACHE);
371
2021-07-14
op
}
372
2021-07-14
op
373
2021-07-15
op
static inline void
374
2021-07-15
op
jump_to_line(struct line *l)
375
2021-07-14
op
{
376
2021-07-14
op
struct vline *vl;
377
2021-07-21
op
struct buffer *buffer;
378
2021-07-14
op
379
2021-07-21
op
buffer = current_buffer();
380
2021-07-21
op
381
2021-07-21
op
TAILQ_FOREACH(vl, &buffer->head, vlines) {
382
2021-07-14
op
if (vl->parent == l)
383
2021-07-14
op
break;
384
2021-07-14
op
}
385
2021-07-14
op
386
2021-07-14
op
if (vl == NULL)
387
2021-07-15
op
message("Ops, %s error! Please report to %s",
388
2021-07-15
op
__func__, PACKAGE_BUGREPORT);
389
2021-07-16
op
else {
390
2021-07-21
op
buffer->top_line = vl;
391
2021-07-21
op
buffer->current_line = vl;
392
2021-07-16
op
}
393
2021-07-14
op
}
394
2021-07-14
op
395
2021-07-15
op
void
396
2021-07-15
op
swiper_select(void)
397
2021-07-15
op
{
398
2021-07-15
op
struct line *l;
399
2021-07-15
op
400
2021-07-15
op
if ((l = minibuffer_metadata()) == NULL) {
401
2021-07-15
op
message("No line selected");
402
2021-07-15
op
return;
403
2021-07-15
op
}
404
2021-07-15
op
405
2021-07-15
op
exit_minibuffer();
406
2021-07-15
op
jump_to_line(l);
407
2021-07-15
op
}
408
2021-07-15
op
409
2021-07-15
op
void
410
2021-07-15
op
toc_select(void)
411
2021-07-15
op
{
412
2021-07-15
op
struct line *l;
413
2021-07-15
op
414
2021-07-15
op
if ((l = minibuffer_metadata()) == NULL) {
415
2021-07-15
op
message("No line selected");
416
2021-07-15
op
return;
417
2021-07-15
op
}
418
2021-07-15
op
419
2021-07-15
op
exit_minibuffer();
420
2021-07-15
op
jump_to_line(l);
421
2021-07-15
op
}
422
2021-07-15
op
423
2021-07-12
op
static void
424
2021-07-12
op
yornp_self_insert(void)
425
2021-07-12
op
{
426
2021-07-12
op
if (thiskey.key != 'y' && thiskey.key != 'n') {
427
2021-07-12
op
message("Please answer y or n");
428
2021-07-12
op
return;
429
2021-07-12
op
}
430
2021-07-12
op
431
2021-07-12
op
exit_minibuffer();
432
2021-07-12
op
yornp_cb(thiskey.key == 'y', yornp_data);
433
2021-07-12
op
}
434
2021-07-12
op
435
2021-07-12
op
static void
436
2021-07-12
op
yornp_abort(void)
437
2021-07-12
op
{
438
2021-07-12
op
exit_minibuffer();
439
2021-07-12
op
yornp_cb(0, yornp_data);
440
2021-07-12
op
}
441
2021-07-12
op
442
2021-07-12
op
static void
443
2021-07-12
op
read_self_insert(void)
444
2021-07-12
op
{
445
2021-07-12
op
if (thiskey.meta || !unicode_isgraph(thiskey.cp)) {
446
2021-07-12
op
global_key_unbound();
447
2021-07-12
op
return;
448
2021-07-12
op
}
449
2021-07-12
op
450
2021-07-12
op
minibuffer_self_insert();
451
2021-07-12
op
}
452
2021-07-12
op
453
2021-07-12
op
static void
454
2021-07-12
op
read_abort(void)
455
2021-07-12
op
{
456
2021-07-12
op
exit_minibuffer();
457
2021-07-12
op
read_cb(NULL, read_data);
458
2021-07-12
op
}
459
2021-07-12
op
460
2021-07-12
op
static void
461
2021-07-12
op
read_select(void)
462
2021-07-12
op
{
463
2021-08-26
op
exit_minibuffer();
464
2021-07-12
op
minibuffer_hist_save_entry();
465
2021-07-12
op
read_cb(ministate.buf, read_data);
466
2021-07-14
op
}
467
2021-07-14
op
468
2021-07-14
op
/*
469
2021-07-14
op
* TODO: we should collect this asynchronously...
470
2021-07-14
op
*/
471
2021-07-14
op
static inline void
472
2021-07-14
op
populate_compl_buffer(complfn *fn, void *data)
473
2021-07-14
op
{
474
2021-07-18
op
const char *s, *descr;
475
2021-07-14
op
struct line *l;
476
2021-07-14
op
struct buffer *b;
477
2021-07-14
op
struct parser *p;
478
2021-07-18
op
void *linedata;
479
2021-07-14
op
480
2021-07-14
op
b = &ministate.compl.buffer;
481
2021-07-14
op
p = &b->page;
482
2021-07-14
op
483
2021-07-18
op
linedata = NULL;
484
2021-07-18
op
descr = NULL;
485
2021-07-18
op
while ((s = fn(&data, &linedata, &descr)) != NULL) {
486
2021-07-14
op
if ((l = calloc(1, sizeof(*l))) == NULL)
487
2021-07-14
op
abort();
488
2021-07-14
op
489
2021-07-14
op
l->type = LINE_COMPL;
490
2021-07-16
op
l->data = linedata;
491
2021-07-18
op
l->alt = (char*)descr;
492
2021-07-14
op
if ((l->line = strdup(s)) == NULL)
493
2021-07-14
op
abort();
494
2021-07-14
op
495
2021-08-12
op
TAILQ_INSERT_TAIL(&p->head, l, lines);
496
2021-07-14
op
497
2021-07-14
op
linedata = NULL;
498
2021-07-18
op
descr = NULL;
499
2021-07-14
op
}
500
2022-04-13
op
501
2022-04-13
op
if ((l = TAILQ_FIRST(&p->head)) != NULL &&
502
2022-04-13
op
ministate.compl.must_select)
503
2022-04-13
op
l->type = LINE_COMPL_CURRENT;
504
2021-07-12
op
}
505
2021-07-12
op
506
2021-07-12
op
void
507
2021-07-12
op
enter_minibuffer(void (*self_insert_fn)(void), void (*donefn)(void),
508
2021-07-13
op
void (*abortfn)(void), struct histhead *hist,
509
2022-04-13
op
complfn *complfn, void *compldata, int must_select)
510
2021-07-12
op
{
511
2022-05-05
op
ministate.compl.must_select = must_select;
512
2022-05-05
op
ministate.compl.fn = complfn;
513
2022-05-05
op
ministate.compl.data = compldata;
514
2022-05-05
op
515
2021-07-14
op
in_minibuffer = complfn == NULL ? MB_READ : MB_COMPREAD;
516
2021-07-14
op
if (in_minibuffer == MB_COMPREAD) {
517
2022-05-05
op
populate_compl_buffer(complfn, compldata);
518
2021-07-14
op
ui_schedule_redraw();
519
2021-07-14
op
}
520
2021-07-14
op
521
2021-07-12
op
base_map = &minibuffer_map;
522
2021-07-12
op
current_map = &minibuffer_map;
523
2021-07-12
op
524
2021-07-12
op
base_map->unhandled_input = self_insert_fn;
525
2021-07-12
op
526
2021-07-12
op
ministate.donefn = donefn;
527
2021-07-12
op
ministate.abortfn = abortfn;
528
2021-07-12
op
memset(ministate.buf, 0, sizeof(ministate.buf));
529
2021-07-12
op
ministate.buffer.current_line = &ministate.vline;
530
2021-07-12
op
ministate.buffer.current_line->line = ministate.buf;
531
2021-07-12
op
ministate.buffer.cpoff = 0;
532
2021-07-12
op
strlcpy(ministate.buf, "", sizeof(ministate.prompt));
533
2021-07-12
op
534
2021-07-12
op
ministate.history = hist;
535
2021-07-12
op
ministate.hist_cur = NULL;
536
2021-07-12
op
ministate.hist_off = 0;
537
2021-07-12
op
}
538
2021-07-12
op
539
2021-07-12
op
void
540
2021-07-12
op
exit_minibuffer(void)
541
2021-07-12
op
{
542
2021-07-14
op
if (in_minibuffer == MB_COMPREAD) {
543
2021-07-14
op
erase_buffer(&ministate.compl.buffer);
544
2021-07-14
op
ui_schedule_redraw();
545
2021-07-14
op
}
546
2021-07-14
op
547
2021-07-12
op
in_minibuffer = 0;
548
2021-07-12
op
base_map = &global_map;
549
2021-07-12
op
current_map = &global_map;
550
2021-07-12
op
}
551
2021-07-12
op
552
2021-07-12
op
void
553
2021-07-12
op
yornp(const char *prompt, void (*fn)(int, struct tab*),
554
2021-07-12
op
struct tab *data)
555
2021-07-12
op
{
556
2021-07-12
op
size_t len;
557
2021-07-12
op
558
2021-07-12
op
if (in_minibuffer) {
559
2021-07-12
op
fn(0, data);
560
2021-07-12
op
return;
561
2021-07-12
op
}
562
2021-07-12
op
563
2021-07-12
op
yornp_cb = fn;
564
2021-07-12
op
yornp_data = data;
565
2021-07-12
op
enter_minibuffer(yornp_self_insert, yornp_self_insert,
566
2022-04-13
op
yornp_abort, NULL, NULL, NULL, 0);
567
2021-07-12
op
568
2021-07-12
op
len = sizeof(ministate.prompt);
569
2021-07-12
op
strlcpy(ministate.prompt, prompt, len);
570
2021-07-12
op
strlcat(ministate.prompt, " (y or n) ", len);
571
2021-07-12
op
}
572
2021-07-12
op
573
2021-07-21
op
void
574
2021-07-21
op
minibuffer_read(const char *prompt, void (*fn)(const char *, struct tab *),
575
2021-07-14
op
struct tab *data)
576
2021-07-12
op
{
577
2021-07-12
op
size_t len;
578
2021-07-12
op
579
2021-07-12
op
if (in_minibuffer)
580
2021-07-12
op
return;
581
2021-07-12
op
582
2021-07-12
op
read_cb = fn;
583
2021-07-12
op
read_data = data;
584
2021-07-12
op
enter_minibuffer(read_self_insert, read_select, read_abort,
585
2022-04-13
op
&read_history, NULL, NULL, 0);
586
2021-07-12
op
587
2021-07-12
op
len = sizeof(ministate.prompt);
588
2021-07-12
op
strlcpy(ministate.prompt, prompt, len);
589
2021-07-12
op
strlcat(ministate.prompt, ": ", len);
590
2021-07-21
op
}
591
2021-07-21
op
592
2021-07-21
op
static void
593
2021-07-21
op
handle_clear_echoarea(int fd, short ev, void *d)
594
2021-07-21
op
{
595
2021-07-21
op
free(ministate.curmesg);
596
2021-07-21
op
ministate.curmesg = NULL;
597
2021-07-21
op
598
2021-07-21
op
ui_after_message_hook();
599
2021-07-21
op
}
600
2021-07-21
op
601
2021-07-21
op
void
602
2021-07-21
op
vmessage(const char *fmt, va_list ap)
603
2021-07-21
op
{
604
2021-07-21
op
if (evtimer_pending(&clechoev, NULL))
605
2021-07-21
op
evtimer_del(&clechoev);
606
2021-07-21
op
607
2021-07-21
op
free(ministate.curmesg);
608
2021-07-21
op
ministate.curmesg = NULL;
609
2021-07-21
op
610
2021-07-21
op
if (fmt != NULL) {
611
2021-07-21
op
evtimer_set(&clechoev, handle_clear_echoarea, NULL);
612
2021-07-21
op
evtimer_add(&clechoev, &clechoev_timer);
613
2021-07-21
op
614
2021-07-21
op
/* TODO: what to do if the allocation fails here? */
615
2021-07-21
op
if (vasprintf(&ministate.curmesg, fmt, ap) == -1)
616
2021-07-21
op
ministate.curmesg = NULL;
617
2021-07-21
op
}
618
2021-07-21
op
619
2021-07-21
op
ui_after_message_hook();
620
2021-07-12
op
}
621
2021-07-21
op
622
2021-07-21
op
void
623
2021-07-21
op
message(const char *fmt, ...)
624
2021-07-21
op
{
625
2021-07-21
op
va_list ap;
626
2021-07-21
op
627
2021-07-21
op
va_start(ap, fmt);
628
2021-07-21
op
vmessage(fmt, ap);
629
2021-07-21
op
va_end(ap);
630
2021-07-21
op
}
631
2021-07-21
op
632
2021-07-21
op
void
633
2021-07-21
op
minibuffer_init(void)
634
2021-07-21
op
{
635
2021-07-21
op
TAILQ_INIT(&eecmd_history.head);
636
2021-07-21
op
TAILQ_INIT(&ir_history.head);
637
2021-07-21
op
TAILQ_INIT(&lu_history.head);
638
2021-08-12
op
TAILQ_INIT(&read_history.head);
639
2021-07-21
op
640
2021-08-12
op
TAILQ_INIT(&ministate.compl.buffer.head);
641
2021-08-12
op
TAILQ_INIT(&ministate.compl.buffer.page.head);
642
2021-08-12
op
643
2021-07-21
op
ministate.line.type = LINE_TEXT;
644
2021-07-21
op
ministate.vline.parent = &ministate.line;
645
2021-07-25
op
ministate.buffer.page.name = "*minibuffer*";
646
2021-07-21
op
ministate.buffer.current_line = &ministate.vline;
647
2021-07-21
op
648
2021-07-21
op
evtimer_set(&clechoev, handle_clear_echoarea, NULL);
649
2021-07-21
op
}
Omar Polo