aboutsummaryrefslogtreecommitdiffstats
path: root/bsie
diff options
context:
space:
mode:
authorMatthias Baumgartner <dev@igsor.net>2022-10-31 13:05:43 +0100
committerMatthias Baumgartner <dev@igsor.net>2022-10-31 13:05:43 +0100
commitd4023fa972af379a4235f51783954671de974372 (patch)
tree065afefdb28d6a16350af750da002397a7e298f8 /bsie
parentce848b215086bd8d0f3e67a25a08239386b11ddb (diff)
parent068b3651c16916877eb8d5fdfec52485a507e204 (diff)
downloadbsie-d4023fa972af379a4235f51783954671de974372.tar.gz
bsie-d4023fa972af379a4235f51783954671de974372.tar.bz2
bsie-d4023fa972af379a4235f51783954671de974372.zip
Merge branch 'mb/readers' into develop
Diffstat (limited to 'bsie')
-rw-r--r--bsie/reader/__init__.py19
-rw-r--r--bsie/reader/path.py31
-rw-r--r--bsie/reader/stat.py34
3 files changed, 84 insertions, 0 deletions
diff --git a/bsie/reader/__init__.py b/bsie/reader/__init__.py
new file mode 100644
index 0000000..a45f22b
--- /dev/null
+++ b/bsie/reader/__init__.py
@@ -0,0 +1,19 @@
+"""The Reader classes return high-level content structures from files.
+
+The Reader fulfills two purposes:
+ First, it brokers between multiple libraries and file formats.
+ Second, it separates multiple aspects of a file into distinct content types.
+
+Often, different libraries focus on reading different types of content from a
+file. E.g. one would use different modules to read file system infos than to
+read exif or pixel data of an image. Hence, this module is organized by content
+type. Each distinct type can be implemented in a file or submodule that
+provides a Reader implementation. Through utilization of submodules, different
+file formats can be supported.
+
+Part of the bsie module.
+A copy of the license is provided with the project.
+Author: Matthias Baumgartner, 2022
+"""
+
+## EOF ##
diff --git a/bsie/reader/path.py b/bsie/reader/path.py
new file mode 100644
index 0000000..d27c664
--- /dev/null
+++ b/bsie/reader/path.py
@@ -0,0 +1,31 @@
+"""The Path reader produces a file path.
+
+Part of the bsie module.
+A copy of the license is provided with the project.
+Author: Matthias Baumgartner, 2022
+"""
+# imports
+import os
+import typing
+
+# inner-module imports
+from bsie.base import reader
+
+# exports
+__all__: typing.Sequence[str] = (
+ 'Path',
+ )
+
+
+## code ##
+
+class Path(reader.Reader):
+ """Return the path."""
+
+ CONTENT_TYPE = typing.Union[str]
+
+ def __call__(self, path: str) -> CONTENT_TYPE:
+ return path
+
+
+## EOF ##
diff --git a/bsie/reader/stat.py b/bsie/reader/stat.py
new file mode 100644
index 0000000..f0b83fb
--- /dev/null
+++ b/bsie/reader/stat.py
@@ -0,0 +1,34 @@
+"""The Stat reader produces filesystem stat information.
+
+Part of the bsie module.
+A copy of the license is provided with the project.
+Author: Matthias Baumgartner, 2022
+"""
+# imports
+import os
+import typing
+
+# inner-module imports
+from bsie.base import reader, errors
+
+# exports
+__all__: typing.Sequence[str] = (
+ 'Stat',
+ )
+
+
+## code ##
+
+class Stat(reader.Reader):
+ """Read and return the filesystem's stat infos."""
+
+ CONTENT_TYPE = typing.Union[os.stat_result]
+
+ def __call__(self, path: str) -> CONTENT_TYPE:
+ try:
+ return os.stat(path)
+ except Exception:
+ raise errors.ReaderError(path)
+
+
+## EOF ##