summaryrefslogtreecommitdiffstatshomepage
Commit message (Expand)AuthorAge
...
* Add missing diff-link in ui-commit.cLars Hjemli2006-12-22
* Only show first 80 characters of commit subject in log and summaryLars Hjemli2006-12-22
* Add missing ttl-options in configLars Hjemli2006-12-22
* cgit 0.1v0.1Lars Hjemli2006-12-21
* Let make know that ui-diff.c depends on xdiff.hLars Hjemli2006-12-21
* Add basic diff viewLars Hjemli2006-12-20
* Use html_filemode in ui-tree.cLars Hjemli2006-12-17
* Don't show new and old filemode for added/removed filesLars Hjemli2006-12-17
* Show list of modified files in ui-commit.cLars Hjemli2006-12-17
* Reformat code to avoid excessive line lengthsLars Hjemli2006-12-16
* Add cgit_free_commitinfo() and use where neededLars Hjemli2006-12-16
* Simplify ui-commit.cLars Hjemli2006-12-16
* Show emails and timestamps in ui-commit.cLars Hjemli2006-12-16
* Teach commit parser about author/committer email + timestampLars Hjemli2006-12-16
* Allow relative paths for cgit_cache_rootLars Hjemli2006-12-16
* Add cache-root option to /cgit/rcLars Hjemli2006-12-16
* Add argument parsing + switch for uncached operationLars Hjemli2006-12-16
* Add head comment to shared.cLars Hjemli2006-12-16
* Add head comment to ui-commit.cLars Hjemli2006-12-16
* gitweb ripoff: set tr:hover to highligt current rowLars Hjemli2006-12-16
* Make repo header a link to summary pageLars Hjemli2006-12-16
* Move cgit_print_date into ui-shared, reuse in ui-summaryLars Hjemli2006-12-16
* Add ui-commit.c + misc ui cleanupsLars Hjemli2006-12-16
* Add a common commit parserLars Hjemli2006-12-15
* Add simple pager to log pageLars Hjemli2006-12-14
* Add separate makefile-rule to clear current cacheLars Hjemli2006-12-13
* Remove implementation details from READMELars Hjemli2006-12-13
* Small layout adjustments to summary and blob viewLars Hjemli2006-12-13
* Add display of tree content w/ui-tree.cLars Hjemli2006-12-13
* cache_lock: do xstrdup/free on lockfileLars Hjemli2006-12-12
* Don't truncate valid cachefilesLars Hjemli2006-12-11
* Move global variables + callback functions into shared.cLars Hjemli2006-12-11
* Move functions for generic object output into ui-view.cLars Hjemli2006-12-11
* Move log-functions into ui-log.cLars Hjemli2006-12-11
* Move repo summary functions into ui-summary.cLars Hjemli2006-12-11
* Move functions for repolist output into ui-repolist.cLars Hjemli2006-12-11
* Move common output-functions into ui-shared.cLars Hjemli2006-12-11
* Rename config.c to parsing.c + move cgit_parse_query from cgit.c to parsing.cLars Hjemli2006-12-11
* Avoid infinite loops in caching layerLars Hjemli2006-12-11
* Let 'make install' clear all cachefilesLars Hjemli2006-12-11
* Fix cache algorithm loopholeLars Hjemli2006-12-11
* Add version identifier in generated filesLars Hjemli2006-12-10
* Add license file and copyright noticesLars Hjemli2006-12-10
* Add caching infrastructureLars Hjemli2006-12-10
* Add .gitignoreLars Hjemli2006-12-09
* Replace useless make rules with generic $(OBJECTS) dependencyLars Hjemli2006-12-09
* Import cgit prototype from git treeLars Hjemli2006-12-09
="w"> const char *pathname, unsigned mode, int stage, void *cbdata) { struct walk_tree_context *walk_tree_ctx = cbdata; if (walk_tree_ctx->file_only && !S_ISREG(mode)) return READ_TREE_RECURSIVE; if (strncmp(base, walk_tree_ctx->match_path, baselen) || strcmp(walk_tree_ctx->match_path + baselen, pathname)) return READ_TREE_RECURSIVE; memmove(walk_tree_ctx->matched_sha1, sha1, 20); walk_tree_ctx->found_path = 1; return 0; } int cgit_ref_path_exists(const char *path, const char *ref, int file_only) { unsigned char sha1[20]; unsigned long size; struct pathspec_item path_items = { .match = path, .len = strlen(path) }; struct pathspec paths = { .nr = 1, .items = &path_items }; struct walk_tree_context walk_tree_ctx = { .match_path = path, .matched_sha1 = sha1, .found_path = 0, .file_only = file_only }; if (get_sha1(ref, sha1)) return 0; if (sha1_object_info(sha1, &size) != OBJ_COMMIT) return 0; read_tree_recursive(lookup_commit_reference(sha1)->tree, "", 0, 0, &paths, walk_tree, &walk_tree_ctx); return walk_tree_ctx.found_path; } int cgit_print_file(char *path, const char *head, int file_only) { unsigned char sha1[20]; enum object_type type; char *buf; unsigned long size; struct commit *commit; struct pathspec_item path_items = { .match = path, .len = strlen(path) }; struct pathspec paths = { .nr = 1, .items = &path_items }; struct walk_tree_context walk_tree_ctx = { .match_path = path, .matched_sha1 = sha1, .found_path = 0, .file_only = file_only }; if (get_sha1(head, sha1)) return -1; type = sha1_object_info(sha1, &size); if (type == OBJ_COMMIT && path) { commit = lookup_commit_reference(sha1); read_tree_recursive(commit->tree, "", 0, 0, &paths, walk_tree, &walk_tree_ctx); if (!walk_tree_ctx.found_path) return -1; type = sha1_object_info(sha1, &size); } if (type == OBJ_BAD) return -1; buf = read_sha1_file(sha1, &type, &size); if (!buf) return -1; buf[size] = '\0'; html_raw(buf, size); return 0; } void cgit_print_blob(const char *hex, char *path, const char *head, int file_only) { unsigned char sha1[20]; enum object_type type; char *buf; unsigned long size; struct commit *commit; struct pathspec_item path_items = { .match = path, .len = path ? strlen(path) : 0 }; struct pathspec paths = { .nr = 1, .items = &path_items }; struct walk_tree_context walk_tree_ctx = { .match_path = path, .matched_sha1 = sha1, .found_path = 0, .file_only = file_only }; if (hex) { if (get_sha1_hex(hex, sha1)) { cgit_print_error("Bad hex value: %s", hex); return; } } else { if (get_sha1(head, sha1)) { cgit_print_error("Bad ref: %s", head); return; } } type = sha1_object_info(sha1, &size); if ((!hex) && type == OBJ_COMMIT && path) { commit = lookup_commit_reference(sha1); read_tree_recursive(commit->tree, "", 0, 0, &paths, walk_tree, &walk_tree_ctx); type = sha1_object_info(sha1,&size); } if (type == OBJ_BAD) { cgit_print_error("Bad object name: %s", hex); return; } buf = read_sha1_file(sha1, &type, &size); if (!buf) { cgit_print_error("Error reading object %s", hex); return; } buf[size] = '\0'; ctx.page.mimetype = ctx.qry.mimetype; if (!ctx.page.mimetype) { if (buffer_is_binary(buf, size)) ctx.page.mimetype = "application/octet-stream"; else ctx.page.mimetype = "text/plain"; } ctx.page.filename = path; cgit_print_http_headers(); html_raw(buf, size); }