API updates for status.h

This commit is contained in:
Russell Belfer 2012-11-21 11:53:54 -08:00 committed by Ben Straub
parent 9daf240053
commit d574de0e6e
2 changed files with 20 additions and 7 deletions

View File

@ -46,6 +46,18 @@ typedef enum {
GIT_STATUS_IGNORED = (1u << 14),
} git_status_t;
/**
* Function pointer to receive status on individual files
*
* `path` is the relative path to the file from the root of the repository.
*
* `status_flags` is a combination of `git_status_t` values that apply.
*
* `payload` is the value you passed to the foreach function as payload.
*/
typedef int (*git_status_cb)(
const char *path, unsigned int status_flags, void *payload);
/**
* Gather file statuses and run a callback for each one.
*
@ -63,7 +75,7 @@ typedef enum {
*/
GIT_EXTERN(int) git_status_foreach(
git_repository *repo,
int (*callback)(const char *, unsigned int, void *),
git_status_cb callback,
void *payload);
/**
@ -146,9 +158,10 @@ typedef enum {
* `GIT_STATUS_OPT_DISABLE_PATHSPEC_MATCH` is specified in the flags.
*/
typedef struct {
unsigned int version;
git_status_show_t show;
unsigned int flags;
git_strarray pathspec;
unsigned int flags;
git_strarray pathspec;
} git_status_options;
/**
@ -168,7 +181,7 @@ typedef struct {
GIT_EXTERN(int) git_status_foreach_ext(
git_repository *repo,
const git_status_options *opts,
int (*callback)(const char *, unsigned int, void *),
git_status_cb callback,
void *payload);
/**

View File

@ -78,7 +78,7 @@ static unsigned int workdir_delta2status(git_delta_t workdir_status)
}
typedef struct {
int (*cb)(const char *, unsigned int, void *);
git_status_cb cb;
void *payload;
} status_user_callback;
@ -104,7 +104,7 @@ static int status_invoke_cb(
int git_status_foreach_ext(
git_repository *repo,
const git_status_options *opts,
int (*cb)(const char *, unsigned int, void *),
git_status_cb cb,
void *payload)
{
int err = 0;
@ -178,7 +178,7 @@ cleanup:
int git_status_foreach(
git_repository *repo,
int (*callback)(const char *, unsigned int, void *),
git_status_cb callback,
void *payload)
{
git_status_options opts;