@mrclrchtr/supi-extras 1.2.0 → 1.3.1
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/node_modules/@mrclrchtr/supi-core/README.md +9 -3
- package/node_modules/@mrclrchtr/supi-core/package.json +12 -2
- package/node_modules/@mrclrchtr/supi-core/src/api.ts +83 -0
- package/node_modules/@mrclrchtr/supi-core/src/extension.ts +1 -0
- package/package.json +10 -4
- package/src/api.ts +1 -0
- package/src/clipboard.ts +8 -3
- package/src/extension.ts +1 -0
- package/src/tab-spinner.ts +1 -1
|
@@ -12,7 +12,12 @@ pnpm add @mrclrchtr/supi-core
|
|
|
12
12
|
|
|
13
13
|
## Package role
|
|
14
14
|
|
|
15
|
-
`@mrclrchtr/supi-core`
|
|
15
|
+
`@mrclrchtr/supi-core` now has two explicit surfaces:
|
|
16
|
+
|
|
17
|
+
- `@mrclrchtr/supi-core/api` — shared library helpers for other SuPi packages
|
|
18
|
+
- `@mrclrchtr/supi-core/extension` — a minimal pi extension that registers `/supi-settings`
|
|
19
|
+
|
|
20
|
+
`pi.extensions` still points at the real file path `./src/extension.ts` inside the package. The `/api` and `/extension` paths are consumer-facing package exports, not manifest aliases.
|
|
16
21
|
|
|
17
22
|
## What it provides
|
|
18
23
|
|
|
@@ -59,7 +64,7 @@ Main helpers:
|
|
|
59
64
|
## Example
|
|
60
65
|
|
|
61
66
|
```ts
|
|
62
|
-
import { loadSupiConfig, registerConfigSettings, wrapExtensionContext } from "@mrclrchtr/supi-core";
|
|
67
|
+
import { loadSupiConfig, registerConfigSettings, wrapExtensionContext } from "@mrclrchtr/supi-core/api";
|
|
63
68
|
|
|
64
69
|
const config = loadSupiConfig("my-extension", process.cwd(), {
|
|
65
70
|
enabled: true,
|
|
@@ -87,4 +92,5 @@ const message = wrapExtensionContext("my-extension", "hello", {
|
|
|
87
92
|
|
|
88
93
|
## Source
|
|
89
94
|
|
|
90
|
-
-
|
|
95
|
+
- Library surface: `src/api.ts`
|
|
96
|
+
- Extension surface: `src/extension.ts`
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mrclrchtr/supi-core",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.3.1",
|
|
4
4
|
"description": "SuPi core — shared infrastructure for SuPi extensions (XML context tags, config system)",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"repository": {
|
|
@@ -30,5 +30,15 @@
|
|
|
30
30
|
"optional": true
|
|
31
31
|
}
|
|
32
32
|
},
|
|
33
|
-
"main": "src/
|
|
33
|
+
"main": "src/api.ts",
|
|
34
|
+
"exports": {
|
|
35
|
+
"./api": "./src/api.ts",
|
|
36
|
+
"./extension": "./src/extension.ts",
|
|
37
|
+
"./package.json": "./package.json"
|
|
38
|
+
},
|
|
39
|
+
"pi": {
|
|
40
|
+
"extensions": [
|
|
41
|
+
"./src/extension.ts"
|
|
42
|
+
]
|
|
43
|
+
}
|
|
34
44
|
}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
// supi-core — shared infrastructure for SuPi extensions.
|
|
2
|
+
// Provides XML context tag wrapping, unified config system, context-message utilities,
|
|
3
|
+
// and settings registry for supi-wide TUI settings.
|
|
4
|
+
|
|
5
|
+
export type { SupiConfigLocation, SupiConfigOptions } from "./config.ts";
|
|
6
|
+
export {
|
|
7
|
+
loadSupiConfig,
|
|
8
|
+
loadSupiConfigForScope,
|
|
9
|
+
removeSupiConfigKey,
|
|
10
|
+
writeSupiConfig,
|
|
11
|
+
} from "./config.ts";
|
|
12
|
+
export type { ConfigSettingsHelpers, ConfigSettingsOptions } from "./config-settings.ts";
|
|
13
|
+
export { registerConfigSettings } from "./config-settings.ts";
|
|
14
|
+
export type { ContextMessageLike } from "./context-messages.ts";
|
|
15
|
+
export {
|
|
16
|
+
findLastUserMessageIndex,
|
|
17
|
+
getContextToken,
|
|
18
|
+
getPromptContent,
|
|
19
|
+
pruneAndReorderContextMessages,
|
|
20
|
+
restorePromptContent,
|
|
21
|
+
} from "./context-messages.ts";
|
|
22
|
+
export type { ContextProvider } from "./context-provider-registry.ts";
|
|
23
|
+
export {
|
|
24
|
+
clearRegisteredContextProviders,
|
|
25
|
+
getRegisteredContextProviders,
|
|
26
|
+
registerContextProvider,
|
|
27
|
+
} from "./context-provider-registry.ts";
|
|
28
|
+
export { wrapExtensionContext } from "./context-tag.ts";
|
|
29
|
+
export type {
|
|
30
|
+
DebugAgentAccess,
|
|
31
|
+
DebugEvent,
|
|
32
|
+
DebugEventInput,
|
|
33
|
+
DebugEventQuery,
|
|
34
|
+
DebugEventQueryResult,
|
|
35
|
+
DebugEventView,
|
|
36
|
+
DebugLevel,
|
|
37
|
+
DebugNotifyLevel,
|
|
38
|
+
DebugRegistryConfig,
|
|
39
|
+
DebugSummary,
|
|
40
|
+
} from "./debug-registry.ts";
|
|
41
|
+
export {
|
|
42
|
+
clearDebugEvents,
|
|
43
|
+
configureDebugRegistry,
|
|
44
|
+
DEBUG_REGISTRY_DEFAULTS,
|
|
45
|
+
getDebugEvents,
|
|
46
|
+
getDebugRegistryConfig,
|
|
47
|
+
getDebugSummary,
|
|
48
|
+
recordDebugEvent,
|
|
49
|
+
redactDebugData,
|
|
50
|
+
resetDebugRegistry,
|
|
51
|
+
} from "./debug-registry.ts";
|
|
52
|
+
export type { KnownRootEntry } from "./project-roots.ts";
|
|
53
|
+
export {
|
|
54
|
+
buildKnownRootsMap,
|
|
55
|
+
byPathDepth,
|
|
56
|
+
dedupeTopmostRoots,
|
|
57
|
+
findProjectRoot,
|
|
58
|
+
isWithin,
|
|
59
|
+
isWithinOrEqual,
|
|
60
|
+
mergeKnownRoots,
|
|
61
|
+
resolveKnownRoot,
|
|
62
|
+
segmentCount,
|
|
63
|
+
sortRootsBySpecificity,
|
|
64
|
+
walkProject,
|
|
65
|
+
} from "./project-roots.ts";
|
|
66
|
+
export { getActiveBranchEntries } from "./session-utils.ts";
|
|
67
|
+
export { registerSettingsCommand } from "./settings-command.ts";
|
|
68
|
+
export type { SettingsScope, SettingsSection } from "./settings-registry.ts";
|
|
69
|
+
export {
|
|
70
|
+
clearRegisteredSettings,
|
|
71
|
+
getRegisteredSettings,
|
|
72
|
+
registerSettings,
|
|
73
|
+
} from "./settings-registry.ts";
|
|
74
|
+
export { createInputSubmenu, openSettingsOverlay } from "./settings-ui.ts";
|
|
75
|
+
export type { TitleTarget } from "./terminal.ts";
|
|
76
|
+
export {
|
|
77
|
+
DONE_SYMBOL,
|
|
78
|
+
formatTitle,
|
|
79
|
+
signalBell,
|
|
80
|
+
signalDone,
|
|
81
|
+
signalWaiting,
|
|
82
|
+
WAITING_SYMBOL,
|
|
83
|
+
} from "./terminal.ts";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { registerSettingsCommand as default } from "./settings-command.ts";
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mrclrchtr/supi-extras",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.3.1",
|
|
4
4
|
"description": "SuPi extras — command aliases, skill shorthand, tab spinner, /supi-stash prompt stash with TUI overlay, and other small utilities",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"repository": {
|
|
@@ -21,12 +21,12 @@
|
|
|
21
21
|
],
|
|
22
22
|
"dependencies": {
|
|
23
23
|
"clipboardy": "^5.3.1",
|
|
24
|
-
"@mrclrchtr/supi-core": "1.
|
|
24
|
+
"@mrclrchtr/supi-core": "1.3.1"
|
|
25
25
|
},
|
|
26
26
|
"bundledDependencies": [
|
|
27
27
|
"@mrclrchtr/supi-core"
|
|
28
28
|
],
|
|
29
|
-
"main": "src/
|
|
29
|
+
"main": "src/api.ts",
|
|
30
30
|
"peerDependencies": {
|
|
31
31
|
"@earendil-works/pi-coding-agent": "*",
|
|
32
32
|
"@earendil-works/pi-tui": "*"
|
|
@@ -41,7 +41,13 @@
|
|
|
41
41
|
},
|
|
42
42
|
"pi": {
|
|
43
43
|
"extensions": [
|
|
44
|
-
"./src/
|
|
44
|
+
"./src/extension.ts",
|
|
45
|
+
"node_modules/@mrclrchtr/supi-core/src/extension.ts"
|
|
45
46
|
]
|
|
47
|
+
},
|
|
48
|
+
"exports": {
|
|
49
|
+
"./api": "./src/api.ts",
|
|
50
|
+
"./extension": "./src/extension.ts",
|
|
51
|
+
"./package.json": "./package.json"
|
|
46
52
|
}
|
|
47
53
|
}
|
package/src/api.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from "./index.ts";
|
package/src/clipboard.ts
CHANGED
|
@@ -1,15 +1,19 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Shared clipboard utility for supi-extras.
|
|
3
3
|
*
|
|
4
|
-
* Copies text to the system clipboard
|
|
5
|
-
* wrapper
|
|
4
|
+
* Copies text to the system clipboard. Uses `clipboardy` when available
|
|
5
|
+
* (preferred cross-platform wrapper), falls back gracefully otherwise.
|
|
6
|
+
*
|
|
7
|
+
* The import is lazy so the extension always loads — clipboard functionality
|
|
8
|
+
* degrades gracefully when `clipboardy` is not installed or unavailable.
|
|
6
9
|
*/
|
|
7
10
|
import type { ExtensionAPI } from "@earendil-works/pi-coding-agent";
|
|
8
|
-
import clipboard from "clipboardy";
|
|
9
11
|
|
|
10
12
|
/**
|
|
11
13
|
* Copy text to the system clipboard.
|
|
12
14
|
*
|
|
15
|
+
* Uses a dynamic import of `clipboardy` to avoid hard-load failures.
|
|
16
|
+
*
|
|
13
17
|
* @returns `true` on success, `false` on failure.
|
|
14
18
|
*/
|
|
15
19
|
export async function copyToClipboard(
|
|
@@ -18,6 +22,7 @@ export async function copyToClipboard(
|
|
|
18
22
|
_pi: ExtensionAPI,
|
|
19
23
|
): Promise<boolean> {
|
|
20
24
|
try {
|
|
25
|
+
const { default: clipboard } = await import("clipboardy");
|
|
21
26
|
await clipboard.write(text);
|
|
22
27
|
return true;
|
|
23
28
|
} catch {
|
package/src/extension.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from "./index.ts";
|
package/src/tab-spinner.ts
CHANGED
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
* agent starts or the session shuts down.
|
|
11
11
|
*/
|
|
12
12
|
import type { ExtensionAPI, ExtensionContext } from "@earendil-works/pi-coding-agent";
|
|
13
|
-
import { formatTitle, signalDone } from "@mrclrchtr/supi-core";
|
|
13
|
+
import { formatTitle, signalDone } from "@mrclrchtr/supi-core/api";
|
|
14
14
|
|
|
15
15
|
const SPINNER_FRAMES = ["⠋", "⠙", "⠹", "⠸", "⠼", "⠴", "⠦", "⠧", "⠇", "⠏"];
|
|
16
16
|
|