Compare commits
26 Commits
55cc53dad4
...
v0.0.1
| Author | SHA1 | Date | |
|---|---|---|---|
| 8062242c1a | |||
| 157a4d38b1 | |||
| ceb4b81b36 | |||
| 82ff05fb30 | |||
| 5a6414b2dd | |||
| dceaea78c6 | |||
| d05e0b8710 | |||
| 9b83721f17 | |||
| 247300c09c | |||
| 28c5f3ac1a | |||
| 9852d6da0a | |||
| 091e8c086a | |||
| b10a2ebdc9 | |||
| d2a0b0b007 | |||
| 048ea69d47 | |||
| d753ce67c3 | |||
| c0751c34df | |||
| 3341125442 | |||
| 4f9cf7f62b | |||
| 1951a0f2e7 | |||
| 39ab19eec0 | |||
| d2f16fee48 | |||
| faf7449802 | |||
| 7266590bbf | |||
| b38656c923 | |||
| 91bd5428a7 |
3
.github/workflows/auto_release.yaml
vendored
3
.github/workflows/auto_release.yaml
vendored
@@ -34,7 +34,7 @@ jobs:
|
|||||||
uses: actions/checkout@v6
|
uses: actions/checkout@v6
|
||||||
with:
|
with:
|
||||||
# Use your GitHub Personal Access Token variable here.
|
# Use your GitHub Personal Access Token variable here.
|
||||||
token: ${{ secrets.GH_BASIC }}
|
token: ${{ secrets.NUGET_KEY }}
|
||||||
lfs: true
|
lfs: true
|
||||||
submodules: 'recursive'
|
submodules: 'recursive'
|
||||||
|
|
||||||
@@ -79,3 +79,4 @@ jobs:
|
|||||||
GH_BASIC: ${{ secrets.GH_BASIC }}
|
GH_BASIC: ${{ secrets.GH_BASIC }}
|
||||||
with:
|
with:
|
||||||
bump: patch
|
bump: patch
|
||||||
|
#994139c880db4bab879ae724ce1ac43b87c88e42
|
||||||
|
|||||||
35
.github/workflows/release.yaml
vendored
35
.github/workflows/release.yaml
vendored
@@ -39,6 +39,7 @@ jobs:
|
|||||||
lfs: true
|
lfs: true
|
||||||
submodules: 'recursive'
|
submodules: 'recursive'
|
||||||
fetch-depth: 0 # So we can get all tags.
|
fetch-depth: 0 # So we can get all tags.
|
||||||
|
fetch-tags: true
|
||||||
|
|
||||||
- name: Read Current Project Version
|
- name: Read Current Project Version
|
||||||
id: current-version
|
id: current-version
|
||||||
@@ -63,16 +64,17 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
# Use the .NET SDK from global.json in the root of the repository.
|
# Use the .NET SDK from global.json in the root of the repository.
|
||||||
global-json-file: global.json
|
global-json-file: global.json
|
||||||
|
|
||||||
# Write version to file so .NET will build correct version.
|
# Write version to file so .NET will build correct version.
|
||||||
|
# - name: Write Version to File
|
||||||
|
# uses: jacobtomlinson/gha-find-replace@v3
|
||||||
|
# with:
|
||||||
|
# find: "0.0.0-devbuild"
|
||||||
|
# replace: ${{ steps.next-version.outputs.version }}
|
||||||
|
# regex: false
|
||||||
|
# include: GodotHelper/GodotHelper.csproj
|
||||||
- name: Write Version to File
|
- name: Write Version to File
|
||||||
uses: jacobtomlinson/gha-find-replace@v3
|
run: |
|
||||||
with:
|
sed -i 's/0.0.0-devbuild/${{ steps.next-version.outputs.version }}/g' GodotHelper/GodotHelper.csproj
|
||||||
find: "0.0.0-devbuild"
|
|
||||||
replace: ${{ steps.next-version.outputs.version }}
|
|
||||||
regex: false
|
|
||||||
include: GodotHelper/GodotHelper.csproj
|
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
working-directory: GodotHelper
|
working-directory: GodotHelper
|
||||||
run: dotnet build -c Release
|
run: dotnet build -c Release
|
||||||
@@ -83,20 +85,27 @@ jobs:
|
|||||||
package=$(find ./GodotHelper/nupkg -name "*.nupkg")
|
package=$(find ./GodotHelper/nupkg -name "*.nupkg")
|
||||||
echo "package=$package" >> "$GITHUB_OUTPUT"
|
echo "package=$package" >> "$GITHUB_OUTPUT"
|
||||||
echo "Found package: $package"
|
echo "Found package: $package"
|
||||||
|
echo "${{ steps.package-path.outputs.package }}"
|
||||||
|
|
||||||
# - name: Create Release
|
# - name: Create Release
|
||||||
# env:
|
|
||||||
# GITHUB_TOKEN: ${{ secrets.GH_BASIC }}
|
|
||||||
# run: |
|
# run: |
|
||||||
# version="${{ steps.next-version.outputs.version }}"
|
# version="${{ steps.next-version.outputs.version }}"
|
||||||
# gh release create --title "v$version" --generate-notes "$version" \
|
|
||||||
# "${{ steps.package-path.outputs.package }}"
|
|
||||||
|
|
||||||
|
# curl -X POST "http://192.168.1.4:3000/api/packages/Ronnie/GodotHelpers/releases" \
|
||||||
|
# -H "Authorization: token ${{ secrets.GH_BASIC }}" \
|
||||||
|
# -H "Content-Type: application/json" \
|
||||||
|
# -d "{
|
||||||
|
# \"tag_name\": \"$version\",
|
||||||
|
# \"name\": \"v$version\",
|
||||||
|
# \"body\": \"Auto release $version\"
|
||||||
|
# }"
|
||||||
- name: Publish to Nuget
|
- name: Publish to Nuget
|
||||||
run: |
|
run: |
|
||||||
dotnet nuget push "${{ steps.package-path.outputs.package }}" \
|
dotnet nuget push "${{ steps.package-path.outputs.package }}" \
|
||||||
--source "http://192.168.1.4:3000/api/packages/Ronnie/nuget/index.json" \
|
--source "http://192.168.1.4:3000/api/packages/Ronnie/nuget/index.json" \
|
||||||
--allow-insecure-connections \
|
--allow-insecure-connections \
|
||||||
--api-key "${{ secrets.NUGET_KEY }}" \
|
--api-key "${{ secrets.NUGET_KEY }}" \
|
||||||
--skip-duplicate
|
# --skip-duplicate
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -48,6 +48,7 @@
|
|||||||
<PrivateAssets>all</PrivateAssets>
|
<PrivateAssets>all</PrivateAssets>
|
||||||
</PackageReference>
|
</PackageReference>
|
||||||
<PackageReference Include="GodotSharp" Version="4.6.2" />
|
<PackageReference Include="GodotSharp" Version="4.6.2" />
|
||||||
<PackageReference Include="SjkScripts" Version="1.0.15" />
|
<PackageReference Include="SjkScripts" Version="1.0.17" />
|
||||||
|
<!-- [1.2.3,2.3.4] use range of versions -->
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
</Project>
|
</Project>
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ public static partial class SJKMath
|
|||||||
// Mathf.Lerp(from.Y, to.Y, weight),
|
// Mathf.Lerp(from.Y, to.Y, weight),
|
||||||
// Mathf.Lerp(from.Z, to.Z, weight)
|
// Mathf.Lerp(from.Z, to.Z, weight)
|
||||||
// );
|
// );
|
||||||
public static Vector3 Lerp(Vector3 from, Vector3 to, float weight) => new Vector3(
|
public static Vector3 Lerp(this Vector3 from, Vector3 to, float weight) => new Vector3(
|
||||||
Mathf.Lerp(from.X, to.X, weight),
|
Mathf.Lerp(from.X, to.X, weight),
|
||||||
Mathf.Lerp(from.Y, to.Y, weight),
|
Mathf.Lerp(from.Y, to.Y, weight),
|
||||||
Mathf.Lerp(from.Z, to.Z, weight)
|
Mathf.Lerp(from.Z, to.Z, weight)
|
||||||
@@ -17,7 +17,7 @@ public static partial class SJKMath
|
|||||||
// Mathf.Lerp(from.X, to.X, weight),
|
// Mathf.Lerp(from.X, to.X, weight),
|
||||||
// Mathf.Lerp(from.Y, to.Y, weight)
|
// Mathf.Lerp(from.Y, to.Y, weight)
|
||||||
// );
|
// );
|
||||||
public static Vector2 Lerp(Vector2 from, Vector2 to, float weight) => new Vector2(
|
public static Vector2 Lerp(this Vector2 from, Vector2 to, float weight) => new Vector2(
|
||||||
Mathf.Lerp(from.X, to.X, weight),
|
Mathf.Lerp(from.X, to.X, weight),
|
||||||
Mathf.Lerp(from.Y, to.Y, weight)
|
Mathf.Lerp(from.Y, to.Y, weight)
|
||||||
);
|
);
|
||||||
|
|||||||
33
GodotHelper/src/Math/RoundVectors.cs
Normal file
33
GodotHelper/src/Math/RoundVectors.cs
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
namespace GodotHelpers;
|
||||||
|
|
||||||
|
using Godot;
|
||||||
|
public static partial class SJKMath
|
||||||
|
{
|
||||||
|
public static Vector3I RoundToIntVector(this Vector3 vector) => new Vector3I(
|
||||||
|
Mathf.RoundToInt(vector.X),
|
||||||
|
Mathf.RoundToInt(vector.Y),
|
||||||
|
Mathf.RoundToInt(vector.Z)
|
||||||
|
);
|
||||||
|
public static Vector3I FloorToIntVector(this Vector3 vector) => new Vector3I(
|
||||||
|
Mathf.FloorToInt(vector.X),
|
||||||
|
Mathf.FloorToInt(vector.Y),
|
||||||
|
Mathf.FloorToInt(vector.Z)
|
||||||
|
);
|
||||||
|
public static Vector3I CeilToIntVector(this Vector3 vector) => new Vector3I(
|
||||||
|
Mathf.CeilToInt(vector.X),
|
||||||
|
Mathf.CeilToInt(vector.Y),
|
||||||
|
Mathf.CeilToInt(vector.Z)
|
||||||
|
);
|
||||||
|
public static Vector2I RoundToIntVector(this Vector2 vector) => new Vector2I(
|
||||||
|
Mathf.RoundToInt(vector.X),
|
||||||
|
Mathf.RoundToInt(vector.Y)
|
||||||
|
);
|
||||||
|
public static Vector2I FloorToIntVector(this Vector2 vector) => new Vector2I(
|
||||||
|
Mathf.FloorToInt(vector.X),
|
||||||
|
Mathf.FloorToInt(vector.Y)
|
||||||
|
);
|
||||||
|
public static Vector2I CeilToIntVector(this Vector2 vector) => new Vector2I(
|
||||||
|
Mathf.CeilToInt(vector.X),
|
||||||
|
Mathf.CeilToInt(vector.Y)
|
||||||
|
);
|
||||||
|
}
|
||||||
@@ -11,10 +11,10 @@ public static class MyNodeExtensions
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Checks if given Property exists on <c>Base</c>
|
/// Checks if given Property exists on <c>Base</c>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="Base">Current <c>GodotObject</c></param>
|
/// <param name="base">Current <c>GodotObject</c></param>
|
||||||
/// <param name="PropertyName">Property Name</param>
|
/// <param name="propertyName">Property Name</param>
|
||||||
/// <returns><c>bool</c> true if given property exists on Base</returns>
|
/// <returns><c>bool</c> true if given property exists on Base</returns>
|
||||||
public static bool HasProperty(this GodotObject Base, string PropertyName)
|
public static bool HasProperty(this GodotObject @base, string propertyName)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
Returns the object's property list as an Godot.Collections.Array of dictionaries.
|
Returns the object's property list as an Godot.Collections.Array of dictionaries.
|
||||||
@@ -26,9 +26,9 @@ public static class MyNodeExtensions
|
|||||||
- hint_string depends on the hint (see PropertyHint);
|
- hint_string depends on the hint (see PropertyHint);
|
||||||
- usage is a combination of PropertyUsageFlags.
|
- usage is a combination of PropertyUsageFlags.
|
||||||
*/
|
*/
|
||||||
foreach (var Property in Base.GetPropertyListEx())
|
foreach (var property in @base.GetPropertyListEx())
|
||||||
{
|
{
|
||||||
if (Property.Name == PropertyName)
|
if (property.Name == propertyName)
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@@ -39,7 +39,7 @@ public static class MyNodeExtensions
|
|||||||
public static (Node node, Resource resource, NodePath remaining) GetNodeAndResourceEx(this Node self, NodePath path)
|
public static (Node node, Resource resource, NodePath remaining) GetNodeAndResourceEx(this Node self, NodePath path)
|
||||||
{
|
{
|
||||||
var result = self.GetNodeAndResource(path);
|
var result = self.GetNodeAndResource(path);
|
||||||
return ((Node)result[0], (Resource)result[1], (NodePath)result[2]);
|
return ((Node)(GodotObject)result[0], (Resource)(GodotObject)result[1], (NodePath)result[2]);
|
||||||
}
|
}
|
||||||
public static void QueueFreeChildren(this Node node) => node.GetChildren().ToList().ForEach(item => item.QueueFree());
|
public static void QueueFreeChildren(this Node node) => node.GetChildren().ToList().ForEach(item => item.QueueFree());
|
||||||
public static void QueueFreeChildren(this Node node, Func<Node, bool> predicate) => node.GetChildren().Where(predicate).ToList().ForEach(item => item.QueueFree());
|
public static void QueueFreeChildren(this Node node, Func<Node, bool> predicate) => node.GetChildren().Where(predicate).ToList().ForEach(item => item.QueueFree());
|
||||||
|
|||||||
@@ -1,12 +1,14 @@
|
|||||||
|
namespace GodotHelpers.Raycasts;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Diagnostics.CodeAnalysis;
|
using System.Diagnostics.CodeAnalysis;
|
||||||
using Godot;
|
using Godot;
|
||||||
using Godot.Collections;
|
using Godot.Collections;
|
||||||
using SJK.Functional;
|
using SJK.Functional;
|
||||||
|
|
||||||
namespace GodotHelpers.Raycasts;
|
/// <summary>
|
||||||
|
/// Extensions for <see cref="PhysicsDirectSpaceState3D"/>.
|
||||||
|
/// Allows for an static way of casting an godot Raycast3D.
|
||||||
|
/// </summary>
|
||||||
public static class RaycastExtensions
|
public static class RaycastExtensions
|
||||||
{
|
{
|
||||||
// --- 3D ---
|
// --- 3D ---
|
||||||
@@ -45,6 +47,10 @@ public static class RaycastExtensions
|
|||||||
|
|
||||||
// --- 2D ---
|
// --- 2D ---
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Extensions for <see cref="PhysicsDirectSpaceState2D"/>.
|
||||||
|
/// Allows for an static way of casting an godot Raycast3D.
|
||||||
|
/// </summary>
|
||||||
public static RaycastResult2D? RaycastEx(this PhysicsDirectSpaceState2D space, Vector2 from, Vector2 to, uint collisionMask = uint.MaxValue, Rid[]? exclude = null, bool hitFromInside = false)
|
public static RaycastResult2D? RaycastEx(this PhysicsDirectSpaceState2D space, Vector2 from, Vector2 to, uint collisionMask = uint.MaxValue, Rid[]? exclude = null, bool hitFromInside = false)
|
||||||
{
|
{
|
||||||
var query = new PhysicsRayQueryParameters2D
|
var query = new PhysicsRayQueryParameters2D
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
using Godot;
|
|
||||||
|
|
||||||
namespace GodotHelpers.Raycasts;
|
namespace GodotHelpers.Raycasts;
|
||||||
|
|
||||||
|
using Godot;
|
||||||
|
|
||||||
public record ShapeCastResult3D(
|
public record ShapeCastResult3D(
|
||||||
GodotObject Collider,
|
GodotObject Collider,
|
||||||
int ColliderId,
|
int ColliderId,
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
|
namespace SJK.GodotHelpers;
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
|
||||||
using Godot;
|
using Godot;
|
||||||
using Godot.Collections;
|
using Godot.Collections;
|
||||||
namespace SJK.GodotHelpers;
|
|
||||||
|
|
||||||
public static class VariantUtils
|
public static class VariantUtils
|
||||||
{
|
{
|
||||||
@@ -73,6 +73,18 @@ public static class VariantUtils
|
|||||||
Variant.Type.Signal => typeof(Signal),
|
Variant.Type.Signal => typeof(Signal),
|
||||||
Variant.Type.Dictionary => typeof(Dictionary),
|
Variant.Type.Dictionary => typeof(Dictionary),
|
||||||
Variant.Type.Array => typeof(Godot.Collections.Array),
|
Variant.Type.Array => typeof(Godot.Collections.Array),
|
||||||
|
Variant.Type.Projection => throw new NotImplementedException(),
|
||||||
|
Variant.Type.PackedByteArray => throw new NotImplementedException(),
|
||||||
|
Variant.Type.PackedInt32Array => throw new NotImplementedException(),
|
||||||
|
Variant.Type.PackedInt64Array => throw new NotImplementedException(),
|
||||||
|
Variant.Type.PackedFloat32Array => throw new NotImplementedException(),
|
||||||
|
Variant.Type.PackedFloat64Array => throw new NotImplementedException(),
|
||||||
|
Variant.Type.PackedStringArray => throw new NotImplementedException(),
|
||||||
|
Variant.Type.PackedVector2Array => throw new NotImplementedException(),
|
||||||
|
Variant.Type.PackedVector3Array => throw new NotImplementedException(),
|
||||||
|
Variant.Type.PackedColorArray => throw new NotImplementedException(),
|
||||||
|
Variant.Type.PackedVector4Array => throw new NotImplementedException(),
|
||||||
|
Variant.Type.Max => throw new NotImplementedException(),
|
||||||
_ => typeof(object)
|
_ => typeof(object)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
13
NuGet.Config
Normal file
13
NuGet.Config
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<configuration>
|
||||||
|
<packageSources>
|
||||||
|
<add key="nuget.org" value="https://api.nuget.org/v3/index.json" protocolVersion="3" />
|
||||||
|
<add key="gitea" value="http://192.168.1.4:3000/api/packages/Ronnie/nuget/index.json" allowInsecureConnections="True" />
|
||||||
|
</packageSources>
|
||||||
|
<packageSourceCredentials>
|
||||||
|
<gitea>
|
||||||
|
<add key="Username" value="Ronnie" />
|
||||||
|
<add key="ClearTextPassword" value="e59e39d60f30b539ae594d8cfc7a9771883d2eb0" />
|
||||||
|
</gitea>
|
||||||
|
</packageSourceCredentials>
|
||||||
|
</configuration>
|
||||||
@@ -4,6 +4,7 @@
|
|||||||
],
|
],
|
||||||
"ignorePaths": [
|
"ignorePaths": [
|
||||||
"**/*.tscn",
|
"**/*.tscn",
|
||||||
|
"**/*.uid",
|
||||||
"**/*.import",
|
"**/*.import",
|
||||||
"**/badges/**/*.*",
|
"**/badges/**/*.*",
|
||||||
"**/coverage/**/*.*",
|
"**/coverage/**/*.*",
|
||||||
@@ -13,6 +14,7 @@
|
|||||||
"**/nupkg/**/*.*"
|
"**/nupkg/**/*.*"
|
||||||
],
|
],
|
||||||
"words": [
|
"words": [
|
||||||
|
"Aabb",
|
||||||
"assemblyfilters",
|
"assemblyfilters",
|
||||||
"automerge",
|
"automerge",
|
||||||
"branchcoverage",
|
"branchcoverage",
|
||||||
@@ -28,14 +30,18 @@
|
|||||||
"endregion",
|
"endregion",
|
||||||
"Finalizer",
|
"Finalizer",
|
||||||
"Finalizers",
|
"Finalizers",
|
||||||
|
"gitea",
|
||||||
"globaltool",
|
"globaltool",
|
||||||
"godotengine",
|
"godotengine",
|
||||||
"godotpackage",
|
"godotpackage",
|
||||||
"issuecomment",
|
"issuecomment",
|
||||||
"justalemon",
|
"justalemon",
|
||||||
|
"Kisner",
|
||||||
"lcov",
|
"lcov",
|
||||||
|
"Lerp",
|
||||||
"lihop",
|
"lihop",
|
||||||
"linecoverage",
|
"linecoverage",
|
||||||
|
"Mathf",
|
||||||
"methodcoverage",
|
"methodcoverage",
|
||||||
"missingall",
|
"missingall",
|
||||||
"msbuild",
|
"msbuild",
|
||||||
|
|||||||
Reference in New Issue
Block a user