VR4RoboticArm2/VR4RoboticArm/Library/PackageCache/com.meta.xr.sdk.interaction/Runtime/Scripts/Attributes/OptionalAttribute.cs
IonutMocanu d7aba243a2 Main
2025-09-08 11:04:02 +03:00

77 lines
2.6 KiB
C#

/*
* Copyright (c) Meta Platforms, Inc. and affiliates.
* All rights reserved.
*
* Licensed under the Oculus SDK License Agreement (the "License");
* you may not use the Oculus SDK except in compliance with the License,
* which is provided at the time of installation or download, or which
* otherwise accompanies this software in either electronic or hard copy form.
*
* You may obtain a copy of the License at
*
* https://developer.oculus.com/licenses/oculussdk/
*
* Unless required by applicable law or agreed to in writing, the Oculus SDK
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
using UnityEngine;
namespace Oculus.Interaction
{
/// <summary>
/// Used on a SerializedField and surfaces the expectation that this field can remain empty.
/// </summary>
public class OptionalAttribute : PropertyAttribute
{
/// <summary>
/// Flags that determine the visibility of the Optional tag in the editor.
/// </summary>
[System.Flags]
public enum Flag
{
/// <summary>
/// Presents the Optional tag and moves it into the Optional Section
/// </summary>
None = 0,
/// <summary>
/// Indicates that if the reference is missing, a new object will be
/// created and linked to it during runtime.
/// </summary>
AutoGenerated = 1 << 0,
/// <summary>
/// Indicates that even though the reference is Optional, it is important
/// for the component to work as expected.
/// </summary>
DontHide = 1 << 1,
/// <summary>
/// Indicates that the field is obsolete and should be avoided
/// </summary>
Obsolete = 1 << 2,
}
/// <summary>
/// These flags determine the behavior of the Optional tag in the editor.
/// </summary>
public Flag Flags { get; private set; } = Flag.None;
/// <summary>
/// Create a new Optional attribute with default flags.
/// </summary>
public OptionalAttribute() { }
/// <summary>
/// Create a new Optional attribute with the specified flags.
/// </summary>
/// <param name="flags">The flags that determine the behavior of
/// this attribute.</param>
public OptionalAttribute(Flag flags)
{
Flags = flags;
}
}
}