Compare commits
11 Commits
draft_text
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
| c78907aeeb | |||
| 1d5b4a4ab7 | |||
| 1dc11c5f76 | |||
| 7e6b950fee | |||
| f32feecd4f | |||
| b03b10b4ed | |||
| 607d5cb6a5 | |||
| f70cab525b | |||
| cadb3e02ac | |||
| 3a08d8ae16 | |||
| b4fabd01bb |
8
.gitignore
vendored
8
.gitignore
vendored
@@ -2,4 +2,10 @@ bin/
|
|||||||
obj/
|
obj/
|
||||||
/packages/
|
/packages/
|
||||||
riderModule.iml
|
riderModule.iml
|
||||||
/_ReSharper.Caches/
|
/_ReSharper.Caches/
|
||||||
|
/summerizer.py
|
||||||
|
/NuGet.config
|
||||||
|
/Polonium.Tasks.sln.DotSettings.user
|
||||||
|
/VersionInfo.props
|
||||||
|
.idea/
|
||||||
|
/summerizer
|
||||||
|
|||||||
13
.idea/.idea.Polonium.Tasks/.idea/.gitignore
generated
vendored
13
.idea/.idea.Polonium.Tasks/.idea/.gitignore
generated
vendored
@@ -1,13 +0,0 @@
|
|||||||
# Default ignored files
|
|
||||||
/shelf/
|
|
||||||
/workspace.xml
|
|
||||||
# Rider ignored files
|
|
||||||
/.idea.Polonium.Tasks.iml
|
|
||||||
/modules.xml
|
|
||||||
/projectSettingsUpdater.xml
|
|
||||||
/contentModel.xml
|
|
||||||
# Editor-based HTTP Client requests
|
|
||||||
/httpRequests/
|
|
||||||
# Datasource local storage ignored files
|
|
||||||
/dataSources/
|
|
||||||
/dataSources.local.xml
|
|
||||||
@@ -1,6 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="utf-8" ?>
|
<?xml version="1.0" encoding="utf-8" ?>
|
||||||
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
|
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<TasksFolder>$(MSBuildThisFileDirectory)tasks/netstandard2.0/</TasksFolder>
|
<TasksFolder>$(MSBuildThisFileDirectory)tasks/netstandard2.0/</TasksFolder>
|
||||||
<TasksAssembly>$(TasksFolder)$(MSBuildThisFileName).dll</TasksAssembly>
|
<TasksAssembly>$(TasksFolder)$(MSBuildThisFileName).dll</TasksAssembly>
|
||||||
@@ -13,4 +12,8 @@
|
|||||||
TaskName="GenerateTextureSetTask"
|
TaskName="GenerateTextureSetTask"
|
||||||
AssemblyFile="$(TasksAssembly)"
|
AssemblyFile="$(TasksAssembly)"
|
||||||
/>
|
/>
|
||||||
|
<UsingTask
|
||||||
|
TaskName="GenerateRegistryPassThrough"
|
||||||
|
AssemblyFile="$(TasksAssembly)"
|
||||||
|
/>
|
||||||
</Project>
|
</Project>
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk">
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
<Import Project="VersionInfo.props" Condition="Exists('VersionInfo.props')" />
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<TargetFramework>netstandard2.0</TargetFramework>
|
<TargetFramework>netstandard2.0</TargetFramework>
|
||||||
<IsPackable>true</IsPackable>
|
<IsPackable>true</IsPackable>
|
||||||
@@ -8,7 +8,7 @@
|
|||||||
<RootNamespace>Polonium.Tasks</RootNamespace>
|
<RootNamespace>Polonium.Tasks</RootNamespace>
|
||||||
<AssemblyName>Polonium.Tasks</AssemblyName>
|
<AssemblyName>Polonium.Tasks</AssemblyName>
|
||||||
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
|
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
|
||||||
<Version>0.1.1-x</Version>
|
<Version>$(PoloniumTasksVersion)</Version>
|
||||||
<CopyLocalLockFileAssemblies>true</CopyLocalLockFileAssemblies>
|
<CopyLocalLockFileAssemblies>true</CopyLocalLockFileAssemblies>
|
||||||
<GenerateDependencyFile>true</GenerateDependencyFile>
|
<GenerateDependencyFile>true</GenerateDependencyFile>
|
||||||
<TargetsForTfmSpecificBuildOutput>$(TargetsForTfmSpecificBuildOutput);CopyProjectReferencesToPackage</TargetsForTfmSpecificBuildOutput>
|
<TargetsForTfmSpecificBuildOutput>$(TargetsForTfmSpecificBuildOutput);CopyProjectReferencesToPackage</TargetsForTfmSpecificBuildOutput>
|
||||||
@@ -18,21 +18,9 @@
|
|||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference
|
<PackageReference Include="Microsoft.Build" Version="17.12.6" PrivateAssets="all" />
|
||||||
Include="Microsoft.Build"
|
<PackageReference Include="Microsoft.Build.Tasks.Core" Version="17.12.6" PrivateAssets="all" />
|
||||||
Version="17.12.6"
|
<PackageReference Include="Microsoft.CodeAnalysis" Version="4.12.0" PrivateAssets="all" />
|
||||||
PrivateAssets="all"
|
|
||||||
/>
|
|
||||||
<PackageReference
|
|
||||||
Include="Microsoft.Build.Tasks.Core"
|
|
||||||
Version="17.12.6"
|
|
||||||
PrivateAssets="all"
|
|
||||||
/>
|
|
||||||
<PackageReference
|
|
||||||
Include="Microsoft.CodeAnalysis"
|
|
||||||
Version="4.12.0"
|
|
||||||
PrivateAssets="all"
|
|
||||||
/>
|
|
||||||
<EmbeddedResource Update="Resources.resx">
|
<EmbeddedResource Update="Resources.resx">
|
||||||
<Generator>ResXFileCodeGenerator</Generator>
|
<Generator>ResXFileCodeGenerator</Generator>
|
||||||
<LastGenOutput>Resources.Designer.cs</LastGenOutput>
|
<LastGenOutput>Resources.Designer.cs</LastGenOutput>
|
||||||
@@ -44,11 +32,8 @@
|
|||||||
</Compile>
|
</Compile>
|
||||||
<AdditionalFiles Remove="AnalyzerReleases.Shipped.md" />
|
<AdditionalFiles Remove="AnalyzerReleases.Shipped.md" />
|
||||||
<AdditionalFiles Remove="AnalyzerReleases.Unshipped.md" />
|
<AdditionalFiles Remove="AnalyzerReleases.Unshipped.md" />
|
||||||
<None
|
<None Include="Package/build/**/*" Pack="true" PackagePath="build" />
|
||||||
Include="Package/build/**/*"
|
<None Include="VersionInfo.props" Condition="Exists('VersionInfo.props')" Pack="true" PackagePath="build" />
|
||||||
Pack="true"
|
|
||||||
PackagePath="build"
|
|
||||||
/>
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<Target Name="CopyProjectReferencesToPackage" DependsOnTargets="ResolveReferences">
|
<Target Name="CopyProjectReferencesToPackage" DependsOnTargets="ResolveReferences">
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
@@ -64,10 +49,10 @@
|
|||||||
Condition="'$(GenerateDependencyFile)' == 'true'"
|
Condition="'$(GenerateDependencyFile)' == 'true'"
|
||||||
>
|
>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<BuiltProjectOutputGroupOutput
|
<BuiltProjectOutputGroupOutput
|
||||||
Include="$(ProjectDepsFilePath)"
|
Include="$(ProjectDepsFilePath)"
|
||||||
TargetPath="$(ProjectDepsFileName)"
|
TargetPath="$(ProjectDepsFileName)"
|
||||||
FinalOutputPath="$(ProjectDepsFilePath)"
|
FinalOutputPath="$(ProjectDepsFilePath)"
|
||||||
/>
|
/>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
</Target>
|
</Target>
|
||||||
@@ -79,8 +64,6 @@
|
|||||||
</Target>
|
</Target>
|
||||||
|
|
||||||
<Target Name="CopyPackageToLocalFeed" AfterTargets="Pack">
|
<Target Name="CopyPackageToLocalFeed" AfterTargets="Pack">
|
||||||
<Message Text="Executing Copy Pack Task" Importance="high" />
|
|
||||||
<Message Text="OutputPath: $(OutputPath)" Importance="high" />
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<NuGetPackages Include="$(OutputPath)../*.nupkg" />
|
<NuGetPackages Include="$(OutputPath)../*.nupkg" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|||||||
33
README.md
Normal file
33
README.md
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
# Polonium.Tasks
|
||||||
|
|
||||||
|
**Project Description**
|
||||||
|
Polonium.Tasks is a set of MSBuild tasks created to support Godot C# projects using the Polonium library. It streamlines building, cleaning, packaging, and code generation steps by automating operations around scripts, templates, and resources.
|
||||||
|
|
||||||
|
**Key Features**
|
||||||
|
- **GenerateProxyNodesTask**: Examines source directories and generates script proxies based on `[ProxyNode]` in Polonium, should not be used manually in custom project.
|
||||||
|
- **GenerateRegistryPassThrough**: Produces bridging files for `[RegistryPassThrough]` attributes in Polonium, should not be used manually in custom project
|
||||||
|
- **GenerateTextureSetTask**: Helps build and bundle multiple textures (e.g., button states) into a coherent set.
|
||||||
|
- **Custom Build Workflows**: Extends typical MSBuild processes to manage Godot-specific tasks.
|
||||||
|
|
||||||
|
**Installation**
|
||||||
|
1. Add the package to your project via `.csproj`:
|
||||||
|
```xml
|
||||||
|
<PackageReference Include="Polonium.Tasks" Version="x.x.x" />
|
||||||
|
```
|
||||||
|
2. Restore the packages and build your project.
|
||||||
|
|
||||||
|
**Usage Example**
|
||||||
|
```xml
|
||||||
|
<Target Name="Prepare" BeforeTargets="BeforeBuild">
|
||||||
|
<GenerateProxyNodesTask
|
||||||
|
SourceDirectory="$(ProjectDir)Package/embedded/GlobalClasses"
|
||||||
|
TemplateDirectory="$(ProjectDir)Package/embedded/polonium_templates"
|
||||||
|
AttributeName="ProxyNode"
|
||||||
|
/>
|
||||||
|
</Target>
|
||||||
|
```
|
||||||
|
When you run a build, these tasks will automatically generate or update relevant files, saving you manual overhead.
|
||||||
|
|
||||||
|
**License**
|
||||||
|
This project is licensed under the [MIT License](https://opensource.org/licenses/MIT).
|
||||||
|
|
||||||
12
publish
Normal file → Executable file
12
publish
Normal file → Executable file
@@ -1,2 +1,12 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
dotnet nuget push "$(ls -t ./bin/Debug/Polonium.Tasks.*.nupkg | head -n 1)" --source hangman-lab
|
|
||||||
|
SCRIPT_DIR=$(dirname "$(realpath "${BASH_SOURCE[0]}")")/
|
||||||
|
LATEST_PACKAGE=$(ls -t "${SCRIPT_DIR}"bin/Debug/Polonium.Tasks.*.nupkg 2>/dev/null | head -n 1)
|
||||||
|
|
||||||
|
if [[ -z "$LATEST_PACKAGE" ]]; then
|
||||||
|
echo "❌ Error: No .nupkg file found in ${SCRIPT_DIR}/bin/Debug/"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "🚀 Pushing NuGet package: $LATEST_PACKAGE"
|
||||||
|
dotnet nuget push "$LATEST_PACKAGE" --source hangman-lab --skip-duplicate
|
||||||
|
|
||||||
|
|||||||
82
src/PoloniumTask.cs
Normal file
82
src/PoloniumTask.cs
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
|
using Microsoft.Build.Utilities;
|
||||||
|
using Microsoft.CodeAnalysis;
|
||||||
|
using Microsoft.CodeAnalysis.CSharp;
|
||||||
|
using Microsoft.CodeAnalysis.CSharp.Syntax;
|
||||||
|
|
||||||
|
namespace Polonium.Tasks;
|
||||||
|
|
||||||
|
public abstract class PoloniumTask : Task
|
||||||
|
{
|
||||||
|
protected static bool HasGetterOnly(PropertyDeclarationSyntax property)
|
||||||
|
{
|
||||||
|
var registryAttribute = property.AttributeLists
|
||||||
|
.SelectMany(a => a.Attributes)
|
||||||
|
.FirstOrDefault(a => a.Name.ToString() == "RegistryPassThrough");
|
||||||
|
|
||||||
|
if (registryAttribute?.ArgumentList != null)
|
||||||
|
{
|
||||||
|
foreach (var argument in registryAttribute.ArgumentList.Arguments)
|
||||||
|
{
|
||||||
|
if (argument.Expression is LiteralExpressionSyntax literal)
|
||||||
|
{
|
||||||
|
if (literal.Kind() == SyntaxKind.TrueLiteralExpression)
|
||||||
|
return true;
|
||||||
|
if (literal.Kind() == SyntaxKind.FalseLiteralExpression)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
protected static string GetDisplayName(ClassDeclarationSyntax cls)
|
||||||
|
{
|
||||||
|
string name = cls.Identifier.Text;
|
||||||
|
SyntaxNode node = cls.Parent;
|
||||||
|
while (node is not null)
|
||||||
|
{
|
||||||
|
if(node is NamespaceDeclarationSyntax ns)
|
||||||
|
name = ns.Name.ToString() + "." + name;
|
||||||
|
else if (node is FileScopedNamespaceDeclarationSyntax fs)
|
||||||
|
name = fs.Name.ToString() + "." + name;
|
||||||
|
node = node.Parent;
|
||||||
|
}
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
protected static string GetRelativePath(string basePath, string fullPath)
|
||||||
|
{
|
||||||
|
Uri baseUri = new Uri(basePath.EndsWith(Path.DirectorySeparatorChar.ToString()) ? basePath : basePath + Path.DirectorySeparatorChar);
|
||||||
|
Uri fullUri = new Uri(fullPath);
|
||||||
|
return Uri.UnescapeDataString(baseUri.MakeRelativeUri(fullUri).ToString().Replace('/', Path.DirectorySeparatorChar));
|
||||||
|
}
|
||||||
|
protected static string GetDisplayName(TypeSyntax type)
|
||||||
|
{
|
||||||
|
if (type is IdentifierNameSyntax identifierName)
|
||||||
|
return identifierName.Identifier.Text;
|
||||||
|
if (type is QualifiedNameSyntax qualifiedName)
|
||||||
|
return GetDisplayName(qualifiedName.Left) + "." + GetDisplayName(qualifiedName.Right);
|
||||||
|
if (type is GenericNameSyntax genericName)
|
||||||
|
{
|
||||||
|
string typeName = genericName.Identifier.Text;
|
||||||
|
string typeArguments = string.Join(", ", genericName.TypeArgumentList.Arguments.Select(GetDisplayName));
|
||||||
|
return $"{typeName}<{typeArguments}>";
|
||||||
|
}
|
||||||
|
if (type is AliasQualifiedNameSyntax aliasQualifiedName)
|
||||||
|
return $"{aliasQualifiedName.Alias.Identifier.Text}::{GetDisplayName(aliasQualifiedName.Name)}";
|
||||||
|
if (type is PredefinedTypeSyntax predefinedType)
|
||||||
|
return predefinedType.Keyword.Text;
|
||||||
|
return type.ToString();
|
||||||
|
}
|
||||||
|
protected static IEnumerable<string> GetUsings(string code)
|
||||||
|
{
|
||||||
|
SyntaxTree tree = CSharpSyntaxTree.ParseText(code);
|
||||||
|
CompilationUnitSyntax root = tree.GetCompilationUnitRoot();
|
||||||
|
|
||||||
|
return root.Usings
|
||||||
|
.Select(u => u.ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -4,13 +4,13 @@ using System.IO;
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using Microsoft.Build.Framework;
|
using Microsoft.Build.Framework;
|
||||||
using Microsoft.Build.Utilities;
|
|
||||||
using Microsoft.CodeAnalysis;
|
using Microsoft.CodeAnalysis;
|
||||||
using Microsoft.CodeAnalysis.CSharp;
|
using Microsoft.CodeAnalysis.CSharp;
|
||||||
using Microsoft.CodeAnalysis.CSharp.Syntax;
|
using Microsoft.CodeAnalysis.CSharp.Syntax;
|
||||||
namespace Polonium.Tasks;
|
using Polonium.Tasks;
|
||||||
|
|
||||||
public class GenerateProxyNodesTask : Task
|
// ReSharper disable once CheckNamespace
|
||||||
|
public class GenerateProxyNodesTask : PoloniumTask
|
||||||
{
|
{
|
||||||
[Required]
|
[Required]
|
||||||
public string SourceDirectory { get; set; }
|
public string SourceDirectory { get; set; }
|
||||||
@@ -97,19 +97,6 @@ public class GenerateProxyNodesTask : Task
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private string GetDisplayName(ClassDeclarationSyntax cls)
|
|
||||||
{
|
|
||||||
string name = cls.Identifier.Text;
|
|
||||||
SyntaxNode node = cls.Parent;
|
|
||||||
while (node is not null)
|
|
||||||
{
|
|
||||||
if(node is NamespaceDeclarationSyntax ns)
|
|
||||||
name = ns.Name.ToString() + "." + name;
|
|
||||||
else if (node is FileScopedNamespaceDeclarationSyntax fs)
|
|
||||||
name = fs.Name.ToString() + "." + name;
|
|
||||||
node = node.Parent;
|
|
||||||
}
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
78
src/Tasks/GenerateRegistryPassThrough.cs
Normal file
78
src/Tasks/GenerateRegistryPassThrough.cs
Normal file
@@ -0,0 +1,78 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using Microsoft.Build.Framework;
|
||||||
|
using Microsoft.CodeAnalysis;
|
||||||
|
using Microsoft.CodeAnalysis.CSharp;
|
||||||
|
using Microsoft.CodeAnalysis.CSharp.Syntax;
|
||||||
|
using Polonium.Tasks;
|
||||||
|
|
||||||
|
|
||||||
|
// ReSharper disable once CheckNamespace
|
||||||
|
public class GenerateRegistryPassThrough : PoloniumTask
|
||||||
|
{
|
||||||
|
[Required] public string ProjectDir { get; set; }
|
||||||
|
|
||||||
|
public override bool Execute()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
StringBuilder sb = new();
|
||||||
|
|
||||||
|
string csFile = Directory
|
||||||
|
.GetFiles($"{ProjectDir}src", "PoloniumRegistry.cs", SearchOption.TopDirectoryOnly)
|
||||||
|
.FirstOrDefault();
|
||||||
|
string code = File.ReadAllText(csFile!);
|
||||||
|
sb.AppendLine("#pragma warning disable IDE0130");
|
||||||
|
foreach (string use in GetUsings(code))
|
||||||
|
sb.AppendLine(use);
|
||||||
|
sb
|
||||||
|
.AppendLine("using System.Collections.Generic;")
|
||||||
|
.AppendLine("// ReSharper disable once CheckNamespace")
|
||||||
|
.AppendLine("public static partial class GlobalRegistry")
|
||||||
|
.AppendLine("{");
|
||||||
|
|
||||||
|
SyntaxTree tree = CSharpSyntaxTree.ParseText(code);
|
||||||
|
CompilationUnitSyntax root = tree.GetCompilationUnitRoot();
|
||||||
|
ClassDeclarationSyntax clas = root
|
||||||
|
.DescendantNodes()
|
||||||
|
.OfType<ClassDeclarationSyntax>()
|
||||||
|
.FirstOrDefault(cls => cls.Identifier.Text == "PoloniumRegistry");
|
||||||
|
IEnumerable<PropertyDeclarationSyntax> properties = clas?.Members
|
||||||
|
.OfType<PropertyDeclarationSyntax>()
|
||||||
|
.Where(m => m.AttributeLists
|
||||||
|
.SelectMany(a => a.Attributes)
|
||||||
|
.Any(a => a.Name.ToString() == "RegistryPassThrough"));
|
||||||
|
if (properties is null)
|
||||||
|
return false;
|
||||||
|
foreach (PropertyDeclarationSyntax property in properties)
|
||||||
|
{
|
||||||
|
if (HasGetterOnly(property))
|
||||||
|
sb.AppendLine($" public static {GetDisplayName(property.Type)} {property.Identifier.ToString()} => PoloniumRegistry.{property.Identifier.ValueText};");
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sb
|
||||||
|
.AppendLine($" public static {GetDisplayName(property.Type)} {property.Identifier.ToString()}")
|
||||||
|
.AppendLine(" {")
|
||||||
|
.AppendLine($" get => PoloniumRegistry.{property.Identifier.ValueText};")
|
||||||
|
.AppendLine($" set => PoloniumRegistry.{property.Identifier.ValueText} = value;")
|
||||||
|
.AppendLine(" }");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sb
|
||||||
|
.AppendLine("}")
|
||||||
|
.AppendLine("#pragma warning restore IDE0130");
|
||||||
|
File.WriteAllText($"{ProjectDir}Package/embedded/Patches/RegistryPassThrough.p.cs", sb.ToString());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
Log.LogErrorFromException(e);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -2,11 +2,11 @@ using System;
|
|||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using Microsoft.Build.Framework;
|
using Microsoft.Build.Framework;
|
||||||
using Microsoft.Build.Utilities;
|
using Polonium.Tasks;
|
||||||
|
|
||||||
namespace Polonium.Tasks;
|
|
||||||
|
|
||||||
public class GenerateTextureSetTask : Task
|
// ReSharper disable once CheckNamespace
|
||||||
|
public class GenerateTextureSetTask : PoloniumTask
|
||||||
{
|
{
|
||||||
[Required]
|
[Required]
|
||||||
public string RootPath { get; set; }
|
public string RootPath { get; set; }
|
||||||
@@ -103,11 +103,6 @@ public class GenerateTextureSetTask : Task
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private string GetRelativePath(string basePath, string fullPath)
|
|
||||||
{
|
|
||||||
Uri baseUri = new Uri(basePath.EndsWith(Path.DirectorySeparatorChar.ToString()) ? basePath : basePath + Path.DirectorySeparatorChar);
|
|
||||||
Uri fullUri = new Uri(fullPath);
|
|
||||||
return Uri.UnescapeDataString(baseUri.MakeRelativeUri(fullUri).ToString().Replace('/', Path.DirectorySeparatorChar));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user