]>
Commit | Line | Data |
---|---|---|
427dcb4b JH |
1 | /* |
2 | * Copyright (C) 2005 Junio C Hamano | |
3 | */ | |
e0173ad9 JH |
4 | #ifndef DIFFCORE_H |
5 | #define DIFFCORE_H | |
427dcb4b JH |
6 | |
7 | /* This header file is internal between diff.c and its diff transformers | |
8 | * (e.g. diffcore-rename, diffcore-pickaxe). Never include this header | |
9 | * in anything else. | |
10 | */ | |
eeaa4603 JH |
11 | |
12 | /* We internally use unsigned short as the score value, | |
13 | * and rely on an int capable to hold 32-bits. -B can take | |
14 | * -Bmerge_score/break_score format and the two scores are | |
15 | * passed around in one int (high 16-bit for merge and low 16-bit | |
16 | * for break). | |
17 | */ | |
ee3d299e | 18 | #define MAX_SCORE 60000.0 |
f345b0a0 | 19 | #define DEFAULT_RENAME_SCORE 30000 /* rename/copy similarity minimum (50%) */ |
4d0f39ce JH |
20 | #define DEFAULT_BREAK_SCORE 30000 /* minimum for break to happen (50%) */ |
21 | #define DEFAULT_MERGE_SCORE 36000 /* maximum for break-merge to happen 60%) */ | |
eeaa4603 JH |
22 | |
23 | #define MINIMUM_BREAK_SIZE 400 /* do not break a file smaller than this */ | |
427dcb4b | 24 | |
122aa6f9 JK |
25 | struct userdiff_driver; |
26 | ||
427dcb4b JH |
27 | struct diff_filespec { |
28 | unsigned char sha1[20]; | |
29 | char *path; | |
30 | void *data; | |
c06c7966 | 31 | void *cnt_data; |
e0e324a4 | 32 | const char *funcname_pattern_ident; |
427dcb4b | 33 | unsigned long size; |
9fb88419 | 34 | int count; /* Reference count */ |
427dcb4b | 35 | int xfrm_flags; /* for use by the xfrm */ |
64479711 | 36 | int rename_used; /* Count of rename users */ |
427dcb4b JH |
37 | unsigned short mode; /* file mode */ |
38 | unsigned sha1_valid : 1; /* if true, use sha1 and trust mode; | |
39 | * if false, use the name and read from | |
40 | * the filesystem. | |
41 | */ | |
dc7090ef | 42 | #define DIFF_FILE_VALID(spec) (((spec)->mode) != 0) |
427dcb4b JH |
43 | unsigned should_free : 1; /* data should be free()'ed */ |
44 | unsigned should_munmap : 1; /* data should be munmap()'ed */ | |
122aa6f9 JK |
45 | |
46 | struct userdiff_driver *driver; | |
47 | /* data should be considered "binary"; -1 means "don't know yet" */ | |
48 | int is_binary; | |
427dcb4b JH |
49 | }; |
50 | ||
51 | extern struct diff_filespec *alloc_filespec(const char *); | |
9fb88419 | 52 | extern void free_filespec(struct diff_filespec *); |
427dcb4b JH |
53 | extern void fill_filespec(struct diff_filespec *, const unsigned char *, |
54 | unsigned short); | |
55 | ||
f0c6b2a2 | 56 | extern int diff_populate_filespec(struct diff_filespec *, int); |
19397b45 | 57 | extern void diff_free_filespec_data(struct diff_filespec *); |
8ae92e63 | 58 | extern void diff_free_filespec_blob(struct diff_filespec *); |
29a3eefd | 59 | extern int diff_filespec_is_binary(struct diff_filespec *); |
427dcb4b | 60 | |
52e95789 | 61 | struct diff_filepair { |
427dcb4b JH |
62 | struct diff_filespec *one; |
63 | struct diff_filespec *two; | |
01c4e70f | 64 | unsigned short int score; |
a5a323f3 | 65 | char status; /* M C R A D U etc. (see Documentation/diff-format.txt or DIFF_STATUS_* in diff.h) */ |
f345b0a0 | 66 | unsigned broken_pair : 1; |
ef677686 | 67 | unsigned renamed_pair : 1; |
e9c84099 | 68 | unsigned is_unmerged : 1; |
427dcb4b | 69 | }; |
e9c84099 | 70 | #define DIFF_PAIR_UNMERGED(p) ((p)->is_unmerged) |
427dcb4b | 71 | |
ef677686 | 72 | #define DIFF_PAIR_RENAME(p) ((p)->renamed_pair) |
01c4e70f | 73 | |
f345b0a0 JH |
74 | #define DIFF_PAIR_BROKEN(p) \ |
75 | ( (!DIFF_FILE_VALID((p)->one) != !DIFF_FILE_VALID((p)->two)) && \ | |
76 | ((p)->broken_pair != 0) ) | |
77 | ||
96716a19 JH |
78 | #define DIFF_PAIR_TYPE_CHANGED(p) \ |
79 | ((S_IFMT & (p)->one->mode) != (S_IFMT & (p)->two->mode)) | |
80 | ||
4130b995 JH |
81 | #define DIFF_PAIR_MODE_CHANGED(p) ((p)->one->mode != (p)->two->mode) |
82 | ||
226406f6 JH |
83 | extern void diff_free_filepair(struct diff_filepair *); |
84 | ||
f7c1512a JH |
85 | extern int diff_unmodified_pair(struct diff_filepair *); |
86 | ||
427dcb4b | 87 | struct diff_queue_struct { |
52e95789 | 88 | struct diff_filepair **queue; |
427dcb4b JH |
89 | int alloc; |
90 | int nr; | |
91 | }; | |
92 | ||
38c6f780 | 93 | extern struct diff_queue_struct diff_queued_diff; |
52e95789 JH |
94 | extern struct diff_filepair *diff_queue(struct diff_queue_struct *, |
95 | struct diff_filespec *, | |
96 | struct diff_filespec *); | |
6b14d7fa | 97 | extern void diff_q(struct diff_queue_struct *, struct diff_filepair *); |
f7c1512a | 98 | |
ce240675 | 99 | extern void diffcore_break(int); |
8082d8d3 | 100 | extern void diffcore_rename(struct diff_options *); |
eeaa4603 | 101 | extern void diffcore_merge_broken(void); |
ce240675 JH |
102 | extern void diffcore_pickaxe(const char *needle, int opts); |
103 | extern void diffcore_order(const char *orderfile); | |
104 | ||
25d5ea41 JH |
105 | #define DIFF_DEBUG 0 |
106 | #if DIFF_DEBUG | |
107 | void diff_debug_filespec(struct diff_filespec *, int, const char *); | |
108 | void diff_debug_filepair(const struct diff_filepair *, int); | |
109 | void diff_debug_queue(const char *, struct diff_queue_struct *); | |
110 | #else | |
111 | #define diff_debug_filespec(a,b,c) do {} while(0) | |
112 | #define diff_debug_filepair(a,b) do {} while(0) | |
113 | #define diff_debug_queue(a,b) do {} while(0) | |
114 | #endif | |
115 | ||
d8c3d03a JH |
116 | extern int diffcore_count_changes(struct diff_filespec *src, |
117 | struct diff_filespec *dst, | |
c06c7966 JH |
118 | void **src_count_p, |
119 | void **dst_count_p, | |
65416758 JH |
120 | unsigned long delta_limit, |
121 | unsigned long *src_copied, | |
122 | unsigned long *literal_added); | |
123 | ||
427dcb4b | 124 | #endif |