diff options
| -rw-r--r-- | cgit.h | 2 | ||||
| -rw-r--r-- | shared.c | 40 | ||||
| -rw-r--r-- | ui-plain.c | 40 | 
3 files changed, 42 insertions, 40 deletions
| @@ -391,4 +391,6 @@ extern int readfile(const char *path, char **buf, size_t *size); | |||
| 391 | 391 | ||
| 392 | extern char *expand_macros(const char *txt); | 392 | extern char *expand_macros(const char *txt); | 
| 393 | 393 | ||
| 394 | extern char *get_mimetype_from_file(const char *filename, const char *ext); | ||
| 395 | |||
| 394 | #endif /* CGIT_H */ | 396 | #endif /* CGIT_H */ | 
| @@ -560,3 +560,43 @@ char *expand_macros(const char *txt) | |||
| 560 | } | 560 | } | 
| 561 | return result; | 561 | return result; | 
| 562 | } | 562 | } | 
| 563 | |||
| 564 | char *get_mimetype_from_file(const char *filename, const char *ext) | ||
| 565 | { | ||
| 566 | static const char *delimiters; | ||
| 567 | char *result; | ||
| 568 | FILE *fd; | ||
| 569 | char line[1024]; | ||
| 570 | char *mimetype; | ||
| 571 | char *token; | ||
| 572 | |||
| 573 | if (!filename) | ||
| 574 | return NULL; | ||
| 575 | |||
| 576 | fd = fopen(filename, "r"); | ||
| 577 | if (!fd) | ||
| 578 | return NULL; | ||
| 579 | |||
| 580 | delimiters = " \t\r\n"; | ||
| 581 | result = NULL; | ||
| 582 | |||
| 583 | /* loop over all lines in the file */ | ||
| 584 | while (!result && fgets(line, sizeof(line), fd)) { | ||
| 585 | mimetype = strtok(line, delimiters); | ||
| 586 | |||
| 587 | /* skip empty lines and comment lines */ | ||
| 588 | if (!mimetype || (mimetype[0] == '#')) | ||
| 589 | continue; | ||
| 590 | |||
| 591 | /* loop over all extensions of mimetype */ | ||
| 592 | while ((token = strtok(NULL, delimiters))) { | ||
| 593 | if (!strcasecmp(ext, token)) { | ||
| 594 | result = xstrdup(mimetype); | ||
| 595 | break; | ||
| 596 | } | ||
| 597 | } | ||
| 598 | } | ||
| 599 | fclose(fd); | ||
| 600 | |||
| 601 | return result; | ||
| 602 | } | ||
| @@ -16,46 +16,6 @@ struct walk_tree_context { | |||
| 16 | int match; | 16 | int match; | 
| 17 | }; | 17 | }; | 
| 18 | 18 | ||
| 19 | static char *get_mimetype_from_file(const char *filename, const char *ext) | ||
| 20 | { | ||
| 21 | static const char *delimiters; | ||
| 22 | char *result; | ||
| 23 | FILE *fd; | ||
| 24 | char line[1024]; | ||
| 25 | char *mimetype; | ||
| 26 | char *token; | ||
| 27 | |||
| 28 | if (!filename) | ||
| 29 | return NULL; | ||
| 30 | |||
| 31 | fd = fopen(filename, "r"); | ||
| 32 | if (!fd) | ||
| 33 | return NULL; | ||
| 34 | |||
| 35 | delimiters = " \t\r\n"; | ||
| 36 | result = NULL; | ||
| 37 | |||
| 38 | /* loop over all lines in the file */ | ||
| 39 | while (!result && fgets(line, sizeof(line), fd)) { | ||
| 40 | mimetype = strtok(line, delimiters); | ||
| 41 | |||
| 42 | /* skip empty lines and comment lines */ | ||
| 43 | if (!mimetype || (mimetype[0] == '#')) | ||
| 44 | continue; | ||
| 45 | |||
| 46 | /* loop over all extensions of mimetype */ | ||
| 47 | while ((token = strtok(NULL, delimiters))) { | ||
| 48 | if (!strcasecmp(ext, token)) { | ||
| 49 | result = xstrdup(mimetype); | ||
| 50 | break; | ||
| 51 | } | ||
| 52 | } | ||
| 53 | } | ||
| 54 | fclose(fd); | ||
| 55 | |||
| 56 | return result; | ||
| 57 | } | ||
| 58 | |||
| 59 | static int print_object(const unsigned char *sha1, const char *path) | 19 | static int print_object(const unsigned char *sha1, const char *path) | 
| 60 | { | 20 | { | 
| 61 | enum object_type type; | 21 | enum object_type type; | 
