Dive into secure and efficient coding practices with our curated list of the top 10 examples showcasing 'pkg-conf' in functional components in JavaScript. Our advanced machine learning engine meticulously scans each line of code, cross-referencing millions of open source libraries to ensure your implementation is not just functional, but also robust and secure. Elevate your React applications to new heights by mastering the art of handling side effects, API calls, and asynchronous operations with confidence and precision.
// const log = require('./lib/log')
const log = (...args) => {
console.log(
chalk.cyan('[mdx]'),
...args
)
}
log.error = (...args) => {
console.log(
chalk.red('[err]'),
...args
)
}
const config = require('pkg-conf').sync('ok-mdx')
const cli = meow(`
Usage:
$ mdx docs
Options:
-o --open Opens development server in default browser
-p --port Port for development server
--vim Enable editor Vim mode
`, {
flags: {
open: {
type: 'boolean',
const absolutePath =
filePath.charAt(0) === '/' ? filePath : path.resolve(cwd, filePath);
if (absolutePath.indexOf('/packages/') === -1) {
// Not a lerna package, use single package.json
const packageOptions = pkgConf.sync('marlint', { cwd });
return buildOptions(packageOptions, runtimeOptions);
}
// Get lerna root directory and package root directory to find specific config
// in package.json. Package specific config will overrides root specific config
const [rootLernaDir, relativeFilePath] = absolutePath.split('/packages/');
const [packageName, ..._] = relativeFilePath.split('/');
const packageDir = `${rootLernaDir}/packages/${packageName}`;
const packageConfig = pkgConf.sync('marlint', { cwd: packageDir });
const rootConfig = pkgConf.sync('marlint', { cwd: rootLernaDir });
const packageOptions = merge({}, rootConfig, packageConfig);
return buildOptions(packageOptions, runtimeOptions);
}
function parseArgs (args, shortCircuit) {
options.__ = y18n.__
options.configuration = pkgConf.sync('yargs', {
defaults: {},
cwd: requireMainFilename(require)
})
const parsed = Parser.detailed(args, options)
const argv = parsed.argv
var aliases = parsed.aliases
argv.$0 = self.$0
self.parsed = parsed
guessLocale() // guess locale lazily, so that it can be turned off in chain.
// while building up the argv object, there
// are two passes through the parser. If completion
// is being performed short-circuit on the first pass.
if (shortCircuit) {
function parseArgs (args, shortCircuit) {
options.__ = y18n.__
options.configuration = pkgConf.sync('yargs', {
defaults: {},
cwd: requireMainFilename(require)
})
const parsed = Parser.detailed(args, options)
const argv = parsed.argv
var aliases = parsed.aliases
argv.$0 = self.$0
self.parsed = parsed
guessLocale() // guess locale lazily, so that it can be turned off in chain.
// while building up the argv object, there
// are two passes through the parser. If completion
// is being performed short-circuit on the first pass.
if (shortCircuit) {
const self = this;
if (opts) {
opts = {};
}
opts = Object.assign({}, opts);
opts.eslintConfig = Object.assign({}, self.eslintConfig);
opts.eslintConfig.fix = !!opts.fix;
if (!opts.cwd) opts.cwd = self.cwd;
// 如果未提供usePackageJson选择,默认为true
const usePackageJson = !_.isNil(opts.usePackageJson) ? opts.usePackageJson : true;
// package.json中的配置
const packageOpts = usePackageJson ? pkgConf.sync(self.cmd, { cwd: opts.cwd }) : {};
// ignore
if (!opts.ignore) opts.ignore = [];
addIgnore(packageOpts.ignore);
if (!packageOpts.noDefaultIgnore) {
addIgnore(DEFAULT_IGNORE);
}
// globals
addGlobals(packageOpts.globals || packageOpts.global);
addGlobals(opts.globals || opts.global);
// plugins
addPlugins(packageOpts.plugins || packageOpts.plugin);
addPlugins(opts.plugins || opts.plugin);
function loadConfig({configFile, resolveFrom = process.cwd(), defaults = {}} = {}) { // eslint-disable-line complexity
let packageConf = pkgConf.sync('ava', {cwd: resolveFrom});
const filepath = pkgConf.filepath(packageConf);
const projectDir = filepath === null ? resolveFrom : path.dirname(filepath);
const fileForErrorMessage = configFile || 'ava.config.js';
const allowConflictWithPackageJson = Boolean(configFile);
if (configFile) {
configFile = path.resolve(configFile); // Relative to CWD
if (path.basename(configFile) !== path.relative(projectDir, configFile)) {
throw new Error('Config files must be located next to the package.json file');
}
} else {
configFile = path.join(projectDir, 'ava.config.js');
}
let fileConf;
try {
test('test', t => {
const conf = pkgConf.sync('ava');
const pkgDir = path.dirname(pkgConf.filepath(conf));
t.is(process.cwd(), pkgDir);
});
const mergeWithPackageConfig = options => {
options = {
cwd: process.cwd(),
...options
};
options.cwd = path.resolve(options.cwd);
const config = pkgConf.sync('xo', {cwd: options.cwd, skipOnFalse: true});
const engines = pkgConf.sync('engines', {cwd: options.cwd});
return {
...config,
nodeVersion: engines && engines.node && semver.validRange(engines.node),
...options
};
};
#!/usr/bin/env node
'use strict'
const fs= require('fs')
const path = require('path')
const importJsx = require('import-jsx')
const { h, render } = require('ink')
const meow = require('meow')
const open = require('react-dev-utils/openBrowser')
const log = require('@compositor/log')
const chalk = require('chalk')
const clipboard = require('clipboardy')
const findup = require('find-up')
const config = require('pkg-conf').sync('kit')
const Init = importJsx('./src/Init')
const parseArgs = require('./lib/parse-args')
const cli = meow(`
Usage
$ kit [options]
Examples
$ kit examples
$ kit dev examples
$ kit init
Options
function hashPartialTestConfig({babelrc, config, options: {plugins, presets}}, projectDir, pluginAndPresetHashes) {
const inputs = [];
if (babelrc) {
inputs.push(babelrc);
const filename = path.basename(babelrc);
if (filename === 'package.json') {
inputs.push(JSON.stringify(pkgConf.sync('babel', {cwd: path.dirname(filename)})));
} else {
inputs.push(stripBomBuf(fs.readFileSync(babelrc)));
}
}
if (config) {
inputs.push(config, stripBomBuf(fs.readFileSync(config)));
}
for (const item of [...plugins, ...presets]) {
if (!item.file) {
continue;
}
const {file: {resolved: filename}} = item;
if (pluginAndPresetHashes.has(filename)) {