mirror of
				https://github.com/9ParsonsB/Pulsar.git
				synced 2025-10-25 12:39:49 -04:00 
			
		
		
		
	Merge branch 'master' of https://github.com/Xjph/ObservatoryCore
This commit is contained in:
		| @@ -30,7 +30,11 @@ namespace Observatory.Botanist | ||||
|         ObservableCollection<object> GridCollection; | ||||
|         private PluginUI pluginUI; | ||||
|         private bool readAllInProgress = false; | ||||
|  | ||||
|         private Guid? samplerStatusNotification = null; | ||||
|         private BotanistSettings botanistSettings = new() | ||||
|         { | ||||
|             OverlayEnabled = true, | ||||
|         }; | ||||
|         public string Name => "Observatory Botanist"; | ||||
|  | ||||
|         public string ShortName => "Botanist"; | ||||
| @@ -39,7 +43,7 @@ namespace Observatory.Botanist | ||||
|  | ||||
|         public PluginUI PluginUI => pluginUI; | ||||
|  | ||||
|         public object Settings { get => null; set { } } | ||||
|         public object Settings { get => botanistSettings; set { botanistSettings = (BotanistSettings)value;  } } | ||||
|  | ||||
|         public void JournalEvent<TJournal>(TJournal journal) where TJournal : JournalBase | ||||
|         { | ||||
| @@ -82,7 +86,7 @@ namespace Observatory.Botanist | ||||
|                         var systemBodyId = (scanOrganic.SystemAddress, scanOrganic.Body); | ||||
|                         if (!BioPlanets.ContainsKey(systemBodyId)) | ||||
|                         { | ||||
|                             //Unlikely to ever end up in here, but just in case create a new planet entry. | ||||
|                             // Unlikely to ever end up in here, but just in case create a new planet entry. | ||||
|                             List<string> genus = new(); | ||||
|                             List<string> species = new(); | ||||
|                             genus.Add(scanOrganic.Genus_Localised); | ||||
| @@ -98,6 +102,25 @@ namespace Observatory.Botanist | ||||
|                             { | ||||
|                                 case ScanOrganicType.Log: | ||||
|                                 case ScanOrganicType.Sample: | ||||
|                                     if (!readAllInProgress && botanistSettings.OverlayEnabled) | ||||
|                                     { | ||||
|                                         NotificationArgs args = new() | ||||
|                                         { | ||||
|                                             Title = scanOrganic.Species_Localised, | ||||
|                                             Detail = string.Format("Sample {0} of 3", scanOrganic.ScanType == ScanOrganicType.Log ? 1 : 2), | ||||
|                                             Rendering = NotificationRendering.NativeVisual, | ||||
|                                             Timeout = 0, | ||||
|                                         }; | ||||
|                                         if (samplerStatusNotification == null) | ||||
|                                         { | ||||
|                                             samplerStatusNotification = Core.SendNotification(args); | ||||
|                                         } | ||||
|                                         else | ||||
|                                         { | ||||
|                                             Core.UpdateNotification(samplerStatusNotification.Value, args); | ||||
|                                         } | ||||
|                                     } | ||||
|  | ||||
|                                     if (!bioPlanet.speciesFound.Contains(scanOrganic.Species_Localised)) | ||||
|                                     { | ||||
|                                         bioPlanet.speciesFound.Add(scanOrganic.Species_Localised); | ||||
| @@ -108,12 +131,30 @@ namespace Observatory.Botanist | ||||
|                                     { | ||||
|                                         bioPlanet.speciesAnalysed.Add(scanOrganic.Species_Localised); | ||||
|                                     } | ||||
|                                     MaybeCloseSamplerStatusNotification(); | ||||
|                                     break; | ||||
|                             } | ||||
|                         } | ||||
|                         UpdateUIGrid(); | ||||
|                     } | ||||
|                     break; | ||||
|                 case LeaveBody: | ||||
|                 case FSDJump: | ||||
|                 case Shutdown: | ||||
|                     // These are all good reasons to kill any open notification. Note that SupercruiseEntry is NOT a | ||||
|                     // suitable reason to close the notification as the player hopping out only to double check the | ||||
|                     // DSS map for another location. Note that a game client crash will not close the status notification. | ||||
|                     MaybeCloseSamplerStatusNotification(); | ||||
|                     break; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         private void MaybeCloseSamplerStatusNotification() | ||||
|         { | ||||
|             if (samplerStatusNotification != null) | ||||
|             { | ||||
|                 Core.CancelNotification(samplerStatusNotification.Value); | ||||
|                 samplerStatusNotification = null; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|   | ||||
							
								
								
									
										15
									
								
								ObservatoryBotanist/BotanistSettings.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								ObservatoryBotanist/BotanistSettings.cs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| using Observatory.Framework; | ||||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Text; | ||||
| using System.Threading.Tasks; | ||||
|  | ||||
| namespace Observatory.Botanist | ||||
| { | ||||
|     class BotanistSettings | ||||
|     { | ||||
|         [SettingDisplayName("Enable Sampler Status Overlay")] | ||||
|         public bool OverlayEnabled { get; set; } | ||||
|     } | ||||
| } | ||||
| @@ -111,6 +111,7 @@ namespace Observatory | ||||
|             // Read at most the last two files (in case we were launched after the game and the latest | ||||
|             // journal is mostly empty) but keeping only the lines since the last FSDJump. | ||||
|             List<String> lastSystemLines = new(); | ||||
|             List<String> lastFileLines = new(); | ||||
|             string lastLoadGame = String.Empty; | ||||
|             bool sawFSDJump = false; | ||||
|             foreach (var file in files.Skip(Math.Max(files.Length - 2, 0))) | ||||
| @@ -125,29 +126,38 @@ namespace Observatory | ||||
|                         lastSystemLines.Clear(); | ||||
|                         sawFSDJump = true; | ||||
|                     } | ||||
|                     else if (eventType.Equals("Fileheader")) | ||||
|                     { | ||||
|                         lastFileLines.Clear(); | ||||
|                     } | ||||
|                     else if (eventType.Equals("LoadGame")) | ||||
|                     { | ||||
|                         lastLoadGame = line; | ||||
|                     } | ||||
|                     lastSystemLines.Add(line); | ||||
|                     lastFileLines.Add(line); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             // So we didn't see a jump in the recent logs. We could be re-logging, or something. | ||||
|             // Just bail on this attempt. | ||||
|             if (!sawFSDJump) return; | ||||
|  | ||||
|             // If we saw a LoadGame, insert it as well. This ensures odyssey biologicials are properly | ||||
|             // counted/presented. | ||||
|             if (!String.IsNullOrEmpty(lastLoadGame)) | ||||
|             // If we didn't see a jump in the recent logs (Cmdr is stationary in a system for a while | ||||
|             // ie. deep-space mining from a carrier), at very least, read from the beginning of the | ||||
|             // current journal file which includes the important stuff like the last "LoadGame", etc. This | ||||
|             // also helps out in cases where one forgets to hit "Start Monitor" until part-way into the | ||||
|             // session (if auto-start is not enabled). | ||||
|             List<string> linesToRead = lastFileLines; | ||||
|             if (sawFSDJump) | ||||
|             { | ||||
|                 lastSystemLines.Insert(0, lastLoadGame); | ||||
|                 // If we saw a LoadGame, insert it as well. This ensures odyssey biologicials are properly | ||||
|                 // counted/presented. | ||||
|                 if (!String.IsNullOrEmpty(lastLoadGame)) | ||||
|                 { | ||||
|                     lastSystemLines.Insert(0, lastLoadGame); | ||||
|                 } | ||||
|                 linesToRead = lastSystemLines; | ||||
|             } | ||||
|  | ||||
|             // We found an FSD jump, buffered the lines for that system (possibly including startup logs | ||||
|             // over a file boundary). Pump these through the plugins. | ||||
|             readall = true; | ||||
|             ReportErrors(ProcessLines(lastSystemLines, "Pre-read")); | ||||
|             ReportErrors(ProcessLines(linesToRead, "Pre-read")); | ||||
|             readall = false; | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -250,7 +250,7 @@ namespace Observatory.PluginManagement | ||||
|  | ||||
|                 //Importing Observatory.Framework in the Explorer Lua scripts causes an attempt to reload | ||||
|                 //the assembly, just hand it back the one we already have. | ||||
|                 if (name.Name.StartsWith("Observatory.Framework")) | ||||
|                 if (name.Name.StartsWith("Observatory.Framework") || name.Name == "ObservatoryFramework") | ||||
|                 { | ||||
|                     return context.Assemblies.Where(a => a.FullName.Contains("ObservatoryFramework")).First(); | ||||
|                 } | ||||
|   | ||||
| @@ -1,4 +1,5 @@ | ||||
| using System.Collections.Immutable; | ||||
| using Observatory.Framework.Files.ParameterTypes; | ||||
| using System.Collections.Immutable; | ||||
|  | ||||
| namespace Observatory.Framework.Files.Journal | ||||
| { | ||||
| @@ -6,6 +7,6 @@ namespace Observatory.Framework.Files.Journal | ||||
|     { | ||||
|         public string Vessel { get; init; } | ||||
|         public int Count { get; init; } | ||||
|         public ImmutableList<Cargo> Inventory { get; init; } | ||||
|         public ImmutableList<CargoType> Inventory { get; init; } | ||||
|     } | ||||
| } | ||||
|   | ||||
							
								
								
									
										8
									
								
								buildAllComponents
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										8
									
								
								buildAllComponents
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| #!/bin/bash | ||||
| dotnet build ./ObservatoryFramework/ObservatoryFramework.csproj "$@" | ||||
| dotnet build ./ObservatoryExplorer/ObservatoryExplorer.csproj "$@" | ||||
| dotnet build ./ObservatoryBotanist/ObservatoryBotanist.csproj "$@" | ||||
| if [ -f ../NetCoreAudio/NetCoreAudio/NetCoreAudio.csproj ]; then | ||||
|     dotnet build ../NetCoreAudio/NetCoreAudio/NetCoreAudio.csproj -c Release | ||||
|     dotnet build ./ObservatoryHerald/ObservatoryHerald.csproj "$@" | ||||
| fi | ||||
							
								
								
									
										7
									
								
								buildAllComponents.cmd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								buildAllComponents.cmd
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| dotnet build ./ObservatoryFramework/ObservatoryFramework.csproj %* | ||||
| dotnet build ./ObservatoryExplorer/ObservatoryExplorer.csproj %* | ||||
| dotnet build ./ObservatoryBotanist/ObservatoryBotanist.csproj %* | ||||
| IF EXIST ..\NetCoreAudio\NetCoreAudio\NetCoreAudio.csproj ( | ||||
|     dotnet build ../NetCoreAudio/NetCoreAudio/NetCoreAudio.csproj -c Release | ||||
|     dotnet build ./ObservatoryHerald/ObservatoryHerald.csproj %*  | ||||
| ) | ||||
		Reference in New Issue
	
	Block a user