Compare commits

...

26 Commits

Author SHA1 Message Date
8062242c1a brute force
All checks were successful
Spellcheck / Spellcheck (push) Successful in 14s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 1m4s
2026-06-10 16:48:58 -04:00
157a4d38b1 Atempent 2
All checks were successful
Spellcheck / Spellcheck (push) Successful in 15s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 1m2s
2026-06-10 16:44:40 -04:00
ceb4b81b36 why not work
All checks were successful
Spellcheck / Spellcheck (push) Successful in 13s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 1m3s
2026-06-10 16:27:50 -04:00
82ff05fb30 HELP
All checks were successful
Spellcheck / Spellcheck (push) Successful in 14s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 1m4s
2026-06-10 16:20:33 -04:00
5a6414b2dd seeing if chaning vesion in godot csproj works, and patch
All checks were successful
Spellcheck / Spellcheck (push) Successful in 17s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 1m2s
2026-06-10 16:05:42 -04:00
dceaea78c6 attepted fix in wrong spot.
All checks were successful
Spellcheck / Spellcheck (push) Successful in 13s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 1m7s
2026-06-10 15:10:54 -04:00
d05e0b8710 Trying to fix uid causing spellcheck error
Some checks failed
Spellcheck / Spellcheck (push) Failing after 13s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 1m4s
2026-06-10 15:04:54 -04:00
9b83721f17 SJK scriptts Bumped to 1.0.17
Some checks failed
Spellcheck / Spellcheck (push) Failing after 1m39s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 1m18s
2026-06-10 14:35:17 -04:00
247300c09c Bumped SJKScript Vesion and added vector Lerp 2026-06-10 14:34:33 -04:00
28c5f3ac1a added fetch tags to see if helps
Some checks failed
Spellcheck / Spellcheck (push) Failing after 26s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 2m21s
2026-04-14 00:23:39 -04:00
9852d6da0a readded emojies to test of mysql is not suportiogn them
Some checks failed
Spellcheck / Spellcheck (push) Failing after 27s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 2m13s
2026-04-14 00:06:19 -04:00
091e8c086a removed emojies from readme
Some checks failed
Spellcheck / Spellcheck (push) Failing after 24s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 2m12s
2026-04-13 23:40:57 -04:00
b10a2ebdc9 wrong brach tag
Some checks failed
Spellcheck / Spellcheck (push) Failing after 23s
Build NuGet / build (push) Failing after 1m10s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 2m14s
2026-04-13 23:10:57 -04:00
d2a0b0b007 more anoyed testing
Some checks failed
Spellcheck / Spellcheck (push) Failing after 29s
Tests / Evaluate Tests on ubuntu-latest (push) Has been cancelled
2026-04-13 23:10:05 -04:00
048ea69d47 test build from diffrent project
Some checks failed
Spellcheck / Spellcheck (push) Failing after 31s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 2m17s
2026-04-13 13:11:50 -04:00
d753ce67c3 fixed secret
Some checks failed
Spellcheck / Spellcheck (push) Failing after 10s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 50s
2026-04-10 21:47:44 -04:00
c0751c34df relse 2
Some checks failed
Spellcheck / Spellcheck (push) Failing after 9s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 51s
2026-04-10 21:39:32 -04:00
3341125442 YAY
Some checks failed
Spellcheck / Spellcheck (push) Failing after 10s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 51s
2026-04-10 21:29:35 -04:00
4f9cf7f62b more cspell fixed, and acidltal paste into release
Some checks failed
Spellcheck / Spellcheck (push) Failing after 10s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 51s
2026-04-10 21:11:09 -04:00
1951a0f2e7 removed reqiments for HG_BASIC
Some checks failed
Spellcheck / Spellcheck (push) Failing after 10s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 55s
2026-04-10 21:06:27 -04:00
39ab19eec0 add some comments and commented out HG_Basic
Some checks failed
Spellcheck / Spellcheck (push) Failing after 10s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 51s
2026-04-10 21:02:05 -04:00
d2f16fee48 same as previous
Some checks failed
Spellcheck / Spellcheck (push) Failing after 9s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 55s
2026-04-10 20:50:12 -04:00
faf7449802 trying to get github working
Some checks failed
Spellcheck / Spellcheck (push) Failing after 9s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 51s
2026-04-10 20:47:05 -04:00
7266590bbf token
Some checks failed
Spellcheck / Spellcheck (push) Failing after 11s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 55s
2026-04-10 20:45:07 -04:00
b38656c923 added cspell and better source
Some checks failed
Spellcheck / Spellcheck (push) Failing after 10s
Tests / Evaluate Tests on ubuntu-latest (push) Successful in 55s
2026-04-10 20:41:00 -04:00
91bd5428a7 nuget source
Some checks failed
Spellcheck / Spellcheck (push) Failing after 10s
Tests / Evaluate Tests on ubuntu-latest (push) Failing after 27s
2026-04-10 20:35:08 -04:00
11 changed files with 112 additions and 31 deletions

View File

