mirror of
https://github.com/xivdev/Penumbra.git
synced 2025-12-12 10:17:22 +01:00
Make temporary collection always respect ownership.
This commit is contained in:
parent
2358eb378d
commit
ed717c69f9
2 changed files with 21 additions and 9 deletions
|
|
@ -48,8 +48,7 @@ public sealed partial class IndividualCollections : IReadOnlyList<(string Displa
|
|||
|
||||
// Handle generic NPC
|
||||
var npcIdentifier = _actors.CreateIndividualUnchecked(IdentifierType.Npc, ByteString.Empty,
|
||||
ushort.MaxValue,
|
||||
identifier.Kind, identifier.DataId);
|
||||
ushort.MaxValue, identifier.Kind, identifier.DataId);
|
||||
if (npcIdentifier.IsValid && _individuals.TryGetValue(npcIdentifier, out collection))
|
||||
return true;
|
||||
|
||||
|
|
@ -58,8 +57,7 @@ public sealed partial class IndividualCollections : IReadOnlyList<(string Displa
|
|||
return false;
|
||||
|
||||
identifier = _actors.CreateIndividualUnchecked(IdentifierType.Player, identifier.PlayerName,
|
||||
identifier.HomeWorld.Id,
|
||||
ObjectKind.None, uint.MaxValue);
|
||||
identifier.HomeWorld.Id, ObjectKind.None, uint.MaxValue);
|
||||
return CheckWorlds(identifier, out collection);
|
||||
}
|
||||
case IdentifierType.Npc: return _individuals.TryGetValue(identifier, out collection);
|
||||
|
|
|
|||
|
|
@ -126,7 +126,7 @@ public sealed unsafe class CollectionResolver(
|
|||
// The lobby uses the first 8 cutscene actors.
|
||||
var idx = gameObject->ObjectIndex - ObjectIndex.CutsceneStart.Index;
|
||||
if (characterList->CharacterMapping.FindFirst(m => m.ClientObjectIndex == idx, out var mapping)
|
||||
&& lobby->LobbyData.CharaSelectEntries.FindFirst(e => e.Value->ContentId == mapping.ContentId, out var charaEntry))
|
||||
&& lobby->LobbyData.CharaSelectEntries.FindFirst(e => e.Value->ContentId == mapping.ContentId, out var charaEntry))
|
||||
{
|
||||
var item = charaEntry.Value;
|
||||
var identifier = actors.CreatePlayer(new ByteString(item->Name), item->HomeWorldId);
|
||||
|
|
@ -199,10 +199,24 @@ public sealed unsafe class CollectionResolver(
|
|||
|
||||
/// <summary> Check both temporary and permanent character collections. Temporary first. </summary>
|
||||
private ModCollection? CollectionByIdentifier(ActorIdentifier identifier)
|
||||
=> tempCollections.Collections.TryGetCollection(identifier, out var collection)
|
||||
|| collectionManager.Active.Individuals.TryGetCollection(identifier, out collection)
|
||||
? collection
|
||||
: null;
|
||||
{
|
||||
if (tempCollections.Collections.TryGetCollection(identifier, out var collection))
|
||||
return collection;
|
||||
|
||||
// Always inherit ownership for temporary collections.
|
||||
if (identifier.Type is IdentifierType.Owned)
|
||||
{
|
||||
var playerIdentifier = actors.CreateIndividualUnchecked(IdentifierType.Player, identifier.PlayerName,
|
||||
identifier.HomeWorld.Id, ObjectKind.None, uint.MaxValue);
|
||||
if (tempCollections.Collections.TryGetCollection(playerIdentifier, out collection))
|
||||
return collection;
|
||||
}
|
||||
|
||||
if (collectionManager.Active.Individuals.TryGetCollection(identifier, out collection))
|
||||
return collection;
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
/// <summary> Check for the Yourself collection. </summary>
|
||||
private ModCollection? CheckYourself(ActorIdentifier identifier, Actor actor)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue