mirror of
https://github.com/p2p-ld/numpydantic.git
synced 2025-01-09 21:44:27 +00:00
allow revalidation of already-proxied arrays
This commit is contained in:
parent
d595e87e10
commit
4152af1f91
3 changed files with 13 additions and 7 deletions
|
@ -194,10 +194,7 @@ class H5Interface(Interface):
|
||||||
passthrough numpy-like interface to the dataset.
|
passthrough numpy-like interface to the dataset.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
input_types = (
|
input_types = (H5ArrayPath, H5Arraylike, H5Proxy)
|
||||||
H5ArrayPath,
|
|
||||||
H5Arraylike,
|
|
||||||
)
|
|
||||||
return_type = H5Proxy
|
return_type = H5Proxy
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
|
@ -211,7 +208,7 @@ class H5Interface(Interface):
|
||||||
Check that the given array is a :class:`.H5ArrayPath` or something that
|
Check that the given array is a :class:`.H5ArrayPath` or something that
|
||||||
resembles one.
|
resembles one.
|
||||||
"""
|
"""
|
||||||
if isinstance(array, H5ArrayPath):
|
if isinstance(array, (H5ArrayPath, H5Proxy)):
|
||||||
return True
|
return True
|
||||||
|
|
||||||
if isinstance(array, (tuple, list)) and len(array) in (2, 3):
|
if isinstance(array, (tuple, list)) and len(array) in (2, 3):
|
||||||
|
@ -242,6 +239,9 @@ class H5Interface(Interface):
|
||||||
"""Create an :class:`.H5Proxy` to use throughout validation"""
|
"""Create an :class:`.H5Proxy` to use throughout validation"""
|
||||||
if isinstance(array, H5ArrayPath):
|
if isinstance(array, H5ArrayPath):
|
||||||
array = H5Proxy.from_h5array(h5array=array)
|
array = H5Proxy.from_h5array(h5array=array)
|
||||||
|
elif isinstance(array, H5Proxy):
|
||||||
|
# nothing to do, already proxied
|
||||||
|
pass
|
||||||
elif isinstance(array, (tuple, list)) and len(array) == 2: # pragma: no cover
|
elif isinstance(array, (tuple, list)) and len(array) == 2: # pragma: no cover
|
||||||
array = H5Proxy(file=array[0], path=array[1])
|
array = H5Proxy(file=array[0], path=array[1])
|
||||||
elif isinstance(array, (tuple, list)) and len(array) == 3:
|
elif isinstance(array, (tuple, list)) and len(array) == 3:
|
||||||
|
|
|
@ -190,7 +190,7 @@ class VideoInterface(Interface):
|
||||||
OpenCV interface to treat videos as arrays.
|
OpenCV interface to treat videos as arrays.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
input_types = (str, Path, VideoCapture)
|
input_types = (str, Path, VideoCapture, VideoProxy)
|
||||||
return_type = VideoProxy
|
return_type = VideoProxy
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
|
@ -204,7 +204,9 @@ class VideoInterface(Interface):
|
||||||
Check if array is a string or Path with a supported video extension,
|
Check if array is a string or Path with a supported video extension,
|
||||||
or an opened VideoCapture object
|
or an opened VideoCapture object
|
||||||
"""
|
"""
|
||||||
if VideoCapture is not None and isinstance(array, VideoCapture):
|
if (VideoCapture is not None and isinstance(array, VideoCapture)) or isinstance(
|
||||||
|
array, VideoProxy
|
||||||
|
):
|
||||||
return True
|
return True
|
||||||
|
|
||||||
if isinstance(array, str):
|
if isinstance(array, str):
|
||||||
|
@ -220,6 +222,8 @@ class VideoInterface(Interface):
|
||||||
"""Get a :class:`.VideoProxy` object for this video"""
|
"""Get a :class:`.VideoProxy` object for this video"""
|
||||||
if isinstance(array, VideoCapture):
|
if isinstance(array, VideoCapture):
|
||||||
proxy = VideoProxy(video=array)
|
proxy = VideoProxy(video=array)
|
||||||
|
elif isinstance(array, VideoProxy):
|
||||||
|
proxy = array
|
||||||
else:
|
else:
|
||||||
proxy = VideoProxy(path=array)
|
proxy = VideoProxy(path=array)
|
||||||
return proxy
|
return proxy
|
||||||
|
|
|
@ -156,5 +156,7 @@ def test_interface_recursive(interfaces):
|
||||||
def test_interface_revalidate(all_interfaces):
|
def test_interface_revalidate(all_interfaces):
|
||||||
"""
|
"""
|
||||||
An interface should revalidate with the output of its initial validation
|
An interface should revalidate with the output of its initial validation
|
||||||
|
|
||||||
|
See: https://github.com/p2p-ld/numpydantic/pull/14
|
||||||
"""
|
"""
|
||||||
_ = type(all_interfaces)(array=all_interfaces.array)
|
_ = type(all_interfaces)(array=all_interfaces.array)
|
||||||
|
|
Loading…
Reference in a new issue