summaryrefslogtreecommitdiff
path: root/include/git2/status.h
diff options
context:
space:
mode:
authorJason Penny <jasonpenny4@gmail.com>2011-06-22 18:19:46 -0400
committerVicent Marti <tanoku@gmail.com>2011-07-09 13:49:50 +0200
commit205166d27c3ab937f1a106de87d511223abc5059 (patch)
tree8a819fd692aa5c11b592fa345a7b2002084fc763 /include/git2/status.h
parent7361857c50a03dae4bba3f1f3d371db41012658f (diff)
downloadlibgit2-205166d27c3ab937f1a106de87d511223abc5059.tar.gz
status: get blob object id of file on disk
Add git_status_hashfile() to get blob's object id for a file without adding it to the object database or needing a repository at all. This functionality is similar to `git hash-object` without '-w'.
Diffstat (limited to 'include/git2/status.h')
-rw-r--r--include/git2/status.h54
1 files changed, 54 insertions, 0 deletions
diff --git a/include/git2/status.h b/include/git2/status.h
new file mode 100644
index 000000000..97fff43e8
--- /dev/null
+++ b/include/git2/status.h
@@ -0,0 +1,54 @@
+/*
+ * This file is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License, version 2,
+ * as published by the Free Software Foundation.
+ *
+ * In addition to the permissions in the GNU General Public License,
+ * the authors give you unlimited permission to link the compiled
+ * version of this file into combinations with other programs,
+ * and to distribute those combinations without any restriction
+ * coming from the use of this file. (The General Public License
+ * restrictions do apply in other respects; for example, they cover
+ * modification of the file, and distribution when not linked into
+ * a combined executable.)
+ *
+ * This file is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; see the file COPYING. If not, write to
+ * the Free Software Foundation, 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+ */
+#ifndef INCLUDE_git_status_h__
+#define INCLUDE_git_status_h__
+
+#include "common.h"
+#include "types.h"
+
+/**
+ * @file git2/status.h
+ * @brief Git file status routines
+ * @defgroup git_status Git file status routines
+ * @ingroup Git
+ * @{
+ */
+GIT_BEGIN_DECL
+
+/**
+ * Read a file from disk and fill a git_oid with the object id
+ * that the file would have if it were written to the Object
+ * Database as a loose blob. Similar functionality to git.git's
+ * `git hash-object` without the `-w` flag.
+ *
+ * @param out oid structure the result is written into.
+ * @param path file to read and determine object id for
+ * @return GIT_SUCCESS if valid; error code otherwise
+ */
+GIT_EXTERN(int) git_status_hashfile(git_oid *out, const char *path);
+
+/** @} */
+GIT_END_DECL
+#endif