UNPKG

@halospv3/hce.shared-config

Version:

Automate commit message quality, changelogs, and CI/CD releases. Exports a semantic-release shareable configuration deserialized from this package's '.releaserc.yml'. Shared resources for .NET projects are also distributed with this package.

74 lines (66 loc) 4.04 kB
/** * @since 3.0.0 * @deprecated EXPERIMENTAL */ /** * [W.I.P. STUB] * * Given an array of {@link PluginInsertRuleSet}s, insert plugins into a * {@link https://developer.mozilla.org/en-US/docs/Web/API/Window/structuredClone structured clone} * (i.e. deep-copy) of the {@link plugins} array, sort the plugin entries, and * return the modified array copy. * @todo implement * @param plugins Your {@link SemanticReleaseOptions.plugins} array. * @param inserts An array of {@link PluginInsertRuleSet}s. * * If a plugin is already in the plugins array, inserting is skipped. The * existing entry is sorted according to its ruleset. * * If any rulesets conflict, an error will be thrown. * - error: A must precede B; B must precede A. * - pass: C must precede D and E; D must precede E and follow B. Add ruleset * interface: {Id:string, BeforeIds:string[], AfterIds:string[] } * @returns A deep-cloned, modified copy of {@link plugins} with plugins * inserted and sorted where needed. * @since 3.0.0 * @deprecated EXPERIMENTAL */ // eslint-disable-next-line @typescript-eslint/no-unused-vars /** * @param plugins {@link SemanticReleaseOptions.plugins} * @param afterPluginsIDs The `string` IDs of plugins that the {@link insertPluginIDs} must follow. * @param insertPluginIDs The `string` IDs of plugins to insert into a copy of the {@link plugins} array. * @param beforePluginsIDs The `string` IDs of plugins that the {@link insertPluginIDs} must precede. * @returns * A modified copy of {@link plugins} with the given plugins inserted * before {@link beforePluginsIDs} and after {@link afterPluginsIDs}. * * Inserted plugins will be a `[string, {}]` tuple. * @throws {ReferenceError} This should never occur. One or more of the * {@link afterPluginsIDs} had been found in {@link plugins}, but a `.find` call * to get the highest index of the found plugins had returned `undefined` * @throws {AggregateError} One or more error occurred when inserting plugins: `insertPlugin was instructed to insert one or more plugins after [${afterPluginsIDs.map(v => '"' + v + '"').join(', ')}] and before [${beforePluginsIDs.map(v => `"${v}"`).join(', ')}], but ${JSON.stringify(pluginIDs[indexOfLastAfter])} comes after ${JSON.stringify(pluginIDs[index])}!` */ function insertPlugin(plugins, afterPluginsIDs, insertPluginIDs, beforePluginsIDs) { const pluginIDs = plugins.map(v => typeof v === 'string' ? v : v[0]); // if any beforePluginIDs are ordered before the last afterPlugin, throw. Impossible to sort. const indexOfLastAfter = afterPluginsIDs.filter(v => pluginIDs.includes(v)).map(v => pluginIDs.indexOf(v)).sort().find((_v, i, obj) => i === obj.length - 1); if (undefined === indexOfLastAfter) throw new ReferenceError('An attempt to get the last element of an array returned undefined.'); const indicesOfBefore = beforePluginsIDs.filter(v => pluginIDs.includes(v)).map(v => pluginIDs.indexOf(v)).sort(); // This for-of collects *all* sorting errors. The resulting AggregateError // notifies the API user of *all* errors in the order rather than just the // first error encountered. const errors = []; for (const index of indicesOfBefore) { if (index <= indexOfLastAfter) { errors.push(new Error(`insertPlugin was instructed to insert one or more plugins after [${afterPluginsIDs.map(v => '"' + v + '"').join(', ')}] and before [${beforePluginsIDs.map(v => `"${v}"`).join(', ')}], but ${JSON.stringify(pluginIDs[indexOfLastAfter])} comes after ${JSON.stringify(pluginIDs[index])}!`)); } } if (errors.length > 0) throw new AggregateError(errors, 'One or more errors occurred while inserting plugin configs into the Semantic Release config!'); // insert plugin(s) const beforeInsert = plugins.slice(0, indexOfLastAfter + 1); const afterInsert = plugins.slice(indexOfLastAfter + 1, plugins.length + 1); return [...beforeInsert, ...insertPluginIDs.map(id => [id, {}]), ...afterInsert]; } export { insertPlugin }; //# sourceMappingURL=insertPlugins.mjs.map