Update AssetDatabase
This commit is contained in:
80
Ghost.Editor.Core/AssetHandle/AssetImporter.cs
Normal file
80
Ghost.Editor.Core/AssetHandle/AssetImporter.cs
Normal file
@@ -0,0 +1,80 @@
|
||||
using Ghost.Core;
|
||||
|
||||
namespace Ghost.Editor.Core.AssetHandle;
|
||||
|
||||
/// <summary>
|
||||
/// Base class for all asset importers.
|
||||
/// Asset importers process source files and convert them into engine-ready formats.
|
||||
/// </summary>
|
||||
/// <typeparam name="TSettings">The type of importer settings this importer uses.</typeparam>
|
||||
internal abstract class AssetImporter<TSettings>
|
||||
where TSettings : ImporterSettings, new()
|
||||
{
|
||||
/// <summary>
|
||||
/// Import the asset at the specified path with the given settings.
|
||||
/// </summary>
|
||||
/// <param name="assetPath">Full path to the source asset file.</param>
|
||||
/// <param name="meta">Metadata for the asset.</param>
|
||||
/// <returns>Result indicating success or failure.</returns>
|
||||
public abstract Task<Result> ImportAsync(string assetPath, AssetMeta meta);
|
||||
|
||||
/// <summary>
|
||||
/// Export in-memory asset data to disk.
|
||||
/// Override this method to support creating assets from code.
|
||||
/// </summary>
|
||||
/// <typeparam name="T">Type of asset data to export.</typeparam>
|
||||
/// <param name="assetPath">Full path where the asset should be saved.</param>
|
||||
/// <param name="assetData">In-memory asset data to serialize.</param>
|
||||
/// <param name="meta">Metadata for the asset.</param>
|
||||
/// <returns>Result indicating success or failure.</returns>
|
||||
public virtual Task<Result> ExportAsync<T>(string assetPath, T assetData, AssetMeta meta) where T : class
|
||||
{
|
||||
return Task.FromResult(Result.Failure("This importer does not support exporting assets."));
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Get the settings for this importer from the metadata.
|
||||
/// Creates default settings if none exist.
|
||||
/// </summary>
|
||||
/// <param name="meta">Asset metadata.</param>
|
||||
/// <returns>The importer settings.</returns>
|
||||
protected TSettings GetSettings(AssetMeta meta)
|
||||
{
|
||||
var typeName = GetType().Name;
|
||||
var settings = meta.GetImporterSettings<TSettings>(typeName);
|
||||
|
||||
if (settings != null)
|
||||
{
|
||||
return settings;
|
||||
}
|
||||
|
||||
var defaultSettings = new TSettings();
|
||||
meta.SetImporterSettings(typeName, defaultSettings);
|
||||
return defaultSettings;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Validate dependencies referenced by this asset.
|
||||
/// Dependencies are extracted from asset content during import and stored in the database.
|
||||
/// </summary>
|
||||
/// <param name="dependencies">List of dependency GUIDs extracted from the asset.</param>
|
||||
/// <returns>Result indicating if all dependencies are valid.</returns>
|
||||
protected virtual ValueTask<Result> ValidateDependenciesAsync(List<Guid> dependencies)
|
||||
{
|
||||
foreach (var dependencyGuid in dependencies)
|
||||
{
|
||||
var path = AssetDatabase.GuidToPath(dependencyGuid);
|
||||
if (path.IsFailure)
|
||||
{
|
||||
return ValueTask.FromResult(Result.Failure($"Missing dependency: {dependencyGuid}"));
|
||||
}
|
||||
|
||||
if (!File.Exists(path.Value))
|
||||
{
|
||||
return ValueTask.FromResult(Result.Failure($"Dependency file does not exist: {path.Value}"));
|
||||
}
|
||||
}
|
||||
|
||||
return ValueTask.FromResult(Result.Success());
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user