115 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // give it a pattern, and it'll be able to tell you if
 | |
| // a given path should be ignored.
 | |
| // Ignoring a path ignores its children if the pattern ends in /**
 | |
| // Ignores are always parsed in dot:true mode
 | |
| import { Minimatch } from 'minimatch';
 | |
| import { Pattern } from './pattern.js';
 | |
| const defaultPlatform = (typeof process === 'object' &&
 | |
|     process &&
 | |
|     typeof process.platform === 'string') ?
 | |
|     process.platform
 | |
|     : 'linux';
 | |
| /**
 | |
|  * Class used to process ignored patterns
 | |
|  */
 | |
| export class Ignore {
 | |
|     relative;
 | |
|     relativeChildren;
 | |
|     absolute;
 | |
|     absoluteChildren;
 | |
|     platform;
 | |
|     mmopts;
 | |
|     constructor(ignored, { nobrace, nocase, noext, noglobstar, platform = defaultPlatform, }) {
 | |
|         this.relative = [];
 | |
|         this.absolute = [];
 | |
|         this.relativeChildren = [];
 | |
|         this.absoluteChildren = [];
 | |
|         this.platform = platform;
 | |
|         this.mmopts = {
 | |
|             dot: true,
 | |
|             nobrace,
 | |
|             nocase,
 | |
|             noext,
 | |
|             noglobstar,
 | |
|             optimizationLevel: 2,
 | |
|             platform,
 | |
|             nocomment: true,
 | |
|             nonegate: true,
 | |
|         };
 | |
|         for (const ign of ignored)
 | |
|             this.add(ign);
 | |
|     }
 | |
|     add(ign) {
 | |
|         // this is a little weird, but it gives us a clean set of optimized
 | |
|         // minimatch matchers, without getting tripped up if one of them
 | |
|         // ends in /** inside a brace section, and it's only inefficient at
 | |
|         // the start of the walk, not along it.
 | |
|         // It'd be nice if the Pattern class just had a .test() method, but
 | |
|         // handling globstars is a bit of a pita, and that code already lives
 | |
|         // in minimatch anyway.
 | |
|         // Another way would be if maybe Minimatch could take its set/globParts
 | |
|         // as an option, and then we could at least just use Pattern to test
 | |
|         // for absolute-ness.
 | |
|         // Yet another way, Minimatch could take an array of glob strings, and
 | |
|         // a cwd option, and do the right thing.
 | |
|         const mm = new Minimatch(ign, this.mmopts);
 | |
|         for (let i = 0; i < mm.set.length; i++) {
 | |
|             const parsed = mm.set[i];
 | |
|             const globParts = mm.globParts[i];
 | |
|             /* c8 ignore start */
 | |
|             if (!parsed || !globParts) {
 | |
|                 throw new Error('invalid pattern object');
 | |
|             }
 | |
|             // strip off leading ./ portions
 | |
|             // https://github.com/isaacs/node-glob/issues/570
 | |
|             while (parsed[0] === '.' && globParts[0] === '.') {
 | |
|                 parsed.shift();
 | |
|                 globParts.shift();
 | |
|             }
 | |
|             /* c8 ignore stop */
 | |
|             const p = new Pattern(parsed, globParts, 0, this.platform);
 | |
|             const m = new Minimatch(p.globString(), this.mmopts);
 | |
|             const children = globParts[globParts.length - 1] === '**';
 | |
|             const absolute = p.isAbsolute();
 | |
|             if (absolute)
 | |
|                 this.absolute.push(m);
 | |
|             else
 | |
|                 this.relative.push(m);
 | |
|             if (children) {
 | |
|                 if (absolute)
 | |
|                     this.absoluteChildren.push(m);
 | |
|                 else
 | |
|                     this.relativeChildren.push(m);
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     ignored(p) {
 | |
|         const fullpath = p.fullpath();
 | |
|         const fullpaths = `${fullpath}/`;
 | |
|         const relative = p.relative() || '.';
 | |
|         const relatives = `${relative}/`;
 | |
|         for (const m of this.relative) {
 | |
|             if (m.match(relative) || m.match(relatives))
 | |
|                 return true;
 | |
|         }
 | |
|         for (const m of this.absolute) {
 | |
|             if (m.match(fullpath) || m.match(fullpaths))
 | |
|                 return true;
 | |
|         }
 | |
|         return false;
 | |
|     }
 | |
|     childrenIgnored(p) {
 | |
|         const fullpath = p.fullpath() + '/';
 | |
|         const relative = (p.relative() || '.') + '/';
 | |
|         for (const m of this.relativeChildren) {
 | |
|             if (m.match(relative))
 | |
|                 return true;
 | |
|         }
 | |
|         for (const m of this.absoluteChildren) {
 | |
|             if (m.match(fullpath))
 | |
|                 return true;
 | |
|         }
 | |
|         return false;
 | |
|     }
 | |
| }
 | |
| //# sourceMappingURL=ignore.js.map
 |