diff options
| author | Vicent Martà <vicent@github.com> | 2013-11-11 06:47:15 -0800 | 
|---|---|---|
| committer | Vicent Martà <vicent@github.com> | 2013-11-11 06:47:15 -0800 | 
| commit | 6414fd338df89eaa5bd4c64f7ab310fb7d5758bb (patch) | |
| tree | 4af0ea37b387c791bd89e73edea10e3353c54423 /include/git2/remote.h | |
| parent | 5e1281f873e7eb5b51569ef33218dd20b69ff707 (diff) | |
| parent | a6192d7c98976edb0ce4fd10438ac7a19c283598 (diff) | |
| download | libgit2-6414fd338df89eaa5bd4c64f7ab310fb7d5758bb.tar.gz | |
Merge pull request #1956 from libgit2/cmn/fetch-default-head
Remote revamp (director's cut)
Diffstat (limited to 'include/git2/remote.h')
| -rw-r--r-- | include/git2/remote.h | 52 | 
1 files changed, 35 insertions, 17 deletions
| diff --git a/include/git2/remote.h b/include/git2/remote.h index b9cf86ef1..9e7d218a8 100644 --- a/include/git2/remote.h +++ b/include/git2/remote.h @@ -54,7 +54,7 @@ GIT_EXTERN(int) git_remote_create(   *   * @param out pointer to the new remote object   * @param repo the associated repository - * @param fetch the fetch refspec to use for this remote. May be NULL for defaults. + * @param fetch the fetch refspec to use for this remote.   * @param url the remote repository's URL   * @return 0 or an error code   */ @@ -145,8 +145,11 @@ GIT_EXTERN(int) git_remote_set_pushurl(git_remote *remote, const char* url);  /**   * Add a fetch refspec to the remote   * + * Convenience function for adding a single fetch refspec to the + * current list in the remote. + *   * @param remote the remote - * @apram refspec the new fetch refspec + * @param refspec the new fetch refspec   * @return 0 or an error value   */  GIT_EXTERN(int) git_remote_add_fetch(git_remote *remote, const char *refspec); @@ -163,8 +166,21 @@ GIT_EXTERN(int) git_remote_add_fetch(git_remote *remote, const char *refspec);  GIT_EXTERN(int) git_remote_get_fetch_refspecs(git_strarray *array, git_remote *remote);  /** + * Set the remote's list of fetch refspecs + * + * The contents of the string array are copied. + * + * @param remote the remote to modify + * @param array the new list of fetch resfpecs + */ +GIT_EXTERN(int) git_remote_set_fetch_refspecs(git_remote *remote, git_strarray *array); + +/**   * Add a push refspec to the remote   * + * Convenience function for adding a single push refspec to the + * current list in the remote. + *   * @param remote the remote   * @param refspec the new push refspec   * @return 0 or an error value @@ -183,6 +199,16 @@ GIT_EXTERN(int) git_remote_add_push(git_remote *remote, const char *refspec);  GIT_EXTERN(int) git_remote_get_push_refspecs(git_strarray *array, git_remote *remote);  /** + * Set the remote's list of push refspecs + * + * The contents of the string array are copied. + * + * @param remote the remote to modify + * @param array the new list of push resfpecs + */ +GIT_EXTERN(int) git_remote_set_push_refspecs(git_remote *remote, git_strarray *array); + +/**   * Clear the refspecs   *   * Remove all configured fetch and push refspecs from the remote. @@ -209,15 +235,6 @@ GIT_EXTERN(size_t) git_remote_refspec_count(git_remote *remote);  GIT_EXTERN(const git_refspec *)git_remote_get_refspec(git_remote *remote, size_t n);  /** - * Remove a refspec from the remote - * - * @param remote the remote to query - * @param n the refspec to remove - * @return 0 or GIT_ENOTFOUND - */ -GIT_EXTERN(int) git_remote_remove_refspec(git_remote *remote, size_t n); - -/**   * Open a connection to a remote   *   * The transport is selected based on the URL. The direction argument @@ -237,15 +254,16 @@ GIT_EXTERN(int) git_remote_connect(git_remote *remote, git_direction direction);   * The remote (or more exactly its transport) must be connected. The   * memory belongs to the remote.   * - * If you a return a non-zero value from the callback, this will stop - * looping over the refs. + * The array will stay valid as long as the remote object exists and + * its transport isn't changed, but a copy is recommended for usage of + * the data.   * + * @param out pointer to the array + * @param size the number of remote heads   * @param remote the remote - * @param list_cb function to call with each ref discovered at the remote - * @param payload additional data to pass to the callback - * @return 0 on success, GIT_EUSER on non-zero callback, or error code + * @return 0 on success, or an error code   */ -GIT_EXTERN(int) git_remote_ls(git_remote *remote, git_headlist_cb list_cb, void *payload); +GIT_EXTERN(int) git_remote_ls(const git_remote_head ***out,  size_t *size, git_remote *remote);  /**   * Download and index the packfile | 
