feat: Add support for ASOCTD, ALQDS, and HALO remark modifiers

Co-authored-by: aider (gemini/gemini-2.5-pro) <aider@aider.chat>
This commit is contained in:
2026-02-14 15:48:03 -07:00
parent 3836f7881d
commit d0416eff79
+20
View File
@@ -277,10 +277,16 @@
decoded.push(` - ${decodeObscurationRemark(part)}`);
} else if (part.match(/^([A-Z]{2}\d)+$/)) {
decoded.push(` - ${decodeCloudTypesRemark(part, metarString)}`);
} else if (part === 'VIRGA' && i + 1 < parts.length && parts[i+1] === 'ALQDS') {
decoded.push(` - VIRGA ALQDS: Virga in all quadrants`);
i++; // Consume ALQDS
} else if (part === 'VIRGA' && i + 1 < parts.length && directions[parts[i+1]]) {
const direction = directions[parts[i+1]];
decoded.push(` - VIRGA ${parts[i+1]}: Virga to the ${direction.toLowerCase()}`);
i++; // Consume direction part
} else if (part === 'TCU' && i + 1 < parts.length && parts[i+1] === 'ALQDS') {
decoded.push(` - TCU ALQDS: Towering cumulus in all quadrants`);
i++; // Consume ALQDS
} else if (part === 'TCU' && i + 2 < parts.length && parts[i+1] === 'DSNT' && directions[parts[i+2]]) {
const direction = directions[parts[i+2]];
decoded.push(` - TCU DSNT ${parts[i+2]}: Towering cumulus distant ${direction.toLowerCase()}`);
@@ -301,6 +307,20 @@
}
decoded.push(remark);
i += consumed;
} else if (cloudTypes[part] && i + 1 < parts.length && parts[i+1] === 'ASOCTD') {
const cloudName = cloudTypes[part];
let remark = ` - ${part} ASOCTD: ${cloudName} associated`;
let consumed = 1;
if (i + 3 < parts.length && parts[i+2] === '/' && parts[i+3] === 'HALO') {
remark = ` - ${part} ASOCTD / HALO: ${cloudName} associated with Halo phenomenon`;
consumed = 3;
}
decoded.push(remark);
i += consumed;
} else if (cloudTypes[part] && i + 1 < parts.length && parts[i+1] === 'ALQDS') {
const cloudName = cloudTypes[part];
decoded.push(` - ${part} ALQDS: ${cloudName} in all quadrants`);
i++; // Consume ALQDS
} else if (specialRemarks[part]) {
decoded.push(` - ${part}: ${specialRemarks[part]}`);
} else if (cloudTypes[part] && i + 1 < parts.length && parts[i + 1] === 'TR') {