wexample-filestate-python 6.5.0__tar.gz → 6.7.0__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (87) hide show
  1. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/PKG-INFO +161 -2
  2. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/README.md +159 -0
  3. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/pyproject.toml +2 -2
  4. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/format_option.py +5 -0
  5. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/cst_cache.py +0 -0
  6. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/__init__.py +0 -0
  7. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/__pycache__/__init__.py +0 -0
  8. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/common/__init__.py +0 -0
  9. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/common/__pycache__/__init__.py +0 -0
  10. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/common/pipy_gateway.py +0 -0
  11. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/config_option/__init__.py +0 -0
  12. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/config_option/__pycache__/__init__.py +0 -0
  13. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/config_option/mixin/__init__.py +0 -0
  14. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/config_option/mixin/__pycache__/__init__.py +0 -0
  15. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/config_option/mixin/with_stdout_wrapping_mixin.py +0 -0
  16. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/config_value/__init__.py +0 -0
  17. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/config_value/__pycache__/__init__.py +0 -0
  18. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/config_value/python_config_value.py +0 -0
  19. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/const/__init__.py +0 -0
  20. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/const/__pycache__/__init__.py +0 -0
  21. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/const/name_pattern.py +0 -0
  22. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/const/path.py +0 -0
  23. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/const/python_file.py +0 -0
  24. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/event/__init__.py +0 -0
  25. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/event/src/__init__.py +0 -0
  26. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/event/src/wexample_event/__init__.py +0 -0
  27. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/file/__init__.py +0 -0
  28. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/file/__pycache__/__init__.py +0 -0
  29. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/file/python_file.py +0 -0
  30. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/helpers/__init__.py +0 -0
  31. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/helpers/__pycache__/__init__.py +0 -0
  32. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/helpers/package.py +0 -0
  33. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/helpers/python/__init__.py +0 -0
  34. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/helpers/toml.py +0 -0
  35. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/__init__.py +0 -0
  36. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/__pycache__/__init__.py +0 -0
  37. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/__init__.py +0 -0
  38. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/abstract_python_file_content_option.py +0 -0
  39. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/add_future_annotations_option.py +0 -0
  40. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/add_return_types_option.py +0 -0
  41. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/class_name_matches_file_name_option.py +0 -0
  42. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/fix_attrs_option.py +0 -0
  43. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/fix_blank_lines_option.py +0 -0
  44. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/fstringify_option.py +0 -0
  45. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/modernize_typing_option.py +0 -0
  46. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/order_class_attributes_option.py +0 -0
  47. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/order_class_docstring_option.py +0 -0
  48. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/order_class_methods_option.py +0 -0
  49. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/order_constants_option.py +0 -0
  50. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/order_iterable_items_option.py +0 -0
  51. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/order_main_guard_option.py +0 -0
  52. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/order_module_docstring_option.py +0 -0
  53. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/order_module_functions_option.py +0 -0
  54. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/order_module_metadata_option.py +0 -0
  55. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/order_type_checking_block_option.py +0 -0
  56. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/relocate_imports_option.py +0 -0
  57. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/remove_unused_option.py +0 -0
  58. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/sort_imports_option.py +0 -0
  59. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python/unquote_annotations_option.py +0 -0
  60. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/option/python_option.py +0 -0
  61. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/options_provider/__init__.py +0 -0
  62. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/options_provider/__pycache__/__init__.py +0 -0
  63. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/options_provider/python_options_provider.py +0 -0
  64. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/py.typed +0 -0
  65. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/__init__.py +0 -0
  66. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/__pycache__/__init__.py +0 -0
  67. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/python_attrs_utils.py +0 -0
  68. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/python_blank_lines_utils.py +0 -0
  69. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/python_class_attributes_utils.py +0 -0
  70. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/python_class_docstring_utils.py +0 -0
  71. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/python_class_methods_utils.py +0 -0
  72. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/python_constants_utils.py +0 -0
  73. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/python_docstring_utils.py +0 -0
  74. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/python_functions_utils.py +0 -0
  75. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/python_iterable_utils.py +0 -0
  76. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/python_main_guard_utils.py +0 -0
  77. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/python_module_metadata_utils.py +0 -0
  78. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/python_type_checking_utils.py +0 -0
  79. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/relocate_imports/__init__.py +0 -0
  80. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/relocate_imports/__pycache__/__init__.py +0 -0
  81. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/relocate_imports/python_import_rewriter.py +0 -0
  82. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/relocate_imports/python_localize_runtime_imports.py +0 -0
  83. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/relocate_imports/python_parser_import_index.py +0 -0
  84. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/relocate_imports/python_runtime_symbol_collector.py +0 -0
  85. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/src/wexample_filestate_python/utils/relocate_imports/python_usage_collector.py +0 -0
  86. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/tests/tests/__init__.py +0 -0
  87. {wexample_filestate_python-6.5.0 → wexample_filestate_python-6.7.0}/tests/wexample_tests/__init__.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: wexample-filestate-python
3
- Version: 6.5.0
3
+ Version: 6.7.0
4
4
  Summary: Helpers for Python.
5
5
  Author-Email: weeger <contact@wexample.com>
6
6
  License: MIT
@@ -20,7 +20,7 @@ Requires-Dist: packaging
20
20
  Requires-Dist: pyupgrade
21
21
  Requires-Dist: tomli
22
22
  Requires-Dist: wexample-api>=6.1.0
23
- Requires-Dist: wexample-filestate>=9.0.0
23
+ Requires-Dist: wexample-filestate>=11.1.0
24
24
  Provides-Extra: dev
25
25
  Requires-Dist: pytest; extra == "dev"
26
26
  Requires-Dist: pytest-cov; extra == "dev"
@@ -28,6 +28,135 @@ Description-Content-Type: text/markdown
28
28
 
29
29
  # filestate_python
30
30
 
31
+ Version: 6.7.0
32
+
33
+ Helpers for Python.
34
+
35
+ ## Table of Contents
36
+
37
+ - [Tests](#tests)
38
+ - [Suite Integration](#suite-integration)
39
+ - [Dependencies](#dependencies)
40
+ - [Versioning](#versioning)
41
+ - [License](#license)
42
+ - [Suite Integration](#suite-integration)
43
+ - [Suite Signature](#suite-signature)
44
+ - [Introduction](#introduction)
45
+ - [Roadmap](#roadmap)
46
+ - [Status Compatibility](#status-compatibility)
47
+ - [Useful Links](#useful-links)
48
+ - [Migration Notes](#migration-notes)
49
+
50
+ ## Tests
51
+
52
+ This project uses `pytest` for testing and `pytest-cov` for code coverage analysis.
53
+
54
+ ### Installation
55
+
56
+ First, install the required testing dependencies:
57
+ ```bash
58
+ .venv/bin/python -m pip install pytest pytest-cov
59
+ ```
60
+
61
+ ### Basic Usage
62
+
63
+ Run all tests with coverage:
64
+ ```bash
65
+ .venv/bin/python -m pytest --cov --cov-report=html
66
+ ```
67
+
68
+ ### Common Commands
69
+ ```bash
70
+ # Run tests with coverage for a specific module
71
+ .venv/bin/python -m pytest --cov=your_module
72
+
73
+ # Show which lines are not covered
74
+ .venv/bin/python -m pytest --cov=your_module --cov-report=term-missing
75
+
76
+ # Generate an HTML coverage report
77
+ .venv/bin/python -m pytest --cov=your_module --cov-report=html
78
+
79
+ # Combine terminal and HTML reports
80
+ .venv/bin/python -m pytest --cov=your_module --cov-report=term-missing --cov-report=html
81
+
82
+ # Run specific test file with coverage
83
+ .venv/bin/python -m pytest tests/test_file.py --cov=your_module --cov-report=term-missing
84
+ ```
85
+
86
+ ### Viewing HTML Reports
87
+
88
+ After generating an HTML report, open `htmlcov/index.html` in your browser to view detailed line-by-line coverage information.
89
+
90
+ ### Coverage Threshold
91
+
92
+ To enforce a minimum coverage percentage:
93
+ ```bash
94
+ .venv/bin/python -m pytest --cov=your_module --cov-fail-under=80
95
+ ```
96
+
97
+ This will cause the test suite to fail if coverage drops below 80%.
98
+
99
+ ## Integration in the Suite
100
+
101
+ This package is part of the Wexample Suite — a collection of high-quality, modular tools designed to work seamlessly together across multiple languages and environments.
102
+
103
+ ### Related Packages
104
+
105
+ The suite includes packages for configuration management, file handling, prompts, and more. Each package can be used independently or as part of the integrated suite.
106
+
107
+ Visit the [Wexample Suite documentation](https://docs.wexample.com) for the complete package ecosystem.
108
+
109
+ ## Dependencies
110
+
111
+ - attrs: >=23.1.0
112
+ - autoflake:
113
+ - black:
114
+ - cattrs: >=23.1.0
115
+ - flynt:
116
+ - isort:
117
+ - libcst:
118
+ - packaging:
119
+ - pyupgrade:
120
+ - tomli:
121
+ - wexample-api: >=6.1.0
122
+ - wexample-filestate: >=11.1.0
123
+
124
+ ## Versioning & Compatibility Policy
125
+
126
+ Wexample packages follow **Semantic Versioning** (SemVer):
127
+
128
+ - **MAJOR**: Breaking changes
129
+ - **MINOR**: New features, backward compatible
130
+ - **PATCH**: Bug fixes, backward compatible
131
+
132
+ We maintain backward compatibility within major versions and provide clear migration guides for breaking changes.
133
+
134
+ ## License
135
+
136
+ This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.
137
+
138
+ Free to use in both personal and commercial projects.
139
+
140
+ ## Integration in the Suite
141
+
142
+ This package is part of the Wexample Suite — a collection of high-quality, modular tools designed to work seamlessly together across multiple languages and environments.
143
+
144
+ ### Related Packages
145
+
146
+ The suite includes packages for configuration management, file handling, prompts, and more. Each package can be used independently or as part of the integrated suite.
147
+
148
+ Visit the [Wexample Suite documentation](https://docs.wexample.com) for the complete package ecosystem.
149
+
150
+ # About us
151
+
152
+ [Wexample](https://wexample.com) stands as a cornerstone of the digital ecosystem — a collective of seasoned engineers, researchers, and creators driven by a relentless pursuit of technological excellence. More than a media platform, it has grown into a vibrant community where innovation meets craftsmanship, and where every line of code reflects a commitment to clarity, durability, and shared intelligence.
153
+
154
+ This packages suite embodies this spirit. Trusted by professionals and enthusiasts alike, it delivers a consistent, high-quality foundation for modern development — open, elegant, and battle-tested. Its reputation is built on years of collaboration, refinement, and rigorous attention to detail, making it a natural choice for those who demand both robustness and beauty in their tools.
155
+
156
+ Wexample cultivates a culture of mastery. Each package, each contribution carries the mark of a community that values precision, ethics, and innovation — a community proud to shape the future of digital craftsmanship.
157
+
158
+ # filestate_python
159
+
31
160
  Version: 6.5.0
32
161
 
33
162
  Helpers for Python.
@@ -342,3 +471,33 @@ See the [project roadmap](https://github.com/wexample/python-filestate_python/is
342
471
  When upgrading between major versions, refer to the migration guides in the documentation.
343
472
 
344
473
  Breaking changes are clearly documented with upgrade paths and examples.
474
+
475
+ ## Known Limitations & Roadmap
476
+
477
+ Current limitations and planned features are tracked in the GitHub issues.
478
+
479
+ See the [project roadmap](https://github.com/wexample/python-filestate_python/issues) for upcoming features and improvements.
480
+
481
+ ## Status & Compatibility
482
+
483
+ **Maturity**: Production-ready
484
+
485
+ **Python Support**: >=3.10
486
+
487
+ **OS Support**: Linux, macOS, Windows
488
+
489
+ **Status**: Actively maintained
490
+
491
+ ## Useful Links
492
+
493
+ - **Homepage**: https://github.com/wexample/python-filestate-python
494
+ - **Documentation**: [docs.wexample.com](https://docs.wexample.com)
495
+ - **Issue Tracker**: https://github.com/wexample/python-filestate-python/issues
496
+ - **Discussions**: https://github.com/wexample/python-filestate-python/discussions
497
+ - **PyPI**: [pypi.org/project/filestate_python](https://pypi.org/project/filestate_python/)
498
+
499
+ ## Migration Notes
500
+
501
+ When upgrading between major versions, refer to the migration guides in the documentation.
502
+
503
+ Breaking changes are clearly documented with upgrade paths and examples.
@@ -1,5 +1,134 @@
1
1
  # filestate_python
2
2
 
3
+ Version: 6.7.0
4
+
5
+ Helpers for Python.
6
+
7
+ ## Table of Contents
8
+
9
+ - [Tests](#tests)
10
+ - [Suite Integration](#suite-integration)
11
+ - [Dependencies](#dependencies)
12
+ - [Versioning](#versioning)
13
+ - [License](#license)
14
+ - [Suite Integration](#suite-integration)
15
+ - [Suite Signature](#suite-signature)
16
+ - [Introduction](#introduction)
17
+ - [Roadmap](#roadmap)
18
+ - [Status Compatibility](#status-compatibility)
19
+ - [Useful Links](#useful-links)
20
+ - [Migration Notes](#migration-notes)
21
+
22
+ ## Tests
23
+
24
+ This project uses `pytest` for testing and `pytest-cov` for code coverage analysis.
25
+
26
+ ### Installation
27
+
28
+ First, install the required testing dependencies:
29
+ ```bash
30
+ .venv/bin/python -m pip install pytest pytest-cov
31
+ ```
32
+
33
+ ### Basic Usage
34
+
35
+ Run all tests with coverage:
36
+ ```bash
37
+ .venv/bin/python -m pytest --cov --cov-report=html
38
+ ```
39
+
40
+ ### Common Commands
41
+ ```bash
42
+ # Run tests with coverage for a specific module
43
+ .venv/bin/python -m pytest --cov=your_module
44
+
45
+ # Show which lines are not covered
46
+ .venv/bin/python -m pytest --cov=your_module --cov-report=term-missing
47
+
48
+ # Generate an HTML coverage report
49
+ .venv/bin/python -m pytest --cov=your_module --cov-report=html
50
+
51
+ # Combine terminal and HTML reports
52
+ .venv/bin/python -m pytest --cov=your_module --cov-report=term-missing --cov-report=html
53
+
54
+ # Run specific test file with coverage
55
+ .venv/bin/python -m pytest tests/test_file.py --cov=your_module --cov-report=term-missing
56
+ ```
57
+
58
+ ### Viewing HTML Reports
59
+
60
+ After generating an HTML report, open `htmlcov/index.html` in your browser to view detailed line-by-line coverage information.
61
+
62
+ ### Coverage Threshold
63
+
64
+ To enforce a minimum coverage percentage:
65
+ ```bash
66
+ .venv/bin/python -m pytest --cov=your_module --cov-fail-under=80
67
+ ```
68
+
69
+ This will cause the test suite to fail if coverage drops below 80%.
70
+
71
+ ## Integration in the Suite
72
+
73
+ This package is part of the Wexample Suite — a collection of high-quality, modular tools designed to work seamlessly together across multiple languages and environments.
74
+
75
+ ### Related Packages
76
+
77
+ The suite includes packages for configuration management, file handling, prompts, and more. Each package can be used independently or as part of the integrated suite.
78
+
79
+ Visit the [Wexample Suite documentation](https://docs.wexample.com) for the complete package ecosystem.
80
+
81
+ ## Dependencies
82
+
83
+ - attrs: >=23.1.0
84
+ - autoflake:
85
+ - black:
86
+ - cattrs: >=23.1.0
87
+ - flynt:
88
+ - isort:
89
+ - libcst:
90
+ - packaging:
91
+ - pyupgrade:
92
+ - tomli:
93
+ - wexample-api: >=6.1.0
94
+ - wexample-filestate: >=11.1.0
95
+
96
+ ## Versioning & Compatibility Policy
97
+
98
+ Wexample packages follow **Semantic Versioning** (SemVer):
99
+
100
+ - **MAJOR**: Breaking changes
101
+ - **MINOR**: New features, backward compatible
102
+ - **PATCH**: Bug fixes, backward compatible
103
+
104
+ We maintain backward compatibility within major versions and provide clear migration guides for breaking changes.
105
+
106
+ ## License
107
+
108
+ This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.
109
+
110
+ Free to use in both personal and commercial projects.
111
+
112
+ ## Integration in the Suite
113
+
114
+ This package is part of the Wexample Suite — a collection of high-quality, modular tools designed to work seamlessly together across multiple languages and environments.
115
+
116
+ ### Related Packages
117
+
118
+ The suite includes packages for configuration management, file handling, prompts, and more. Each package can be used independently or as part of the integrated suite.
119
+
120
+ Visit the [Wexample Suite documentation](https://docs.wexample.com) for the complete package ecosystem.
121
+
122
+ # About us
123
+
124
+ [Wexample](https://wexample.com) stands as a cornerstone of the digital ecosystem — a collective of seasoned engineers, researchers, and creators driven by a relentless pursuit of technological excellence. More than a media platform, it has grown into a vibrant community where innovation meets craftsmanship, and where every line of code reflects a commitment to clarity, durability, and shared intelligence.
125
+
126
+ This packages suite embodies this spirit. Trusted by professionals and enthusiasts alike, it delivers a consistent, high-quality foundation for modern development — open, elegant, and battle-tested. Its reputation is built on years of collaboration, refinement, and rigorous attention to detail, making it a natural choice for those who demand both robustness and beauty in their tools.
127
+
128
+ Wexample cultivates a culture of mastery. Each package, each contribution carries the mark of a community that values precision, ethics, and innovation — a community proud to shape the future of digital craftsmanship.
129
+
130
+ # filestate_python
131
+
3
132
  Version: 6.5.0
4
133
 
5
134
  Helpers for Python.
@@ -314,3 +443,33 @@ See the [project roadmap](https://github.com/wexample/python-filestate_python/is
314
443
  When upgrading between major versions, refer to the migration guides in the documentation.
315
444
 
316
445
  Breaking changes are clearly documented with upgrade paths and examples.
446
+
447
+ ## Known Limitations & Roadmap
448
+
449
+ Current limitations and planned features are tracked in the GitHub issues.
450
+
451
+ See the [project roadmap](https://github.com/wexample/python-filestate_python/issues) for upcoming features and improvements.
452
+
453
+ ## Status & Compatibility
454
+
455
+ **Maturity**: Production-ready
456
+
457
+ **Python Support**: >=3.10
458
+
459
+ **OS Support**: Linux, macOS, Windows
460
+
461
+ **Status**: Actively maintained
462
+
463
+ ## Useful Links
464
+
465
+ - **Homepage**: https://github.com/wexample/python-filestate-python
466
+ - **Documentation**: [docs.wexample.com](https://docs.wexample.com)
467
+ - **Issue Tracker**: https://github.com/wexample/python-filestate-python/issues
468
+ - **Discussions**: https://github.com/wexample/python-filestate-python/discussions
469
+ - **PyPI**: [pypi.org/project/filestate_python](https://pypi.org/project/filestate_python/)
470
+
471
+ ## Migration Notes
472
+
473
+ When upgrading between major versions, refer to the migration guides in the documentation.
474
+
475
+ Breaking changes are clearly documented with upgrade paths and examples.
@@ -6,7 +6,7 @@ build-backend = "pdm.backend"
6
6
 
7
7
  [project]
8
8
  name = "wexample-filestate-python"
9
- version = "6.5.0"
9
+ version = "6.7.0"
10
10
  description = "Helpers for Python."
11
11
  authors = [
12
12
  { name = "weeger", email = "contact@wexample.com" },
@@ -29,7 +29,7 @@ dependencies = [
29
29
  "pyupgrade",
30
30
  "tomli",
31
31
  "wexample-api>=6.1.0",
32
- "wexample-filestate>=9.0.0",
32
+ "wexample-filestate>=11.1.0",
33
33
  ]
34
34
 
35
35
  [project.readme]
@@ -34,6 +34,11 @@ class FormatOption(WithBatchOptionMixin, AbstractPythonFileContentOption):
34
34
  reference_target: TargetFileOrDirectoryType,
35
35
  paths: list[Path],
36
36
  ) -> None:
37
+ # Black is loaded lazily here. Thread-safety: dry_run()/apply() always
38
+ # call _prepare_options() before parallel inspection, which runs this
39
+ # method in the main thread first — so by the time worker threads run,
40
+ # the module is fully loaded and there is no concurrent first-import
41
+ # race on its lazy attribute table.
37
42
  import black
38
43
 
39
44
  mode = black.Mode(line_length=self._line_length)