]> jfr.im git - solanum.git/blobdiff - include/msgbuf.h
wsproc: call rb_clear_cloexec on child fds
[solanum.git] / include / msgbuf.h
index 1bcff5edc6b1ac12cb4d2c39e55b73015f84e91d..e553253eb0363fd5822ffcf8809befc7600ca565 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * charybdis - an advanced ircd.
+ * solanum - an advanced ircd.
  * Copyright (c) 2016 William Pitcock <nenolod@dereferenced.org>.
  *
  * Permission to use, copy, modify, and/or distribute this software for any
@@ -19,8 +19,8 @@
  * POSSIBILITY OF SUCH DAMAGE.
  */
 
-#ifndef CHARYBDIS__MSGBUF_H
-#define CHARYBDIS__MSGBUF_H
+#ifndef SOLANUM__MSGBUF_H
+#define SOLANUM__MSGBUF_H
 
 #define MAXPARA                (15)
 
@@ -38,17 +38,51 @@ struct MsgBuf {
        const char *origin;             /* the origin of the message (or NULL) */
        const char *target;             /* the target of the message (either NULL, or custom defined) */
        const char *cmd;                /* the cmd/verb of the message (either NULL, or para[0]) */
+       char *endp;                     /* one past the end of the original array */
 
        size_t n_para;                  /* the number of parameters (always at least 1 if a full message) */
        const char *para[MAXPARA];      /* parameters vector (starting with cmd as para[0]) */
 };
 
+struct MsgBuf_str_data {
+       const struct MsgBuf *msgbuf;
+       unsigned int caps;
+};
+
+#define MSGBUF_CACHE_SIZE 32
+
+struct MsgBuf_cache_entry {
+       unsigned int caps;
+       buf_head_t linebuf;
+       struct MsgBuf_cache_entry *next;
+};
+
+struct MsgBuf_cache {
+       const struct MsgBuf *msgbuf;
+       char message[DATALEN + 1];
+       unsigned int overall_capmask;
+
+       /* Fixed maximum size linked list, new entries are allocated at the end
+        * of the array but are accessed through the "next" pointers.
+        *
+        * This does not use rb dlink to avoid unnecessary individual allocations.
+        */
+       struct MsgBuf_cache_entry entry[MSGBUF_CACHE_SIZE];
+       struct MsgBuf_cache_entry *head; /* LRU cache head */
+};
+
 /*
  * parse a message into a MsgBuf.
  * returns 0 on success, 1 on error.
  */
 int msgbuf_parse(struct MsgBuf *msgbuf, char *line);
 
+/*
+ * Unparse the tail of a msgbuf perfectly, preserving framing details
+ * msgbuf->para[n] will reach to the end of the line
+ */
+void msgbuf_reconstruct_tail(struct MsgBuf *msgbuf, size_t n);
+
 /*
  * unparse a pure MsgBuf into a buffer.
  * if origin is NULL, me.name will be used.
@@ -66,7 +100,13 @@ int msgbuf_unparse(char *buf, size_t buflen, const struct MsgBuf *msgbuf, unsign
 int msgbuf_unparse_fmt(char *buf, size_t buflen, const struct MsgBuf *head, unsigned int capmask, const char *fmt, ...) AFP(5, 6);
 int msgbuf_vunparse_fmt(char *buf, size_t buflen, const struct MsgBuf *head, unsigned int capmask, const char *fmt, va_list va);
 
-void msgbuf_unparse_prefix(char *buf, size_t *buflen, const struct MsgBuf *msgbuf, unsigned int capmask);
+int msgbuf_unparse_linebuf_tags(char *buf, size_t buflen, void *data);
+int msgbuf_unparse_prefix(char *buf, size_t *buflen, const struct MsgBuf *msgbuf, unsigned int capmask);
+
+void msgbuf_cache_init(struct MsgBuf_cache *cache, const struct MsgBuf *msgbuf, const rb_strf_t *message);
+void msgbuf_cache_initf(struct MsgBuf_cache *cache, const struct MsgBuf *msgbuf, const rb_strf_t *message, const char *format, ...) AFP(4, 5);
+buf_head_t *msgbuf_cache_get(struct MsgBuf_cache *cache, unsigned int caps);
+void msgbuf_cache_free(struct MsgBuf_cache *cache);
 
 static inline void
 msgbuf_init(struct MsgBuf *msgbuf)