mirror of
https://github.com/danielmiessler/Fabric.git
synced 2026-01-10 06:48:04 -05:00
feat: handle JSONDecodeError in load_existing_file gracefully
### CHANGES - Add JSONDecodeError handling with warning message. - Initialize with empty list on JSON decode failure. - Reorder pattern processing to reduce redundant logs. - Remove redundant directory check logging. - Ensure new pattern processing is logged correctly.
This commit is contained in:
@@ -11,8 +11,14 @@ import shutil
|
||||
def load_existing_file(filepath):
|
||||
"""Load existing JSON file or return default structure"""
|
||||
if os.path.exists(filepath):
|
||||
with open(filepath, "r", encoding="utf-8") as f:
|
||||
return json.load(f)
|
||||
try:
|
||||
with open(filepath, "r", encoding="utf-8") as f:
|
||||
return json.load(f)
|
||||
except json.JSONDecodeError:
|
||||
print(
|
||||
f"Warning: Malformed JSON in {filepath}. Starting with an empty list."
|
||||
)
|
||||
return {"patterns": []}
|
||||
return {"patterns": []}
|
||||
|
||||
|
||||
@@ -46,16 +52,13 @@ def extract_pattern_info():
|
||||
new_descriptions = []
|
||||
|
||||
for dirname in sorted(os.listdir(patterns_dir)):
|
||||
# Only log new pattern processing
|
||||
if dirname not in existing_extract_names:
|
||||
print(f"Processing new pattern: {dirname}")
|
||||
|
||||
pattern_path = os.path.join(patterns_dir, dirname)
|
||||
system_md_path = os.path.join(pattern_path, "system.md")
|
||||
print(f"Checking system.md at: {system_md_path}")
|
||||
|
||||
if os.path.isdir(pattern_path) and os.path.exists(system_md_path):
|
||||
print(f"Valid pattern directory found: {dirname}")
|
||||
if dirname not in existing_extract_names:
|
||||
print(f"Processing new pattern: {dirname}")
|
||||
|
||||
try:
|
||||
if dirname not in existing_extract_names:
|
||||
print(f"Creating new extract for: {dirname}")
|
||||
|
||||
Reference in New Issue
Block a user