2014-12-06 06:25:17 -05:00
|
|
|
module.exports = function AttachCommentTreeVisitor(ParseTreeVisitor, log) {
|
|
|
|
|
|
|
|
function AttachCommentTreeVisitorImpl() {
|
|
|
|
ParseTreeVisitor.call(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
AttachCommentTreeVisitorImpl.prototype = {
|
|
|
|
|
|
|
|
__proto__: ParseTreeVisitor.prototype,
|
|
|
|
|
|
|
|
|
|
|
|
visit: function(tree, comments) {
|
|
|
|
this.comments = comments;
|
|
|
|
this.index = 0;
|
|
|
|
this.currentComment = this.comments[this.index];
|
|
|
|
|
|
|
|
if (this.currentComment) log.silly('comment: ' +
|
|
|
|
this.currentComment.range.start.line + ' - ' +
|
2015-03-18 13:54:15 -04:00
|
|
|
this.currentComment.range.end.line + ' : ' +
|
|
|
|
this.currentComment.range.toString());
|
2014-12-06 06:25:17 -05:00
|
|
|
|
|
|
|
ParseTreeVisitor.prototype.visit.call(this, tree);
|
|
|
|
},
|
|
|
|
|
|
|
|
// Really we ought to subclass ParseTreeVisitor but this is fiddly in ES5 so
|
|
|
|
// it is easier to simply override the prototype's method on the instance
|
|
|
|
visitAny: function(tree) {
|
2015-03-18 13:54:15 -04:00
|
|
|
if (tree && tree.location && tree.location.start && this.currentComment &&
|
|
|
|
this.currentComment.range.end.offset < tree.location.start.offset) {
|
|
|
|
log.silly('tree: ' + tree.constructor.name + ' - ' + tree.location.start.line);
|
|
|
|
while (this.currentComment &&
|
|
|
|
this.currentComment.range.end.offset < tree.location.start.offset) {
|
|
|
|
log.silly('comment: ' + this.currentComment.range.start.line + ' - ' +
|
|
|
|
this.currentComment.range.end.line + ' : ' +
|
|
|
|
this.currentComment.range.toString());
|
2014-12-06 06:25:17 -05:00
|
|
|
tree.commentBefore = this.currentComment;
|
|
|
|
this.currentComment.treeAfter = tree;
|
|
|
|
this.index++;
|
|
|
|
this.currentComment = this.comments[this.index];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ParseTreeVisitor.prototype.visitAny.call(this, tree);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
return AttachCommentTreeVisitorImpl;
|
|
|
|
};
|