Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
quarto-dev
GitHub Repository: quarto-dev/quarto-cli
Path: blob/main/src/command/add/cmd.ts
3584 views
1
/*
2
* cmd.ts
3
*
4
* Copyright (C) 2021-2022 Posit Software, PBC
5
*/
6
import { Command } from "cliffy/command/mod.ts";
7
import { initYamlIntelligenceResourcesFromFilesystem } from "../../core/schema/utils.ts";
8
import { createTempContext } from "../../core/temp.ts";
9
import { installExtension } from "../../extension/install.ts";
10
11
import { info } from "../../deno_ral/log.ts";
12
import { signalCommandFailure } from "../utils.ts";
13
14
export const addCommand = new Command()
15
.name("add")
16
.arguments("<extension:string>")
17
.option(
18
"--no-prompt",
19
"Do not prompt to confirm actions",
20
)
21
.option(
22
"--embed <extensionId>",
23
"Embed this extension within another extension (used when authoring extensions).",
24
)
25
.description(
26
"Add an extension to this folder or project",
27
)
28
.example(
29
"Install extension (Github)",
30
"quarto add <gh-org>/<gh-repo>",
31
)
32
.example(
33
"Install extension (file)",
34
"quarto add <path-to-zip>",
35
)
36
.example(
37
"Install extension (url)",
38
"quarto add <url>",
39
)
40
.action(
41
async (
42
options: { prompt?: boolean; embed?: string; updatePath?: boolean },
43
extension: string,
44
) => {
45
await initYamlIntelligenceResourcesFromFilesystem();
46
const temp = createTempContext();
47
try {
48
if (!extension) {
49
info("Please provide an extension name, url, or path.");
50
signalCommandFailure();
51
}
52
// Install an extension
53
const result = await installExtension(
54
extension,
55
temp,
56
options.prompt !== false,
57
options.embed,
58
);
59
if (!result) {
60
signalCommandFailure();
61
}
62
} finally {
63
temp.cleanup();
64
}
65
},
66
);
67
68