mirror of
https://git.proxmox.com/git/libgit2
synced 2025-05-02 21:34:15 +00:00
git_diff_generated: abstract generated diffs
This commit is contained in:
parent
aa4bfb32b9
commit
9be638ecf0
@ -26,6 +26,7 @@
|
||||
#include "filter.h"
|
||||
#include "blob.h"
|
||||
#include "diff.h"
|
||||
#include "diff_generate.h"
|
||||
#include "pathspec.h"
|
||||
#include "buf_text.h"
|
||||
#include "diff_xdiff.h"
|
||||
|
1579
src/diff.c
1579
src/diff.c
File diff suppressed because it is too large
Load Diff
132
src/diff.h
132
src/diff.h
@ -22,68 +22,30 @@
|
||||
#define DIFF_OLD_PREFIX_DEFAULT "a/"
|
||||
#define DIFF_NEW_PREFIX_DEFAULT "b/"
|
||||
|
||||
enum {
|
||||
GIT_DIFFCAPS_HAS_SYMLINKS = (1 << 0), /* symlinks on platform? */
|
||||
GIT_DIFFCAPS_IGNORE_STAT = (1 << 1), /* use stat? */
|
||||
GIT_DIFFCAPS_TRUST_MODE_BITS = (1 << 2), /* use st_mode? */
|
||||
GIT_DIFFCAPS_TRUST_CTIME = (1 << 3), /* use st_ctime? */
|
||||
GIT_DIFFCAPS_USE_DEV = (1 << 4), /* use st_dev? */
|
||||
};
|
||||
|
||||
#define DIFF_FLAGS_KNOWN_BINARY (GIT_DIFF_FLAG_BINARY|GIT_DIFF_FLAG_NOT_BINARY)
|
||||
#define DIFF_FLAGS_NOT_BINARY (GIT_DIFF_FLAG_NOT_BINARY|GIT_DIFF_FLAG__NO_DATA)
|
||||
|
||||
enum {
|
||||
GIT_DIFF_FLAG__FREE_PATH = (1 << 7), /* `path` is allocated memory */
|
||||
GIT_DIFF_FLAG__FREE_DATA = (1 << 8), /* internal file data is allocated */
|
||||
GIT_DIFF_FLAG__UNMAP_DATA = (1 << 9), /* internal file data is mmap'ed */
|
||||
GIT_DIFF_FLAG__NO_DATA = (1 << 10), /* file data should not be loaded */
|
||||
GIT_DIFF_FLAG__FREE_BLOB = (1 << 11), /* release the blob when done */
|
||||
GIT_DIFF_FLAG__LOADED = (1 << 12), /* file data has been loaded */
|
||||
|
||||
GIT_DIFF_FLAG__TO_DELETE = (1 << 16), /* delete entry during rename det. */
|
||||
GIT_DIFF_FLAG__TO_SPLIT = (1 << 17), /* split entry during rename det. */
|
||||
GIT_DIFF_FLAG__IS_RENAME_TARGET = (1 << 18),
|
||||
GIT_DIFF_FLAG__IS_RENAME_SOURCE = (1 << 19),
|
||||
GIT_DIFF_FLAG__HAS_SELF_SIMILARITY = (1 << 20),
|
||||
};
|
||||
|
||||
#define GIT_DIFF_FLAG__CLEAR_INTERNAL(F) (F) = ((F) & 0x00FFFF)
|
||||
|
||||
#define GIT_DIFF__VERBOSE (1 << 30)
|
||||
typedef enum {
|
||||
GIT_DIFF_TYPE_UNKNOWN = 0,
|
||||
GIT_DIFF_TYPE_GENERATED = 1,
|
||||
} git_diff_origin_t;
|
||||
|
||||
struct git_diff {
|
||||
git_refcount rc;
|
||||
git_repository *repo;
|
||||
git_diff_origin_t type;
|
||||
git_diff_options opts;
|
||||
git_vector pathspec;
|
||||
git_vector deltas; /* vector of git_diff_delta */
|
||||
git_pool pool;
|
||||
git_iterator_type_t old_src;
|
||||
git_iterator_type_t new_src;
|
||||
uint32_t diffcaps;
|
||||
git_diff_perfdata perf;
|
||||
bool index_updated;
|
||||
|
||||
int (*strcomp)(const char *, const char *);
|
||||
int (*strncomp)(const char *, const char *, size_t);
|
||||
int (*pfxcomp)(const char *str, const char *pfx);
|
||||
int (*entrycomp)(const void *a, const void *b);
|
||||
|
||||
void (*free_fn)(git_diff *diff);
|
||||
};
|
||||
|
||||
extern void git_diff__cleanup_modes(
|
||||
uint32_t diffcaps, uint32_t *omode, uint32_t *nmode);
|
||||
|
||||
extern void git_diff_addref(git_diff *diff);
|
||||
|
||||
extern int git_diff_delta__cmp(const void *a, const void *b);
|
||||
extern int git_diff_delta__casecmp(const void *a, const void *b);
|
||||
|
||||
extern const char *git_diff_delta__path(const git_diff_delta *delta);
|
||||
|
||||
extern bool git_diff_delta__should_skip(
|
||||
const git_diff_options *opts, const git_diff_delta *delta);
|
||||
|
||||
extern int git_diff_delta__format_file_header(
|
||||
git_buf *out,
|
||||
const git_diff_delta *delta,
|
||||
@ -91,84 +53,8 @@ extern int git_diff_delta__format_file_header(
|
||||
const char *newpfx,
|
||||
int oid_strlen);
|
||||
|
||||
extern int git_diff__oid_for_file(
|
||||
git_oid *out, git_diff *, const char *, uint16_t, git_off_t);
|
||||
extern int git_diff__oid_for_entry(
|
||||
git_oid *out, git_diff *, const git_index_entry *, uint16_t, const git_oid *update);
|
||||
|
||||
extern int git_diff__from_iterators(
|
||||
git_diff **diff_ptr,
|
||||
git_repository *repo,
|
||||
git_iterator *old_iter,
|
||||
git_iterator *new_iter,
|
||||
const git_diff_options *opts);
|
||||
|
||||
extern int git_diff__paired_foreach(
|
||||
git_diff *idx2head,
|
||||
git_diff *wd2idx,
|
||||
int (*cb)(git_diff_delta *i2h, git_diff_delta *w2i, void *payload),
|
||||
void *payload);
|
||||
|
||||
extern int git_diff_find_similar__hashsig_for_file(
|
||||
void **out, const git_diff_file *f, const char *path, void *p);
|
||||
|
||||
extern int git_diff_find_similar__hashsig_for_buf(
|
||||
void **out, const git_diff_file *f, const char *buf, size_t len, void *p);
|
||||
|
||||
extern void git_diff_find_similar__hashsig_free(void *sig, void *payload);
|
||||
|
||||
extern int git_diff_find_similar__calc_similarity(
|
||||
int *score, void *siga, void *sigb, void *payload);
|
||||
|
||||
extern int git_diff__commit(
|
||||
git_diff **diff, git_repository *repo, const git_commit *commit, const git_diff_options *opts);
|
||||
|
||||
/* Merge two `git_diff`s according to the callback given by `cb`. */
|
||||
|
||||
typedef git_diff_delta *(*git_diff__merge_cb)(
|
||||
const git_diff_delta *left,
|
||||
const git_diff_delta *right,
|
||||
git_pool *pool);
|
||||
|
||||
extern int git_diff__merge(
|
||||
git_diff *onto, const git_diff *from, git_diff__merge_cb cb);
|
||||
|
||||
extern git_diff_delta *git_diff__merge_like_cgit(
|
||||
const git_diff_delta *a,
|
||||
const git_diff_delta *b,
|
||||
git_pool *pool);
|
||||
|
||||
/* Duplicate a `git_diff_delta` out of the `git_pool` */
|
||||
extern git_diff_delta *git_diff__delta_dup(
|
||||
const git_diff_delta *d, git_pool *pool);
|
||||
|
||||
/*
|
||||
* Sometimes a git_diff_file will have a zero size; this attempts to
|
||||
* fill in the size without loading the blob if possible. If that is
|
||||
* not possible, then it will return the git_odb_object that had to be
|
||||
* loaded and the caller can use it or dispose of it as needed.
|
||||
*/
|
||||
GIT_INLINE(int) git_diff_file__resolve_zero_size(
|
||||
git_diff_file *file, git_odb_object **odb_obj, git_repository *repo)
|
||||
{
|
||||
int error;
|
||||
git_odb *odb;
|
||||
size_t len;
|
||||
git_otype type;
|
||||
|
||||
if ((error = git_repository_odb(&odb, repo)) < 0)
|
||||
return error;
|
||||
|
||||
error = git_odb__read_header_or_object(
|
||||
odb_obj, &len, &type, odb, &file->id);
|
||||
|
||||
git_odb_free(odb);
|
||||
|
||||
if (!error)
|
||||
file->size = (git_off_t)len;
|
||||
|
||||
return error;
|
||||
}
|
||||
extern int git_diff_delta__cmp(const void *a, const void *b);
|
||||
extern int git_diff_delta__casecmp(const void *a, const void *b);
|
||||
|
||||
#endif
|
||||
|
||||
|
@ -8,6 +8,7 @@
|
||||
#include "git2/blob.h"
|
||||
#include "git2/submodule.h"
|
||||
#include "diff.h"
|
||||
#include "diff_generate.h"
|
||||
#include "diff_file.h"
|
||||
#include "odb.h"
|
||||
#include "fileops.h"
|
||||
|
1627
src/diff_generate.c
Normal file
1627
src/diff_generate.c
Normal file
File diff suppressed because it is too large
Load Diff
123
src/diff_generate.h
Normal file
123
src/diff_generate.h
Normal file
@ -0,0 +1,123 @@
|
||||
/*
|
||||
* Copyright (C) the libgit2 contributors. All rights reserved.
|
||||
*
|
||||
* This file is part of libgit2, distributed under the GNU GPL v2 with
|
||||
* a Linking Exception. For full terms see the included COPYING file.
|
||||
*/
|
||||
#ifndef INCLUDE_diff_generate_h__
|
||||
#define INCLUDE_diff_generate_h__
|
||||
|
||||
enum {
|
||||
GIT_DIFFCAPS_HAS_SYMLINKS = (1 << 0), /* symlinks on platform? */
|
||||
GIT_DIFFCAPS_IGNORE_STAT = (1 << 1), /* use stat? */
|
||||
GIT_DIFFCAPS_TRUST_MODE_BITS = (1 << 2), /* use st_mode? */
|
||||
GIT_DIFFCAPS_TRUST_CTIME = (1 << 3), /* use st_ctime? */
|
||||
GIT_DIFFCAPS_USE_DEV = (1 << 4), /* use st_dev? */
|
||||
};
|
||||
|
||||
#define DIFF_FLAGS_KNOWN_BINARY (GIT_DIFF_FLAG_BINARY|GIT_DIFF_FLAG_NOT_BINARY)
|
||||
#define DIFF_FLAGS_NOT_BINARY (GIT_DIFF_FLAG_NOT_BINARY|GIT_DIFF_FLAG__NO_DATA)
|
||||
|
||||
enum {
|
||||
GIT_DIFF_FLAG__FREE_PATH = (1 << 7), /* `path` is allocated memory */
|
||||
GIT_DIFF_FLAG__FREE_DATA = (1 << 8), /* internal file data is allocated */
|
||||
GIT_DIFF_FLAG__UNMAP_DATA = (1 << 9), /* internal file data is mmap'ed */
|
||||
GIT_DIFF_FLAG__NO_DATA = (1 << 10), /* file data should not be loaded */
|
||||
GIT_DIFF_FLAG__FREE_BLOB = (1 << 11), /* release the blob when done */
|
||||
GIT_DIFF_FLAG__LOADED = (1 << 12), /* file data has been loaded */
|
||||
|
||||
GIT_DIFF_FLAG__TO_DELETE = (1 << 16), /* delete entry during rename det. */
|
||||
GIT_DIFF_FLAG__TO_SPLIT = (1 << 17), /* split entry during rename det. */
|
||||
GIT_DIFF_FLAG__IS_RENAME_TARGET = (1 << 18),
|
||||
GIT_DIFF_FLAG__IS_RENAME_SOURCE = (1 << 19),
|
||||
GIT_DIFF_FLAG__HAS_SELF_SIMILARITY = (1 << 20),
|
||||
};
|
||||
|
||||
#define GIT_DIFF_FLAG__CLEAR_INTERNAL(F) (F) = ((F) & 0x00FFFF)
|
||||
|
||||
#define GIT_DIFF__VERBOSE (1 << 30)
|
||||
|
||||
extern void git_diff_addref(git_diff *diff);
|
||||
|
||||
extern bool git_diff_delta__should_skip(
|
||||
const git_diff_options *opts, const git_diff_delta *delta);
|
||||
|
||||
extern int git_diff__from_iterators(
|
||||
git_diff **diff_ptr,
|
||||
git_repository *repo,
|
||||
git_iterator *old_iter,
|
||||
git_iterator *new_iter,
|
||||
const git_diff_options *opts);
|
||||
|
||||
extern int git_diff__commit(
|
||||
git_diff **diff, git_repository *repo, const git_commit *commit, const git_diff_options *opts);
|
||||
|
||||
extern int git_diff__paired_foreach(
|
||||
git_diff *idx2head,
|
||||
git_diff *wd2idx,
|
||||
int (*cb)(git_diff_delta *i2h, git_diff_delta *w2i, void *payload),
|
||||
void *payload);
|
||||
|
||||
/* Merge two `git_diff`s according to the callback given by `cb`. */
|
||||
|
||||
typedef git_diff_delta *(*git_diff__merge_cb)(
|
||||
const git_diff_delta *left,
|
||||
const git_diff_delta *right,
|
||||
git_pool *pool);
|
||||
|
||||
extern int git_diff__merge(
|
||||
git_diff *onto, const git_diff *from, git_diff__merge_cb cb);
|
||||
|
||||
extern git_diff_delta *git_diff__merge_like_cgit(
|
||||
const git_diff_delta *a,
|
||||
const git_diff_delta *b,
|
||||
git_pool *pool);
|
||||
|
||||
/* Duplicate a `git_diff_delta` out of the `git_pool` */
|
||||
extern git_diff_delta *git_diff__delta_dup(
|
||||
const git_diff_delta *d, git_pool *pool);
|
||||
|
||||
extern int git_diff__oid_for_file(
|
||||
git_oid *out,
|
||||
git_diff *diff,
|
||||
const char *path,
|
||||
uint16_t mode,
|
||||
git_off_t size);
|
||||
|
||||
extern int git_diff__oid_for_entry(
|
||||
git_oid *out,
|
||||
git_diff *diff,
|
||||
const git_index_entry *src,
|
||||
uint16_t mode,
|
||||
const git_oid *update_match);
|
||||
|
||||
/*
|
||||
* Sometimes a git_diff_file will have a zero size; this attempts to
|
||||
* fill in the size without loading the blob if possible. If that is
|
||||
* not possible, then it will return the git_odb_object that had to be
|
||||
* loaded and the caller can use it or dispose of it as needed.
|
||||
*/
|
||||
GIT_INLINE(int) git_diff_file__resolve_zero_size(
|
||||
git_diff_file *file, git_odb_object **odb_obj, git_repository *repo)
|
||||
{
|
||||
int error;
|
||||
git_odb *odb;
|
||||
size_t len;
|
||||
git_otype type;
|
||||
|
||||
if ((error = git_repository_odb(&odb, repo)) < 0)
|
||||
return error;
|
||||
|
||||
error = git_odb__read_header_or_object(
|
||||
odb_obj, &len, &type, odb, &file->id);
|
||||
|
||||
git_odb_free(odb);
|
||||
|
||||
if (!error)
|
||||
file->size = (git_off_t)len;
|
||||
|
||||
return error;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -11,6 +11,7 @@
|
||||
#include "git2/sys/hashsig.h"
|
||||
|
||||
#include "diff.h"
|
||||
#include "diff_generate.h"
|
||||
#include "path.h"
|
||||
#include "fileops.h"
|
||||
#include "config.h"
|
||||
|
22
src/diff_tform.h
Normal file
22
src/diff_tform.h
Normal file
@ -0,0 +1,22 @@
|
||||
/*
|
||||
* Copyright (C) the libgit2 contributors. All rights reserved.
|
||||
*
|
||||
* This file is part of libgit2, distributed under the GNU GPL v2 with
|
||||
* a Linking Exception. For full terms see the included COPYING file.
|
||||
*/
|
||||
#ifndef INCLUDE_diff_tform_h__
|
||||
#define INCLUDE_diff_tform_h__
|
||||
|
||||
extern int git_diff_find_similar__hashsig_for_file(
|
||||
void **out, const git_diff_file *f, const char *path, void *p);
|
||||
|
||||
extern int git_diff_find_similar__hashsig_for_buf(
|
||||
void **out, const git_diff_file *f, const char *buf, size_t len, void *p);
|
||||
|
||||
extern void git_diff_find_similar__hashsig_free(void *sig, void *payload);
|
||||
|
||||
extern int git_diff_find_similar__calc_similarity(
|
||||
int *score, void *siga, void *sigb, void *payload);
|
||||
|
||||
#endif
|
||||
|
@ -18,6 +18,8 @@
|
||||
#include "iterator.h"
|
||||
#include "refs.h"
|
||||
#include "diff.h"
|
||||
#include "diff_generate.h"
|
||||
#include "diff_tform.h"
|
||||
#include "checkout.h"
|
||||
#include "tree.h"
|
||||
#include "blob.h"
|
||||
|
@ -7,6 +7,7 @@
|
||||
#include "common.h"
|
||||
#include "git2/blob.h"
|
||||
#include "diff.h"
|
||||
#include "diff_generate.h"
|
||||
#include "diff_file.h"
|
||||
#include "diff_driver.h"
|
||||
#include "patch_generate.h"
|
||||
|
@ -23,6 +23,7 @@
|
||||
#include "iterator.h"
|
||||
#include "merge.h"
|
||||
#include "diff.h"
|
||||
#include "diff_generate.h"
|
||||
|
||||
static int create_error(int error, const char *msg)
|
||||
{
|
||||
|
@ -19,6 +19,7 @@
|
||||
|
||||
#include "git2/diff.h"
|
||||
#include "diff.h"
|
||||
#include "diff_generate.h"
|
||||
|
||||
static unsigned int index_delta2status(const git_diff_delta *head2idx)
|
||||
{
|
||||
|
@ -4,6 +4,7 @@
|
||||
#include "buffer.h"
|
||||
#include "commit.h"
|
||||
#include "diff.h"
|
||||
#include "diff_generate.h"
|
||||
|
||||
static git_repository *repo;
|
||||
|
||||
|
@ -4,6 +4,7 @@
|
||||
#include "buffer.h"
|
||||
#include "commit.h"
|
||||
#include "diff.h"
|
||||
#include "diff_generate.h"
|
||||
|
||||
static git_repository *_repo;
|
||||
static git_diff_stats *_stats;
|
||||
|
@ -3,6 +3,7 @@
|
||||
#include "merge.h"
|
||||
#include "../merge_helpers.h"
|
||||
#include "diff.h"
|
||||
#include "diff_tform.h"
|
||||
#include "git2/sys/hashsig.h"
|
||||
|
||||
static git_repository *repo;
|
||||
|
Loading…
Reference in New Issue
Block a user