From b8745fa7e3dea877eeee8e486e801e71cc5c8a8c Mon Sep 17 00:00:00 2001 From: punkfairie Date: Wed, 10 May 2023 22:00:33 -0700 Subject: [PATCH] Find last location if no FSDJump found. --- src/interfaces/JournalInterface.ts | 26 +++++++++++++++++++++----- 1 file changed, 21 insertions(+), 5 deletions(-) diff --git a/src/interfaces/JournalInterface.ts b/src/interfaces/JournalInterface.ts index a33cfe9..84564db 100644 --- a/src/interfaces/JournalInterface.ts +++ b/src/interfaces/JournalInterface.ts @@ -76,15 +76,31 @@ export class JournalInterface extends EventEmitter { this.emit('ENTERED_NEW_SYSTEM') return false } else if (last) { - log('Warning: unable to find last hyperspace jump. Current location unknown.') + log('Unable to find last hyperspace jump. Searching for last known location.') return false } } }).then(() => { - if (this.location.name !== 'Unknown') { - log('Attempting to find scanned bodies in current system.') - this.getScannedBodies() - } + lineReader.eachLine(this.currentJournal, (raw: string, last: boolean) => { + if (raw) { + const line = JSON.parse(raw) + + if (line.event === 'Location') { + this.location = new System(line.StarSystem) + log(`Current location set to ${this.location.name}.`) + this.emit('ENTERED_NEW_SYSTEM') + return false + } else if (last) { + log('WARNING: Unable to find last known location.') + return false + } + } + }).then(() => { + if (this.location.name !== 'Unknown') { + log('Attempting to find scanned bodies in current system.') + this.getScannedBodies() + } + }) }) }