docrev 0.9.11 → 0.9.14
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.
- package/.claude/settings.local.json +9 -9
- package/.gitattributes +1 -1
- package/CHANGELOG.md +149 -149
- package/PLAN-tables-and-postprocess.md +850 -850
- package/README.md +391 -391
- package/bin/rev.js +11 -11
- package/bin/rev.ts +145 -145
- package/completions/rev.bash +127 -127
- package/completions/rev.ps1 +210 -210
- package/completions/rev.zsh +207 -207
- package/dev_notes/stress2/build_adversarial.ts +186 -186
- package/dev_notes/stress2/drift_matcher.ts +62 -62
- package/dev_notes/stress2/probe_anchors.ts +35 -35
- package/dev_notes/stress2/project/discussion.before.md +3 -3
- package/dev_notes/stress2/project/discussion.md +3 -3
- package/dev_notes/stress2/project/methods.before.md +20 -20
- package/dev_notes/stress2/project/methods.md +20 -20
- package/dev_notes/stress2/project/rev.yaml +5 -5
- package/dev_notes/stress2/project/sections.yaml +4 -4
- package/dev_notes/stress2/sections.yaml +5 -5
- package/dev_notes/stress2/trace_placement.ts +50 -50
- package/dev_notes/stresstest_boundaries.ts +27 -27
- package/dev_notes/stresstest_drift_apply.ts +43 -43
- package/dev_notes/stresstest_drift_compare.ts +43 -43
- package/dev_notes/stresstest_drift_v2.ts +54 -54
- package/dev_notes/stresstest_inspect.ts +54 -54
- package/dev_notes/stresstest_pstyle.ts +55 -55
- package/dev_notes/stresstest_section_debug.ts +23 -23
- package/dev_notes/stresstest_split.ts +70 -70
- package/dev_notes/stresstest_trace.ts +19 -19
- package/dev_notes/stresstest_verify_no_overwrite.ts +40 -40
- package/dist/lib/build.d.ts +50 -1
- package/dist/lib/build.d.ts.map +1 -1
- package/dist/lib/build.js +80 -30
- package/dist/lib/build.js.map +1 -1
- package/dist/lib/commands/build.d.ts.map +1 -1
- package/dist/lib/commands/build.js +38 -5
- package/dist/lib/commands/build.js.map +1 -1
- package/dist/lib/commands/utilities.js +164 -164
- package/dist/lib/commands/word-tools.js +8 -8
- package/dist/lib/grammar.js +3 -3
- package/dist/lib/import.d.ts.map +1 -1
- package/dist/lib/import.js +146 -24
- package/dist/lib/import.js.map +1 -1
- package/dist/lib/pdf-comments.js +44 -44
- package/dist/lib/plugins.js +57 -57
- package/dist/lib/pptx-themes.js +115 -115
- package/dist/lib/spelling.js +2 -2
- package/dist/lib/templates.js +387 -387
- package/dist/lib/themes.js +51 -51
- package/dist/lib/types.d.ts +20 -0
- package/dist/lib/types.d.ts.map +1 -1
- package/dist/lib/word-extraction.d.ts +6 -0
- package/dist/lib/word-extraction.d.ts.map +1 -1
- package/dist/lib/word-extraction.js +46 -3
- package/dist/lib/word-extraction.js.map +1 -1
- package/dist/lib/wordcomments.d.ts.map +1 -1
- package/dist/lib/wordcomments.js +23 -5
- package/dist/lib/wordcomments.js.map +1 -1
- package/eslint.config.js +27 -27
- package/lib/anchor-match.ts +276 -276
- package/lib/annotations.ts +644 -644
- package/lib/build.ts +1300 -1227
- package/lib/citations.ts +160 -160
- package/lib/commands/build.ts +833 -801
- package/lib/commands/citations.ts +515 -515
- package/lib/commands/comments.ts +1050 -1050
- package/lib/commands/context.ts +174 -174
- package/lib/commands/core.ts +309 -309
- package/lib/commands/doi.ts +435 -435
- package/lib/commands/file-ops.ts +372 -372
- package/lib/commands/history.ts +320 -320
- package/lib/commands/index.ts +87 -87
- package/lib/commands/init.ts +259 -259
- package/lib/commands/merge-resolve.ts +378 -378
- package/lib/commands/preview.ts +178 -178
- package/lib/commands/project-info.ts +244 -244
- package/lib/commands/quality.ts +517 -517
- package/lib/commands/response.ts +454 -454
- package/lib/commands/section-boundaries.ts +82 -82
- package/lib/commands/sections.ts +451 -451
- package/lib/commands/sync.ts +706 -706
- package/lib/commands/text-ops.ts +449 -449
- package/lib/commands/utilities.ts +448 -448
- package/lib/commands/verify-anchors.ts +272 -272
- package/lib/commands/word-tools.ts +340 -340
- package/lib/comment-realign.ts +517 -517
- package/lib/config.ts +84 -84
- package/lib/crossref.ts +781 -781
- package/lib/csl.ts +191 -191
- package/lib/dependencies.ts +98 -98
- package/lib/diff-engine.ts +465 -465
- package/lib/doi-cache.ts +115 -115
- package/lib/doi.ts +897 -897
- package/lib/equations.ts +506 -506
- package/lib/errors.ts +346 -346
- package/lib/format.ts +541 -541
- package/lib/git.ts +326 -326
- package/lib/grammar.ts +303 -303
- package/lib/image-registry.ts +180 -180
- package/lib/import.ts +911 -792
- package/lib/journals.ts +543 -543
- package/lib/merge.ts +633 -633
- package/lib/orcid.ts +144 -144
- package/lib/pdf-comments.ts +263 -263
- package/lib/pdf-import.ts +524 -524
- package/lib/plugins.ts +362 -362
- package/lib/postprocess.ts +188 -188
- package/lib/pptx-color-filter.lua +37 -37
- package/lib/pptx-template.ts +469 -469
- package/lib/pptx-themes.ts +483 -483
- package/lib/protect-restore.ts +520 -520
- package/lib/rate-limiter.ts +94 -94
- package/lib/response.ts +197 -197
- package/lib/restore-references.ts +240 -240
- package/lib/review.ts +327 -327
- package/lib/schema.ts +417 -417
- package/lib/scientific-words.ts +73 -73
- package/lib/sections.ts +335 -335
- package/lib/slides.ts +756 -756
- package/lib/spelling.ts +334 -334
- package/lib/templates.ts +526 -526
- package/lib/themes.ts +742 -742
- package/lib/trackchanges.ts +247 -247
- package/lib/tui.ts +450 -450
- package/lib/types.ts +550 -530
- package/lib/undo.ts +250 -250
- package/lib/utils.ts +69 -69
- package/lib/variables.ts +179 -179
- package/lib/word-extraction.ts +806 -759
- package/lib/word.ts +643 -643
- package/lib/wordcomments.ts +817 -798
- package/package.json +137 -137
- package/scripts/postbuild.js +28 -28
- package/skill/REFERENCE.md +431 -431
- package/skill/SKILL.md +258 -258
- package/tsconfig.json +26 -26
- package/types/index.d.ts +525 -525
|
@@ -1,82 +1,82 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Compute section boundaries in a DOCX from its real heading paragraphs.
|
|
3
|
-
*
|
|
4
|
-
* Given the configured `sections.yaml` and the headings extracted via
|
|
5
|
-
* `extractHeadings()`, return one boundary per section file with text
|
|
6
|
-
* positions in the same coordinate system as `CommentAnchorData.docPosition`.
|
|
7
|
-
*
|
|
8
|
-
* Matching is by heading text (primary header + aliases, case-insensitive).
|
|
9
|
-
* This replaces the older keyword-search-in-body-text approach which would
|
|
10
|
-
* pick up section names that happen to appear inside prose ("results across
|
|
11
|
-
* countries") or in structured-abstract labels where paragraph boundaries
|
|
12
|
-
* are lost in concatenation.
|
|
13
|
-
*/
|
|
14
|
-
|
|
15
|
-
import type { DocxHeading } from '../word-extraction.js';
|
|
16
|
-
import type { SectionConfig } from '../types.js';
|
|
17
|
-
|
|
18
|
-
export interface SectionBoundary {
|
|
19
|
-
file: string;
|
|
20
|
-
start: number;
|
|
21
|
-
end: number;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
export function computeSectionBoundaries(
|
|
25
|
-
sections: Record<string, SectionConfig>,
|
|
26
|
-
headings: DocxHeading[],
|
|
27
|
-
docLength?: number,
|
|
28
|
-
): SectionBoundary[] {
|
|
29
|
-
const matched: SectionBoundary[] = [];
|
|
30
|
-
|
|
31
|
-
// Only consider top-level (Heading1-style) when level info is available;
|
|
32
|
-
// when level==0 (unparseable style), fall back to all headings.
|
|
33
|
-
const haveLevels = headings.some(h => h.level > 0);
|
|
34
|
-
const candidates = haveLevels ? headings.filter(h => h.level === 1) : headings;
|
|
35
|
-
|
|
36
|
-
for (const [file, cfg] of Object.entries(sections)) {
|
|
37
|
-
const targets = [cfg.header, ...(cfg.aliases || [])]
|
|
38
|
-
.filter(Boolean)
|
|
39
|
-
.map(s => s.toLowerCase().trim());
|
|
40
|
-
|
|
41
|
-
let firstMatch = -1;
|
|
42
|
-
for (const h of candidates) {
|
|
43
|
-
const text = h.text.toLowerCase().trim();
|
|
44
|
-
if (targets.includes(text)) {
|
|
45
|
-
firstMatch = h.docPosition;
|
|
46
|
-
break;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
// Fallback: if no level-1 hit, allow any-level match (handles single-level docs)
|
|
51
|
-
if (firstMatch < 0 && haveLevels) {
|
|
52
|
-
for (const h of headings) {
|
|
53
|
-
const text = h.text.toLowerCase().trim();
|
|
54
|
-
if (targets.includes(text)) {
|
|
55
|
-
firstMatch = h.docPosition;
|
|
56
|
-
break;
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
if (firstMatch >= 0) {
|
|
62
|
-
matched.push({ file, start: firstMatch, end: Number.MAX_SAFE_INTEGER });
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
// Sort by start position and tighten each end to the next start.
|
|
67
|
-
// The last section's end is capped at docLength when known, otherwise
|
|
68
|
-
// left at MAX_SAFE_INTEGER. Without the cap, single-section configs
|
|
69
|
-
// produce a sectionLength of ~9e15, collapsing proportional-position
|
|
70
|
-
// math in insertCommentsIntoMarkdown to 0 and stacking every comment
|
|
71
|
-
// at the document start.
|
|
72
|
-
matched.sort((a, b) => a.start - b.start);
|
|
73
|
-
for (let i = 0; i < matched.length - 1; i++) {
|
|
74
|
-
matched[i].end = matched[i + 1].start;
|
|
75
|
-
}
|
|
76
|
-
if (matched.length > 0 && docLength !== undefined) {
|
|
77
|
-
const last = matched[matched.length - 1];
|
|
78
|
-
if (last.end > docLength) last.end = docLength;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
return matched;
|
|
82
|
-
}
|
|
1
|
+
/**
|
|
2
|
+
* Compute section boundaries in a DOCX from its real heading paragraphs.
|
|
3
|
+
*
|
|
4
|
+
* Given the configured `sections.yaml` and the headings extracted via
|
|
5
|
+
* `extractHeadings()`, return one boundary per section file with text
|
|
6
|
+
* positions in the same coordinate system as `CommentAnchorData.docPosition`.
|
|
7
|
+
*
|
|
8
|
+
* Matching is by heading text (primary header + aliases, case-insensitive).
|
|
9
|
+
* This replaces the older keyword-search-in-body-text approach which would
|
|
10
|
+
* pick up section names that happen to appear inside prose ("results across
|
|
11
|
+
* countries") or in structured-abstract labels where paragraph boundaries
|
|
12
|
+
* are lost in concatenation.
|
|
13
|
+
*/
|
|
14
|
+
|
|
15
|
+
import type { DocxHeading } from '../word-extraction.js';
|
|
16
|
+
import type { SectionConfig } from '../types.js';
|
|
17
|
+
|
|
18
|
+
export interface SectionBoundary {
|
|
19
|
+
file: string;
|
|
20
|
+
start: number;
|
|
21
|
+
end: number;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export function computeSectionBoundaries(
|
|
25
|
+
sections: Record<string, SectionConfig>,
|
|
26
|
+
headings: DocxHeading[],
|
|
27
|
+
docLength?: number,
|
|
28
|
+
): SectionBoundary[] {
|
|
29
|
+
const matched: SectionBoundary[] = [];
|
|
30
|
+
|
|
31
|
+
// Only consider top-level (Heading1-style) when level info is available;
|
|
32
|
+
// when level==0 (unparseable style), fall back to all headings.
|
|
33
|
+
const haveLevels = headings.some(h => h.level > 0);
|
|
34
|
+
const candidates = haveLevels ? headings.filter(h => h.level === 1) : headings;
|
|
35
|
+
|
|
36
|
+
for (const [file, cfg] of Object.entries(sections)) {
|
|
37
|
+
const targets = [cfg.header, ...(cfg.aliases || [])]
|
|
38
|
+
.filter(Boolean)
|
|
39
|
+
.map(s => s.toLowerCase().trim());
|
|
40
|
+
|
|
41
|
+
let firstMatch = -1;
|
|
42
|
+
for (const h of candidates) {
|
|
43
|
+
const text = h.text.toLowerCase().trim();
|
|
44
|
+
if (targets.includes(text)) {
|
|
45
|
+
firstMatch = h.docPosition;
|
|
46
|
+
break;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
// Fallback: if no level-1 hit, allow any-level match (handles single-level docs)
|
|
51
|
+
if (firstMatch < 0 && haveLevels) {
|
|
52
|
+
for (const h of headings) {
|
|
53
|
+
const text = h.text.toLowerCase().trim();
|
|
54
|
+
if (targets.includes(text)) {
|
|
55
|
+
firstMatch = h.docPosition;
|
|
56
|
+
break;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
if (firstMatch >= 0) {
|
|
62
|
+
matched.push({ file, start: firstMatch, end: Number.MAX_SAFE_INTEGER });
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// Sort by start position and tighten each end to the next start.
|
|
67
|
+
// The last section's end is capped at docLength when known, otherwise
|
|
68
|
+
// left at MAX_SAFE_INTEGER. Without the cap, single-section configs
|
|
69
|
+
// produce a sectionLength of ~9e15, collapsing proportional-position
|
|
70
|
+
// math in insertCommentsIntoMarkdown to 0 and stacking every comment
|
|
71
|
+
// at the document start.
|
|
72
|
+
matched.sort((a, b) => a.start - b.start);
|
|
73
|
+
for (let i = 0; i < matched.length - 1; i++) {
|
|
74
|
+
matched[i].end = matched[i + 1].start;
|
|
75
|
+
}
|
|
76
|
+
if (matched.length > 0 && docLength !== undefined) {
|
|
77
|
+
const last = matched[matched.length - 1];
|
|
78
|
+
if (last.end > docLength) last.end = docLength;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
return matched;
|
|
82
|
+
}
|