Blob


1 /*
2 * Copyright (c) 2021 Omar Polo <op@omarpolo.com>
3 *
4 * Permission to use, copy, modify, and distribute this software for any
5 * purpose with or without fee is hereby granted, provided that the above
6 * copyright notice and this permission notice appear in all copies.
7 *
8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15 */
17 #ifndef TELESCOPE_H
18 #define TELESCOPE_H
20 #include "config.h"
21 #include "compat.h"
23 #include "url.h"
25 #define GEMINI_URL_LEN 1024
27 enum imsg_type {
28 IMSG_GET, /* data is URL, peerid the tab id */
29 IMSG_ERR,
30 IMSG_CHECK_CERT,
31 IMSG_CERT_STATUS,
32 IMSG_GOT_CODE,
33 IMSG_GOT_META,
34 IMSG_PROCEED,
35 IMSG_STOP,
36 IMSG_BUF,
37 IMSG_EOF,
38 IMSG_QUIT,
39 };
41 enum line_type {
42 LINE_TEXT,
43 LINE_LINK,
44 LINE_TITLE_1,
45 LINE_TITLE_2,
46 LINE_TITLE_3,
47 LINE_ITEM,
48 LINE_QUOTE,
49 LINE_PRE_START,
50 LINE_PRE_CONTENT,
51 LINE_PRE_END,
52 };
54 struct line {
55 enum line_type type;
56 char *line;
57 char *alt;
58 TAILQ_ENTRY(line) lines;
59 };
61 struct parser;
62 struct page;
64 /* typedef void (*initparserfn)(struct parser*); */
66 typedef int (*parsechunkfn)(struct parser*, const char*, size_t);
67 typedef int (*parserfreefn)(struct parser*);
69 typedef void (imsg_handlerfn)(struct imsg*, size_t);
71 struct parser {
72 char *buf;
73 size_t len;
74 size_t cap;
75 int flags;
76 parsechunkfn parse;
77 parserfreefn free;
79 TAILQ_HEAD(, line) head;
80 };
82 struct ui_state;
84 extern TAILQ_HEAD(tabshead, tab) tabshead;
85 struct tab {
86 struct parser page;
87 TAILQ_ENTRY(tab) tabs;
88 uint32_t id;
89 uint32_t flags;
91 char urlstr[GEMINI_URL_LEN];
92 struct url url;
94 int code;
95 char meta[GEMINI_URL_LEN];
96 int redirect_count;
98 struct ui_state *s;
99 };
101 struct proto {
102 const char *schema;
104 /* should load the given url in the tab. Optionally, it may
105 * consider the given url as relative to the one already
106 * present in tab. It must set tab->urlstr to a serialized
107 * human-friendly URL. */
108 void (*loadfn)(struct tab*, const char*);
109 };
111 extern struct event imsgev;
113 /* gemini.c */
114 int client_main(struct imsgbuf *b);
116 /* gemtext.c */
117 void gemtext_initparser(struct parser*);
119 /* mime.c */
120 int setup_parser_for(struct tab*);
122 /* pages.c */
123 extern const char *about_new;
125 #define CANNOT_FETCH 0
126 #define TOO_MUCH_REDIRECTS 1
127 #define MALFORMED_RESPONSE 2
128 #define UNKNOWN_TYPE_OR_CSET 3
129 extern const char *err_pages[70];
131 /* telescope.c */
132 void load_about_url(struct tab*, const char*);
133 void load_gemini_url(struct tab*, const char*);
134 void load_url(struct tab*, const char*);
135 void stop_tab(struct tab*);
137 /* ui.c */
138 int ui_init(void);
139 void ui_on_tab_loaded(struct tab*);
140 void ui_on_tab_refresh(struct tab*);
141 void ui_require_input(struct tab*, int);
142 void ui_end(void);
144 /* util.c */
145 int mark_nonblock(int);
146 char *telescope_strnchr(char*, char, size_t);
147 int has_prefix(const char*, const char*);
149 #endif /* TELESCOPE_H */