Files
libremetaverse/LibreMetaverse.RLV/RlvSharedFolder.cs
nooperation d905210ecf Initial commit of LibreMetaverse.RLV and LibreMetaverse.RLV.Tests.
This library provides RLV command processing and ease of use for checking current RLV permissions and restrictions
2025-08-17 19:55:33 -04:00

124 lines
4.2 KiB
C#

using System;
using System.Collections.Generic;
namespace LibreMetaverse.RLV
{
public class RlvSharedFolder
{
public Guid Id { get; }
public string Name { get; set; }
public RlvSharedFolder? Parent { get; private set; }
public IReadOnlyList<RlvSharedFolder> Children => _children;
public IReadOnlyList<RlvInventoryItem> Items => _items;
private readonly List<RlvSharedFolder> _children;
private readonly List<RlvInventoryItem> _items;
public RlvSharedFolder(Guid id, string name)
{
Id = id;
Name = name ?? throw new ArgumentException("Name cannot be null", nameof(name));
Parent = null;
_children = [];
_items = [];
}
/// <summary>
/// Adds a child folder to this folder
/// </summary>
/// <param name="id">Folder ID</param>
/// <param name="name">Folder Name</param>
/// <returns>Newly added Folder</returns>
public RlvSharedFolder AddChild(Guid id, string name)
{
if (string.IsNullOrEmpty(name))
{
throw new ArgumentException("Name cannot be null or empty", nameof(name));
}
var newChild = new RlvSharedFolder(id, name)
{
Parent = this
};
_children.Add(newChild);
return newChild;
}
/// <summary>
/// Adds an item to this folder
/// </summary>
/// <param name="id">Item ID</param>
/// <param name="name">Item Name</param>
/// <param name="attachedTo">Item attachment point if attached</param>
/// <param name="attachedPrimId">ID of the attached prim</param>
/// <param name="wornOn">Item wearable type if worn</param>
/// <returns>Newly added item</returns>
public RlvInventoryItem AddItem(Guid id, string name, RlvAttachmentPoint? attachedTo, Guid? attachedPrimId, RlvWearableType? wornOn)
{
if (string.IsNullOrEmpty(name))
{
throw new ArgumentException("Name cannot be null or empty", nameof(name));
}
var newItem = new RlvInventoryItem(id, name, this, attachedTo, attachedPrimId, wornOn);
_items.Add(newItem);
return newItem;
}
/// <summary>
/// Gets a list of items currently worn as the specified wearable type
/// </summary>
/// <param name="wearableType">Finds all items worn of this type</param>
/// <returns>Collection of items that are worn as the specified wearable type</returns>
public IEnumerable<RlvInventoryItem> GetWornItems(RlvWearableType wearableType)
{
foreach (var item in Items)
{
if (item.WornOn == wearableType)
{
yield return item;
}
}
foreach (var child in Children)
{
foreach (var childItem in child.GetWornItems(wearableType))
{
yield return childItem;
}
}
}
/// <summary>
/// Gets a list of items currently attached to the specified attachment point
/// </summary>
/// <param name="attachmentPoint">Finds all items attached to this attachment point</param>
/// <returns>Collection of items currently attached to the specified attachment point</returns>
public IEnumerable<RlvInventoryItem> GetAttachedItems(RlvAttachmentPoint attachmentPoint)
{
foreach (var item in Items)
{
if (item.AttachedTo == attachmentPoint)
{
yield return item;
}
}
foreach (var child in Children)
{
foreach (var childItem in child.GetAttachedItems(attachmentPoint))
{
yield return childItem;
}
}
}
public override string ToString()
{
return $"{Name ?? Id.ToString()} (Children: {_children.Count}, Items: {_items.Count})";
}
}
}