Start using stralloc.
Clean up a few web page generation functions. Signed-off-by: Dan Cross <patchdev@fat-dragon.org>
This commit is contained in:
parent
e196292503
commit
77bf763939
@ -268,6 +268,8 @@ struct ptr_vector {
|
|||||||
void **ptrs;
|
void **ptrs;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct ptr_vector EMPTY_PTR_VECTOR = { 0, 0, NULL };
|
||||||
|
|
||||||
extern void init_ptr_vector(struct ptr_vector *vec);
|
extern void init_ptr_vector(struct ptr_vector *vec);
|
||||||
extern void ptr_vector_clear(struct ptr_vector *vec);
|
extern void ptr_vector_clear(struct ptr_vector *vec);
|
||||||
extern void *ptr_vector_get(struct ptr_vector *vec, size_t i);
|
extern void *ptr_vector_get(struct ptr_vector *vec, size_t i);
|
||||||
|
@ -63,3 +63,33 @@ int stralloc_append1(stralloc *sa, char b) {
|
|||||||
sa->s[sa->len++] = b;
|
sa->s[sa->len++] = b;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int stralloc_cat_ulong_rec(stralloc *sa, unsigned long uv) {
|
||||||
|
if (uv == 0) return 1;
|
||||||
|
if (!stralloc_cat_ulong_rec(sa, uv / 10)) return 0;
|
||||||
|
return stralloc_append1(sa, (uv % 10) + '0');
|
||||||
|
}
|
||||||
|
|
||||||
|
int stralloc_cat_ulong(stralloc *sa, unsigned long uv) {
|
||||||
|
if (uv == 0)
|
||||||
|
return stralloc_append1(sa, '0');
|
||||||
|
return stralloc_cat_ulong_rec(sa, uv);
|
||||||
|
}
|
||||||
|
|
||||||
|
int stralloc_cat_long(stralloc *sa, long v) {
|
||||||
|
if (v < 0)
|
||||||
|
if (!stralloc_append1(sa, '-')) return 0;
|
||||||
|
return stralloc_cat_ulong(sa, labs(v));
|
||||||
|
}
|
||||||
|
|
||||||
|
int stralloc_cat_byte(stralloc *sa, int b) {
|
||||||
|
static const char *hex = "0123456789abcdef";
|
||||||
|
if (!stralloc_append1(sa, hex[(b >> 4) & 0xF])) return 0;
|
||||||
|
return stralloc_append1(sa, hex[(b >> 0) & 0xF]);
|
||||||
|
}
|
||||||
|
|
||||||
|
int stralloc_cat_Byte(stralloc *sa, int b) {
|
||||||
|
static const char *hex = "0123456789ABCDEF";
|
||||||
|
if (!stralloc_append1(sa, hex[(b >> 4) & 0xF])) return 0;
|
||||||
|
return stralloc_append1(sa, hex[(b >> 0) & 0xF]);
|
||||||
|
}
|
||||||
|
@ -12,11 +12,17 @@ struct stralloc {
|
|||||||
size_t a;
|
size_t a;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const stralloc EMPTY_STRALLOC = { NULL, 0, 0 };
|
||||||
|
|
||||||
extern int stralloc_ready(stralloc *sa, size_t n);
|
extern int stralloc_ready(stralloc *sa, size_t n);
|
||||||
extern int stralloc_starts(stralloc *sa, const char *s);
|
extern int stralloc_starts(stralloc *sa, const char *s);
|
||||||
extern int stralloc_copyb(stralloc *sa, const char *s, size_t n);
|
extern int stralloc_copyb(stralloc *sa, const char *s, size_t n);
|
||||||
extern int stralloc_catb(stralloc *sa, const char *s, size_t n);
|
extern int stralloc_catb(stralloc *sa, const char *s, size_t n);
|
||||||
extern int stralloc_append1(stralloc *sa, char b);
|
extern int stralloc_append1(stralloc *sa, char b);
|
||||||
|
extern int stralloc_cat_ulong(stralloc *sa, unsigned long uv);
|
||||||
|
extern int stralloc_cat_long(stralloc *sa, long v);
|
||||||
|
extern int stralloc_cat_byte(stralloc *sa, int b);
|
||||||
|
extern int stralloc_cat_Byte(stralloc *sa, int b);
|
||||||
|
|
||||||
static inline int stralloc_readyplus(stralloc *sa, size_t n) {
|
static inline int stralloc_readyplus(stralloc *sa, size_t n) {
|
||||||
assert(sa != NULL);
|
assert(sa != NULL);
|
||||||
|
165
src/www_msgs.c
165
src/www_msgs.c
@ -58,53 +58,35 @@ char *www_sanitize(char *inp) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
char *www_msgs_arealist(struct user_record *user) {
|
char *www_msgs_arealist(struct user_record *user) {
|
||||||
char *page;
|
stralloc page = EMPTY_STRALLOC;
|
||||||
int max_len;
|
|
||||||
int len;
|
|
||||||
char buffer[4096];
|
|
||||||
int i, j;
|
int i, j;
|
||||||
|
|
||||||
page = (char *)malloz(4096);
|
stralloc_copys(&page, "<div class=\"content-header\"><h2>Message Conferences</h2></div>\n");
|
||||||
max_len = 4096;
|
|
||||||
len = 0;
|
|
||||||
|
|
||||||
sprintf(buffer, "<div class=\"content-header\"><h2>Message Conferences</h2></div>\n");
|
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
|
||||||
max_len += 4096;
|
|
||||||
page = (char *)realloc(page, max_len);
|
|
||||||
}
|
|
||||||
strcat(page, buffer);
|
|
||||||
len += strlen(buffer);
|
|
||||||
|
|
||||||
for (i = 0; i < conf.mail_conference_count; i++) {
|
for (i = 0; i < conf.mail_conference_count; i++) {
|
||||||
if (conf.mail_conferences[i]->sec_level <= user->sec_level) {
|
if (conf.mail_conferences[i]->sec_level <= user->sec_level) {
|
||||||
sprintf(buffer, "<div class=\"conference-list-item\">%s</div>\n", conf.mail_conferences[i]->name);
|
stralloc_cats(&page, "<div class=\"conference-list-item\">");
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
stralloc_cats(&page, conf.mail_conferences[i]->name);
|
||||||
max_len += 4096;
|
stralloc_cats(&page, "</div>\n");
|
||||||
page = (char *)realloc(page, max_len);
|
|
||||||
}
|
|
||||||
strcat(page, buffer);
|
|
||||||
len += strlen(buffer);
|
|
||||||
|
|
||||||
for (j = 0; j < conf.mail_conferences[i]->mail_area_count; j++) {
|
for (j = 0; j < conf.mail_conferences[i]->mail_area_count; j++) {
|
||||||
if (conf.mail_conferences[i]->mail_areas[j]->read_sec_level <= user->sec_level) {
|
if (conf.mail_conferences[i]->mail_areas[j]->read_sec_level > user->sec_level) {
|
||||||
|
continue;
|
||||||
if (new_messages(user, i, j) > 0) {
|
|
||||||
sprintf(buffer, "<div class=\"area-list-new\"><a href=\"%smsgs/%d/%d/\">%s</a></div>\n", conf.www_url, i, j, conf.mail_conferences[i]->mail_areas[j]->name);
|
|
||||||
} else {
|
|
||||||
sprintf(buffer, "<div class=\"area-list-item\"><a href=\"%smsgs/%d/%d/\">%s</a></div>\n", conf.www_url, i, j, conf.mail_conferences[i]->mail_areas[j]->name);
|
|
||||||
}
|
}
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
stralloc_cats(&page, "<div class=\"area-list-");
|
||||||
max_len += 4096;
|
stralloc_cats(&page, (new_messages(user, i, j) > 0) ? "new" : "item");
|
||||||
page = (char *)realloc(page, max_len);
|
stralloc_cats(&page, "\"><a href=\"");
|
||||||
}
|
stralloc_cats(&page, conf.www_url);
|
||||||
strcat(page, buffer);
|
stralloc_cats(&page, "msgs/");
|
||||||
len += strlen(buffer);
|
stralloc_cat_long(&page, i);
|
||||||
|
stralloc_append1(&page, '/');
|
||||||
|
stralloc_cat_long(&page, j);
|
||||||
|
stralloc_cats(&page, "/\">");
|
||||||
|
stralloc_cats(&page, conf.mail_conferences[i]->mail_areas[j]->name);
|
||||||
|
stralloc_cats(&page, "</a></div>\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
stralloc_0(&page);
|
||||||
return page;
|
return page.s;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *www_msgs_messagelist(struct user_record *user, int conference, int area, int skip) {
|
char *www_msgs_messagelist(struct user_record *user, int conference, int area, int skip) {
|
||||||
@ -1085,95 +1067,28 @@ int www_send_msg(struct user_record *user, char *to, char *subj, int conference,
|
|||||||
}
|
}
|
||||||
|
|
||||||
char *www_new_msg(struct user_record *user, int conference, int area) {
|
char *www_new_msg(struct user_record *user, int conference, int area) {
|
||||||
char *page;
|
stralloc page = EMPTY_STRALLOC;
|
||||||
int max_len;
|
|
||||||
int len;
|
|
||||||
char buffer[4096];
|
|
||||||
|
|
||||||
page = (char *)malloz(4096);
|
stralloc_copys(&page, "<div class=\"content-header\"><h2>New Message</h2></div>\n");
|
||||||
max_len = 4096;
|
stralloc_cats(&page, "<form action=\"");
|
||||||
len = 0;
|
stralloc_cats(&page, conf.www_url);
|
||||||
|
stralloc_cats(&page, "msgs/\" method=\"POST\" onsubmit=\"return validate()\" "
|
||||||
|
"enctype=\"application/x-www-form-urlencoded;charset=UTF-8\">\n");
|
||||||
|
stralloc_cats(&page, "<input type=\"hidden\" name=\"conference\" value=\"");
|
||||||
|
stralloc_cat_long(&page, conference);
|
||||||
|
stralloc_cats(&page, "\" />\n");
|
||||||
|
stralloc_cats(&page, "<input type=\"hidden\" name=\"area\" value=\"");
|
||||||
|
stralloc_cat_long(&page, area);
|
||||||
|
stralloc_cats(&page, "\" />\n");
|
||||||
|
stralloc_cats(&page, "<input type=\"hidden\" name=\"replyid\" value=\"NULL\" />\n");
|
||||||
|
stralloc_cats(&page, "To : <input type=\"text\" name=\"recipient\" value=\"All\" id=\"recipient\"/><br />\n");
|
||||||
|
stralloc_cats(&page, "Subject : <input type=\"text\" name=\"subject\" id=\"subject\" /><br />\n");
|
||||||
|
stralloc_cats(&page, "<textarea name=\"body\" id=\"body\" rows=\"25\" cols=\"79\" wrap=\"soft\"></textarea>\n<br />");
|
||||||
|
stralloc_cats(&page, "<input type=\"submit\" name=\"submit\" value=\"Send\" />\n<br />");
|
||||||
|
stralloc_cats(&page, "</form>\n");
|
||||||
|
stralloc_0(&page);
|
||||||
|
|
||||||
sprintf(buffer, "<div class=\"content-header\"><h2>New Message</h2></div>\n");
|
return page.s;
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
|
||||||
max_len += 4096;
|
|
||||||
page = (char *)realloc(page, max_len);
|
|
||||||
}
|
|
||||||
strcat(page, buffer);
|
|
||||||
len += strlen(buffer);
|
|
||||||
|
|
||||||
sprintf(buffer, "<form action=\"%smsgs/\" method=\"POST\" onsubmit=\"return validate()\" enctype=\"application/x-www-form-urlencoded;charset=UTF-8\">\n", conf.www_url);
|
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
|
||||||
max_len += 4096;
|
|
||||||
page = (char *)realloc(page, max_len);
|
|
||||||
}
|
|
||||||
strcat(page, buffer);
|
|
||||||
len += strlen(buffer);
|
|
||||||
|
|
||||||
sprintf(buffer, "<input type=\"hidden\" name=\"conference\" value=\"%d\" />\n", conference);
|
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
|
||||||
max_len += 4096;
|
|
||||||
page = (char *)realloc(page, max_len);
|
|
||||||
}
|
|
||||||
strcat(page, buffer);
|
|
||||||
len += strlen(buffer);
|
|
||||||
sprintf(buffer, "<input type=\"hidden\" name=\"area\" value=\"%d\" />\n", area);
|
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
|
||||||
max_len += 4096;
|
|
||||||
page = (char *)realloc(page, max_len);
|
|
||||||
}
|
|
||||||
strcat(page, buffer);
|
|
||||||
len += strlen(buffer);
|
|
||||||
|
|
||||||
sprintf(buffer, "<input type=\"hidden\" name=\"replyid\" value=\"NULL\" />\n");
|
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
|
||||||
max_len += 4096;
|
|
||||||
page = (char *)realloc(page, max_len);
|
|
||||||
}
|
|
||||||
strcat(page, buffer);
|
|
||||||
len += strlen(buffer);
|
|
||||||
|
|
||||||
sprintf(buffer, "To : <input type=\"text\" name=\"recipient\" value=\"All\" id=\"recipient\"/><br />\n");
|
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
|
||||||
max_len += 4096;
|
|
||||||
page = (char *)realloc(page, max_len);
|
|
||||||
}
|
|
||||||
strcat(page, buffer);
|
|
||||||
len += strlen(buffer);
|
|
||||||
|
|
||||||
sprintf(buffer, "Subject : <input type=\"text\" name=\"subject\" id=\"subject\" /><br />\n");
|
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
|
||||||
max_len += 4096;
|
|
||||||
page = (char *)realloc(page, max_len);
|
|
||||||
}
|
|
||||||
strcat(page, buffer);
|
|
||||||
len += strlen(buffer);
|
|
||||||
|
|
||||||
sprintf(buffer, "<textarea name=\"body\" id=\"body\" rows=\"25\" cols=\"79\" wrap=\"soft\"></textarea>\n<br />");
|
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
|
||||||
max_len += 4096;
|
|
||||||
page = (char *)realloc(page, max_len);
|
|
||||||
}
|
|
||||||
strcat(page, buffer);
|
|
||||||
len += strlen(buffer);
|
|
||||||
|
|
||||||
sprintf(buffer, "<input type=\"submit\" name=\"submit\" value=\"Send\" />\n<br />");
|
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
|
||||||
max_len += 4096;
|
|
||||||
page = (char *)realloc(page, max_len);
|
|
||||||
}
|
|
||||||
strcat(page, buffer);
|
|
||||||
len += strlen(buffer);
|
|
||||||
|
|
||||||
sprintf(buffer, "</form>\n");
|
|
||||||
if (len + strlen(buffer) > max_len - 1) {
|
|
||||||
max_len += 4096;
|
|
||||||
page = (char *)realloc(page, max_len);
|
|
||||||
}
|
|
||||||
strcat(page, buffer);
|
|
||||||
len += strlen(buffer);
|
|
||||||
|
|
||||||
return page;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Reference in New Issue
Block a user