Deduplication is applied in the following priority order:
DOI (primary)
Case-insensitive comparison after normalization.
Title + Year (secondary)
Title is normalized (e.g., whitespace/case normalization) and combined with year.
File hash (fallback)
Used only when DOI and Title+Year are unavailable.
The chosen rule is recorded in dedup_rule, and the computed key is stored in dedup_key.
Tagging Rules
All --tag values are always applied to imported records.
If metadata includes keywords, they are converted into tags and merged with manual tags.
File Organization Rules
Target path pattern:
<library>/files/<Year>/<Journal>/
Unknown values are mapped to:
UnknownYear, UnknownJournal
Filenames are preserved when possible; if a conflict occurs, a suffix is appended to avoid overwriting.
Security / Compliance Constraints
No network access is used or required.
No external APIs or credentials are used.
The tool only reads from the specified --source-dir.
The tool only writes within the specified --library-dir (no writes outside the library root).
When Not to Use
Do not use this skill when the required source data, identifiers, files, or credentials are missing.
Do not use this skill when the user asks for fabricated results, unsupported claims, or out-of-scope conclusions.
Do not use this skill when a simpler direct answer is more appropriate than the documented workflow.
Required Inputs
A clearly specified task goal aligned with the documented scope.
All required files, identifiers, parameters, or environment variables before execution.
Any domain constraints, formatting requirements, and expected output destination if applicable.
Recommended Workflow
Validate the request against the skill boundary and confirm all required inputs are present.
Select the documented execution path and prefer the simplest supported command or procedure.
Produce the expected output using the documented file format, schema, or narrative structure.
Run a final validation pass for completeness, consistency, and safety before returning the result.
Output Contract
Return a structured deliverable that is directly usable without reformatting.
If a file is produced, prefer a deterministic output name such as literature_management_result.md unless the skill documentation defines a better convention.
Include a short validation summary describing what was checked, what assumptions were made, and any remaining limitations.
Validation and Safety Rules
Validate required inputs before execution and stop early when mandatory fields or files are missing.
Do not fabricate measurements, references, findings, or conclusions that are not supported by the provided source material.
Emit a clear warning when credentials, privacy constraints, safety boundaries, or unsupported requests affect the result.
Keep the output safe, reproducible, and within the documented scope at all times.
Failure Handling
If validation fails, explain the exact missing field, file, or parameter and show the minimum fix required.
If an external dependency or script fails, surface the command path, likely cause, and the next recovery step.
If partial output is returned, label it clearly and identify which checks could not be completed.
Quick Validation
Run this minimal verification path before full execution when possible:
python scripts/import_library.py --help
Expected output format:
Result file: literature_management_result.md
Validation summary: PASS/FAIL with brief notes
Assumptions: explicit list if any