Fossil SCM
don't forget to compensate for the line-length check
Commit
9011fe122662ecb25c79e7bcd7038d1f489897e6
Parent
4e86b06a9f03db1…
1 file changed
+7
-7
+7
-7
| --- src/diff.c | ||
| +++ src/diff.c | ||
| @@ -202,36 +202,36 @@ | ||
| 202 | 202 | |
| 203 | 203 | /* Check individual lines. |
| 204 | 204 | */ |
| 205 | 205 | if( n==0 ) return result; /* Empty file -> text */ |
| 206 | 206 | c = *z; |
| 207 | + j = (c!='\n'); | |
| 207 | 208 | if( c<0x80 ){ |
| 208 | 209 | if( c==0 ) return 0; /* Zero byte in a file -> binary */ |
| 209 | 210 | }else if( c<0xC0 ){ |
| 210 | 211 | result = -2; /* Invalid UTF-8, continue */ |
| 211 | 212 | }else if( c<0xE0 ){ |
| 212 | 213 | if( n<2 || ((z[1]&0xC0)!=0x80) ){ |
| 213 | 214 | result = -2; /* Invalid 2-byte UTF-8, continue */ |
| 214 | 215 | }else{ |
| 215 | - --n; ++z; | |
| 216 | + --n; ++j; ++z; | |
| 216 | 217 | } |
| 217 | 218 | }else if( c<0xF0 ){ |
| 218 | 219 | if( n<3 || ((z[1]&0xC0)!=0x80) || ((z[2]&0xC0)!=0x80) ){ |
| 219 | 220 | result = -2; /* Invalid 3-byte UTF-8, continue */ |
| 220 | 221 | }else{ |
| 221 | - n-=2; z+=2; | |
| 222 | + n-=2; j+=2; z+=2; | |
| 222 | 223 | } |
| 223 | 224 | }else if( c<0xF8 ){ |
| 224 | 225 | if( n<4 || ((z[1]&0xC0)!=0x80) || ((z[2]&0xC0)!=0x80) || ((z[3]&0xC0)!=0x80) ){ |
| 225 | 226 | result = -2; /* Invalid 4-byte UTF-8, continue */ |
| 226 | 227 | }else{ |
| 227 | - n-=3; z+=3; | |
| 228 | + n-=3; j+=3; z+=3; | |
| 228 | 229 | } |
| 229 | 230 | }else{ |
| 230 | 231 | result = -2; /* Invalid multi-byte UTF-8, continue */ |
| 231 | 232 | } |
| 232 | - j = (c!='\n'); | |
| 233 | 233 | while( --n>0 ){ |
| 234 | 234 | c = *++z; ++j; |
| 235 | 235 | if( c<0x80 ){ |
| 236 | 236 | if( c==0 ) return 0; /* Zero byte in a file -> binary */ |
| 237 | 237 | if( c=='\n' ){ |
| @@ -248,21 +248,21 @@ | ||
| 248 | 248 | result = -2; /* Invalid UTF-8, continue */ |
| 249 | 249 | }else if( c<0xE0 ){ |
| 250 | 250 | if( n<2 || ((z[1]&0xC0)!=0x80) ){ |
| 251 | 251 | result = -2; continue; /* Invalid 2-byte UTF-8, continue */ |
| 252 | 252 | } |
| 253 | - --n; ++z; | |
| 253 | + --n; ++j; ++z; | |
| 254 | 254 | }else if( c<0xF0 ){ |
| 255 | 255 | if( n<3 || ((z[1]&0xC0)!=0x80) || ((z[2]&0xC0)!=0x80) ){ |
| 256 | 256 | result = -2; continue; /* Invalid 3-byte UTF-8, continue */ |
| 257 | 257 | } |
| 258 | - n-=2; z+=2; | |
| 258 | + n-=2; j+=2; z+=2; | |
| 259 | 259 | }else if( c<0xF8 ){ |
| 260 | 260 | if( n<4 || ((z[1]&0xC0)!=0x80) || ((z[2]&0xC0)!=0x80) || ((z[3]&0xC0)!=0x80) ){ |
| 261 | 261 | result = -2; continue; /* Invalid 4-byte UTF-8, continue */ |
| 262 | 262 | } |
| 263 | - n-=3; z+=3; | |
| 263 | + n-=3; j+=3; z+=3; | |
| 264 | 264 | }else{ |
| 265 | 265 | result = -2; /* Invalid multi-byte UTF-8, continue */ |
| 266 | 266 | } |
| 267 | 267 | } |
| 268 | 268 | if( j>LENGTH_MASK ){ |
| 269 | 269 |
| --- src/diff.c | |
| +++ src/diff.c | |
| @@ -202,36 +202,36 @@ | |
| 202 | |
| 203 | /* Check individual lines. |
| 204 | */ |
| 205 | if( n==0 ) return result; /* Empty file -> text */ |
| 206 | c = *z; |
| 207 | if( c<0x80 ){ |
| 208 | if( c==0 ) return 0; /* Zero byte in a file -> binary */ |
| 209 | }else if( c<0xC0 ){ |
| 210 | result = -2; /* Invalid UTF-8, continue */ |
| 211 | }else if( c<0xE0 ){ |
| 212 | if( n<2 || ((z[1]&0xC0)!=0x80) ){ |
| 213 | result = -2; /* Invalid 2-byte UTF-8, continue */ |
| 214 | }else{ |
| 215 | --n; ++z; |
| 216 | } |
| 217 | }else if( c<0xF0 ){ |
| 218 | if( n<3 || ((z[1]&0xC0)!=0x80) || ((z[2]&0xC0)!=0x80) ){ |
| 219 | result = -2; /* Invalid 3-byte UTF-8, continue */ |
| 220 | }else{ |
| 221 | n-=2; z+=2; |
| 222 | } |
| 223 | }else if( c<0xF8 ){ |
| 224 | if( n<4 || ((z[1]&0xC0)!=0x80) || ((z[2]&0xC0)!=0x80) || ((z[3]&0xC0)!=0x80) ){ |
| 225 | result = -2; /* Invalid 4-byte UTF-8, continue */ |
| 226 | }else{ |
| 227 | n-=3; z+=3; |
| 228 | } |
| 229 | }else{ |
| 230 | result = -2; /* Invalid multi-byte UTF-8, continue */ |
| 231 | } |
| 232 | j = (c!='\n'); |
| 233 | while( --n>0 ){ |
| 234 | c = *++z; ++j; |
| 235 | if( c<0x80 ){ |
| 236 | if( c==0 ) return 0; /* Zero byte in a file -> binary */ |
| 237 | if( c=='\n' ){ |
| @@ -248,21 +248,21 @@ | |
| 248 | result = -2; /* Invalid UTF-8, continue */ |
| 249 | }else if( c<0xE0 ){ |
| 250 | if( n<2 || ((z[1]&0xC0)!=0x80) ){ |
| 251 | result = -2; continue; /* Invalid 2-byte UTF-8, continue */ |
| 252 | } |
| 253 | --n; ++z; |
| 254 | }else if( c<0xF0 ){ |
| 255 | if( n<3 || ((z[1]&0xC0)!=0x80) || ((z[2]&0xC0)!=0x80) ){ |
| 256 | result = -2; continue; /* Invalid 3-byte UTF-8, continue */ |
| 257 | } |
| 258 | n-=2; z+=2; |
| 259 | }else if( c<0xF8 ){ |
| 260 | if( n<4 || ((z[1]&0xC0)!=0x80) || ((z[2]&0xC0)!=0x80) || ((z[3]&0xC0)!=0x80) ){ |
| 261 | result = -2; continue; /* Invalid 4-byte UTF-8, continue */ |
| 262 | } |
| 263 | n-=3; z+=3; |
| 264 | }else{ |
| 265 | result = -2; /* Invalid multi-byte UTF-8, continue */ |
| 266 | } |
| 267 | } |
| 268 | if( j>LENGTH_MASK ){ |
| 269 |
| --- src/diff.c | |
| +++ src/diff.c | |
| @@ -202,36 +202,36 @@ | |
| 202 | |
| 203 | /* Check individual lines. |
| 204 | */ |
| 205 | if( n==0 ) return result; /* Empty file -> text */ |
| 206 | c = *z; |
| 207 | j = (c!='\n'); |
| 208 | if( c<0x80 ){ |
| 209 | if( c==0 ) return 0; /* Zero byte in a file -> binary */ |
| 210 | }else if( c<0xC0 ){ |
| 211 | result = -2; /* Invalid UTF-8, continue */ |
| 212 | }else if( c<0xE0 ){ |
| 213 | if( n<2 || ((z[1]&0xC0)!=0x80) ){ |
| 214 | result = -2; /* Invalid 2-byte UTF-8, continue */ |
| 215 | }else{ |
| 216 | --n; ++j; ++z; |
| 217 | } |
| 218 | }else if( c<0xF0 ){ |
| 219 | if( n<3 || ((z[1]&0xC0)!=0x80) || ((z[2]&0xC0)!=0x80) ){ |
| 220 | result = -2; /* Invalid 3-byte UTF-8, continue */ |
| 221 | }else{ |
| 222 | n-=2; j+=2; z+=2; |
| 223 | } |
| 224 | }else if( c<0xF8 ){ |
| 225 | if( n<4 || ((z[1]&0xC0)!=0x80) || ((z[2]&0xC0)!=0x80) || ((z[3]&0xC0)!=0x80) ){ |
| 226 | result = -2; /* Invalid 4-byte UTF-8, continue */ |
| 227 | }else{ |
| 228 | n-=3; j+=3; z+=3; |
| 229 | } |
| 230 | }else{ |
| 231 | result = -2; /* Invalid multi-byte UTF-8, continue */ |
| 232 | } |
| 233 | while( --n>0 ){ |
| 234 | c = *++z; ++j; |
| 235 | if( c<0x80 ){ |
| 236 | if( c==0 ) return 0; /* Zero byte in a file -> binary */ |
| 237 | if( c=='\n' ){ |
| @@ -248,21 +248,21 @@ | |
| 248 | result = -2; /* Invalid UTF-8, continue */ |
| 249 | }else if( c<0xE0 ){ |
| 250 | if( n<2 || ((z[1]&0xC0)!=0x80) ){ |
| 251 | result = -2; continue; /* Invalid 2-byte UTF-8, continue */ |
| 252 | } |
| 253 | --n; ++j; ++z; |
| 254 | }else if( c<0xF0 ){ |
| 255 | if( n<3 || ((z[1]&0xC0)!=0x80) || ((z[2]&0xC0)!=0x80) ){ |
| 256 | result = -2; continue; /* Invalid 3-byte UTF-8, continue */ |
| 257 | } |
| 258 | n-=2; j+=2; z+=2; |
| 259 | }else if( c<0xF8 ){ |
| 260 | if( n<4 || ((z[1]&0xC0)!=0x80) || ((z[2]&0xC0)!=0x80) || ((z[3]&0xC0)!=0x80) ){ |
| 261 | result = -2; continue; /* Invalid 4-byte UTF-8, continue */ |
| 262 | } |
| 263 | n-=3; j+=3; z+=3; |
| 264 | }else{ |
| 265 | result = -2; /* Invalid multi-byte UTF-8, continue */ |
| 266 | } |
| 267 | } |
| 268 | if( j>LENGTH_MASK ){ |
| 269 |