[PATCH 0/5] Refactor excludes library

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The exclude library defined in dir.h was originally written for the
.gitignore feature, but has since been used for .gitattributes and
sparse-checkout. In the later applications, these patterns are used for 
inclusion rather than exclusion, so the name is confusing. This gets
particularly bad when looking at how the sparse-checkout feature uses
is_excluded_from_list() to really mean "should be included in the working
directory".

This series performs several renames of structs and methods to generalize
the exclude library to be a "pattern matching" library. Instead of a list of
excludes, we have a list of path patterns. It is up to the consumer to
decide what to do with a match. The .gitignore logic will still treat the
patterns as a list of exclusions, the sparse-checkout logic treats the
patterns as a list of inclusions.

For this reason, some methods and structs in dir.h retain "exclude" in their
name. These are limited to things consumed only by the .gitignore feature
(as far as I can tell).

Most of these changes are mechanical find-and-replaces, with the exception
of some variable names and the last patch.

The last patch, "unpack-trees: rename 'is_excluded_from_list()'", performs a
more meaningful refactor. The method is_excluded_from_list() was only used
by sparse-checkout (inside the clear_ce_flags() methods) to see if a path
should be included in the working directory. The return value of "1 for
excluded" was confusing. Instead, use a new enum value. This required
changing several method prototypes inside unpack-trees.c.

This refactor was inspired by Elijah Newren's feedback [1] on my
sparse-checkout builtin RFC. I am working on a few other orthogonal changes
to make to the existing sparse-checkout behavior before I resubmit that RFC.

I had started working on v2.23.0, but found adjacent-diff conflicts with
md/list-objects-filter-combo [2] and js/partial-clone-sparse-blob [3]. Those
branches are independent, but the conflicts with
md/list-objects-filter-combo were more severe (and that branch seems closer
to merging) so this is based on md/list-object-filter-combo. Hopefully the
conflicts with js/partial-clone-sparse-blob are clear enough to resolve
easily.

Thanks, -Stolee

[1] 
https://public-inbox.org/git/CABPp-BFMtO=7UGVZPbqh3tthSetvz5F=W3S=RsryPSuchmZeZw@xxxxxxxxxxxxxx/
Re: [PATCH 8/9] sparse-checkout: use hashmaps for cone patterns

[2] https://public-inbox.org/git/cover.1558030802.git.matvore@xxxxxxxxxx/
[RFC PATCH 0/3] implement composite filters

[3] https://public-inbox.org/git/20190828201824.1255-1-jon@xxxxxxxxxxxxx/
[PATCH 0/2] partial-clone: fix two issues with sparse filter handling

Derrick Stolee (5):
  treewide: rename 'struct exclude' to 'struct path_pattern'
  treewide: rename 'struct exclude_list' to 'struct pattern_list'
  treewide: rename 'EXCL_FLAG_' to 'PATTERN_FLAG_'
  treewide: rename 'exclude' methods to 'pattern'
  unpack-trees: rename 'is_excluded_from_list()'

 Documentation/RelNotes/2.7.1.txt              |   2 +-
 Documentation/RelNotes/2.8.0.txt              |   2 +-
 .../technical/api-directory-listing.txt       |   6 +-
 attr.c                                        |  10 +-
 builtin/check-ignore.c                        |  34 +--
 builtin/clean.c                               |  12 +-
 builtin/ls-files.c                            |   8 +-
 dir.c                                         | 284 +++++++++---------
 dir.h                                         |  71 +++--
 list-objects-filter.c                         |  37 +--
 unpack-trees.c                                |  67 +++--
 unpack-trees.h                                |   4 +-
 12 files changed, 285 insertions(+), 252 deletions(-)


base-commit: 90d21f9ebf6906f0ebb4fb1b20ec9536072e2916
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-329%2Fderrickstolee%2Fexclude-refactor-v1
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-329/derrickstolee/exclude-refactor-v1
Pull-Request: https://github.com/gitgitgadget/git/pull/329
-- 
gitgitgadget



[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux