abstract-utilities 0.2.2.430__tar.gz → 0.2.2.432__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.

Potentially problematic release.


This version of abstract-utilities might be problematic. Click here for more details.

Files changed (88) hide show
  1. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/PKG-INFO +1 -1
  2. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/setup.py +1 -1
  3. abstract_utilities-0.2.2.432/src/abstract_utilities/file_utils/file_utils/file_utils.py +213 -0
  4. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/imports/classes.py +1 -1
  5. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/imports/imports.py +2 -1
  6. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/imports/module_imports.py +1 -1
  7. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities.egg-info/PKG-INFO +1 -1
  8. abstract_utilities-0.2.2.430/src/abstract_utilities/file_utils/file_utils/file_utils.py +0 -207
  9. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/README.md +0 -0
  10. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/pyproject.toml +0 -0
  11. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/setup.cfg +0 -0
  12. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/__init__.py +0 -0
  13. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/abstract_classes.py +0 -0
  14. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/class_utils.py +0 -0
  15. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/cmd_utils/__init__.py +0 -0
  16. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/cmd_utils/cmd_utils.py +0 -0
  17. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/cmd_utils/imports/__init__.py +0 -0
  18. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/cmd_utils/imports/imports.py +0 -0
  19. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/cmd_utils/pexpect_utils.py +0 -0
  20. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/cmd_utils/user_utils.py +0 -0
  21. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/collator_utils.py +0 -0
  22. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/compare_utils/__init__.py +0 -0
  23. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/compare_utils/best_match.py +0 -0
  24. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/compare_utils/compare_utils.py +0 -0
  25. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/compare_utils/find_value.py +0 -0
  26. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/doit.py +0 -0
  27. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/dynimport.py +0 -0
  28. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/env_utils/__init__.py +0 -0
  29. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/env_utils/abstractEnv.py +0 -0
  30. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/env_utils/envy_it.py +0 -0
  31. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/env_utils/imports/__init__.py +0 -0
  32. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/env_utils/imports/imports.py +0 -0
  33. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/env_utils/imports/utils.py +0 -0
  34. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/error_utils.py +0 -0
  35. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/__init__.py +0 -0
  36. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/file_utils/__init__.py +0 -0
  37. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/file_utils/file_filters.py +0 -0
  38. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/file_utils/file_reader.py +0 -0
  39. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/file_utils/filter_params.py +0 -0
  40. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/file_utils/imports.py +0 -0
  41. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/file_utils/map_utils.py +0 -0
  42. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/file_utils/pdf_utils.py +0 -0
  43. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/imports/__init__.py +0 -0
  44. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/imports/constants.py +0 -0
  45. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/imports/file_functions.py +0 -0
  46. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/file_utils/req.py +0 -0
  47. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/global_utils.py +0 -0
  48. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/hash_utils.py +0 -0
  49. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/history_utils.py +0 -0
  50. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/json_utils.py +0 -0
  51. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/list_utils.py +0 -0
  52. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/log_utils.py +0 -0
  53. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/math_utils.py +0 -0
  54. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/parse_utils.py +0 -0
  55. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/path_utils.py +0 -0
  56. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/read_write_utils.py +0 -0
  57. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_reader/__init__.py +0 -0
  58. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_reader/file_reader2.py +0 -0
  59. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_reader/file_readers.py +0 -0
  60. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_reader/imports/__init__.py +0 -0
  61. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_reader/imports/imports.py +0 -0
  62. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_reader/sadfsad.py +0 -0
  63. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_readers/__init__.py +0 -0
  64. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_readers/import_utils/__init__.py +0 -0
  65. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_readers/import_utils/dot_utils.py +0 -0
  66. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_readers/import_utils/function_utils.py +0 -0
  67. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_readers/import_utils/import_utils.py +0 -0
  68. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_readers/import_utils/impot_functions.py +0 -0
  69. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_readers/import_utils/safe_import_utils.py +0 -0
  70. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_readers/import_utils/sysroot_utils.py +0 -0
  71. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_readers/import_utils/utils.py +0 -0
  72. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_readers/imports.py +0 -0
  73. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/robust_readers/initFuncGen.py +0 -0
  74. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/ssh_utils/__init__.py +0 -0
  75. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/ssh_utils/classes.py +0 -0
  76. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/ssh_utils/imports.py +0 -0
  77. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/ssh_utils/pexpect_utils.py +0 -0
  78. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/ssh_utils/utils.py +0 -0
  79. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/string_clean.py +0 -0
  80. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/tetsts.py +0 -0
  81. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/thread_utils.py +0 -0
  82. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/time_utils.py +0 -0
  83. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/type_utils.py +0 -0
  84. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities/utils.py +0 -0
  85. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities.egg-info/SOURCES.txt +0 -0
  86. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities.egg-info/dependency_links.txt +0 -0
  87. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities.egg-info/requires.txt +0 -0
  88. {abstract_utilities-0.2.2.430 → abstract_utilities-0.2.2.432}/src/abstract_utilities.egg-info/top_level.txt +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: abstract_utilities
3
- Version: 0.2.2.430
3
+ Version: 0.2.2.432
4
4
  Summary: abstract_utilities is a collection of utility modules providing a variety of functions to aid in tasks such as data comparison, list manipulation, JSON handling, string manipulation, mathematical computations, and time operations.
5
5
  Home-page: https://github.com/AbstractEndeavors/abstract_utilities
6
6
  Author: putkoff
@@ -4,7 +4,7 @@ with open("README.md", "r", encoding="utf-8") as fh:
4
4
  long_description = fh.read()
5
5
  setuptools.setup(
6
6
  name='abstract_utilities',
7
- version='0.2.2.430',
7
+ version='0.2.2.432',
8
8
  author='putkoff',
9
9
  author_email='partners@abstractendeavors.com',
10
10
  description='abstract_utilities is a collection of utility modules providing a variety of functions to aid in tasks such as data comparison, list manipulation, JSON handling, string manipulation, mathematical computations, and time operations.',
@@ -0,0 +1,213 @@
1
+ from pathlib import Path
2
+ from typing import *
3
+ import fnmatch, os, glob
4
+ from .filter_params import *
5
+ ##from abstract_utilities import make_list,get_media_exts, is_media_type
6
+ def get_allowed_predicate(allowed=None):
7
+ if allowed != False:
8
+ if allowed == True:
9
+ allowed = None
10
+ allowed = allowed or make_allowed_predicate()
11
+ else:
12
+ def allowed(*args):
13
+ return True
14
+ allowed = allowed
15
+ return allowed
16
+ def get_globs(items,recursive: bool = True,allowed=None):
17
+ glob_paths = []
18
+ items = [item for item in make_list(items) if item]
19
+ for item in items:
20
+ pattern = os.path.join(item, "**/*") # include all files recursively\n
21
+ nuItems = glob.glob(pattern, recursive=recursive)
22
+ if allowed:
23
+ nuItems = [nuItem for nuItem in nuItems if nuItem and allowed(nuItem)]
24
+ glob_paths += nuItems
25
+ return glob_paths
26
+ def get_allowed_files(items,allowed=True):
27
+ allowed = get_allowed_predicate(allowed=allowed)
28
+ return [item for item in items if item and os.path.isfile(item) and allowed(item)]
29
+ def get_allowed_dirs(items,allowed=False):
30
+ allowed = get_allowed_predicate(allowed=allowed)
31
+ return [item for item in items if item and os.path.isdir(item) and allowed(item)]
32
+
33
+ def get_filtered_files(items,allowed=None,files = []):
34
+ allowed = get_allowed_predicate(allowed=allowed)
35
+ glob_paths = get_globs(items)
36
+ return [glob_path for glob_path in glob_paths if glob_path and os.path.isfile(glob_path) and glob_path not in files and allowed(glob_path)]
37
+ def get_filtered_dirs(items,allowed=None,dirs = []):
38
+ allowed = get_allowed_predicate(allowed=allowed)
39
+ glob_paths = get_globs(items)
40
+ return [glob_path for glob_path in glob_paths if glob_path and os.path.isdir(glob_path) and glob_path not in dirs and allowed(glob_path)]
41
+
42
+ def get_all_allowed_files(items,allowed=None):
43
+ dirs = get_all_allowed_dirs(items)
44
+ files = get_allowed_files(items)
45
+ nu_files = []
46
+ for directory in dirs:
47
+ files += get_filtered_files(directory,allowed=allowed,files=files)
48
+ return files
49
+ def get_all_allowed_dirs(items,allowed=None):
50
+ allowed = get_allowed_predicate(allowed=allowed)
51
+ dirs = get_allowed_dirs(items)
52
+ nu_dirs=[]
53
+ for directory in dirs:
54
+ nu_dirs += get_filtered_dirs(directory,allowed=allowed,dirs=nu_dirs)
55
+ return nu_dirs
56
+ def get_files_and_dirs(
57
+ directory: str,
58
+ cfg: Optional["ScanConfig"] = None,
59
+ allowed_exts: Optional[Set[str]] = False,
60
+ unallowed_exts: Optional[Set[str]] = False,
61
+ exclude_types: Optional[Set[str]] = False,
62
+ exclude_dirs: Optional[List[str]] = False,
63
+ exclude_patterns: Optional[List[str]] = False,
64
+ add = False,
65
+ recursive: bool = True,
66
+ include_files: bool = True,
67
+ **kwargs
68
+ ):
69
+ cfg = cfg or define_defaults(
70
+ allowed_exts=allowed_exts,
71
+ unallowed_exts=unallowed_exts,
72
+ exclude_types=exclude_types,
73
+ exclude_dirs=exclude_dirs,
74
+ exclude_patterns=exclude_patterns,
75
+ add=add
76
+ )
77
+ allowed = make_allowed_predicate(cfg)
78
+ items=[]
79
+ files =[]
80
+ if recursive:
81
+ items = get_globs(directory,recursive=recursive,allowed=allowed)
82
+ else:
83
+ directories = make_list(directory)
84
+ for directory in directories:
85
+ items +=[os.path.join(directory,item) for item in os.listdir(directory)]
86
+ dirs = get_allowed_dirs(items,allowed=allowed)
87
+ if include_files:
88
+ files = get_allowed_files(items,allowed=allowed)
89
+ return dirs,files
90
+ def make_allowed_predicate(cfg: ScanConfig) -> Callable[[str], bool]:
91
+ def allowed(path: str) -> bool:
92
+ p = Path(path)
93
+ name = p.name.lower()
94
+ path_str = str(p).lower()
95
+ # A) directories
96
+ if cfg.exclude_dirs:
97
+ for dpat in cfg.exclude_dirs:
98
+ if dpat in path_str or fnmatch.fnmatch(name, dpat.lower()):
99
+ if p.is_dir() or dpat in path_str:
100
+ return False
101
+
102
+ if cfg.exclude_patterns:
103
+ # B) filename patterns
104
+ for pat in cfg.exclude_patterns:
105
+ if fnmatch.fnmatch(name, pat.lower()):
106
+ return False
107
+
108
+ # C) extension gates
109
+ if p.is_file():
110
+ ext = p.suffix.lower()
111
+ if (cfg.allowed_exts and ext not in cfg.allowed_exts) or (cfg.unallowed_exts and ext in cfg.unallowed_exts):
112
+ return False
113
+ return True
114
+ return allowed
115
+ def collect_filepaths(
116
+ directory: List[str],
117
+ cfg: ScanConfig=None,
118
+ allowed_exts: Optional[Set[str]] = False,
119
+ unallowed_exts: Optional[Set[str]] = False,
120
+ exclude_types: Optional[Set[str]] = False,
121
+ exclude_dirs: Optional[List[str]] = False,
122
+ exclude_patterns: Optional[List[str]] = False,
123
+ add=False,
124
+ allowed: Optional[Callable[[str], bool]] = None,
125
+ **kwargs
126
+ ) -> List[str]:
127
+ cfg = cfg or define_defaults(
128
+ allowed_exts=allowed_exts,
129
+ unallowed_exts=unallowed_exts,
130
+ exclude_types=exclude_types,
131
+ exclude_dirs=exclude_dirs,
132
+ exclude_patterns=exclude_patterns,
133
+ add = add
134
+ )
135
+ allowed = allowed or make_allowed_predicate(cfg)
136
+ directories = make_list(directory)
137
+ roots = [r for r in directories if r]
138
+
139
+ # your existing helpers (get_dirs, get_globs, etc.) stay the same
140
+ original_dirs = get_allowed_dirs(roots, allowed=allowed)
141
+ original_globs = get_globs(original_dirs)
142
+ files = get_allowed_files(original_globs, allowed=allowed)
143
+
144
+ for d in get_filtered_dirs(original_dirs, allowed=allowed):
145
+ files += get_filtered_files(d, allowed=allowed, files=files)
146
+
147
+ # de-dupe while preserving order
148
+ seen, out = set(), []
149
+ for f in files:
150
+ if f not in seen:
151
+ seen.add(f)
152
+ out.append(f)
153
+ return out
154
+
155
+
156
+ def _fast_walk(
157
+ root: Path,
158
+ exts: Iterable[str],
159
+ skip_dirs: Iterable[str] = (),
160
+ skip_patterns: Iterable[str] = (),
161
+ ) -> List[Path]:
162
+ exts = tuple(exts)
163
+ skip_dirs = set(sd.lower() for sd in skip_dirs or ())
164
+ skip_patterns = tuple(sp.lower() for sp in (skip_patterns or ()))
165
+
166
+ out = []
167
+ for p in root.rglob("*"):
168
+ # skip directories by name hit
169
+ if p.is_dir():
170
+ name = p.name.lower()
171
+ if name in skip_dirs:
172
+ # rglob doesn't let us prune mid-iteration cleanly; we just won't collect under it
173
+ continue
174
+ # nothing to collect for dirs
175
+ continue
176
+
177
+ # file filters
178
+ name = p.name.lower()
179
+ if any(fnmatch.fnmatch(name, pat) for pat in skip_patterns):
180
+ continue
181
+ if p.suffix.lower() in exts:
182
+ out.append(p)
183
+
184
+ # de-dup and normalize
185
+ return sorted({pp.resolve() for pp in out})
186
+
187
+
188
+ def enumerate_source_files(
189
+ src_root: Path,
190
+ cfg: Optional["ScanConfig"] = None,
191
+ *,
192
+ exts: Optional[Iterable[str]] = None,
193
+ fast_skip_dirs: Optional[Iterable[str]] = None,
194
+ fast_skip_patterns: Optional[Iterable[str]] = None,
195
+ ) -> List[Path]:
196
+ """
197
+ Unified enumerator:
198
+ - If `cfg` is provided: use collect_filepaths(...) with full rules.
199
+ - Else: fast walk using rglob over `exts` (defaults to EXTS) with optional light excludes.
200
+ """
201
+ src_root = Path(src_root)
202
+
203
+ if cfg is not None:
204
+ files = collect_filepaths([str(src_root)], cfg=cfg)
205
+ return sorted({Path(f).resolve() for f in files})
206
+
207
+ # Fast mode
208
+ return _fast_walk(
209
+ src_root,
210
+ exts or EXTS,
211
+ skip_dirs=fast_skip_dirs or (),
212
+ skip_patterns=fast_skip_patterns or (),
213
+ )
@@ -343,7 +343,7 @@ def normalize_items(
343
343
  ) -> List[tuple[PathBackend, str, dict]]:
344
344
  pairs: List[tuple[PathBackend, str, dict]] = []
345
345
  host = user_at_host or kwargs.get("host") or kwargs.get("user")
346
-
346
+ paths = make_list(paths)
347
347
  for item in paths:
348
348
  if not item:
349
349
  continue
@@ -8,6 +8,7 @@ from pdf2image import convert_from_path
8
8
  from dataclasses import dataclass, field
9
9
  from werkzeug.utils import secure_filename
10
10
  from werkzeug.datastructures import FileStorage
11
- import fnmatch, fnmatch,shlex, os, glob, platform, textwrap, pkgutil
11
+ import fnmatch, fnmatch,shlex, os, glob, platform, textwrap, pkgutil,time
12
12
  import tempfile,shutil,logging,ezodf,fnmatch,pytesseract,pdfplumber,re
13
13
  import textwrap, sys, types, importlib, importlib.util, inspect,PyPDF2
14
+
@@ -5,4 +5,4 @@ from ...ssh_utils import *
5
5
  from ...env_utils import *
6
6
  from ...read_write_utils import *
7
7
  from ...abstract_classes import SingletonMeta
8
-
8
+ from ...log_utils import get_logFile
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: abstract_utilities
3
- Version: 0.2.2.430
3
+ Version: 0.2.2.432
4
4
  Summary: abstract_utilities is a collection of utility modules providing a variety of functions to aid in tasks such as data comparison, list manipulation, JSON handling, string manipulation, mathematical computations, and time operations.
5
5
  Home-page: https://github.com/AbstractEndeavors/abstract_utilities
6
6
  Author: putkoff
@@ -1,207 +0,0 @@
1
- from .imports import *
2
- # -------- Public API drop-ins that mirror your originals --------
3
- from .filter_params import *
4
- from .file_filters import *
5
- # -------------------------------------------------------------
6
- # Wrapper: respects your original API and naming conventions
7
- # -------------------------------------------------------------
8
-
9
- def get_allowed_predicate(allowed=None):
10
- if allowed is not False:
11
- if allowed is True:
12
- allowed = None
13
- allowed = allowed or make_allowed_predicate()
14
- else:
15
- def allowed(*args):
16
- return True
17
- return allowed
18
-
19
-
20
- # -------------------------------------------------------------
21
- # Remote-aware globbing
22
- # -------------------------------------------------------------
23
- def get_globs(items, recursive: bool = True, allowed=None, **kwargs):
24
- """
25
- Behaves like your original get_globs(), but can traverse both
26
- local and remote paths transparently via normalize_items().
27
- """
28
- glob_paths = []
29
- roots = [p for p in make_list(items) if p]
30
-
31
- kwargs.setdefault("mindepth", 0)
32
- if not recursive:
33
- kwargs.setdefault("maxdepth", 1)
34
-
35
- for fs, root, _ in normalize_items(roots, **kwargs):
36
- # use the backend's recursive walker
37
- nu_items = fs.glob_recursive(root, **kwargs)
38
- if allowed:
39
-
40
- nu_items = [n for n in nu_items if n and allowed(n)]
41
-
42
- glob_paths += nu_items
43
- return glob_paths
44
-
45
-
46
- # -------------------------------------------------------------
47
- # Allowed filters
48
- # -------------------------------------------------------------
49
- def get_allowed_files(items, allowed=True, **kwargs):
50
- allowed = get_allowed_predicate(allowed=allowed)
51
- out = []
52
- for fs, item, _ in normalize_items(items, **kwargs):
53
- if fs.isfile(item) and allowed(item):
54
- out.append(item)
55
- return out
56
-
57
-
58
- def get_allowed_dirs(items, allowed=False, **kwargs):
59
- allowed = get_allowed_predicate(allowed=allowed)
60
- out = []
61
- for fs, item, _ in normalize_items(items, **kwargs):
62
- if fs.isdir(item) and allowed(item):
63
- out.append(item)
64
- return out
65
-
66
-
67
- # -------------------------------------------------------------
68
- # Filtered sets
69
- # -------------------------------------------------------------
70
- def get_filtered_files(items, allowed=None, files=None, **kwargs):
71
- allowed = get_allowed_predicate(allowed=allowed)
72
- files = set(files or [])
73
- out = []
74
- for fs, root, _ in normalize_items(items, **kwargs):
75
- for p in fs.glob_recursive(root, **kwargs):
76
- if p in files:
77
- continue
78
- if allowed(p) and fs.isfile(p):
79
- out.append(p)
80
- return out
81
-
82
-
83
- def get_filtered_dirs(items, allowed=None, dirs=None, **kwargs):
84
- allowed = get_allowed_predicate(allowed=allowed)
85
- dirs = set(dirs or [])
86
- out = []
87
- for fs, root, _ in normalize_items(items, **kwargs):
88
- for p in fs.glob_recursive(root, **kwargs):
89
- if p in dirs:
90
- continue
91
- if allowed(p) and fs.isdir(p):
92
- out.append(p)
93
- return out
94
-
95
-
96
- # -------------------------------------------------------------
97
- # Recursive expansion
98
- # -------------------------------------------------------------
99
- def get_all_allowed_files(items, allowed=None, **kwargs):
100
- dirs = get_all_allowed_dirs(items, allowed=allowed, **kwargs)
101
- files = get_allowed_files(items, allowed=allowed, **kwargs)
102
- seen = set(files)
103
- for fs, directory, _ in normalize_items(dirs, **kwargs):
104
- for p in fs.glob_recursive(directory, **kwargs):
105
- if p in seen:
106
- continue
107
- if allowed and not allowed(p):
108
- continue
109
- if fs.isfile(p):
110
- files.append(p)
111
- seen.add(p)
112
- return files
113
-
114
-
115
- def get_all_allowed_dirs(items, allowed=None, **kwargs):
116
- allowed = get_allowed_predicate(allowed=allowed)
117
- out = []
118
- seen = set()
119
- for fs, root, _ in normalize_items(items, **kwargs):
120
- if fs.isdir(root) and allowed(root):
121
- out.append(root)
122
- seen.add(root)
123
- for p in fs.glob_recursive(root, **kwargs):
124
- if p in seen:
125
- continue
126
- if allowed(p) and fs.isdir(p):
127
- out.append(p)
128
- seen.add(p)
129
- return out
130
-
131
-
132
- # -------------------------------------------------------------
133
- # Unified directory scan
134
- # -------------------------------------------------------------
135
- def get_files_and_dirs(
136
- directory: str,
137
- cfg: Optional["ScanConfig"] = None,
138
- allowed_exts: Optional[Set[str]] = False,
139
- unallowed_exts: Optional[Set[str]] = False,
140
- exclude_types: Optional[Set[str]] = False,
141
- exclude_dirs: Optional[List[str]] = False,
142
- exclude_patterns: Optional[List[str]] = False,
143
- add=False,
144
- recursive: bool = True,
145
- include_files: bool = True,
146
- **kwargs
147
- ):
148
- """
149
- Same public signature as your original get_files_and_dirs(),
150
- but powered by backend objects (LocalFS or SSHFS).
151
- """
152
- cfg = cfg or define_defaults(
153
- allowed_exts=allowed_exts,
154
- unallowed_exts=unallowed_exts,
155
- exclude_types=exclude_types,
156
- exclude_dirs=exclude_dirs,
157
- exclude_patterns=exclude_patterns,
158
- add=add
159
- )
160
- allowed = make_allowed_predicate(cfg)
161
- items = []
162
- files = []
163
- if recursive:
164
- items = get_globs(directory, recursive=recursive, allowed=allowed, **kwargs)
165
- else:
166
- for fs, base, _ in normalize_items(make_list(directory), **kwargs):
167
- try:
168
- items += [fs.join(base, name) for name in fs.listdir(base)]
169
- except Exception:
170
- pass
171
-
172
- dirs = get_allowed_dirs(items, allowed=allowed, **kwargs)
173
- if include_files:
174
- files = get_allowed_files(items, allowed=allowed, **kwargs)
175
- return dirs, files
176
-
177
-
178
- # -------------------------------------------------------------
179
- # Unchanged predicate builder
180
- # -------------------------------------------------------------
181
- def make_allowed_predicate(cfg: ScanConfig) -> Callable[[str], bool]:
182
- def allowed(path: str) -> bool:
183
- p = Path(path)
184
- name = p.name.lower()
185
- path_str = str(p).lower()
186
-
187
- # A) directory exclusions
188
- if cfg.exclude_dirs:
189
- for dpat in cfg.exclude_dirs:
190
- if dpat in path_str or fnmatch.fnmatch(name, dpat.lower()):
191
- if p.is_dir() or dpat in path_str:
192
- return False
193
-
194
- # B) filename pattern exclusions
195
- if cfg.exclude_patterns:
196
- for pat in cfg.exclude_patterns:
197
- if fnmatch.fnmatch(name, pat.lower()):
198
- return False
199
-
200
- # C) extension gates
201
- if p.is_file():
202
- ext = p.suffix.lower()
203
- if (cfg.allowed_exts and ext not in cfg.allowed_exts) or \
204
- (cfg.unallowed_exts and ext in cfg.unallowed_exts):
205
- return False
206
- return True
207
- return allowed