about summary refs log tree commit diff
path: root/third_party/git/unpack-trees.h
diff options
context:
space:
mode:
authorVincent Ambo <mail@tazj.in>2021-09-21T10·03+0300
committerVincent Ambo <mail@tazj.in>2021-09-21T11·29+0300
commit43b1791ec601732ac31195df96781a848360a9ac (patch)
treedaae8d638343295d2f1f7da955e556ef4c958864 /third_party/git/unpack-trees.h
parent2d8e7dc9d9c38127ec4ebd13aee8e8f586a43318 (diff)
chore(3p/git): Unvendor git and track patches instead r/2903
This was vendored a long time ago under the expectation that keeping
it in sync with cgit would be easier this way, but it has proven not
to be a big issue.

On the other hand, a vendored copy of git is an annoying maintenance
burden. It is much easier to rebase the single (dottime) patch that we
have.

This removes the vendored copy of git and instead passes the git
source code to cgit via `pkgs.srcOnly`, which includes the applied
patch so that cgit can continue rendering dottime.

Change-Id: If31f62dea7ce688fd1b9050204e9378019775f2b
Diffstat (limited to 'third_party/git/unpack-trees.h')
-rw-r--r--third_party/git/unpack-trees.h118
1 files changed, 0 insertions, 118 deletions
diff --git a/third_party/git/unpack-trees.h b/third_party/git/unpack-trees.h
deleted file mode 100644
index 2e87875b1545..000000000000
--- a/third_party/git/unpack-trees.h
+++ /dev/null
@@ -1,118 +0,0 @@
-#ifndef UNPACK_TREES_H
-#define UNPACK_TREES_H
-
-#include "cache.h"
-#include "strvec.h"
-#include "string-list.h"
-#include "tree-walk.h"
-
-#define MAX_UNPACK_TREES MAX_TRAVERSE_TREES
-
-struct cache_entry;
-struct unpack_trees_options;
-struct pattern_list;
-
-typedef int (*merge_fn_t)(const struct cache_entry * const *src,
-		struct unpack_trees_options *options);
-
-enum unpack_trees_error_types {
-	ERROR_WOULD_OVERWRITE = 0,
-	ERROR_NOT_UPTODATE_FILE,
-	ERROR_NOT_UPTODATE_DIR,
-	ERROR_WOULD_LOSE_UNTRACKED_OVERWRITTEN,
-	ERROR_WOULD_LOSE_UNTRACKED_REMOVED,
-	ERROR_BIND_OVERLAP,
-	ERROR_WOULD_LOSE_SUBMODULE,
-
-	NB_UNPACK_TREES_ERROR_TYPES,
-
-	WARNING_SPARSE_NOT_UPTODATE_FILE,
-	WARNING_SPARSE_UNMERGED_FILE,
-	WARNING_SPARSE_ORPHANED_NOT_OVERWRITTEN,
-
-	NB_UNPACK_TREES_WARNING_TYPES,
-};
-
-/*
- * Sets the list of user-friendly error messages to be used by the
- * command "cmd" (either merge or checkout), and show_all_errors to 1.
- */
-void setup_unpack_trees_porcelain(struct unpack_trees_options *opts,
-				  const char *cmd);
-
-/*
- * Frees resources allocated by setup_unpack_trees_porcelain().
- */
-void clear_unpack_trees_porcelain(struct unpack_trees_options *opts);
-
-struct unpack_trees_options {
-	unsigned int reset,
-		     merge,
-		     update,
-		     clone,
-		     index_only,
-		     nontrivial_merge,
-		     trivial_merges_only,
-		     verbose_update,
-		     aggressive,
-		     skip_unmerged,
-		     initial_checkout,
-		     diff_index_cached,
-		     debug_unpack,
-		     skip_sparse_checkout,
-		     quiet,
-		     exiting_early,
-		     show_all_errors,
-		     dry_run;
-	const char *prefix;
-	int cache_bottom;
-	struct dir_struct *dir;
-	struct pathspec *pathspec;
-	merge_fn_t fn;
-	const char *msgs[NB_UNPACK_TREES_WARNING_TYPES];
-	struct strvec msgs_to_free;
-	/*
-	 * Store error messages in an array, each case
-	 * corresponding to a error message type
-	 */
-	struct string_list unpack_rejects[NB_UNPACK_TREES_WARNING_TYPES];
-
-	int head_idx;
-	int merge_size;
-
-	struct cache_entry *df_conflict_entry;
-	void *unpack_data;
-
-	struct index_state *dst_index;
-	struct index_state *src_index;
-	struct index_state result;
-
-	struct pattern_list *pl; /* for internal use */
-	struct checkout_metadata meta;
-};
-
-int unpack_trees(unsigned n, struct tree_desc *t,
-		 struct unpack_trees_options *options);
-
-enum update_sparsity_result {
-	UPDATE_SPARSITY_SUCCESS = 0,
-	UPDATE_SPARSITY_WARNINGS = 1,
-	UPDATE_SPARSITY_INDEX_UPDATE_FAILURES = -1,
-	UPDATE_SPARSITY_WORKTREE_UPDATE_FAILURES = -2
-};
-
-enum update_sparsity_result update_sparsity(struct unpack_trees_options *options);
-
-int verify_uptodate(const struct cache_entry *ce,
-		    struct unpack_trees_options *o);
-
-int threeway_merge(const struct cache_entry * const *stages,
-		   struct unpack_trees_options *o);
-int twoway_merge(const struct cache_entry * const *src,
-		 struct unpack_trees_options *o);
-int bind_merge(const struct cache_entry * const *src,
-	       struct unpack_trees_options *o);
-int oneway_merge(const struct cache_entry * const *src,
-		 struct unpack_trees_options *o);
-
-#endif