summaryrefslogtreecommitdiff
path: root/include/git2/strarray.h
diff options
context:
space:
mode:
authorBen Straub <bs@github.com>2012-10-17 11:55:26 -0700
committerBen Straub <bs@github.com>2012-10-17 11:55:26 -0700
commit6012e86839bbdfc98085662c22f8e34b6f6abefb (patch)
tree8bf11719e6e910889ed18abd0a449d9974e412a0 /include/git2/strarray.h
parent5300cd759d1da36893328ec28b30906edbca19bc (diff)
parentb46708aaf953df11fa62fe1c718b794c874873ff (diff)
downloadlibgit2-6012e86839bbdfc98085662c22f8e34b6f6abefb.tar.gz
Merge pull request #972 from PaulThompson/separate_strarray
Separated git_strarray from common.h. Added doxy comments.
Diffstat (limited to 'include/git2/strarray.h')
-rw-r--r--include/git2/strarray.h54
1 files changed, 54 insertions, 0 deletions
diff --git a/include/git2/strarray.h b/include/git2/strarray.h
new file mode 100644
index 000000000..f6092fa9c
--- /dev/null
+++ b/include/git2/strarray.h
@@ -0,0 +1,54 @@
+/*
+ * Copyright (C) 2009-2012 the libgit2 contributors
+ *
+ * This file is part of libgit2, distributed under the GNU GPL v2 with
+ * a Linking Exception. For full terms see the included COPYING file.
+ */
+#ifndef INCLUDE_git_strarray_h__
+#define INCLUDE_git_strarray_h__
+
+#include "common.h"
+
+/**
+ * @file git2/strarray.h
+ * @brief Git string array routines
+ * @defgroup git_strarray Git string array routines
+ * @ingroup Git
+ * @{
+ */
+GIT_BEGIN_DECL
+
+/** Array of strings */
+typedef struct _git_strarray git_strarray;
+struct _git_strarray {
+ char **strings;
+ size_t count;
+};
+
+/**
+ * Close a string array object
+ *
+ * This method must always be called once a git_strarray is no
+ * longer needed, otherwise memory will leak.
+ *
+ * @param array array to close
+ */
+GIT_EXTERN(void) git_strarray_free(git_strarray *array);
+
+/**
+ * Copy a string array object from source to target.
+ *
+ * Note: target is overwritten and hence should be empty,
+ * otherwise its contents are leaked.
+ *
+ * @param tgt target
+ * @param src source
+ */
+GIT_EXTERN(int) git_strarray_copy(git_strarray *tgt, const git_strarray *src);
+
+
+/** @} */
+GIT_END_DECL
+
+#endif
+