General purpose utility library
Project description
haggis
This is a library of general purpose utility functions and classes written in Python. Much of this code is intended to support the imprint project https://gitlab.com/madphysicist/imprint. The modules of this library are more-or-less standalone utilities, organized by category.
This library contains plenty of code that relies on external programs and less common Python libraries. The code is considered to be "extras", in the setuptools sense. Extras can be omitted without any modification to the python code. The following extras are supported:
- [docx]: Support for docx file utilities requires python-docx to be installed.
- [latex]: Supporting LaTeX requires a host of external programs to work properly, so this feature is optional. See the dependency page in the main documentation for more information.
- [pdf]: Requires the poppler library to be installed.
- [ps]: Requires GhostScript to be installed.
- [plot]: Plotting tools require matplotlib, which is a heavy dependency, and unnecessary for many purposes.
- [qt]: Some optional utilities for pyqt6 are provided if it is installed. Since this a heavy dependency, they are quite optional.
- [term]: Terminal colors work out of the box on Linux, but require the colorama library to work on Windows.
- [scio]: Science I/O depends on the scipy and astropy libraries to deliver IDL and FITS file support, respectively.
- [xlsx]: Support for xlsx file utilities requires openpyxl to be installed.
To install extras such as latex and pdf, do:
pip install haggis[latex,pdf]
See the documentation at https://haggis.readthedocs.io/en/latest for more information, including the API documentation.
This library is licensed under the AGPLv3, and compatible with later versions. You should have received a copy of the GNU Affero General Public License along with this program. If not, see https://www.gnu.org/licenses/.
Changelog
0.14.1 (2024-10-17)
- Fixes:
configuration.JSONConfiguration
outputs newlines at end of file- Improved formatting of multi-line
configuration.NumpyObject
0.14.0 (2024-07-15)
- New class:
- args.StoreVariableNargs
- API change:
recipes.islast
has a new attribute,last
, containing the latest elementstring_util.format_list
acceptslast_sep
to allow for more natural outputstring_util.format_list
indent
defaults to zero
- New unit tests:
- tests.string_util.TestFormatList
- tests.test_recipes.TestIsLast
- tests.test_args.TestStoreVariableNargs
- Bugfixes:
- Missing raw-string identifiers in
tests.string_util.TestParseList
string_util.format_list
checks for invalid width
- Missing raw-string identifiers in
0.13.3 (2024-07-15)
- New functions:
- os.redirect_stderr
- os.redirect_stdout
- os.redirect_stream
- os.suppress_stderr
- os.suppress_stdout
- Bugfix:
logs.ReturnableStreamHandler
clears the previous line when it gets a line after a carriage return.
0.13.2 (2024-07-12)
- New class:
- logs.ReturnableStreamHandler
- API changes:
- New attribute
logs.RETURNABLE == "returnable"
- New keyword values in
logs.configure_logger
:log_stderr
accepts stringRETURNABLE
to useReturnableStreamHandler
when logginglog_stdout
accepts stringRETURNABLE
to useReturnableStreamHandler
when logging
- New attribute
0.13.1 (2024-07-11)
- Bugfix:
- Extra newlines printed in
configuraition.JSONConfiguration._pprint
- Extra newlines printed in
- Nominal Qt5 support in gui.qt
0.13.0 (2024-04-29)
- New modules and packages:
- gui package
- gui.qt
- New classes:
- gui.qt.ImageAspectLabel
0.12.1 (2024-06-24)
- Bufixes:
islast
does not crash on empty iterators
- Typo fixes in documentation
0.12.0 (2023-08-29)
- New functions and classes:
- string_util.parse_list
- string_util.parse_pair
- string_util.func_name
- New unit tests:
- tests.test_string_util.TestParsePair
- tests.test_string_util.TestParseList
0.11.0 (2023-08-29)
- Bugfixes:
- Setting correct
stacklevel
inlogs.add_logging_level
- Fixes to documentation of properties in
recipes.RangeBuilder
andtime.Stopwatch
- Counting tabs in prefix rather than entire string in
args.SmartHelpFormatter
- Setting correct
- API changes:
- New keywords in
string_util.horiz_cat
andstring_util.split_horiz_cat
.titles
: optional headings included with each columnheaders
: string or string generator to insert after the titlewidth
: minimum width to allow for each columnhsep
: header separator, similar tosep
, which it defaults to- Dropped
missing='missing'
option since it truncated anyway
- Renamed
recipes.shift_left
torecipes.shift_up
- New keywords in
- New unit tests:
- tests.test_string_util
- Added pytest-cov to required test dependencies
0.10.1 (2023-08-21)
- Fixes to test and documentation warnings
0.10.0 (2023-08-20)
- New modules:
- args
- New functions and classes:
- args.SmartHelpFormatter
- New unit tests:
- tests.test_args
0.9.2 (2023-08-20)
- Switched to trunk-based development
0.9.1 (2023-03-26)
- Migrated to GitLab hosting
0.9.0 (2023-03-15)
- New functions and classes:
- logs.add_detail_level
- Bugfixes:
- Added missing default kwargs to monkeypatched version of logging.LogAdapter method in logs.add_log_level
- Updated bondary handling in npy_util.prune_mask
- logs.add_logging_level verifies exception info settings if prior calls are found
0.8.0 (2022-11-04)
- New functions and classes:
- recipes.chained_getter
- New unit tests:
- tests.test_logs.TestAddLoggingLevel
- tests.test_logs.TestResetHandlers
- tests.test_logs.TestLogMaxFilter
- tests.test_logs.TestMetaLoggableType
- tests.test_recipes.TestChainedGetter
- Bugfixes:
- Fixed sense of inclusive in logs.LogMaxFilter
- logs.add_logging_level updates logging.LoggerAdapter
0.7.1 (2022-10-24)
- New functions and classes:
- npy_util.prune_mask
0.7.0 (2022-10-17)
- New functions and classes:
- npy_util.masked_index
- npy_util.unmasked_index
- npy_util.find_peaks
- New unit tests:
- tests.test_npy_util.TestMaskedIndex
- tests.test_npy_util.TestUnmaskedIndex
- tests.test_npy_util.TestFindPeaks
0.6.0 (2022-10-11)
- API changes:
- Parameter stop in recipes.RangeBuilder.update is now optional
- Property span in recipes.RangeBuilder
- Bugfixes:
- Fixed handling of bulleted list styles in files.docx.list_number
0.5.0 (2022-06-17)
- New functions and classes:
- multiline_repr in string_util
- RangeBuilder in recipes
0.4.0 (2022-06-02)
- New functions and classes:
- npy_util.replace_field
- New unit tests:
- tests.test_npy_util.TestReplaceField
0.3.0 (2022-03-29)
- New functions and classes:
- load.load_module no longer nested in load.module_as_dict
- npy_util.iterate_dtype
- Bugfixes:
- files.PreOpenedFile object is now properly iterable
- New unit tests:
- tests.test_load.TestLoadModule
- tests.test_load.TestModuleAsDict
0.2.0 (2022-01-27)
- New modules:
- npy_util
- tests.test_numbers
- tests.test_objects
- New functions and classes:
- getsizeof, size_type_mapping in objects
- ndarray_handler added to size_type_mapping in objects
- isolate_dtype in npy_util
- as_base, digit_count in numbers
- New unit tests:
- tests.test_objects.TestGetsizeof
- tests.test_numbers.TestAsBase
- tests.test_numbers.TestDigitCount
- Added docs to sdist
- Moved map_array, mask2runs, runs2mask from math to npy_util
0.1.1 (2022-01-16)
Minor updates to first release.
- New functions and classes:
- segment_distance in math
- Bugfixes:
- math.read_divide correctly handles scalar inputs
- Created pytest configuration, added first set of unit tests
- files.tests.test_csv
- tests.test_math.TestSegmentDistance
- Improved documentation with autosummary
- Added this CHANGELOG to installed data
0.1 (2022-01-10)
First release.
- New modules
- time
- files.ui
- New functions and classes:
- json_registry made public in configuration
- semilogx_base, semilogy_base, loglog_base in mpl_util
- map_array, rms in math
- split_extension in files
- API changes:
- string_util.timestamp moved to time
- Added mask2runs and runs2mask to math
- Improvements to NumpyObject in configuration
- Improvements to copy_func in objects
- Added n argument to insert_suffix in files
- Bufixes:
- mpl_util.show_extents axis confusion
- Broken imports in submodules
- Officially supporting Python versions up to 3.10
- README -> README.md so GitHub can pick it up
0.1a2 (2021-01-09)
Second alpha release.
- Major additions to API
- New modules:
- threads
- configuration
- structures
- mapping
- ctypes_util
- New functions and classes:
- CloseableMixin in recipes
- to_hex, camel2snake, snake2camel, timestamp in string_util
- set_labels in mpl_utils
- real_divide, threshold, ang_diff_* in math
- API changes:
- Moved half of recipes to mapping
- Updated Namespace, (in mapping), added setdefaults
0.1a1 (2021-04-03)
First alpha release.
- API changes:
- SentinelType made public in root package
- ensure_extension.modes renamed to ensure_exntension.policies in files
0.1a1.dev2 (2019-03-31)
Second development pre-release.
- Major overhaul of documentation
0.1a1.dev1 (2019-03-20)
First development pre-release.
- First release on PyPI.
- Created Read the Docs pages.
- Only code required for imprint present initially.
- Documentation 90% complete.
- No tests worth speaking of.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file haggis-0.14.1.tar.gz
.
File metadata
- Download URL: haggis-0.14.1.tar.gz
- Upload date:
- Size: 179.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 16f1f9352107e398bbd87475f267ff7f8d7648f407014770b35862e8d14ff3c1 |
|
MD5 | 80c2ffe93e245ac20bd59317877c1986 |
|
BLAKE2b-256 | adc8832f5820c4967182ab341b8b868465b550a94bd9a16267025b24f938040f |
File details
Details for the file haggis-0.14.1-py3-none-any.whl
.
File metadata
- Download URL: haggis-0.14.1-py3-none-any.whl
- Upload date:
- Size: 221.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7962ce71bb0b40c3d81342f8083e256895c122c96cf166b7d120317a107f290a |
|
MD5 | 568b1e13a6cf9160564661c3154f04b0 |
|
BLAKE2b-256 | 3a114d86aca86b85493ef50c029f9aa155cb8013234b8eee124ff9d7877877dd |