You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					54 lines
				
				1.5 KiB
			
		
		
			
		
	
	
					54 lines
				
				1.5 KiB
			| 
											2 years ago
										 | // Basically just a wrapper around an fs.readlink
 | ||
|  | //
 | ||
|  | // XXX: Enhance this to support the Link type, by keeping
 | ||
|  | // a lookup table of {<dev+inode>:<path>}, so that hardlinks
 | ||
|  | // can be preserved in tarballs.
 | ||
|  | 
 | ||
|  | module.exports = LinkReader | ||
|  | 
 | ||
|  | var fs = require('graceful-fs') | ||
|  | var inherits = require('inherits') | ||
|  | var Reader = require('./reader.js') | ||
|  | 
 | ||
|  | inherits(LinkReader, Reader) | ||
|  | 
 | ||
|  | function LinkReader (props) { | ||
|  |   var self = this | ||
|  |   if (!(self instanceof LinkReader)) { | ||
|  |     throw new Error('LinkReader must be called as constructor.') | ||
|  |   } | ||
|  | 
 | ||
|  |   if (!((props.type === 'Link' && props.Link) || | ||
|  |     (props.type === 'SymbolicLink' && props.SymbolicLink))) { | ||
|  |     throw new Error('Non-link type ' + props.type) | ||
|  |   } | ||
|  | 
 | ||
|  |   Reader.call(self, props) | ||
|  | } | ||
|  | 
 | ||
|  | // When piping a LinkReader into a LinkWriter, we have to
 | ||
|  | // already have the linkpath property set, so that has to
 | ||
|  | // happen *before* the "ready" event, which means we need to
 | ||
|  | // override the _stat method.
 | ||
|  | LinkReader.prototype._stat = function (currentStat) { | ||
|  |   var self = this | ||
|  |   fs.readlink(self._path, function (er, linkpath) { | ||
|  |     if (er) return self.error(er) | ||
|  |     self.linkpath = self.props.linkpath = linkpath | ||
|  |     self.emit('linkpath', linkpath) | ||
|  |     Reader.prototype._stat.call(self, currentStat) | ||
|  |   }) | ||
|  | } | ||
|  | 
 | ||
|  | LinkReader.prototype._read = function () { | ||
|  |   var self = this | ||
|  |   if (self._paused) return | ||
|  |   // basically just a no-op, since we got all the info we need
 | ||
|  |   // from the _stat method
 | ||
|  |   if (!self._ended) { | ||
|  |     self.emit('end') | ||
|  |     self.emit('close') | ||
|  |     self._ended = true | ||
|  |   } | ||
|  | } |