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>
45 lines
1.4 KiB
JavaScript
45 lines
1.4 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.removeSections = removeSections;
|
|
|
|
var _ast = require("@webassemblyjs/ast");
|
|
|
|
var _helperBuffer = require("@webassemblyjs/helper-buffer");
|
|
|
|
function removeSections(ast, uint8Buffer, section) {
|
|
var sectionMetadatas = (0, _ast.getSectionMetadatas)(ast, section);
|
|
|
|
if (sectionMetadatas.length === 0) {
|
|
throw new Error("Section metadata not found");
|
|
}
|
|
|
|
return sectionMetadatas.reverse().reduce(function (uint8Buffer, sectionMetadata) {
|
|
var startsIncludingId = sectionMetadata.startOffset - 1;
|
|
var ends = section === "start" ? sectionMetadata.size.loc.end.column + 1 : sectionMetadata.startOffset + sectionMetadata.size.value + 1;
|
|
var delta = -(ends - startsIncludingId);
|
|
/**
|
|
* update AST
|
|
*/
|
|
// Once we hit our section every that is after needs to be shifted by the delta
|
|
|
|
var encounteredSection = false;
|
|
(0, _ast.traverse)(ast, {
|
|
SectionMetadata: function SectionMetadata(path) {
|
|
if (path.node.section === section) {
|
|
encounteredSection = true;
|
|
return path.remove();
|
|
}
|
|
|
|
if (encounteredSection === true) {
|
|
(0, _ast.shiftSection)(ast, path.node, delta);
|
|
}
|
|
}
|
|
}); // replacement is nothing
|
|
|
|
var replacement = [];
|
|
return (0, _helperBuffer.overrideBytesInBuffer)(uint8Buffer, startsIncludingId, ends, replacement);
|
|
}, uint8Buffer);
|
|
} |