2
0
mirror of https://github.com/9ParsonsB/Pulsar.git synced 2025-10-26 04:49:50 -04:00
Commit Graph

214 Commits

Author SHA1 Message Date
F K
7e401adb6f Handle disposed timer object in ResetTimer() (#104)
I've had this occur a number of times (twice in a row yesterday) where if you receive new records while doing a long read-all, this exception crashes ObsCore.

So may need some further digging, but in the meantime, it won't crash here.
2023-03-01 16:21:23 -03:30
F K
6298316c94 Implement Tab separated export format (#103)
Tab separated output facilitates much more efficient opening of exported content in a spreadsheet for further data analysis, furthermore, it vastly reduces file size at the cost of human-readability. However, for the spreadsheet junkies among us, this is a welcome option.

To complement this, there is now an "Export Options" expander in the Core settings panel. Here one can select their preferred export style (default remains Fixed width) and now one can pre-select the export folder.

With this change, clicking export *will not* prompt for an export folder if one is already set. It will simply immediately export data.

Enjoy!
2023-02-26 11:20:59 -03:30
Xjph
f1790608e8 Avoid default null as collection key. 2023-01-19 19:34:34 -03:30
Xjph
c20af38a2e Always attempt properties upgrade 2023-01-19 19:28:31 -03:30
Xjph
e3e019e3f7 Handle missing effect full range of "+"s 2023-01-19 19:24:56 -03:30
Xjph
565aaf0838 Apply same test for string length for both ordinal operations 2023-01-19 19:20:58 -03:30
Xjph
52aa9fb1e5 Handle exceptions during async http requests. 2023-01-18 21:38:24 -03:30
Xjph
cacaa98033 Fix barycentre naming logic 2023-01-17 19:06:30 -03:30
Xjph
7a7c110b45 Skip property upgrade if no version present 2023-01-17 19:06:08 -03:30
Jonathan Miller
f9341c8cd3 Allow omit of explicit true in complex criteria (#101) 2022-12-21 10:02:06 -03:30
Xjph
229e76b87d Add SRV to VehicleSwitchTo 2022-12-13 19:12:34 -03:30
Xjph
c4309b204c Update innosetup for .NET 6 2022-12-12 21:50:06 -03:30
Xjph
eeae99dc2a Migrate to .NET 6 2022-12-04 15:01:56 -03:30
Xjph
388b7110cf U14 Status change 2022-12-04 15:01:24 -03:30
Xjph
e4049d67c1 Update 14 jounal changes 2022-12-04 11:00:07 -03:30
F K
9b34d50d32 Disable ShowActivated on notifications to avoid focus stealing (#98)
The recently updated avalonia seemed to change behavior in a way that caused notifications to steal focus from the game (often at at inopportune times). Not all users experienced this.
2022-12-04 10:41:30 -03:30
Xjph
3a9b4da2b7 Update framework xml doc 2022-10-30 19:17:01 -02:30
Xjph
62dd6730e8 Handle general exceptions during plugin loading. 2022-10-30 19:16:47 -02:30
Xjph
95db12de72 Additional custom criteria convenience functions. 2022-09-04 19:20:49 -02:30
Xjph
796819617b Odyssey Update 13 journal changes 2022-08-29 10:03:51 -02:30
Xjph
428b44cc2b Make file browse result check nullsafe 2022-08-29 09:48:15 -02:30
F K
11a2dcb819 Adds ring/belt helper functions, improved criteria debuggability (#96)
Adds new functions to the Lua environment available to custom criteria for handling rings and belts:
- the existing `rings(scan.Rings)` function behavior is unchanged
- NEW: `ringsOnly(scan.Rings)` and `beltsOnly(scan.Rings)` functions return ONLY rings or belts, respectively, and shortcuts the `scan.Rings` check
- NEW: `hasRings(scan.Rings)` and `hasBelts(scan.Rings)` functions return true if there are one or more proper rings or belts, respectively, in scan.Rings and shortcuts the check, too

Furthermore, this adds a debugging aid that identifies what custom criteria caused an error/crash. For simple criteria, ie:
`::Hot Landable::`
... the description "Hot Landable" is used. For complex criteria, you can now annotate the `::Criteria::` line with a description used for debugging like so:
`::Criteria=Hot Landable::`. Criteria errors are logged like this:

```
Error encountered in Elite Observatory from plugin Explorer while processing custom criteria 'Criteria14=I just crash' on scan:
```

Duplicates are avoided by prepending the user-provided description with a generated name (ie. `Criteria14`, in the example above).

Finally, the Detail expression for simple criteria can now safely reference values checked as part of the criteria condition. In particular, the Detail expression is now conditionally evaluated if the result is true. So the following will now work (previously it failed for non-star bodies when StarType was nil):

```
::Ringed Star::
scan.StarType and hasRings(scan.Rings)
::Detail::
'Star type: ' .. scan.StarType
```
2022-08-29 09:45:51 -02:30
F K
be6ef85fa4 Fix boolean logic bug that slows ancillary file reading to a crawl (#93)
Symptoms: App takes a very long time to start up, sluggish response to events because it's reading and processing every ancillary file 10x instead of just once when successful.
2022-07-24 18:47:18 -02:30
Jonathan Miller
342d5af11c Error handling improvements (#92)
* Consolidate plugin errors into single window.

* Handle error aggregation and loggin inside error reporter.

* Minor logging corrections.

* Error popup tweaking
2022-07-24 15:48:55 -02:30
Jonathan Miller
d8d5f2794b Limited retries when ancillary files are locked. (#90)
* Limited retries when anciliary files are locked.

* Move sleep to top of loop.
2022-07-24 09:54:31 -02:30
Xjph
ef31102d11 Handle barycentres without ordinals 2022-06-26 13:27:21 -02:30
Xjph
48284c574d Make Lua GC call nullsafe 2022-06-26 13:14:02 -02:30
Xjph
0c218ed52b Added framework xml documentation for all "exploration" events. 2022-06-12 14:44:04 -02:30
Xjph
9586e37be7 Update to Avalonia 0.10.15 2022-06-12 13:57:25 -02:30
Xjph
750cb5bec4 Handle anciliary files. 2022-06-09 21:10:35 -02:30
Xjph
3896621092 Add new FCMaterials file classes. 2022-06-09 21:10:26 -02:30
Xjph
d03d75aa24 Add descriptive error for multi-line criteria overruns. 2022-06-05 23:14:04 -02:30
Xjph
396a5a9217 Journal changes for Odyssey Update 12 2022-06-05 23:09:16 -02:30
Xjph
2200b94a6c Manually trigger Lua GC periodically. 2022-05-29 21:57:57 -02:30
Xjph
bb9185ef8a Guard against empty rings array. 2022-05-29 21:52:44 -02:30
F K
fc4d038645 Workaround journal bug: Already mapped bodies are not undiscovered (#85)
Just checking something is not already discovered is not enough. Many valuable bodies in the bubble mis-fire this criteria because the journal reports them as not discovered (because they have no first discoverer because they're well known systems). Checking that they're also not mapped ensures this doesn't happen.

Also simplified rendering of the string info.
2022-05-28 18:56:47 -02:30
F K
8106fbd0df Explorer: Show data for the current system only (#86)
Resolves #63

This behavior is suppressed during batch reads.
2022-05-28 10:33:36 -02:30
F K
6616b54852 Suppress pre-reading if read-all is also selected (as it is redundant) (#84) 2022-05-28 10:24:10 -02:30
Jonathan Miller
8de34a141c Export version fixes (#83)
* Add file association for .eop, prompt for install dir

* Handle .eop or .aip file passed as arg.

* VS2022 version bump

* Filter neutron stars and black holes from fast spinning criteria.

* Adjustments for new "high value" check

* Refactor herald cache

* Fix element order and namespaces for voice moods.

* Add explicit .Stop() between audio player calls.

* Use nullsafe member access instead of skipping

* Don't queue up a title that's already queued.

* Improve body ordinal handling for explorer speech titles.

* Escape strings being inserted into xml

* Handle flip-flopping JSON type

* Converter for flip-flopping property type

* Use the converter

* Escape characters *before* we wrap it in xml.

* Give Eahlstan his clear button. :D

* Exclude all stars from fast rotation check.

* Close outstanding popup notifications on exit.

* TO DONE

* [Herald] Suppress duplicate notification titles for spoken notifications

If you have notifications from multiple plugins producing notifications with the same title in quick succession (ie. "Body A 1 e" from both Explorer and BioInsights), the title on successive notifications will not be spoken again to save the breath of our friendly Azure speakers.

* Doc update

* Remove unintended member hiding

* Fix export errors when exporting BioInsights data, cleanup

Discovered a couple issues with exporting BioInsights data resulting from using two different types of objects in the data grid; improved error handling as well.

Also cleaned up some old-style read all code.

* Add read-all on launch setting

* Updated framework xml

* Improve high-value body description text

Co-authored-by: Fred Kuipers <mr.fredk@gmail.com>
2022-05-21 13:00:47 -02:30
Xjph
921f3867fa Add herald build api key to gitignore 2022-05-09 11:17:21 -02:30
Phil Chuang
9708a5fbc7 added HighValueMappable checks (#81)
* added HighValueMappable checks

* added high value mappable details
2022-05-09 11:12:17 -02:30
Jonathan Miller
fb45b5c3e2 Export, plugin archive install, and herald cache race condition fixes (#82)
* WIP: Grid export and plugin extraction

* Tweak export process

* Check for recursion of the same assembly load.

* Individual screens aren't always primary?

* Wait for cache to be writable

* Export selection only.

* Update built xml docs

* Ignore invalid archives.

* Need to ensure task is started.
2022-05-09 11:11:57 -02:30
Xjph
a67cf7f6bb Merge branch 'master' of https://github.com/Xjph/ObservatoryCore 2022-05-03 19:03:43 -02:30
Xjph
ee5833e58e Remove azure libraries from installer. 2022-05-03 19:03:41 -02:30
F K
ab365cd322 Expose core error logger to plugins and report custom criteria errors (#78)
* Expose core error logger to plugins and report custom criteria errors

Fixes #77

This adds an error logging method on the IObservatoryCore interface that writes the exception details to ObservatoryCore's central error log (found in `${Documents}/ObservatoryErrorLog.txt`). In addition, added a timestamp to each error log.

Also updates the Explorer to report Custom Criteria file load errors and execution errors to the log. Also updates HeraldNotifier to report CacheIndex.json parse failures to the error log as well.

* Expand debugging/error logging in Herald; cleanup empty mp3 files

Herald crashes if attempting to play 0-byte mp3s so if detected, delete, re-request (empty files can occur in some azure failure cases (ie. out of quota). Trap and log errors in other places in HeraldQueue to avoid hard crashes due to weird and wonderful unexpected stuff.
2022-05-03 19:02:31 -02:30
Xjph
7fe11b8094 fix monitor crash on no journals 2022-04-08 15:51:43 -02:30
Xjph
e7f7250c08 Correcting version check 2022-04-04 21:22:51 -02:30
Xjph
3fe3ef9901 Updated versioning 2022-04-04 12:29:59 -02:30
Jonathan Miller
1950d477fd Herald v2 (#74)
* Add speech rate setting

* Add volume slider

* New speech manager skeleton

* User API key from resx

* Implement voice list retrieve via new api

* Rewrite to use ObAPI, remove all dependancies

* Use volume setting

* Clean up using statements

* Volume and timing adjustments

* Lookup rate value

* Use numeric rates for tighter spread

* Manage plugin data folder via core interface

* Add check that nullable settings are not null.

* Get file size before it's deleted.

* Improve old settings migration.

* Ignore cache sizes below 1MB

* Re-index orphaned files in cache, purge legacy wav files.

* Call top level error logging for native voice exception.

* Async title and detail requests to remove pause

* Remove NetCoreAudio use of temp files.

* Remove orphan using.
2022-04-04 11:58:30 -02:30
F K
3cc8cc3abe Fix a "Call from invalid thread" exception. (#72)
Random occurrence triggered by a plugin's grid update. It's either fairly rare (related to something I was doing in-app) or new with a recent update to the plugin that caused it (just updated it last night).
2022-03-25 08:47:28 -02:30