object: allow passing a type object to peel()
Allow usage of a python type instead of having to use the libgit2 constants.
This commit is contained in:
33
src/object.c
33
src/object.c
@@ -127,6 +127,24 @@ Object_read_raw(Object *self)
|
|||||||
return aux;
|
return aux;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static git_otype
|
||||||
|
py_type_to_git_type(PyTypeObject *py_type)
|
||||||
|
{
|
||||||
|
git_otype type = GIT_OBJ_BAD;
|
||||||
|
|
||||||
|
if (py_type == &CommitType) {
|
||||||
|
type = GIT_OBJ_COMMIT;
|
||||||
|
} else if (py_type == &TreeType) {
|
||||||
|
type = GIT_OBJ_TREE;
|
||||||
|
} else if (py_type == &BlobType) {
|
||||||
|
type = GIT_OBJ_BLOB;
|
||||||
|
} else if (py_type == &TagType) {
|
||||||
|
type = GIT_OBJ_TAG;
|
||||||
|
}
|
||||||
|
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
PyDoc_STRVAR(Object_peel__doc__,
|
PyDoc_STRVAR(Object_peel__doc__,
|
||||||
"peel(target_type) -> Object\n"
|
"peel(target_type) -> Object\n"
|
||||||
"\n"
|
"\n"
|
||||||
@@ -135,12 +153,21 @@ PyDoc_STRVAR(Object_peel__doc__,
|
|||||||
PyObject *
|
PyObject *
|
||||||
Object_peel(Object *self, PyObject *py_type)
|
Object_peel(Object *self, PyObject *py_type)
|
||||||
{
|
{
|
||||||
int type, err;
|
int type = -1, err;
|
||||||
git_object *peeled;
|
git_object *peeled;
|
||||||
|
|
||||||
type = PyLong_AsLong(py_type);
|
if (PyLong_Check(py_type)) {
|
||||||
if (type == -1 && PyErr_Occurred())
|
type = PyLong_AsLong(py_type);
|
||||||
|
if (type == -1 && PyErr_Occurred())
|
||||||
|
return NULL;
|
||||||
|
} else if (PyType_Check(py_type)) {
|
||||||
|
type = py_type_to_git_type((PyTypeObject *) py_type);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (type == -1) {
|
||||||
|
PyErr_SetString(PyExc_ValueError, "invalid target type");
|
||||||
return NULL;
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
err = git_object_peel(&peeled, self->obj, (git_otype)type);
|
err = git_object_peel(&peeled, self->obj, (git_otype)type);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
|
@@ -33,7 +33,7 @@ from os.path import dirname, join
|
|||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
import pygit2
|
import pygit2
|
||||||
from pygit2 import GIT_OBJ_TREE, GIT_OBJ_TAG
|
from pygit2 import GIT_OBJ_TREE, GIT_OBJ_TAG, Tree, Tag
|
||||||
from . import utils
|
from . import utils
|
||||||
|
|
||||||
|
|
||||||
@@ -54,14 +54,29 @@ class ObjectTest(utils.RepoTestCase):
|
|||||||
# and peel to the tree
|
# and peel to the tree
|
||||||
tree = commit.peel(GIT_OBJ_TREE)
|
tree = commit.peel(GIT_OBJ_TREE)
|
||||||
|
|
||||||
self.assertEqual(type(tree), pygit2.Tree)
|
self.assertEqual(type(tree), Tree)
|
||||||
self.assertEqual(str(tree.id), 'fd937514cb799514d4b81bb24c5fcfeb6472b245')
|
self.assertEqual(str(tree.id), 'fd937514cb799514d4b81bb24c5fcfeb6472b245')
|
||||||
|
|
||||||
|
def test_peel_commit_type(self):
|
||||||
|
commit_id = self.repo.lookup_reference('refs/heads/master').target
|
||||||
|
commit = self.repo[commit_id]
|
||||||
|
tree = commit.peel(Tree)
|
||||||
|
|
||||||
|
self.assertEqual(type(tree), Tree)
|
||||||
|
self.assertEqual(str(tree.id), 'fd937514cb799514d4b81bb24c5fcfeb6472b245')
|
||||||
|
|
||||||
|
|
||||||
def test_invalid(self):
|
def test_invalid(self):
|
||||||
commit_id = self.repo.lookup_reference('refs/heads/master').target
|
commit_id = self.repo.lookup_reference('refs/heads/master').target
|
||||||
commit = self.repo[commit_id]
|
commit = self.repo[commit_id]
|
||||||
|
|
||||||
self.assertRaises(ValueError, commit.peel, GIT_OBJ_TAG)
|
self.assertRaises(ValueError, commit.peel, GIT_OBJ_TAG)
|
||||||
|
|
||||||
|
def test_invalid_type(self):
|
||||||
|
commit_id = self.repo.lookup_reference('refs/heads/master').target
|
||||||
|
commit = self.repo[commit_id]
|
||||||
|
|
||||||
|
self.assertRaises(ValueError, commit.peel, Tag)
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
Reference in New Issue
Block a user