You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
103 lines
2.8 KiB
103 lines
2.8 KiB
#ifndef LIST_OBJECTS_FILTER_OPTIONS_H |
|
#define LIST_OBJECTS_FILTER_OPTIONS_H |
|
|
|
#include "parse-options.h" |
|
#include "strbuf.h" |
|
|
|
/* |
|
* The list of defined filters for list-objects. |
|
*/ |
|
enum list_objects_filter_choice { |
|
LOFC_DISABLED = 0, |
|
LOFC_BLOB_NONE, |
|
LOFC_BLOB_LIMIT, |
|
LOFC_TREE_DEPTH, |
|
LOFC_SPARSE_OID, |
|
LOFC_COMBINE, |
|
LOFC__COUNT /* must be last */ |
|
}; |
|
|
|
struct list_objects_filter_options { |
|
/* |
|
* 'filter_spec' is the raw argument value given on the command line |
|
* or protocol request. (The part after the "--keyword=".) For |
|
* commands that launch filtering sub-processes, or for communication |
|
* over the network, don't use this value; use the result of |
|
* expand_list_objects_filter_spec() instead. |
|
*/ |
|
char *filter_spec; |
|
|
|
/* |
|
* 'choice' is determined by parsing the filter-spec. This indicates |
|
* the filtering algorithm to use. |
|
*/ |
|
enum list_objects_filter_choice choice; |
|
|
|
/* |
|
* Choice is LOFC_DISABLED because "--no-filter" was requested. |
|
*/ |
|
unsigned int no_filter : 1; |
|
|
|
/* |
|
* BEGIN choice-specific parsed values from within the filter-spec. Only |
|
* some values will be defined for any given choice. |
|
*/ |
|
|
|
struct object_id *sparse_oid_value; |
|
unsigned long blob_limit_value; |
|
unsigned long tree_exclude_depth; |
|
|
|
/* LOFC_COMBINE values */ |
|
|
|
/* This array contains all the subfilters which this filter combines. */ |
|
size_t sub_nr, sub_alloc; |
|
struct list_objects_filter_options *sub; |
|
|
|
/* |
|
* END choice-specific parsed values. |
|
*/ |
|
}; |
|
|
|
/* Normalized command line arguments */ |
|
#define CL_ARG__FILTER "filter" |
|
|
|
int parse_list_objects_filter( |
|
struct list_objects_filter_options *filter_options, |
|
const char *arg); |
|
|
|
int opt_parse_list_objects_filter(const struct option *opt, |
|
const char *arg, int unset); |
|
|
|
#define OPT_PARSE_LIST_OBJECTS_FILTER(fo) \ |
|
{ OPTION_CALLBACK, 0, CL_ARG__FILTER, fo, N_("args"), \ |
|
N_("object filtering"), 0, \ |
|
opt_parse_list_objects_filter } |
|
|
|
/* |
|
* Translates abbreviated numbers in the filter's filter_spec into their |
|
* fully-expanded forms (e.g., "limit:blob=1k" becomes "limit:blob=1024"). |
|
* |
|
* This form should be used instead of the raw filter_spec field when |
|
* communicating with a remote process or subprocess. |
|
*/ |
|
void expand_list_objects_filter_spec( |
|
const struct list_objects_filter_options *filter, |
|
struct strbuf *expanded_spec); |
|
|
|
void list_objects_filter_release( |
|
struct list_objects_filter_options *filter_options); |
|
|
|
static inline void list_objects_filter_set_no_filter( |
|
struct list_objects_filter_options *filter_options) |
|
{ |
|
list_objects_filter_release(filter_options); |
|
filter_options->no_filter = 1; |
|
} |
|
|
|
void partial_clone_register( |
|
const char *remote, |
|
const struct list_objects_filter_options *filter_options); |
|
void partial_clone_get_default_filter_spec( |
|
struct list_objects_filter_options *filter_options); |
|
|
|
#endif /* LIST_OBJECTS_FILTER_OPTIONS_H */
|
|
|