]> git.ipfire.org Git - thirdparty/git.git/commitdiff
xdiff: replace xdfile_t.dend with xdfenv_t.delta_end
authorEzekiel Newren <ezekielnewren@gmail.com>
Fri, 2 Jan 2026 18:52:22 +0000 (18:52 +0000)
committerJunio C Hamano <gitster@pobox.com>
Sun, 4 Jan 2026 02:44:52 +0000 (11:44 +0900)
View with --color-words. Same argument as delta_start.

Signed-off-by: Ezekiel Newren <ezekielnewren@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
xdiff/xhistogram.c
xdiff/xpatience.c
xdiff/xprepare.c
xdiff/xtypes.h

index eb6a52d9ba5729c4458ec1f8ec998941a0c12553..b4d6f88748fff66379a77d7eac26085033a472d3 100644 (file)
@@ -364,7 +364,10 @@ out:
 
 int xdl_do_histogram_diff(xpparam_t const *xpp, xdfenv_t *env)
 {
+       ptrdiff_t dend1 = env->xdf1.nrec - 1 - env->delta_end;
+       ptrdiff_t dend2 = env->xdf2.nrec - 1 - env->delta_end;
+
        return histogram_diff(xpp, env,
-               env->delta_start + 1, env->xdf1.dend - env->delta_start + 1,
-               env->delta_start + 1, env->xdf2.dend - env->delta_start + 1);
+               env->delta_start + 1, dend1 - env->delta_start + 1,
+               env->delta_start + 1, dend2 - env->delta_start + 1);
 }
index bd0ffbb417fb510e7eccff185c1d74819af4ae37..5b8bb34d2ba4a50c9c23c5c5669d2967b9c41353 100644 (file)
@@ -373,7 +373,10 @@ static int patience_diff(xpparam_t const *xpp, xdfenv_t *env,
 
 int xdl_do_patience_diff(xpparam_t const *xpp, xdfenv_t *env)
 {
+       ptrdiff_t dend1 = env->xdf1.nrec - 1 - env->delta_end;
+       ptrdiff_t dend2 = env->xdf2.nrec - 1 - env->delta_end;
+
        return patience_diff(xpp, env,
-               env->delta_start + 1, env->xdf1.dend - env->delta_start + 1,
-               env->delta_start + 1, env->xdf2.dend - env->delta_start + 1);
+               env->delta_start + 1, dend1 - env->delta_start + 1,
+               env->delta_start + 1, dend2 - env->delta_start + 1);
 }
