b99a579f8e
The in-core repository instances are passed through more codepaths. * sb/more-repo-in-api: (23 commits) t/helper/test-repository: celebrate independence from the_repository path.h: make REPO_GIT_PATH_FUNC repository agnostic commit: prepare free_commit_buffer and release_commit_memory for any repo commit-graph: convert remaining functions to handle any repo submodule: don't add submodule as odb for push submodule: use submodule repos for object lookup pretty: prepare format_commit_message to handle arbitrary repositories commit: prepare logmsg_reencode to handle arbitrary repositories commit: prepare repo_unuse_commit_buffer to handle any repo commit: prepare get_commit_buffer to handle any repo commit-reach: prepare in_merge_bases[_many] to handle any repo commit-reach: prepare get_merge_bases to handle any repo commit-reach.c: allow get_merge_bases_many_0 to handle any repo commit-reach.c: allow remove_redundant to handle any repo commit-reach.c: allow merge_bases_many to handle any repo commit-reach.c: allow paint_down_to_common to handle any repo commit: allow parse_commit* to handle any repo object: parse_object to honor its repository argument object-store: prepare has_{sha1, object}_file to handle any repo object-store: prepare read_object_file to deal with any repo ... |
||
---|---|---|
.. | ||
.gitignore | ||
array.cocci | ||
commit.cocci | ||
free.cocci | ||
object_id.cocci | ||
preincr.cocci | ||
qsort.cocci | ||
README | ||
strbuf.cocci | ||
swap.cocci | ||
the_repository.pending.cocci | ||
xstrdup_or_null.cocci |
This directory provides examples of Coccinelle (http://coccinelle.lip6.fr/) semantic patches that might be useful to developers. There are two types of semantic patches: * Using the semantic transformation to check for bad patterns in the code; The target 'make coccicheck' is designed to check for these patterns and it is expected that any resulting patch indicates a regression. The patches resulting from 'make coccicheck' are small and infrequent, so once they are found, they can be sent to the mailing list as per usual. Example for introducing new patterns: 67947c34ae (convert "hashcmp() != 0" to "!hasheq()", 2018-08-28) b84c783882 (fsck: s/++i > 1/i++/, 2018-10-24) Example of fixes using this approach: 248f66ed8e (run-command: use strbuf_addstr() for adding a string to a strbuf, 2018-03-25) f919ffebed (Use MOVE_ARRAY, 2018-01-22) These types of semantic patches are usually part of testing, c.f. 0860a7641b (travis-ci: fail if Coccinelle static analysis found something to transform, 2018-07-23) * Using semantic transformations in large scale refactorings throughout the code base. When applying the semantic patch into a real patch, sending it to the mailing list in the usual way, such a patch would be expected to have a lot of textual and semantic conflicts as such large scale refactorings change function signatures that are used widely in the code base. A textual conflict would arise if surrounding code near any call of such function changes. A semantic conflict arises when other patch series in flight introduce calls to such functions. So to aid these large scale refactorings, semantic patches can be used. However we do not want to store them in the same place as the checks for bad patterns, as then automated builds would fail. That is why semantic patches 'contrib/coccinelle/*.pending.cocci' are ignored for checks, and can be applied using 'make coccicheck-pending'. This allows to expose plans of pending large scale refactorings without impacting the bad pattern checks.