summaryrefslogtreecommitdiffabout
authorLars Hjemli <hjemli@gmail.com>2006-12-28 00:54:43 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2006-12-28 00:54:43 (UTC)
commit27cd3b2a700e1cc46cd0393ddea48c07b62ee3a6 (patch) (unidiff)
tree041158893604fa4127bc0df31a2c22f8d48b852f
parentc43f1246cb759eb811ab0ebef0613b86dda99581 (diff)
downloadcgit-27cd3b2a700e1cc46cd0393ddea48c07b62ee3a6.zip
cgit-27cd3b2a700e1cc46cd0393ddea48c07b62ee3a6.tar.gz
cgit-27cd3b2a700e1cc46cd0393ddea48c07b62ee3a6.tar.bz2
Test for NULL-pointers in html_txt() and friends
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--html.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/html.c b/html.c
index 957b326..3a5d28d 100644
--- a/html.c
+++ b/html.c
@@ -32,85 +32,85 @@ void html(const char *txt)
32} 32}
33 33
34void htmlf(const char *format, ...) 34void htmlf(const char *format, ...)
35{ 35{
36 static char buf[65536]; 36 static char buf[65536];
37 va_list args; 37 va_list args;
38 38
39 va_start(args, format); 39 va_start(args, format);
40 vsnprintf(buf, sizeof(buf), format, args); 40 vsnprintf(buf, sizeof(buf), format, args);
41 va_end(args); 41 va_end(args);
42 html(buf); 42 html(buf);
43} 43}
44 44
45void html_txt(char *txt) 45void html_txt(char *txt)
46{ 46{
47 char *t = txt; 47 char *t = txt;
48 while(*t){ 48 while(t && *t){
49 int c = *t; 49 int c = *t;
50 if (c=='<' || c=='>' || c=='&') { 50 if (c=='<' || c=='>' || c=='&') {
51 *t = '\0'; 51 *t = '\0';
52 html(txt); 52 html(txt);
53 *t = c; 53 *t = c;
54 if (c=='>') 54 if (c=='>')
55 html("&gt;"); 55 html("&gt;");
56 else if (c=='<') 56 else if (c=='<')
57 html("&lt;"); 57 html("&lt;");
58 else if (c=='&') 58 else if (c=='&')
59 html("&amp;"); 59 html("&amp;");
60 txt = t+1; 60 txt = t+1;
61 } 61 }
62 t++; 62 t++;
63 } 63 }
64 if (t!=txt) 64 if (t!=txt)
65 html(txt); 65 html(txt);
66} 66}
67 67
68void html_ntxt(int len, char *txt) 68void html_ntxt(int len, char *txt)
69{ 69{
70 char *t = txt; 70 char *t = txt;
71 while(*t && len--){ 71 while(t && *t && len--){
72 int c = *t; 72 int c = *t;
73 if (c=='<' || c=='>' || c=='&') { 73 if (c=='<' || c=='>' || c=='&') {
74 *t = '\0'; 74 *t = '\0';
75 html(txt); 75 html(txt);
76 *t = c; 76 *t = c;
77 if (c=='>') 77 if (c=='>')
78 html("&gt;"); 78 html("&gt;");
79 else if (c=='<') 79 else if (c=='<')
80 html("&lt;"); 80 html("&lt;");
81 else if (c=='&') 81 else if (c=='&')
82 html("&amp;"); 82 html("&amp;");
83 txt = t+1; 83 txt = t+1;
84 } 84 }
85 t++; 85 t++;
86 } 86 }
87 if (t!=txt) { 87 if (t!=txt) {
88 char c = *t; 88 char c = *t;
89 *t = '\0'; 89 *t = '\0';
90 html(txt); 90 html(txt);
91 *t = c; 91 *t = c;
92 } 92 }
93 if (len<0) 93 if (len<0)
94 html("..."); 94 html("...");
95} 95}
96 96
97void html_attr(char *txt) 97void html_attr(char *txt)
98{ 98{
99 char *t = txt; 99 char *t = txt;
100 while(*t){ 100 while(t && *t){
101 int c = *t; 101 int c = *t;
102 if (c=='<' || c=='>' || c=='\'') { 102 if (c=='<' || c=='>' || c=='\'') {
103 *t = '\0'; 103 *t = '\0';
104 html(txt); 104 html(txt);
105 *t = c; 105 *t = c;
106 if (c=='>') 106 if (c=='>')
107 html("&gt;"); 107 html("&gt;");
108 else if (c=='<') 108 else if (c=='<')
109 html("&lt;"); 109 html("&lt;");
110 else if (c=='\'') 110 else if (c=='\'')
111 html("&quote;"); 111 html("&quote;");
112 txt = t+1; 112 txt = t+1;
113 } 113 }
114 t++; 114 t++;
115 } 115 }
116 if (t!=txt) 116 if (t!=txt)
@@ -142,17 +142,16 @@ void html_fileperm(unsigned short mode)
142 htmlf("%c%c%c", (mode & 4 ? 'r' : '-'), 142 htmlf("%c%c%c", (mode & 4 ? 'r' : '-'),
143 (mode & 2 ? 'w' : '-'), (mode & 1 ? 'x' : '-')); 143 (mode & 2 ? 'w' : '-'), (mode & 1 ? 'x' : '-'));
144} 144}
145 145
146void html_filemode(unsigned short mode) 146void html_filemode(unsigned short mode)
147{ 147{
148 if (S_ISDIR(mode)) 148 if (S_ISDIR(mode))
149 html("d"); 149 html("d");
150 else if (S_ISLNK(mode)) 150 else if (S_ISLNK(mode))
151 html("l"); 151 html("l");
152 else 152 else
153 html("-"); 153 html("-");
154 html_fileperm(mode >> 6); 154 html_fileperm(mode >> 6);
155 html_fileperm(mode >> 3); 155 html_fileperm(mode >> 3);
156 html_fileperm(mode); 156 html_fileperm(mode);
157} 157}
158