index e88468e74c03327356723d773c23ca656c33100c..d3cdb6ac02fb589170b6ed9f7bbaeb62329ba766 100644 (file)
@@ -173,7 +173,6 @@ static int xdl_prepare_ctx(mmfile_t *mf, xdfile_t *xdf, uint64_t flags) {
 
        xdf->changed += 1;
        xdf->nreff = 0;
-       xdf->dend = xdf->nrec - 1;
 
        return 0;
 
@@ -267,6 +266,8 @@ static int xdl_cleanup_records(xdlclassifier_t *cf, xdfenv_t *xe) {
        uint8_t *action1 = NULL, *action2 = NULL;
        bool need_min = !!(cf->flags & XDF_NEED_MINIMAL);
        int ret = 0;
+       ptrdiff_t dend1 = xe->xdf1.nrec - 1 - xe->delta_end;
+       ptrdiff_t dend2 = xe->xdf2.nrec - 1 - xe->delta_end;
 
        /*
         * Create temporary arrays that will help us decide if
@@ -286,7 +287,7 @@ static int xdl_cleanup_records(xdlclassifier_t *cf, xdfenv_t *xe) {
         */
        if ((mlim = xdl_bogosqrt((long)xe->xdf1.nrec)) > XDL_MAX_EQLIMIT)
                mlim = XDL_MAX_EQLIMIT;
-       for (i = xe->delta_start, recs = &xe->xdf1.recs[xe->delta_start]; i <= xe->xdf1.dend; i++, recs++) {
+       for (i = xe->delta_start, recs = &xe->xdf1.recs[xe->delta_start]; i <= dend1; i++, recs++) {
                rcrec = cf->rcrecs[recs->minimal_perfect_hash];
                nm = rcrec ? rcrec->len2 : 0;
                action1[i] = (nm == 0) ? DISCARD: (nm >= mlim && !need_min) ? INVESTIGATE: KEEP;
@@ -294,7 +295,7 @@ static int xdl_cleanup_records(xdlclassifier_t *cf, xdfenv_t *xe) {
 
        if ((mlim = xdl_bogosqrt((long)xe->xdf2.nrec)) > XDL_MAX_EQLIMIT)
                mlim = XDL_MAX_EQLIMIT;
-       for (i = xe->delta_start, recs = &xe->xdf2.recs[xe->delta_start]; i <= xe->xdf2.dend; i++, recs++) {
+       for (i = xe->delta_start, recs = &xe->xdf2.recs[xe->delta_start]; i <= dend2; i++, recs++) {
                rcrec = cf->rcrecs[recs->minimal_perfect_hash];
                nm = rcrec ? rcrec->len1 : 0;
                action2[i] = (nm == 0) ? DISCARD: (nm >= mlim && !need_min) ? INVESTIGATE: KEEP;
@@ -306,9 +307,9 @@ static int xdl_cleanup_records(xdlclassifier_t *cf, xdfenv_t *xe) {
         */
        xe->xdf1.nreff = 0;
        for (i = xe->delta_start, recs = &xe->xdf1.recs[xe->delta_start];
-            i <= xe->xdf1.dend; i++, recs++) {
+            i <= dend1; i++, recs++) {
                if (action1[i] == KEEP ||
-                   (action1[i] == INVESTIGATE && !xdl_clean_mmatch(action1, i, xe->delta_start, xe->xdf1.dend))) {
+                   (action1[i] == INVESTIGATE && !xdl_clean_mmatch(action1, i, xe->delta_start, dend1))) {
                        xe->xdf1.reference_index[xe->xdf1.nreff++] = i;
                        /* changed[i] remains false, i.e. keep */
                } else
@@ -318,9 +319,9 @@ static int xdl_cleanup_records(xdlclassifier_t *cf, xdfenv_t *xe) {
 
        xe->xdf2.nreff = 0;
        for (i = xe->delta_start, recs = &xe->xdf2.recs[xe->delta_start];
-            i <= xe->xdf2.dend; i++, recs++) {
+            i <= dend2; i++, recs++) {
                if (action2[i] == KEEP ||
-                   (action2[i] == INVESTIGATE && !xdl_clean_mmatch(action2, i, xe->delta_start, xe->xdf2.dend))) {
+                   (action2[i] == INVESTIGATE && !xdl_clean_mmatch(action2, i, xe->delta_start, dend2))) {
                        xe->xdf2.reference_index[xe->xdf2.nreff++] = i;
                        /* changed[i] remains false, i.e. keep */
                } else
@@ -357,8 +358,7 @@ static void xdl_trim_ends(xdfenv_t *xe)
                size_t mph1 = xe->xdf1.recs[xe->xdf1.nrec - 1 - i].minimal_perfect_hash;
                size_t mph2 = xe->xdf2.recs[xe->xdf2.nrec - 1 - i].minimal_perfect_hash;
                if (mph1 != mph2) {
-                       xe->xdf1.dend = xe->xdf1.nrec - 1 - i;
-                       xe->xdf2.dend = xe->xdf2.nrec - 1 - i;
+                       xe->delta_end = i;
                        break;
                }
        }
@@ -370,6 +370,7 @@ int xdl_prepare_env(mmfile_t *mf1, mmfile_t *mf2, xpparam_t const *xpp,
        xdlclassifier_t cf;
 
        xe->delta_start = 0;
+       xe->delta_end = 0;
 
        if (xdl_prepare_ctx(mf1, &xe->xdf1, xpp->flags) < 0) {
 
index bda1f85eb09f937071613b7ad49a16306645efa6..a9393960645d631977f8161ccb741ff1811af3b8 100644 (file)
@@ -48,7 +48,6 @@ typedef struct s_xrecord {
 typedef struct s_xdfile {
        xrecord_t *recs;
        size_t nrec;
-       ptrdiff_t dend;
        bool *changed;
        size_t *reference_index;
        size_t nreff;
@@ -56,7 +55,7 @@ typedef struct s_xdfile {
 
 typedef struct s_xdfenv {
        xdfile_t xdf1, xdf2;
-       size_t delta_start;
+       size_t delta_start, delta_end;
 } xdfenv_t;