about summary refs log tree commit diff
path: root/cache.h
diff options
context:
space:
mode:
authorLars Hjemli <hjemli@gmail.com>2008-03-27 09:22:13 +0100
committerLars Hjemli <hjemli@gmail.com>2008-03-27 09:22:13 +0100
commitee4056bd2c902a12dea67874368863fe60ea5a5f (patch)
treed54da54ace7b8999cf8785d877a0a9cad5262a0c /cache.h
parentdc3282f0baa14949439593729a45fbe143e3622c (diff)
downloadcgit-pink-ee4056bd2c902a12dea67874368863fe60ea5a5f.tar.gz
cgit-pink-ee4056bd2c902a12dea67874368863fe60ea5a5f.zip
Add cache.h
The functions found in cache.c are only used by cgit.c, so there's no
point in rebuilding all object files when the cache interface is changed.


Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to 'cache.h')
-rw-r--r--cache.h23
1 files changed, 23 insertions, 0 deletions
diff --git a/cache.h b/cache.h
new file mode 100644
index 0000000..4dcbea3
--- /dev/null
+++ b/cache.h
@@ -0,0 +1,23 @@
+/*
+ * Since git has it's own cache.h which we include,
+ * lets test on CGIT_CACHE_H to avoid confusion
+ */
+
+#ifndef CGIT_CACHE_H
+#define CGIT_CACHE_H
+
+struct cacheitem {
+	char *name;
+	struct stat st;
+	int ttl;
+	int fd;
+};
+
+extern char *cache_safe_filename(const char *unsafe);
+extern int cache_lock(struct cacheitem *item);
+extern int cache_unlock(struct cacheitem *item);
+extern int cache_cancel_lock(struct cacheitem *item);
+extern int cache_exist(struct cacheitem *item);
+extern int cache_expired(struct cacheitem *item);
+
+#endif /* CGIT_CACHE_H */