@@ -34,7 +34,7 @@ jobs:
uses: actions/checkout@v6
with:
# Use your GitHub Personal Access Token variable here.
token: ${{ secrets.GH_BASIC }}
token: ${{ secrets.NUGET_KEY }}
lfs: true
submodules: 'recursive'
@@ -79,3 +79,4 @@ jobs:
GH_BASIC: ${{ secrets.GH_BASIC }}
with:
bump: patch
#994139c880db4bab879ae724ce1ac43b87c88e42

View File

@@ -39,6 +39,7 @@ jobs:
lfs: true
submodules: 'recursive'
fetch-depth: 0 # So we can get all tags.
fetch-tags: true
- name: Read Current Project Version
id: current-version
@@ -63,16 +64,17 @@ jobs:
with:
# Use the .NET SDK from global.json in the root of the repository.
global-json-file: global.json
# 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
uses: jacobtomlinson/gha-find-replace@v3
with:
find: "0.0.0-devbuild"
replace: ${{ steps.next-version.outputs.version }}
regex: false
include: GodotHelper/GodotHelper.csproj
run: |
sed -i 's/0.0.0-devbuild/${{ steps.next-version.outputs.version }}/g' GodotHelper/GodotHelper.csproj
- name: Build
working-directory: GodotHelper
run: dotnet build -c Release
@@ -83,20 +85,27 @@ jobs:
package=$(find ./GodotHelper/nupkg -name "*.nupkg")
echo "package=$package" >> "$GITHUB_OUTPUT"
echo "Found package: $package"
echo "${{ steps.package-path.outputs.package }}"
# - name: Create Release
# env:
# GITHUB_TOKEN: ${{ secrets.GH_BASIC }}
# run: |
# 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
run: |
dotnet nuget push "${{ steps.package-path.outputs.package }}" \
--source "http://192.168.1.4:3000/api/packages/Ronnie/nuget/index.json" \
--allow-insecure-connections \
--api-key "${{ secrets.NUGET_KEY }}" \
--skip-duplicate
# --skip-duplicate

View File

@@ -48,6 +48,7 @@
<PrivateAssets>all</PrivateAssets>
</PackageReference>
<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>
</Project>

View File

@@ -8,7 +8,7 @@ public static partial class SJKMath
// Mathf.Lerp(from.Y, to.Y, 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.Y, to.Y, 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.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.Y, to.Y, weight)
);

View 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)
);
}

View File

@@ -11,10 +11,10 @@ public static class MyNodeExtensions
/// <summary>
/// Checks if given Property exists on <c>Base</c>
/// </summary>
/// <param name="Base">Current <c>GodotObject</c></param>
/// <param name="PropertyName">Property Name</param>
/// <param name="base">Current <c>GodotObject</c></param>
/// <param name="propertyName">Property Name</param>
/// <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.
@@ -26,9 +26,9 @@ public static class MyNodeExtensions
- hint_string depends on the hint (see PropertyHint);
- 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;
}
@@ -39,7 +39,7 @@ public static class MyNodeExtensions
public static (Node node, Resource resource, NodePath remaining) GetNodeAndResourceEx(this Node self, NodePath 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, Func<Node, bool> predicate) => node.GetChildren().Where(predicate).ToList().ForEach(item => item.QueueFree());

View File

@@ -1,12 +1,14 @@
namespace GodotHelpers.Raycasts;
using System.Collections.Generic;
using System.Diagnostics.CodeAnalysis;
using Godot;
using Godot.Collections;
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
{
// --- 3D ---
@@ -45,6 +47,10 @@ public static class RaycastExtensions
// --- 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)
{
var query = new PhysicsRayQueryParameters2D

View File

@@ -1,7 +1,7 @@
using Godot;
namespace GodotHelpers.Raycasts;
using Godot;
public record ShapeCastResult3D(
GodotObject Collider,
int ColliderId,

View File

@@ -1,8 +1,8 @@
namespace SJK.GodotHelpers;
using System;
using System.Collections.Generic;
using Godot;
using Godot.Collections;
namespace SJK.GodotHelpers;
public static class VariantUtils
{
@@ -73,6 +73,18 @@ public static class VariantUtils
Variant.Type.Signal => typeof(Signal),
Variant.Type.Dictionary => typeof(Dictionary),
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)
};
}

13
NuGet.Config Normal file
View 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>

View File

@@ -4,6 +4,7 @@
],
"ignorePaths": [
"**/*.tscn",
"**/*.uid",
"**/*.import",
"**/badges/**/*.*",
"**/coverage/**/*.*",
@@ -13,6 +14,7 @@
"**/nupkg/**/*.*"
],
"words": [
"Aabb",
"assemblyfilters",
"automerge",
"branchcoverage",
@@ -28,14 +30,18 @@
"endregion",
"Finalizer",
"Finalizers",
"gitea",
"globaltool",
"godotengine",
"godotpackage",
"issuecomment",
"justalemon",
"Kisner",
"lcov",
"Lerp",
"lihop",
"linecoverage",
"Mathf",
"methodcoverage",
"missingall",
"msbuild",
@@ -67,4 +73,4 @@
"Unparented",
"Xunit"
]
}
}