[backfire] merge r27628
[openwrt-10.03/.git] / package / uhttpd / src / uhttpd-utils.h
index a6448b63bc1d1e9055ed67edd7c6b8ff8c71ed96..68191a3a6ac520605cff8fe890764b69359a1efe 100644 (file)
 #define fd_cloexec(fd) \
        fcntl(fd, F_SETFD, fcntl(fd, F_GETFD) | FD_CLOEXEC)
 
+#define ensure_out(x) \
+       do { if((x) < 0) goto out; } while(0)
+
+#define ensure_ret(x) \
+       do { if((x) < 0) return -1; } while(0)
+
+
 struct path_info {
        char *root;
        char *phys;
        char *name;
        char *info;
        char *query;
+       int redirected;
        struct stat stat;
 };
 
@@ -49,6 +57,7 @@ struct path_info {
 const char * sa_straddr(void *sa);
 const char * sa_strport(void *sa);
 int sa_port(void *sa);
+int sa_rfc1918(void *sa);
 
 char *strfind(char *haystack, int hslen, const char *needle, int ndlen);
 
@@ -100,4 +109,9 @@ struct client * uh_client_add(int sock, struct listener *serv);
 struct client * uh_client_lookup(int sock);
 void uh_client_remove(int sock);
 
+#ifdef HAVE_CGI
+struct interpreter * uh_interpreter_add(const char *extn, const char *path);
+struct interpreter * uh_interpreter_lookup(const char *path);
+#endif
+
 #endif