Skip to content

Commit

Permalink
pack: include contents of directories in files field
Browse files Browse the repository at this point in the history
This makes it so that you don't have to put '/**' after a directory in
the `files` field of package.json to ensure that the contents of the
directory will be published.

Fixes #2498
Fixes #2942
Fixes #2851

Includes and closes #3170
  • Loading branch information
josephfrazier committed Apr 18, 2017
1 parent 6626c5e commit ecf172b
Showing 1 changed file with 27 additions and 2 deletions.
29 changes: 27 additions & 2 deletions src/cli/commands/pack.js
Original file line number Diff line number Diff line change
Expand Up @@ -76,12 +76,27 @@ export async function pack(config: Config, dir: string): Promise<stream$Duplex>

// `files` field
if (onlyFiles) {
// Append '**' to directories in the `files` field.
// This ensures that their contents get included.
const onlyFilesGlobs = await Promise.all(onlyFiles.map(async (filename: string): Promise<string> => {
try {
const loc = path.join(config.cwd, filename);
const stat = await fs.lstat(loc);

if (stat.isDirectory()) {
return path.join(filename, '**');
}
return filename;
} catch (err) {
return filename;
}
}));
let lines = [
'*', // ignore all files except those that are explicitly included with a negation filter
'.*', // files with "." as first character have to be excluded explicitly
];
lines = lines.concat(
onlyFiles.map((filename: string): string => `!${filename}`),
onlyFilesGlobs.map((filename: string): string => `!${filename}`),
);
const regexes = ignoreLinesToRegex(lines, '.');
filters = filters.concat(regexes);
Expand Down Expand Up @@ -115,7 +130,17 @@ export async function pack(config: Config, dir: string): Promise<stream$Duplex>
sortFilter(files, filters, keepFiles, possibleKeepFiles, ignoredFiles);

const packer = tar.pack(config.cwd, {
ignore: (name) => !keepFiles.has(path.relative(config.cwd, name)),
ignore: (name) => {
const relative = path.relative(config.cwd, name);
// Don't ignore directories, since we need to recurse inside them to check for unignored files.
if (fs2.lstatSync(name).isDirectory()) {
const isParentOfKeptFile = Array.from(keepFiles).some((name) =>
!path.relative(relative, name).startsWith('..'));
return !isParentOfKeptFile;
}
// Otherwise, ignore a file if we're not supposed to keep it.
return !keepFiles.has(relative);
},
map: (header) => {
const suffix = header.name === '.' ? '' : `/${header.name}`;
header.name = `package${suffix}`;
Expand Down

0 comments on commit ecf172b

Please sign in to comment.