@drizzle-team/brocli
Advanced tools
Comparing version 0.5.2 to 0.6.0
@@ -194,3 +194,12 @@ /** | ||
}; | ||
declare const command: <TOpts extends Record<string, GenericBuilderInternals> | undefined, TOptsData = TOpts extends Record<string, GenericBuilderInternals> ? { [K_1 in keyof { [K in keyof TOpts]: TOpts[K]["_"]["$output"]; }]: { [K in keyof TOpts]: TOpts[K]["_"]["$output"]; }[K_1]; } : undefined, TTransformed = TOptsData>(command: RawCommandUniversal<TOpts, TOptsData, TTransformed>) => Command<TOptsData, TTransformed>; | ||
type TestResult<THandlerInput> = { | ||
type: 'handler'; | ||
options: THandlerInput; | ||
} | { | ||
type: 'help' | 'version'; | ||
} | { | ||
type: 'error'; | ||
error: unknown; | ||
}; | ||
declare const command: <TOpts extends Record<string, GenericBuilderInternals> | undefined, TOptsData = TOpts extends Record<string, GenericBuilderInternals> ? { [K_1 in keyof { [K in keyof TOpts]: TOpts[K]["_"]["$output"]; }]: { [K in keyof TOpts]: TOpts[K]["_"]["$output"]; }[K_1]; } : undefined, TTransformed = TOptsData>(command: RawCommandUniversal<TOpts, TOptsData, TTransformed>) => Command<TOptsData, Awaited<TTransformed>>; | ||
/** | ||
@@ -205,3 +214,4 @@ * Runs CLI commands | ||
declare const handler: <TOpts extends Record<string, GenericBuilderInternals>>(options: TOpts, handler: CommandHandler<TOpts>) => CommandHandler<TOpts>; | ||
declare const test: <TOpts, THandlerInput>(command: Command<TOpts, THandlerInput>, args: string) => Promise<TestResult<THandlerInput>>; | ||
export { type AnyRawCommand, type BroCliConfig, BroCliError, type BuilderConfig, type BuilderConfigLimited, type Command, type CommandCandidate, type CommandHandler, type GenericBuilderInternals, type GenericBuilderInternalsFields, type GenericBuilderInternalsFieldsLimited, type GenericBuilderInternalsLimited, type GenericCommandHandler, type HelpHandler, type InnerCommandParseRes, OptionBuilderBase, type OptionType, type OutputType, type ProcessedBuilderConfig, type ProcessedOptions, type RawCommand, type RawCommandUniversal, type RawCommandWithPositionals, type RawCommandWithSubcommands, type Simplify, type TypeOf, boolean, command, handler, number, positional, runCli, string }; | ||
export { type AnyRawCommand, type BroCliConfig, BroCliError, type BuilderConfig, type BuilderConfigLimited, type Command, type CommandCandidate, type CommandHandler, type GenericBuilderInternals, type GenericBuilderInternalsFields, type GenericBuilderInternalsFieldsLimited, type GenericBuilderInternalsLimited, type GenericCommandHandler, type HelpHandler, type InnerCommandParseRes, OptionBuilderBase, type OptionType, type OutputType, type ProcessedBuilderConfig, type ProcessedOptions, type RawCommand, type RawCommandUniversal, type RawCommandWithPositionals, type RawCommandWithSubcommands, type Simplify, type TestResult, type TypeOf, boolean, command, handler, number, positional, runCli, string, test }; |
284
index.js
@@ -0,1 +1,254 @@ | ||
var __create = Object.create; | ||
var __defProp = Object.defineProperty; | ||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor; | ||
var __getOwnPropNames = Object.getOwnPropertyNames; | ||
var __getProtoOf = Object.getPrototypeOf; | ||
var __hasOwnProp = Object.prototype.hasOwnProperty; | ||
var __commonJS = (cb, mod) => function __require() { | ||
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; | ||
}; | ||
var __copyProps = (to, from, except, desc) => { | ||
if (from && typeof from === "object" || typeof from === "function") { | ||
for (let key of __getOwnPropNames(from)) | ||
if (!__hasOwnProp.call(to, key) && key !== except) | ||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); | ||
} | ||
return to; | ||
}; | ||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( | ||
// If the importer is in node compatibility mode or this is not an ESM | ||
// file that has been converted to a CommonJS file using a Babel- | ||
// compatible transform (i.e. "__esModule" has not been set), then set | ||
// "default" to the CommonJS "module.exports" for node compatibility. | ||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, | ||
mod | ||
)); | ||
// node_modules/.pnpm/shell-quote@1.8.1/node_modules/shell-quote/quote.js | ||
var require_quote = __commonJS({ | ||
"node_modules/.pnpm/shell-quote@1.8.1/node_modules/shell-quote/quote.js"(exports, module) { | ||
"use strict"; | ||
module.exports = function quote(xs) { | ||
return xs.map(function(s) { | ||
if (s && typeof s === "object") { | ||
return s.op.replace(/(.)/g, "\\$1"); | ||
} | ||
if (/["\s]/.test(s) && !/'/.test(s)) { | ||
return "'" + s.replace(/(['\\])/g, "\\$1") + "'"; | ||
} | ||
if (/["'\s]/.test(s)) { | ||
return '"' + s.replace(/(["\\$`!])/g, "\\$1") + '"'; | ||
} | ||
return String(s).replace(/([A-Za-z]:)?([#!"$&'()*,:;<=>?@[\\\]^`{|}])/g, "$1\\$2"); | ||
}).join(" "); | ||
}; | ||
} | ||
}); | ||
// node_modules/.pnpm/shell-quote@1.8.1/node_modules/shell-quote/parse.js | ||
var require_parse = __commonJS({ | ||
"node_modules/.pnpm/shell-quote@1.8.1/node_modules/shell-quote/parse.js"(exports, module) { | ||
"use strict"; | ||
var CONTROL = "(?:" + [ | ||
"\\|\\|", | ||
"\\&\\&", | ||
";;", | ||
"\\|\\&", | ||
"\\<\\(", | ||
"\\<\\<\\<", | ||
">>", | ||
">\\&", | ||
"<\\&", | ||
"[&;()|<>]" | ||
].join("|") + ")"; | ||
var controlRE = new RegExp("^" + CONTROL + "$"); | ||
var META = "|&;()<> \\t"; | ||
var SINGLE_QUOTE = '"((\\\\"|[^"])*?)"'; | ||
var DOUBLE_QUOTE = "'((\\\\'|[^'])*?)'"; | ||
var hash = /^#$/; | ||
var SQ = "'"; | ||
var DQ = '"'; | ||
var DS = "$"; | ||
var TOKEN = ""; | ||
var mult = 4294967296; | ||
for (i = 0; i < 4; i++) { | ||
TOKEN += (mult * Math.random()).toString(16); | ||
} | ||
var i; | ||
var startsWithToken = new RegExp("^" + TOKEN); | ||
function matchAll(s, r) { | ||
var origIndex = r.lastIndex; | ||
var matches = []; | ||
var matchObj; | ||
while (matchObj = r.exec(s)) { | ||
matches.push(matchObj); | ||
if (r.lastIndex === matchObj.index) { | ||
r.lastIndex += 1; | ||
} | ||
} | ||
r.lastIndex = origIndex; | ||
return matches; | ||
} | ||
function getVar(env, pre, key) { | ||
var r = typeof env === "function" ? env(key) : env[key]; | ||
if (typeof r === "undefined" && key != "") { | ||
r = ""; | ||
} else if (typeof r === "undefined") { | ||
r = "$"; | ||
} | ||
if (typeof r === "object") { | ||
return pre + TOKEN + JSON.stringify(r) + TOKEN; | ||
} | ||
return pre + r; | ||
} | ||
function parseInternal(string2, env, opts) { | ||
if (!opts) { | ||
opts = {}; | ||
} | ||
var BS = opts.escape || "\\"; | ||
var BAREWORD = "(\\" + BS + `['"` + META + `]|[^\\s'"` + META + "])+"; | ||
var chunker = new RegExp([ | ||
"(" + CONTROL + ")", | ||
// control chars | ||
"(" + BAREWORD + "|" + SINGLE_QUOTE + "|" + DOUBLE_QUOTE + ")+" | ||
].join("|"), "g"); | ||
var matches = matchAll(string2, chunker); | ||
if (matches.length === 0) { | ||
return []; | ||
} | ||
if (!env) { | ||
env = {}; | ||
} | ||
var commented = false; | ||
return matches.map(function(match) { | ||
var s = match[0]; | ||
if (!s || commented) { | ||
return void 0; | ||
} | ||
if (controlRE.test(s)) { | ||
return { op: s }; | ||
} | ||
var quote = false; | ||
var esc = false; | ||
var out = ""; | ||
var isGlob = false; | ||
var i2; | ||
function parseEnvVar() { | ||
i2 += 1; | ||
var varend; | ||
var varname; | ||
var char = s.charAt(i2); | ||
if (char === "{") { | ||
i2 += 1; | ||
if (s.charAt(i2) === "}") { | ||
throw new Error("Bad substitution: " + s.slice(i2 - 2, i2 + 1)); | ||
} | ||
varend = s.indexOf("}", i2); | ||
if (varend < 0) { | ||
throw new Error("Bad substitution: " + s.slice(i2)); | ||
} | ||
varname = s.slice(i2, varend); | ||
i2 = varend; | ||
} else if (/[*@#?$!_-]/.test(char)) { | ||
varname = char; | ||
i2 += 1; | ||
} else { | ||
var slicedFromI = s.slice(i2); | ||
varend = slicedFromI.match(/[^\w\d_]/); | ||
if (!varend) { | ||
varname = slicedFromI; | ||
i2 = s.length; | ||
} else { | ||
varname = slicedFromI.slice(0, varend.index); | ||
i2 += varend.index - 1; | ||
} | ||
} | ||
return getVar(env, "", varname); | ||
} | ||
for (i2 = 0; i2 < s.length; i2++) { | ||
var c = s.charAt(i2); | ||
isGlob = isGlob || !quote && (c === "*" || c === "?"); | ||
if (esc) { | ||
out += c; | ||
esc = false; | ||
} else if (quote) { | ||
if (c === quote) { | ||
quote = false; | ||
} else if (quote == SQ) { | ||
out += c; | ||
} else { | ||
if (c === BS) { | ||
i2 += 1; | ||
c = s.charAt(i2); | ||
if (c === DQ || c === BS || c === DS) { | ||
out += c; | ||
} else { | ||
out += BS + c; | ||
} | ||
} else if (c === DS) { | ||
out += parseEnvVar(); | ||
} else { | ||
out += c; | ||
} | ||
} | ||
} else if (c === DQ || c === SQ) { | ||
quote = c; | ||
} else if (controlRE.test(c)) { | ||
return { op: s }; | ||
} else if (hash.test(c)) { | ||
commented = true; | ||
var commentObj = { comment: string2.slice(match.index + i2 + 1) }; | ||
if (out.length) { | ||
return [out, commentObj]; | ||
} | ||
return [commentObj]; | ||
} else if (c === BS) { | ||
esc = true; | ||
} else if (c === DS) { | ||
out += parseEnvVar(); | ||
} else { | ||
out += c; | ||
} | ||
} | ||
if (isGlob) { | ||
return { op: "glob", pattern: out }; | ||
} | ||
return out; | ||
}).reduce(function(prev, arg) { | ||
return typeof arg === "undefined" ? prev : prev.concat(arg); | ||
}, []); | ||
} | ||
module.exports = function parse(s, env, opts) { | ||
var mapped = parseInternal(s, env, opts); | ||
if (typeof env !== "function") { | ||
return mapped; | ||
} | ||
return mapped.reduce(function(acc, s2) { | ||
if (typeof s2 === "object") { | ||
return acc.concat(s2); | ||
} | ||
var xs = s2.split(RegExp("(" + TOKEN + ".*?" + TOKEN + ")", "g")); | ||
if (xs.length === 1) { | ||
return acc.concat(xs[0]); | ||
} | ||
return acc.concat(xs.filter(Boolean).map(function(x) { | ||
if (startsWithToken.test(x)) { | ||
return JSON.parse(x.split(TOKEN)[1]); | ||
} | ||
return x; | ||
})); | ||
}, []); | ||
}; | ||
} | ||
}); | ||
// node_modules/.pnpm/shell-quote@1.8.1/node_modules/shell-quote/index.js | ||
var require_shell_quote = __commonJS({ | ||
"node_modules/.pnpm/shell-quote@1.8.1/node_modules/shell-quote/index.js"(exports) { | ||
"use strict"; | ||
exports.quote = require_quote(); | ||
exports.parse = require_parse(); | ||
} | ||
}); | ||
// src/brocli-error.ts | ||
@@ -9,2 +262,5 @@ var BroCliError = class extends Error { | ||
// src/command-core.ts | ||
var import_shell_quote = __toESM(require_shell_quote(), 1); | ||
// src/help-themes.ts | ||
@@ -513,2 +769,27 @@ var defaultTheme = (calledFor) => { | ||
var handler = (options, handler2) => handler2; | ||
var shellArgs = (str) => { | ||
const spaces = str.match(/"[^"]+"|'[^']+'|\S+/g) ?? []; | ||
return spaces.flatMap((s) => (0, import_shell_quote.parse)(s)).map((s) => s.toString()); | ||
}; | ||
var test = async (command2, args) => { | ||
try { | ||
const cliParsedArgs = shellArgs(args); | ||
console.log(cliParsedArgs); | ||
const options = parseOptions(command2, cliParsedArgs); | ||
if (options === "help" || options === "version") { | ||
return { | ||
type: options | ||
}; | ||
} | ||
return { | ||
options: command2.transform ? await command2.transform(options) : options, | ||
type: "handler" | ||
}; | ||
} catch (e) { | ||
return { | ||
type: "error", | ||
error: e | ||
}; | ||
} | ||
}; | ||
@@ -621,4 +902,5 @@ // src/option-builder.ts | ||
runCli, | ||
string | ||
string, | ||
test | ||
}; | ||
//# sourceMappingURL=index.js.map |
@@ -5,3 +5,3 @@ { | ||
"author": "Drizzle Team", | ||
"version": "0.5.2", | ||
"version": "0.6.0", | ||
"description": "Typed CLI command runner", | ||
@@ -31,3 +31,5 @@ "license": "Apache-2.0", | ||
"@types/node": "^20.12.13", | ||
"@types/shell-quote": "^1.7.5", | ||
"dprint": "^0.46.2", | ||
"shell-quote": "^1.8.1", | ||
"tsup": "^8.1.0", | ||
@@ -34,0 +36,0 @@ "tsx": "^4.7.0", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
246988
2025
12