summaryrefslogtreecommitdiffabout
authorLars Hjemli <hjemli@gmail.com>2010-11-09 18:57:18 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2010-11-09 23:22:41 (UTC)
commit958a95b37891098133369e835a2ab687e0dfa9dc (patch) (unidiff)
tree31bcd62973d381b072b91da15528c48c6fc14a41
parent52558a6d39d52e2b2968b622534b0ffa4da285cb (diff)
downloadcgit-958a95b37891098133369e835a2ab687e0dfa9dc.zip
cgit-958a95b37891098133369e835a2ab687e0dfa9dc.tar.gz
cgit-958a95b37891098133369e835a2ab687e0dfa9dc.tar.bz2
Add vector utility functions
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--Makefile1
-rw-r--r--vector.c38
-rw-r--r--vector.h17
3 files changed, 56 insertions, 0 deletions
diff --git a/Makefile b/Makefile
index be1d796..31d88ef 100644
--- a/Makefile
+++ b/Makefile
@@ -10,184 +10,185 @@ GIT_URL = http://www.kernel.org/pub/software/scm/git/git-$(GIT_VER).tar.bz2
10INSTALL = install 10INSTALL = install
11 11
12# Define NO_STRCASESTR if you don't have strcasestr. 12# Define NO_STRCASESTR if you don't have strcasestr.
13# 13#
14# Define NO_OPENSSL to disable linking with OpenSSL and use bundled SHA1 14# Define NO_OPENSSL to disable linking with OpenSSL and use bundled SHA1
15# implementation (slower). 15# implementation (slower).
16# 16#
17# Define NEEDS_LIBICONV if linking with libc is not enough (eg. Darwin). 17# Define NEEDS_LIBICONV if linking with libc is not enough (eg. Darwin).
18# 18#
19# Define NO_C99_FORMAT if your formatted IO functions (printf/scanf et.al.) 19# Define NO_C99_FORMAT if your formatted IO functions (printf/scanf et.al.)
20# do not support the 'size specifiers' introduced by C99, namely ll, hh, 20# do not support the 'size specifiers' introduced by C99, namely ll, hh,
21# j, z, t. (representing long long int, char, intmax_t, size_t, ptrdiff_t). 21# j, z, t. (representing long long int, char, intmax_t, size_t, ptrdiff_t).
22# some C compilers supported these specifiers prior to C99 as an extension. 22# some C compilers supported these specifiers prior to C99 as an extension.
23# 23#
24 24
25#-include config.mak 25#-include config.mak
26 26
27# 27#
28# Platform specific tweaks 28# Platform specific tweaks
29# 29#
30 30
31uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not') 31uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not')
32uname_O := $(shell sh -c 'uname -o 2>/dev/null || echo not') 32uname_O := $(shell sh -c 'uname -o 2>/dev/null || echo not')
33uname_R := $(shell sh -c 'uname -r 2>/dev/null || echo not') 33uname_R := $(shell sh -c 'uname -r 2>/dev/null || echo not')
34 34
35ifeq ($(uname_O),Cygwin) 35ifeq ($(uname_O),Cygwin)
36 NO_STRCASESTR = YesPlease 36 NO_STRCASESTR = YesPlease
37 NEEDS_LIBICONV = YesPlease 37 NEEDS_LIBICONV = YesPlease
38endif 38endif
39 39
40# 40#
41# Let the user override the above settings. 41# Let the user override the above settings.
42# 42#
43-include cgit.conf 43-include cgit.conf
44 44
45# 45#
46# Define a way to invoke make in subdirs quietly, shamelessly ripped 46# Define a way to invoke make in subdirs quietly, shamelessly ripped
47# from git.git 47# from git.git
48# 48#
49QUIET_SUBDIR0 = +$(MAKE) -C # space to separate -C and subdir 49QUIET_SUBDIR0 = +$(MAKE) -C # space to separate -C and subdir
50QUIET_SUBDIR1 = 50QUIET_SUBDIR1 =
51 51
52ifneq ($(findstring $(MAKEFLAGS),w),w) 52ifneq ($(findstring $(MAKEFLAGS),w),w)
53PRINT_DIR = --no-print-directory 53PRINT_DIR = --no-print-directory
54else # "make -w" 54else # "make -w"
55NO_SUBDIR = : 55NO_SUBDIR = :
56endif 56endif
57 57
58ifndef V 58ifndef V
59 QUIET_CC = @echo ' ' CC $@; 59 QUIET_CC = @echo ' ' CC $@;
60 QUIET_MM = @echo ' ' MM $@; 60 QUIET_MM = @echo ' ' MM $@;
61 QUIET_SUBDIR0 = +@subdir= 61 QUIET_SUBDIR0 = +@subdir=
62 QUIET_SUBDIR1 = ;$(NO_SUBDIR) echo ' ' SUBDIR $$subdir; \ 62 QUIET_SUBDIR1 = ;$(NO_SUBDIR) echo ' ' SUBDIR $$subdir; \
63 $(MAKE) $(PRINT_DIR) -C $$subdir 63 $(MAKE) $(PRINT_DIR) -C $$subdir
64endif 64endif
65 65
66# 66#
67# Define a pattern rule for automatic dependency building 67# Define a pattern rule for automatic dependency building
68# 68#
69%.d: %.c 69%.d: %.c
70 $(QUIET_MM)$(CC) $(CFLAGS) -MM -MP $< | sed -e 's/\($*\)\.o:/\1.o $@:/g' >$@ 70 $(QUIET_MM)$(CC) $(CFLAGS) -MM -MP $< | sed -e 's/\($*\)\.o:/\1.o $@:/g' >$@
71 71
72# 72#
73# Define a pattern rule for silent object building 73# Define a pattern rule for silent object building
74# 74#
75%.o: %.c 75%.o: %.c
76 $(QUIET_CC)$(CC) -o $*.o -c $(CFLAGS) $< 76 $(QUIET_CC)$(CC) -o $*.o -c $(CFLAGS) $<
77 77
78 78
79EXTLIBS = git/libgit.a git/xdiff/lib.a -lz -lpthread 79EXTLIBS = git/libgit.a git/xdiff/lib.a -lz -lpthread
80OBJECTS = 80OBJECTS =
81OBJECTS += cache.o 81OBJECTS += cache.o
82OBJECTS += cgit.o 82OBJECTS += cgit.o
83OBJECTS += cmd.o 83OBJECTS += cmd.o
84OBJECTS += configfile.o 84OBJECTS += configfile.o
85OBJECTS += html.o 85OBJECTS += html.o
86OBJECTS += parsing.o 86OBJECTS += parsing.o
87OBJECTS += scan-tree.o 87OBJECTS += scan-tree.o
88OBJECTS += shared.o 88OBJECTS += shared.o
89OBJECTS += ui-atom.o 89OBJECTS += ui-atom.o
90OBJECTS += ui-blob.o 90OBJECTS += ui-blob.o
91OBJECTS += ui-clone.o 91OBJECTS += ui-clone.o
92OBJECTS += ui-commit.o 92OBJECTS += ui-commit.o
93OBJECTS += ui-diff.o 93OBJECTS += ui-diff.o
94OBJECTS += ui-log.o 94OBJECTS += ui-log.o
95OBJECTS += ui-patch.o 95OBJECTS += ui-patch.o
96OBJECTS += ui-plain.o 96OBJECTS += ui-plain.o
97OBJECTS += ui-refs.o 97OBJECTS += ui-refs.o
98OBJECTS += ui-repolist.o 98OBJECTS += ui-repolist.o
99OBJECTS += ui-shared.o 99OBJECTS += ui-shared.o
100OBJECTS += ui-snapshot.o 100OBJECTS += ui-snapshot.o
101OBJECTS += ui-ssdiff.o 101OBJECTS += ui-ssdiff.o
102OBJECTS += ui-stats.o 102OBJECTS += ui-stats.o
103OBJECTS += ui-summary.o 103OBJECTS += ui-summary.o
104OBJECTS += ui-tag.o 104OBJECTS += ui-tag.o
105OBJECTS += ui-tree.o 105OBJECTS += ui-tree.o
106OBJECTS += vector.o
106 107
107ifdef NEEDS_LIBICONV 108ifdef NEEDS_LIBICONV
108 EXTLIBS += -liconv 109 EXTLIBS += -liconv
109endif 110endif
110 111
111 112
112.PHONY: all libgit test install uninstall clean force-version get-git \ 113.PHONY: all libgit test install uninstall clean force-version get-git \
113 doc man-doc html-doc clean-doc 114 doc man-doc html-doc clean-doc
114 115
115all: cgit 116all: cgit
116 117
117VERSION: force-version 118VERSION: force-version
118 @./gen-version.sh "$(CGIT_VERSION)" 119 @./gen-version.sh "$(CGIT_VERSION)"
119-include VERSION 120-include VERSION
120 121
121 122
122CFLAGS += -g -Wall -Igit 123CFLAGS += -g -Wall -Igit
123CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)' 124CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)'
124CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"' 125CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"'
125CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"' 126CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"'
126CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"' 127CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"'
127CFLAGS += -DCGIT_CACHE_ROOT='"$(CACHE_ROOT)"' 128CFLAGS += -DCGIT_CACHE_ROOT='"$(CACHE_ROOT)"'
128 129
129GIT_OPTIONS = prefix=/usr 130GIT_OPTIONS = prefix=/usr
130 131
131ifdef NO_ICONV 132ifdef NO_ICONV
132 CFLAGS += -DNO_ICONV 133 CFLAGS += -DNO_ICONV
133endif 134endif
134ifdef NO_STRCASESTR 135ifdef NO_STRCASESTR
135 CFLAGS += -DNO_STRCASESTR 136 CFLAGS += -DNO_STRCASESTR
136endif 137endif
137ifdef NO_C99_FORMAT 138ifdef NO_C99_FORMAT
138 CFLAGS += -DNO_C99_FORMAT 139 CFLAGS += -DNO_C99_FORMAT
139endif 140endif
140ifdef NO_OPENSSL 141ifdef NO_OPENSSL
141 CFLAGS += -DNO_OPENSSL 142 CFLAGS += -DNO_OPENSSL
142 GIT_OPTIONS += NO_OPENSSL=1 143 GIT_OPTIONS += NO_OPENSSL=1
143else 144else
144 EXTLIBS += -lcrypto 145 EXTLIBS += -lcrypto
145endif 146endif
146 147
147cgit: $(OBJECTS) libgit 148cgit: $(OBJECTS) libgit
148 $(QUIET_CC)$(CC) $(CFLAGS) $(LDFLAGS) -o cgit $(OBJECTS) $(EXTLIBS) 149 $(QUIET_CC)$(CC) $(CFLAGS) $(LDFLAGS) -o cgit $(OBJECTS) $(EXTLIBS)
149 150
150cgit.o: VERSION 151cgit.o: VERSION
151 152
152ifneq "$(MAKECMDGOALS)" "clean" 153ifneq "$(MAKECMDGOALS)" "clean"
153 -include $(OBJECTS:.o=.d) 154 -include $(OBJECTS:.o=.d)
154endif 155endif
155 156
156libgit: 157libgit:
157 $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) NO_CURL=1 $(GIT_OPTIONS) libgit.a 158 $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) NO_CURL=1 $(GIT_OPTIONS) libgit.a
158 $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) NO_CURL=1 $(GIT_OPTIONS) xdiff/lib.a 159 $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) NO_CURL=1 $(GIT_OPTIONS) xdiff/lib.a
159 160
160test: all 161test: all
161 $(QUIET_SUBDIR0)tests $(QUIET_SUBDIR1) all 162 $(QUIET_SUBDIR0)tests $(QUIET_SUBDIR1) all
162 163
163install: all 164install: all
164 $(INSTALL) -m 0755 -d $(DESTDIR)$(CGIT_SCRIPT_PATH) 165 $(INSTALL) -m 0755 -d $(DESTDIR)$(CGIT_SCRIPT_PATH)
165 $(INSTALL) -m 0755 cgit $(DESTDIR)$(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) 166 $(INSTALL) -m 0755 cgit $(DESTDIR)$(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME)
166 $(INSTALL) -m 0755 -d $(DESTDIR)$(CGIT_DATA_PATH) 167 $(INSTALL) -m 0755 -d $(DESTDIR)$(CGIT_DATA_PATH)
167 $(INSTALL) -m 0644 cgit.css $(DESTDIR)$(CGIT_DATA_PATH)/cgit.css 168 $(INSTALL) -m 0644 cgit.css $(DESTDIR)$(CGIT_DATA_PATH)/cgit.css
168 $(INSTALL) -m 0644 cgit.png $(DESTDIR)$(CGIT_DATA_PATH)/cgit.png 169 $(INSTALL) -m 0644 cgit.png $(DESTDIR)$(CGIT_DATA_PATH)/cgit.png
169 170
170uninstall: 171uninstall:
171 rm -f $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) 172 rm -f $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME)
172 rm -f $(CGIT_DATA_PATH)/cgit.css 173 rm -f $(CGIT_DATA_PATH)/cgit.css
173 rm -f $(CGIT_DATA_PATH)/cgit.png 174 rm -f $(CGIT_DATA_PATH)/cgit.png
174 175
175doc: man-doc html-doc pdf-doc 176doc: man-doc html-doc pdf-doc
176 177
177man-doc: cgitrc.5.txt 178man-doc: cgitrc.5.txt
178 a2x -f manpage cgitrc.5.txt 179 a2x -f manpage cgitrc.5.txt
179 180
180html-doc: cgitrc.5.txt 181html-doc: cgitrc.5.txt
181 a2x -f xhtml --stylesheet=cgit-doc.css cgitrc.5.txt 182 a2x -f xhtml --stylesheet=cgit-doc.css cgitrc.5.txt
182 183
183pdf-doc: cgitrc.5.txt 184pdf-doc: cgitrc.5.txt
184 a2x -f pdf cgitrc.5.txt 185 a2x -f pdf cgitrc.5.txt
185 186
186clean: clean-doc 187clean: clean-doc
187 rm -f cgit VERSION *.o *.d 188 rm -f cgit VERSION *.o *.d
188 189
189clean-doc: 190clean-doc:
190 rm -f cgitrc.5 cgitrc.5.html cgitrc.5.pdf cgitrc.5.xml cgitrc.5.fo 191 rm -f cgitrc.5 cgitrc.5.html cgitrc.5.pdf cgitrc.5.xml cgitrc.5.fo
191 192
192get-git: 193get-git:
193 curl $(GIT_URL) | tar -xj && rm -rf git && mv git-$(GIT_VER) git 194 curl $(GIT_URL) | tar -xj && rm -rf git && mv git-$(GIT_VER) git
diff --git a/vector.c b/vector.c
new file mode 100644
index 0000000..0863908
--- a/dev/null
+++ b/vector.c
@@ -0,0 +1,38 @@
1#include <stdio.h>
2#include <string.h>
3#include <errno.h>
4#include "vector.h"
5
6static int grow(struct vector *vec, int gently)
7{
8 size_t new_alloc;
9 void *new_data;
10
11 new_alloc = vec->alloc * 3 / 2;
12 if (!new_alloc)
13 new_alloc = 8;
14 new_data = realloc(vec->data, new_alloc * vec->size);
15 if (!new_data) {
16 if (gently)
17 return ENOMEM;
18 perror("vector.c:grow()");
19 exit(1);
20 }
21 vec->data = new_data;
22 vec->alloc = new_alloc;
23 return 0;
24}
25
26int vector_push(struct vector *vec, const void *data, int gently)
27{
28 int rc;
29
30 if (vec->count == vec->alloc && (rc = grow(vec, gently)))
31 return rc;
32 if (data)
33 memmove(vec->data + vec->count * vec->size, data, vec->size);
34 else
35 memset(vec->data + vec->count * vec->size, 0, vec->size);
36 vec->count++;
37 return 0;
38}
diff --git a/vector.h b/vector.h
new file mode 100644
index 0000000..c64eb1f
--- a/dev/null
+++ b/vector.h
@@ -0,0 +1,17 @@
1#ifndef CGIT_VECTOR_H
2#define CGIT_VECTOR_H
3
4#include <stdlib.h>
5
6struct vector {
7 size_t size;
8 size_t count;
9 size_t alloc;
10 void *data;
11};
12
13#define VECTOR_INIT(type) {sizeof(type), 0, 0, NULL}
14
15int vector_push(struct vector *vec, const void *data, int gently);
16
17#endif /* CGIT_VECTOR_H */