##// END OF EJS Templates
match: add visitchildrenset complement to visitdir...
match: add visitchildrenset complement to visitdir `visitdir(d)` lets a caller query whether the directory is part of the matcher. It can receive a response of 'all' (yes, and all children, you can stop calling visitdir now), False (no, and no children either), or True (yes, either something in this directory or a child is part of the matcher). `visitchildrenset(d)` augments that by instead of returning True, it returns a list of items to actually investigate. With this, code can be modified from: for f in self.all_items: if match.visitdir(self.dir + '/' + f): <do stuff> to be: for f in self.all_items.intersect(match.visitchildrenset(self.dir)): <do stuff> use of this function can provide significant performance improvements, especially when using narrow (so that the matcher is much smaller than the stuff we see on disk) and/or treemanifests (so that we can avoid loading manifests for trees that aren't part of the matcher). Differential Revision: https://phab.mercurial-scm.org/D4130

File last commit:

r36636:9a639a33 default
r38990:081cc9a9 default
Show More
util.h
61 lines | 1.6 KiB | text/x-c | CLexer
Yuya Nishihara
cext: move util.h to cext tree...
r32384 /*
util.h - utility functions for interfacing with the various python APIs.
This software may be used and distributed according to the terms of
the GNU General Public License, incorporated herein by reference.
*/
#ifndef _HG_UTIL_H_
#define _HG_UTIL_H_
#include "compat.h"
#if PY_MAJOR_VERSION >= 3
#define IS_PY3K
#endif
Yuya Nishihara
py3: add PY23() macro to switch string literal depending on python version...
r36636 /* helper to switch things like string literal depending on Python version */
#ifdef IS_PY3K
#define PY23(py2, py3) py3
#else
#define PY23(py2, py3) py2
#endif
Augie Fackler
util: add clang-format control comment around struct and format macro...
r34636 /* clang-format off */
Yuya Nishihara
cext: move util.h to cext tree...
r32384 typedef struct {
PyObject_HEAD
char state;
int mode;
int size;
int mtime;
} dirstateTupleObject;
Augie Fackler
util: add clang-format control comment around struct and format macro...
r34636 /* clang-format on */
Yuya Nishihara
cext: move util.h to cext tree...
r32384
extern PyTypeObject dirstateTupleType;
#define dirstate_tuple_check(op) (Py_TYPE(op) == &dirstateTupleType)
André Sintzoff
cext: define MIN macro only if it is not yet defined...
r35793 #ifndef MIN
Augie Fackler
util: add clang-format control comment around struct and format macro...
r34636 #define MIN(a, b) (((a) < (b)) ? (a) : (b))
André Sintzoff
cext: define MIN macro only if it is not yet defined...
r35793 #endif
Yuya Nishihara
cext: move util.h to cext tree...
r32384 /* VC9 doesn't include bool and lacks stdbool.h based on my searching */
#if defined(_MSC_VER) || __STDC_VERSION__ < 199901L
#define true 1
#define false 0
typedef unsigned char bool;
#else
#include <stdbool.h>
#endif
Yuya Nishihara
cext: move _dict_new_presized() to header...
r33751 static inline PyObject *_dict_new_presized(Py_ssize_t expected_size)
{
/* _PyDict_NewPresized expects a minused parameter, but it actually
creates a dictionary that's the nearest power of two bigger than the
parameter. For example, with the initial minused = 1000, the
dictionary created has size 1024. Of course in a lot of cases that
can be greater than the maximum load factor Python's dict object
expects (= 2/3), so as soon as we cross the threshold we'll resize
anyway. So create a dictionary that's at least 3/2 the size. */
return _PyDict_NewPresized(((1 + expected_size) / 2) * 3);
}
Yuya Nishihara
cext: move util.h to cext tree...
r32384 #endif /* _HG_UTIL_H_ */