Adjust European short trip heuristic from >3 days to >1 day to correctly detect when user has returned home from European trips. This fixes the April 29-30, 2023 case where the location incorrectly showed "Sankt Georg, Hamburg" instead of "Bristol" when the user was free (no events scheduled) after the foss-north trip ended on April 27. The previous logic required more than 3 days to pass before assuming return home from European countries, but for short European trips by rail/ferry, users typically return within 1-2 days. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
58 lines
2 KiB
JavaScript
58 lines
2 KiB
JavaScript
/**
|
|
* @fileoverview Define the cursor which iterates tokens and comments in reverse.
|
|
* @author Toru Nagashima
|
|
*/
|
|
"use strict";
|
|
|
|
//------------------------------------------------------------------------------
|
|
// Requirements
|
|
//------------------------------------------------------------------------------
|
|
|
|
const Cursor = require("./cursor");
|
|
const utils = require("./utils");
|
|
|
|
//------------------------------------------------------------------------------
|
|
// Exports
|
|
//------------------------------------------------------------------------------
|
|
|
|
/**
|
|
* The cursor which iterates tokens and comments in reverse.
|
|
*/
|
|
module.exports = class BackwardTokenCommentCursor extends Cursor {
|
|
|
|
/**
|
|
* Initializes this cursor.
|
|
* @param {Token[]} tokens The array of tokens.
|
|
* @param {Comment[]} comments The array of comments.
|
|
* @param {Object} indexMap The map from locations to indices in `tokens`.
|
|
* @param {number} startLoc The start location of the iteration range.
|
|
* @param {number} endLoc The end location of the iteration range.
|
|
*/
|
|
constructor(tokens, comments, indexMap, startLoc, endLoc) {
|
|
super();
|
|
this.tokens = tokens;
|
|
this.comments = comments;
|
|
this.tokenIndex = utils.getLastIndex(tokens, indexMap, endLoc);
|
|
this.commentIndex = utils.search(comments, endLoc) - 1;
|
|
this.border = startLoc;
|
|
}
|
|
|
|
/** @inheritdoc */
|
|
moveNext() {
|
|
const token = (this.tokenIndex >= 0) ? this.tokens[this.tokenIndex] : null;
|
|
const comment = (this.commentIndex >= 0) ? this.comments[this.commentIndex] : null;
|
|
|
|
if (token && (!comment || token.range[1] > comment.range[1])) {
|
|
this.current = token;
|
|
this.tokenIndex -= 1;
|
|
} else if (comment) {
|
|
this.current = comment;
|
|
this.commentIndex -= 1;
|
|
} else {
|
|
this.current = null;
|
|
}
|
|
|
|
return Boolean(this.current) && (this.border === -1 || this.current.range[0] >= this.border);
|
|
}
|
|
};
|