summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarlos Martín Nieto <cmn@dwim.me>2015-05-05 09:25:17 +0200
committerCarlos Martín Nieto <cmn@dwim.me>2015-06-22 17:02:55 +0200
commit961861fafad45c9eab29f523e51261ba78ab10be (patch)
treef62724e049940d8c1b238d3abe18c0214c1db3aa
parentd6073b30f38f95aa25b1545cccac38261b359de1 (diff)
downloadlibgit2-961861fafad45c9eab29f523e51261ba78ab10be.tar.gz
submodule: get rid of `_save()`
We no longer have any setters which affect an instance, so `git_submodule_save()` is no longer relevant.
-rw-r--r--include/git2/submodule.h14
-rw-r--r--src/submodule.c38
-rw-r--r--tests/submodule/modify.c9
3 files changed, 0 insertions, 61 deletions
diff --git a/include/git2/submodule.h b/include/git2/submodule.h
index 16895ac3b..0169d1c27 100644
--- a/include/git2/submodule.h
+++ b/include/git2/submodule.h
@@ -301,20 +301,6 @@ GIT_EXTERN(int) git_submodule_add_to_index(
int write_index);
/**
- * Write submodule settings to .gitmodules file.
- *
- * This commits any in-memory changes to the submodule to the gitmodules
- * file on disk. You may also be interested in `git_submodule_init()` which
- * writes submodule info to ".git/config" (which is better for local changes
- * to submodule settings) and/or `git_submodule_sync()` which writes
- * settings about remotes to the actual submodule repository.
- *
- * @param submodule The submodule to write.
- * @return 0 on success, <0 on failure.
- */
-GIT_EXTERN(int) git_submodule_save(git_submodule *submodule);
-
-/**
* Get the containing repository for a submodule.
*
* This returns a pointer to the repository that contains the submodule.
diff --git a/src/submodule.c b/src/submodule.c
index 24d31fe77..738d57921 100644
--- a/src/submodule.c
+++ b/src/submodule.c
@@ -764,44 +764,6 @@ const char *git_submodule_recurse_to_str(git_submodule_recurse_t recurse)
return NULL;
}
-int git_submodule_save(git_submodule *submodule)
-{
- int error = 0;
- git_config_backend *mods;
- git_buf key = GIT_BUF_INIT;
-
- assert(submodule);
-
- mods = open_gitmodules(submodule->repo, GITMODULES_CREATE);
- if (!mods) {
- giterr_set(GITERR_SUBMODULE,
- "Adding submodules to a bare repository is not supported");
- return -1;
- }
-
- if ((error = git_buf_printf(&key, "submodule.%s.", submodule->name)) < 0)
- goto cleanup;
-
- /* save values for path, url, update, ignore, fetchRecurseSubmodules */
-
- if ((error = submodule_config_key_trunc_puts(&key, "path")) < 0 ||
- (error = git_config_file_set_string(mods, key.ptr, submodule->path)) < 0)
- goto cleanup;
-
- /* update internal defaults */
-
- submodule->ignore_default = submodule->ignore;
- submodule->update_default = submodule->update;
- submodule->fetch_recurse_default = submodule->fetch_recurse;
- submodule->flags |= GIT_SUBMODULE_STATUS_IN_CONFIG;
-
-cleanup:
- git_config_file_free(mods);
- git_buf_free(&key);
-
- return error;
-}
-
git_repository *git_submodule_owner(git_submodule *submodule)
{
assert(submodule);
diff --git a/tests/submodule/modify.c b/tests/submodule/modify.c
index 9c387a3b5..77f86e514 100644
--- a/tests/submodule/modify.c
+++ b/tests/submodule/modify.c
@@ -194,12 +194,3 @@ void test_submodule_modify__set_url(void)
cl_assert_equal_s(SM_LIBGIT2_URL, git_submodule_url(sm));
git_submodule_free(sm);
}
-
-void test_submodule_modify__save_last(void)
-{
- git_submodule *sm;
-
- cl_git_pass(git_submodule_lookup(&sm, g_repo, "sm_gitmodules_only"));
- cl_git_pass(git_submodule_save(sm));
- git_submodule_free(sm);
-}