Merge remote branch 'julien/status3'
This commit is contained in:
46
pygit2.c
46
pygit2.c
@@ -761,6 +761,30 @@ Repository_packall_references(Repository *self, PyObject *args)
|
|||||||
Py_RETURN_NONE;
|
Py_RETURN_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int read_status_cb(const char *path, unsigned int status_flags,
|
||||||
|
void *payload_dict)
|
||||||
|
{
|
||||||
|
/* This is the callback that will be called in git_status_foreach. It
|
||||||
|
* will be called for every path.*/
|
||||||
|
PyObject *flags;
|
||||||
|
|
||||||
|
flags = PyInt_FromLong((long) status_flags);
|
||||||
|
PyDict_SetItemString(payload_dict, path, flags);
|
||||||
|
|
||||||
|
return GIT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyObject *
|
||||||
|
Repository_status(Repository *self, PyObject *args)
|
||||||
|
{
|
||||||
|
PyObject *payload_dict;
|
||||||
|
|
||||||
|
payload_dict = PyDict_New();
|
||||||
|
git_status_foreach(self->repo, read_status_cb, payload_dict);
|
||||||
|
|
||||||
|
return payload_dict;
|
||||||
|
}
|
||||||
|
|
||||||
static PyMethodDef Repository_methods[] = {
|
static PyMethodDef Repository_methods[] = {
|
||||||
{"create_commit", (PyCFunction)Repository_create_commit, METH_VARARGS,
|
{"create_commit", (PyCFunction)Repository_create_commit, METH_VARARGS,
|
||||||
"Create a new commit object, return its SHA."},
|
"Create a new commit object, return its SHA."},
|
||||||
@@ -789,6 +813,9 @@ static PyMethodDef Repository_methods[] = {
|
|||||||
"\"target\"."},
|
"\"target\"."},
|
||||||
{"packall_references", (PyCFunction)Repository_packall_references,
|
{"packall_references", (PyCFunction)Repository_packall_references,
|
||||||
METH_NOARGS, "Pack all the loose references in the repository."},
|
METH_NOARGS, "Pack all the loose references in the repository."},
|
||||||
|
{"status", (PyCFunction)Repository_status, METH_NOARGS, "Reads the "
|
||||||
|
"status of the repository and returns a dictionnary with file paths "
|
||||||
|
"as keys and status flags as values.\nSee pygit2.GIT_STATUS_*."},
|
||||||
{NULL}
|
{NULL}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -2534,4 +2561,23 @@ initpygit2(void)
|
|||||||
PyModule_AddIntConstant(m,"GIT_REF_OID", GIT_REF_OID);
|
PyModule_AddIntConstant(m,"GIT_REF_OID", GIT_REF_OID);
|
||||||
PyModule_AddIntConstant(m,"GIT_REF_SYMBOLIC", GIT_REF_SYMBOLIC);
|
PyModule_AddIntConstant(m,"GIT_REF_SYMBOLIC", GIT_REF_SYMBOLIC);
|
||||||
PyModule_AddIntConstant(m,"GIT_REF_PACKED", GIT_REF_PACKED);
|
PyModule_AddIntConstant(m,"GIT_REF_PACKED", GIT_REF_PACKED);
|
||||||
|
|
||||||
|
/** Git status flags **/
|
||||||
|
PyModule_AddIntConstant(m,"GIT_STATUS_CURRENT", GIT_STATUS_CURRENT);
|
||||||
|
|
||||||
|
/* Flags for index status */
|
||||||
|
PyModule_AddIntConstant(m,"GIT_STATUS_INDEX_NEW", GIT_STATUS_INDEX_NEW);
|
||||||
|
PyModule_AddIntConstant(m,"GIT_STATUS_INDEX_MODIFIED",
|
||||||
|
GIT_STATUS_INDEX_MODIFIED);
|
||||||
|
PyModule_AddIntConstant(m,"GIT_STATUS_INDEX_DELETED" ,
|
||||||
|
GIT_STATUS_INDEX_DELETED);
|
||||||
|
|
||||||
|
/* Flags for worktree status */
|
||||||
|
PyModule_AddIntConstant(m,"GIT_STATUS_WT_NEW", GIT_STATUS_WT_NEW);
|
||||||
|
PyModule_AddIntConstant(m,"GIT_STATUS_WT_MODIFIED" ,
|
||||||
|
GIT_STATUS_WT_MODIFIED);
|
||||||
|
PyModule_AddIntConstant(m,"GIT_STATUS_WT_DELETED", GIT_STATUS_WT_DELETED);
|
||||||
|
|
||||||
|
/* Flags for ignored files */
|
||||||
|
PyModule_AddIntConstant(m,"GIT_STATUS_IGNORED", GIT_STATUS_IGNORED);
|
||||||
}
|
}
|
||||||
|
@@ -36,7 +36,7 @@ import unittest
|
|||||||
|
|
||||||
|
|
||||||
names = ['blob', 'commit', 'index', 'refs', 'repository', 'revwalk', 'tag',
|
names = ['blob', 'commit', 'index', 'refs', 'repository', 'revwalk', 'tag',
|
||||||
'tree']
|
'tree', 'status']
|
||||||
def test_suite():
|
def test_suite():
|
||||||
modules = ['test.test_%s' % n for n in names]
|
modules = ['test.test_%s' % n for n in names]
|
||||||
return unittest.defaultTestLoader.loadTestsFromNames(modules)
|
return unittest.defaultTestLoader.loadTestsFromNames(modules)
|
||||||
|
BIN
test/data/dirtyrepo.tar
Normal file
BIN
test/data/dirtyrepo.tar
Normal file
Binary file not shown.
79
test/test_status.py
Normal file
79
test/test_status.py
Normal file
@@ -0,0 +1,79 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
# -*- coding: UTF-8 -*-
|
||||||
|
#
|
||||||
|
# Copyright 2011 Julien Miotte
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
|
||||||
|
"""Tests for revision walk."""
|
||||||
|
|
||||||
|
__author__ = 'mike.perdide@gmail.com (Julien Miotte)'
|
||||||
|
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
import pygit2
|
||||||
|
import utils
|
||||||
|
|
||||||
|
EXPECTED = {
|
||||||
|
"current_file": pygit2.GIT_STATUS_CURRENT,
|
||||||
|
"file_deleted": pygit2.GIT_STATUS_WT_DELETED,
|
||||||
|
"modified_file": pygit2.GIT_STATUS_WT_MODIFIED,
|
||||||
|
"new_file": pygit2.GIT_STATUS_WT_NEW,
|
||||||
|
|
||||||
|
"staged_changes": pygit2.GIT_STATUS_INDEX_MODIFIED,
|
||||||
|
"staged_changes_file_deleted": pygit2.GIT_STATUS_INDEX_MODIFIED |
|
||||||
|
pygit2.GIT_STATUS_WT_DELETED,
|
||||||
|
"staged_changes_file_modified": pygit2.GIT_STATUS_INDEX_MODIFIED |
|
||||||
|
pygit2.GIT_STATUS_WT_MODIFIED,
|
||||||
|
|
||||||
|
"staged_delete": pygit2.GIT_STATUS_INDEX_DELETED,
|
||||||
|
"staged_delete_file_modified": pygit2.GIT_STATUS_INDEX_DELETED |
|
||||||
|
pygit2.GIT_STATUS_WT_NEW,
|
||||||
|
"staged_new": pygit2.GIT_STATUS_INDEX_NEW,
|
||||||
|
|
||||||
|
"staged_new_file_deleted": pygit2.GIT_STATUS_INDEX_NEW |
|
||||||
|
pygit2.GIT_STATUS_WT_DELETED,
|
||||||
|
"staged_new_file_modified": pygit2.GIT_STATUS_INDEX_NEW |
|
||||||
|
pygit2.GIT_STATUS_WT_MODIFIED,
|
||||||
|
|
||||||
|
"subdir/current_file": pygit2.GIT_STATUS_CURRENT,
|
||||||
|
"subdir/deleted_file": pygit2.GIT_STATUS_WT_DELETED,
|
||||||
|
"subdir/modified_file": pygit2.GIT_STATUS_WT_MODIFIED,
|
||||||
|
"subdir/new_file": pygit2.GIT_STATUS_WT_NEW,
|
||||||
|
}
|
||||||
|
|
||||||
|
class StatusTest(utils.DirtyRepoTestCase):
|
||||||
|
|
||||||
|
def test_status(self):
|
||||||
|
"""
|
||||||
|
For every file in the status, check that the flags are correct.
|
||||||
|
"""
|
||||||
|
git_status = self.repo.status()
|
||||||
|
for filepath, status in git_status.items():
|
||||||
|
self.assertTrue(filepath in git_status)
|
||||||
|
self.assertEqual(status, git_status[filepath])
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
@@ -66,8 +66,10 @@ class BareRepoTestCase(BaseTestCase):
|
|||||||
|
|
||||||
class RepoTestCase(BaseTestCase):
|
class RepoTestCase(BaseTestCase):
|
||||||
|
|
||||||
def setUp(self):
|
|
||||||
repo_dir = 'testrepo'
|
repo_dir = 'testrepo'
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
repo_dir = self.repo_dir
|
||||||
repo_path = os.path.join(os.path.dirname(__file__), 'data', repo_dir)
|
repo_path = os.path.join(os.path.dirname(__file__), 'data', repo_dir)
|
||||||
temp_dir = tempfile.mkdtemp()
|
temp_dir = tempfile.mkdtemp()
|
||||||
tar = tarfile.open(repo_path + '.tar')
|
tar = tarfile.open(repo_path + '.tar')
|
||||||
@@ -76,3 +78,7 @@ class RepoTestCase(BaseTestCase):
|
|||||||
self._temp_dir = temp_dir
|
self._temp_dir = temp_dir
|
||||||
temp_repo_path = os.path.join(temp_dir, repo_dir, '.git')
|
temp_repo_path = os.path.join(temp_dir, repo_dir, '.git')
|
||||||
self.repo = pygit2.Repository(temp_repo_path)
|
self.repo = pygit2.Repository(temp_repo_path)
|
||||||
|
|
||||||
|
class DirtyRepoTestCase(RepoTestCase):
|
||||||
|
|
||||||
|
repo_dir = 'dirtyrepo'
|
||||||
|
Reference in New Issue
Block a user