restructure template project generation
parent
4fee6459fc
commit
64c59fa434
|
@ -1,36 +1,14 @@
|
||||||
{
|
{
|
||||||
"version": "0.2.0",
|
"version": "0.2.0",
|
||||||
"configurations": [
|
"configurations": [
|
||||||
{
|
|
||||||
"name": "Attach to Framework Debugger",
|
|
||||||
"type": "clr",
|
|
||||||
"request": "launch",
|
|
||||||
"preLaunchTask": "Build: Framework Debug",
|
|
||||||
"program": "${workspaceFolder}/ProjectName/bin/x64/Debug/net472/ProjectName.exe",
|
|
||||||
"args": [],
|
|
||||||
"cwd": "${workspaceFolder}/ProjectName/bin/x64/Debug/net472",
|
|
||||||
"console": "integratedTerminal",
|
|
||||||
"internalConsoleOptions": "neverOpen"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Attach to Mono Debugger",
|
|
||||||
"type": "mono",
|
|
||||||
"request": "launch",
|
|
||||||
"preLaunchTask": "Build: Mono Debug",
|
|
||||||
"program": "${workspaceFolder}/ProjectName/bin/x64/Debug/net472/ProjectName.exe",
|
|
||||||
"args": [],
|
|
||||||
"cwd": "${workspaceFolder}/ProjectName/bin/x64/Debug/net472",
|
|
||||||
"console": "integratedTerminal",
|
|
||||||
"internalConsoleOptions": "neverOpen"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"name": "Attach to .NET 5 Debugger",
|
"name": "Attach to .NET 5 Debugger",
|
||||||
"type": "coreclr",
|
"type": "coreclr",
|
||||||
"request": "launch",
|
"request": "launch",
|
||||||
"preLaunchTask": "Build: .NET 5 Debug",
|
"preLaunchTask": "Build: .NET 5 Debug",
|
||||||
"program": "${workspaceFolder}/ProjectName/bin/x64/Debug/net5.0/ProjectName.dll",
|
"program": "${workspaceFolder}/bin/x64/Debug/net5.0/ProjectName.dll",
|
||||||
"args": [],
|
"args": [],
|
||||||
"cwd": "${workspaceFolder}/ProjectName/bin/x64/Debug/net5.0",
|
"cwd": "${workspaceFolder}/bin/x64/Debug/net5.0",
|
||||||
"console": "integratedTerminal",
|
"console": "integratedTerminal",
|
||||||
"internalConsoleOptions": "neverOpen"
|
"internalConsoleOptions": "neverOpen"
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,106 +20,6 @@
|
||||||
"panel": "shared"
|
"panel": "shared"
|
||||||
},
|
},
|
||||||
"tasks": [
|
"tasks": [
|
||||||
{
|
|
||||||
"label": "Build: Mono Release",
|
|
||||||
"command": "msbuild",
|
|
||||||
"args": [
|
|
||||||
"-restore:True",
|
|
||||||
"${workspaceFolder}/ProjectName.Framework.sln",
|
|
||||||
"-p:Configuration=Release",
|
|
||||||
"-p:Platform=x64"
|
|
||||||
],
|
|
||||||
"type": "shell",
|
|
||||||
"group": {
|
|
||||||
"kind": "build",
|
|
||||||
"isDefault": true
|
|
||||||
},
|
|
||||||
"problemMatcher": "$msCompile"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Run: Mono Release",
|
|
||||||
"command": "mono",
|
|
||||||
"args": [
|
|
||||||
"ProjectName.exe"
|
|
||||||
],
|
|
||||||
"options": {
|
|
||||||
"env": {
|
|
||||||
"LD_LIBRARY_PATH": "./lib64",
|
|
||||||
"DYLD_LIBRARY_PATH": "./osx"
|
|
||||||
},
|
|
||||||
"cwd": "${workspaceFolder}/ProjectName/bin/x64/Release/net472"
|
|
||||||
},
|
|
||||||
"type": "process",
|
|
||||||
"group": {
|
|
||||||
"kind": "build",
|
|
||||||
"isDefault": true
|
|
||||||
},
|
|
||||||
"problemMatcher": []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Build & Run: Mono Release",
|
|
||||||
"dependsOn": [
|
|
||||||
"Build: Mono Release",
|
|
||||||
"Run: Mono Release"
|
|
||||||
],
|
|
||||||
"dependsOrder": "sequence",
|
|
||||||
"type": "shell",
|
|
||||||
"group": {
|
|
||||||
"kind": "build",
|
|
||||||
"isDefault": true
|
|
||||||
},
|
|
||||||
"problemMatcher": []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Build: Mono Debug",
|
|
||||||
"command": "msbuild",
|
|
||||||
"args": [
|
|
||||||
"-restore:True",
|
|
||||||
"${workspaceFolder}/ProjectName.Framework.sln",
|
|
||||||
"-p:Configuration=Debug",
|
|
||||||
"-p:Platform=x64"
|
|
||||||
],
|
|
||||||
"type": "shell",
|
|
||||||
"group": {
|
|
||||||
"kind": "build",
|
|
||||||
"isDefault": true
|
|
||||||
},
|
|
||||||
"problemMatcher": []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Run: Mono Debug",
|
|
||||||
"command": "mono",
|
|
||||||
"args": [
|
|
||||||
"ProjectName.exe"
|
|
||||||
],
|
|
||||||
"options": {
|
|
||||||
"env": {
|
|
||||||
"LD_LIBRARY_PATH": "./lib64",
|
|
||||||
"DYLD_LIBRARY_PATH": "./osx"
|
|
||||||
},
|
|
||||||
"cwd": "${workspaceFolder}/ProjectName/bin/x64/Debug/net472"
|
|
||||||
},
|
|
||||||
"type": "process",
|
|
||||||
"group": {
|
|
||||||
"kind": "build",
|
|
||||||
"isDefault": true
|
|
||||||
},
|
|
||||||
"problemMatcher": []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Build & Run: Mono Debug",
|
|
||||||
"dependsOn": [
|
|
||||||
"Build: Mono Debug",
|
|
||||||
"Run: Mono Debug"
|
|
||||||
],
|
|
||||||
"dependsOrder": "sequence",
|
|
||||||
"type": "shell",
|
|
||||||
"group": {
|
|
||||||
"kind": "build",
|
|
||||||
"isDefault": true
|
|
||||||
},
|
|
||||||
"problemMatcher": []
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"label": "Build & Run: .NET 5 Debug",
|
"label": "Build & Run: .NET 5 Debug",
|
||||||
"type": "shell",
|
"type": "shell",
|
||||||
|
@ -139,7 +39,7 @@
|
||||||
"command": "dotnet",
|
"command": "dotnet",
|
||||||
"args": [
|
"args": [
|
||||||
"build",
|
"build",
|
||||||
"./ProjectName/ProjectName.Core.csproj",
|
"./ProjectName.csproj",
|
||||||
"-p:SolutionDir=${workspaceFolder}/",
|
"-p:SolutionDir=${workspaceFolder}/",
|
||||||
"-p:Platform=x64"
|
"-p:Platform=x64"
|
||||||
],
|
],
|
||||||
|
@ -161,7 +61,7 @@
|
||||||
"LD_LIBRARY_PATH": "./lib64",
|
"LD_LIBRARY_PATH": "./lib64",
|
||||||
"DYLD_LIBRARY_PATH": "./osx"
|
"DYLD_LIBRARY_PATH": "./osx"
|
||||||
},
|
},
|
||||||
"cwd": "${workspaceFolder}/ProjectName/bin/x64/Debug/net5.0"
|
"cwd": "${workspaceFolder}/bin/x64/Debug/net5.0"
|
||||||
},
|
},
|
||||||
"type": "process",
|
"type": "process",
|
||||||
"group": {
|
"group": {
|
||||||
|
@ -175,7 +75,7 @@
|
||||||
"command": "dotnet",
|
"command": "dotnet",
|
||||||
"args": [
|
"args": [
|
||||||
"build",
|
"build",
|
||||||
"./ProjectName/ProjectName.Core.csproj",
|
"./ProjectName.csproj",
|
||||||
"--configuration",
|
"--configuration",
|
||||||
"Release",
|
"Release",
|
||||||
"-p:SolutionDir=${workspaceFolder}/",
|
"-p:SolutionDir=${workspaceFolder}/",
|
||||||
|
@ -199,7 +99,7 @@
|
||||||
"LD_LIBRARY_PATH": "./lib64",
|
"LD_LIBRARY_PATH": "./lib64",
|
||||||
"DYLD_LIBRARY_PATH": "./osx"
|
"DYLD_LIBRARY_PATH": "./osx"
|
||||||
},
|
},
|
||||||
"cwd": "${workspaceFolder}/ProjectName/bin/x64/Release/net5.0"
|
"cwd": "${workspaceFolder}/bin/x64/Release/net5.0"
|
||||||
},
|
},
|
||||||
"type": "process",
|
"type": "process",
|
||||||
"group": {
|
"group": {
|
||||||
|
@ -221,92 +121,6 @@
|
||||||
"isDefault": true
|
"isDefault": true
|
||||||
},
|
},
|
||||||
"problemMatcher": []
|
"problemMatcher": []
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Build: Framework Debug",
|
|
||||||
"command": "MsBuild.exe",
|
|
||||||
"args": [
|
|
||||||
"-restore:True",
|
|
||||||
"${workspaceFolder}/ProjectName.Framework.sln",
|
|
||||||
"-p:Configuration=Debug",
|
|
||||||
"-p:Platform=x64"
|
|
||||||
],
|
|
||||||
"type": "shell",
|
|
||||||
"group": {
|
|
||||||
"kind": "build",
|
|
||||||
"isDefault": true
|
|
||||||
},
|
|
||||||
"problemMatcher": []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Run: Framework Debug",
|
|
||||||
"command": "ProjectName.exe",
|
|
||||||
"options": {
|
|
||||||
"cwd": "${workspaceFolder}/ProjectName/bin/x64/Debug/net472"
|
|
||||||
},
|
|
||||||
"type": "process",
|
|
||||||
"group": {
|
|
||||||
"kind": "build",
|
|
||||||
"isDefault": true
|
|
||||||
},
|
|
||||||
"problemMatcher": []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Build & Run: Framework Debug",
|
|
||||||
"dependsOn": [
|
|
||||||
"Build: Framework Debug",
|
|
||||||
"Run: Framework Debug"
|
|
||||||
],
|
|
||||||
"dependsOrder": "sequence",
|
|
||||||
"type": "shell",
|
|
||||||
"group": {
|
|
||||||
"kind": "build",
|
|
||||||
"isDefault": true
|
|
||||||
},
|
|
||||||
"problemMatcher": []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Build: Framework Release",
|
|
||||||
"command": "MsBuild.exe",
|
|
||||||
"args": [
|
|
||||||
"-restore:True",
|
|
||||||
"${workspaceFolder}/ProjectName.Framework.sln",
|
|
||||||
"-p:Configuration=Release",
|
|
||||||
"-p:Platform=x64"
|
|
||||||
],
|
|
||||||
"type": "shell",
|
|
||||||
"group": {
|
|
||||||
"kind": "build",
|
|
||||||
"isDefault": true
|
|
||||||
},
|
|
||||||
"problemMatcher": []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Run: Framework Release",
|
|
||||||
"command": "ProjectName.exe",
|
|
||||||
"options": {
|
|
||||||
"cwd": "${workspaceFolder}/ProjectName/bin/x64/Release/net472"
|
|
||||||
},
|
|
||||||
"type": "process",
|
|
||||||
"group": {
|
|
||||||
"kind": "build",
|
|
||||||
"isDefault": true
|
|
||||||
},
|
|
||||||
"problemMatcher": []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Build & Run: Framework Release",
|
|
||||||
"dependsOn": [
|
|
||||||
"Build: Framework Release",
|
|
||||||
"Run: Framework Release"
|
|
||||||
],
|
|
||||||
"dependsOrder": "sequence",
|
|
||||||
"type": "shell",
|
|
||||||
"group": {
|
|
||||||
"kind": "build",
|
|
||||||
"isDefault": true
|
|
||||||
},
|
|
||||||
"problemMatcher": []
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,26 +5,26 @@
|
||||||
<Message Text="Runtime ID: $(RuntimeIdentifier)" Importance="high"/>
|
<Message Text="Runtime ID: $(RuntimeIdentifier)" Importance="high"/>
|
||||||
</Target>
|
</Target>
|
||||||
|
|
||||||
<ItemGroup Condition="$(RuntimeIdentifier.Contains('win'))">
|
<ItemGroup Condition="$([System.Runtime.InteropServices.RuntimeInformation]::IsOSPlatform($([System.Runtime.InteropServices.OSPlatform]::Windows)))">
|
||||||
<Content Include="..\moonlibs\windows\FAudio.dll">
|
<Content Include=".\moonlibs\windows\FAudio.dll">
|
||||||
<Link>%(RecursiveDir)%(Filename)%(Extension)</Link>
|
<Link>%(RecursiveDir)%(Filename)%(Extension)</Link>
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
<Content Include="..\moonlibs\windows\Refresh.dll">
|
<Content Include=".\moonlibs\windows\Refresh.dll">
|
||||||
<Link>%(RecursiveDir)%(Filename)%(Extension)</Link>
|
<Link>%(RecursiveDir)%(Filename)%(Extension)</Link>
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
<Content Include="..\moonlibs\windows\SDL2.dll">
|
<Content Include=".\moonlibs\windows\SDL2.dll">
|
||||||
<Link>%(RecursiveDir)%(Filename)%(Extension)</Link>
|
<Link>%(RecursiveDir)%(Filename)%(Extension)</Link>
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup Condition="('$(RuntimeIdentifier)' == '' AND $([MSBuild]::IsOSPlatform('Linux'))) OR $(RuntimeIdentifier.Contains('linux'))">
|
<ItemGroup Condition="$([System.Runtime.InteropServices.RuntimeInformation]::IsOSPlatform($([System.Runtime.InteropServices.OSPlatform]::OSX)))">
|
||||||
<Content Include="..\moonlibs\lib64\libFAudio.*">
|
<Content Include=".\moonlibs\lib64\libFAudio.*">
|
||||||
<Link>%(RecursiveDir)%(Filename)%(Extension)</Link>
|
<Link>%(RecursiveDir)%(Filename)%(Extension)</Link>
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
<Content Include="..\moonlibs\lib64\libRefresh.*">
|
<Content Include=".\moonlibs\lib64\libRefresh.*">
|
||||||
<Link>%(RecursiveDir)%(Filename)%(Extension)</Link>
|
<Link>%(RecursiveDir)%(Filename)%(Extension)</Link>
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
|
@ -33,8 +33,8 @@
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup Condition="$(RuntimeIdentifier.Contains('osx'))">
|
<ItemGroup Condition="$([System.Runtime.InteropServices.RuntimeInformation]::IsOSPlatform($([System.Runtime.InteropServices.OSPlatform]::Linux)))">
|
||||||
<Content Include="..\moonlibs\osx\**\*.*" >
|
<Content Include=".\moonlibs\osx\**\*.*" >
|
||||||
<Link>%(RecursiveDir)%(Filename)%(Extension)</Link>
|
<Link>%(RecursiveDir)%(Filename)%(Extension)</Link>
|
||||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
|
@ -1,31 +0,0 @@
|
||||||
|
|
||||||
Microsoft Visual Studio Solution File, Format Version 12.00
|
|
||||||
# Visual Studio Version 16
|
|
||||||
VisualStudioVersion = 16.0.30717.126
|
|
||||||
MinimumVisualStudioVersion = 15.0.26124.0
|
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "ProjectName.Framework", "ProjectName\ProjectName.Framework.csproj", "{9ED076FA-32C3-4F1E-BB90-549B3A2FA46F}"
|
|
||||||
EndProject
|
|
||||||
Global
|
|
||||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
|
||||||
Debug|x64 = Debug|x64
|
|
||||||
Debug|x86 = Debug|x86
|
|
||||||
Release|x64 = Release|x64
|
|
||||||
Release|x86 = Release|x86
|
|
||||||
EndGlobalSection
|
|
||||||
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
|
||||||
{9ED076FA-32C3-4F1E-BB90-549B3A2FA46F}.Debug|x64.ActiveCfg = Debug|x64
|
|
||||||
{9ED076FA-32C3-4F1E-BB90-549B3A2FA46F}.Debug|x64.Build.0 = Debug|x64
|
|
||||||
{9ED076FA-32C3-4F1E-BB90-549B3A2FA46F}.Debug|x86.ActiveCfg = Debug|x86
|
|
||||||
{9ED076FA-32C3-4F1E-BB90-549B3A2FA46F}.Debug|x86.Build.0 = Debug|x86
|
|
||||||
{9ED076FA-32C3-4F1E-BB90-549B3A2FA46F}.Release|x64.ActiveCfg = Release|x64
|
|
||||||
{9ED076FA-32C3-4F1E-BB90-549B3A2FA46F}.Release|x64.Build.0 = Release|x64
|
|
||||||
{9ED076FA-32C3-4F1E-BB90-549B3A2FA46F}.Release|x86.ActiveCfg = Release|x86
|
|
||||||
{9ED076FA-32C3-4F1E-BB90-549B3A2FA46F}.Release|x86.Build.0 = Release|x86
|
|
||||||
EndGlobalSection
|
|
||||||
GlobalSection(SolutionProperties) = preSolution
|
|
||||||
HideSolutionNode = FALSE
|
|
||||||
EndGlobalSection
|
|
||||||
GlobalSection(ExtensibilityGlobals) = postSolution
|
|
||||||
SolutionGuid = {4DB7BE1E-CAC6-4275-B514-20CBE80F794F}
|
|
||||||
EndGlobalSection
|
|
||||||
EndGlobal
|
|
|
@ -1,11 +1,12 @@
|
||||||
<Project>
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<BaseIntermediateOutputPath>obj\$(MSBuildProjectName)</BaseIntermediateOutputPath>
|
<OutputType>Exe</OutputType>
|
||||||
<Platforms>x64;x86</Platforms>
|
<TargetFramework>net5.0</TargetFramework>
|
||||||
|
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<Import Sdk="Microsoft.NET.Sdk" Project="Sdk.props" />
|
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<OutputType>WinExe</OutputType>
|
<OutputType>Exe</OutputType>
|
||||||
<TargetFramework>net5.0</TargetFramework>
|
<TargetFramework>net5.0</TargetFramework>
|
||||||
<TargetName>ProjectName</TargetName>
|
<TargetName>ProjectName</TargetName>
|
||||||
<GenerateAssemblyInfo>false</GenerateAssemblyInfo>
|
<GenerateAssemblyInfo>false</GenerateAssemblyInfo>
|
||||||
|
@ -15,17 +16,22 @@
|
||||||
<AssemblyName>ProjectName</AssemblyName>
|
<AssemblyName>ProjectName</AssemblyName>
|
||||||
<RootNamespace>ProjectName</RootNamespace>
|
<RootNamespace>ProjectName</RootNamespace>
|
||||||
<TargetLatestRuntimePatch>true</TargetLatestRuntimePatch>
|
<TargetLatestRuntimePatch>true</TargetLatestRuntimePatch>
|
||||||
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
|
|
||||||
<ApplicationIcon />
|
<ApplicationIcon />
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Content Include="Content\**\*.*">
|
<Content Include="Content\**\*.*">
|
||||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
|
<PropertyGroup>
|
||||||
|
<DefaultItemExcludes>$(DefaultItemExcludes);lib\**\*</DefaultItemExcludes>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ProjectReference Include="..\lib\MoonWorks\MoonWorks.csproj" />
|
<ProjectReference Include="lib\MoonWorks\MoonWorks.csproj" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<Import Project=".\CopyMoonlibs.targets" />
|
<Import Project=".\CopyMoonlibs.targets" />
|
||||||
<Import Sdk="Microsoft.NET.Sdk" Project="Sdk.targets" />
|
|
||||||
</Project>
|
</Project>
|
|
@ -8,19 +8,13 @@ EndProject
|
||||||
Global
|
Global
|
||||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
Debug|x64 = Debug|x64
|
Debug|x64 = Debug|x64
|
||||||
Debug|x86 = Debug|x86
|
|
||||||
Release|x64 = Release|x64
|
Release|x64 = Release|x64
|
||||||
Release|x86 = Release|x86
|
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||||
{4589302C-174A-4173-9654-CAA6CA1B5220}.Debug|x64.ActiveCfg = Debug|x64
|
{4589302C-174A-4173-9654-CAA6CA1B5220}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
{4589302C-174A-4173-9654-CAA6CA1B5220}.Debug|x64.Build.0 = Debug|x64
|
{4589302C-174A-4173-9654-CAA6CA1B5220}.Debug|x64.Build.0 = Debug|x64
|
||||||
{4589302C-174A-4173-9654-CAA6CA1B5220}.Debug|x86.ActiveCfg = Debug|x86
|
|
||||||
{4589302C-174A-4173-9654-CAA6CA1B5220}.Debug|x86.Build.0 = Debug|x86
|
|
||||||
{4589302C-174A-4173-9654-CAA6CA1B5220}.Release|x64.ActiveCfg = Release|x64
|
{4589302C-174A-4173-9654-CAA6CA1B5220}.Release|x64.ActiveCfg = Release|x64
|
||||||
{4589302C-174A-4173-9654-CAA6CA1B5220}.Release|x64.Build.0 = Release|x64
|
{4589302C-174A-4173-9654-CAA6CA1B5220}.Release|x64.Build.0 = Release|x64
|
||||||
{4589302C-174A-4173-9654-CAA6CA1B5220}.Release|x86.ActiveCfg = Release|x86
|
|
||||||
{4589302C-174A-4173-9654-CAA6CA1B5220}.Release|x86.Build.0 = Release|x86
|
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(SolutionProperties) = preSolution
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
HideSolutionNode = FALSE
|
HideSolutionNode = FALSE
|
|
@ -1,259 +0,0 @@
|
||||||
// only works in .NET Core. disable in .NET framework
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.IO;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Reflection;
|
|
||||||
using System.Runtime.InteropServices;
|
|
||||||
using System.Xml.Linq;
|
|
||||||
|
|
||||||
public static class DllMap
|
|
||||||
{
|
|
||||||
[DllImport("kernel32.dll", CharSet = CharSet.Unicode, SetLastError = true)]
|
|
||||||
[return: MarshalAs(UnmanagedType.Bool)]
|
|
||||||
static extern bool SetDefaultDllDirectories(int directoryFlags);
|
|
||||||
|
|
||||||
[DllImport("kernel32.dll", CharSet = CharSet.Unicode, SetLastError = true)]
|
|
||||||
static extern void AddDllDirectory(string lpPathName);
|
|
||||||
|
|
||||||
[DllImport("kernel32.dll", CharSet = CharSet.Unicode, SetLastError = true)]
|
|
||||||
[return: MarshalAs(UnmanagedType.Bool)]
|
|
||||||
static extern bool SetDllDirectory(string lpPathName);
|
|
||||||
|
|
||||||
const int LOAD_LIBRARY_SEARCH_DEFAULT_DIRS = 0x00001000;
|
|
||||||
|
|
||||||
public static Dictionary<string, string> MapDictionary;
|
|
||||||
public static string OS;
|
|
||||||
public static string CPU;
|
|
||||||
public static bool Optimise;
|
|
||||||
|
|
||||||
public static void Initialise(bool optimise = true)
|
|
||||||
{
|
|
||||||
Optimise = optimise;
|
|
||||||
|
|
||||||
// Our executabe needs to know how to find the native libraries
|
|
||||||
// For Windows, we can set this to be x86 or x64 directory at runtime (below)
|
|
||||||
// For Linux we need to move our native libraries to 'netcoredeps' which is set by .net core
|
|
||||||
// For OSX we need to set an environment variable (DYLD_LIBRARY_PATH) outside of the process by a script
|
|
||||||
if (Environment.OSVersion.Platform == PlatformID.Win32NT)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
SetDefaultDllDirectories(LOAD_LIBRARY_SEARCH_DEFAULT_DIRS);
|
|
||||||
AddDllDirectory(Path.Combine(
|
|
||||||
AppDomain.CurrentDomain.BaseDirectory,
|
|
||||||
Environment.Is64BitProcess ? "x64" : "x86"
|
|
||||||
));
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
// Pre-Windows 7, KB2533623
|
|
||||||
SetDllDirectory(Path.Combine(
|
|
||||||
AppDomain.CurrentDomain.BaseDirectory,
|
|
||||||
Environment.Is64BitProcess ? "x64" : "x86"
|
|
||||||
));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// .NET Core also doesn't use DllImport but we can replicate this using NativeLibrary as per below
|
|
||||||
// Uses MoonWorks.dll.config to dictate what the name of the native library is per platform and architecture
|
|
||||||
var moonWorksAssembly = Assembly.GetAssembly(typeof(Microsoft.Xna.Framework.Graphics.ColorWriteChannels));
|
|
||||||
DllMap.Register(moonWorksAssembly);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Register a call-back for native library resolution.
|
|
||||||
public static void Register(Assembly assembly)
|
|
||||||
{
|
|
||||||
NativeLibrary.SetDllImportResolver(assembly, MapAndLoad);
|
|
||||||
|
|
||||||
// Do setup so that MapLibraryName is faster than reading the XML each time
|
|
||||||
|
|
||||||
// 1) Get platform & cpu
|
|
||||||
OS = GetCurrentPlatform().ToString().ToLowerInvariant();
|
|
||||||
CPU = GetCurrentRuntimeArchitecture().ToString().ToLowerInvariant();
|
|
||||||
|
|
||||||
// 2) Setup MapDictionary
|
|
||||||
// For Windows use hardcoded values
|
|
||||||
// Why? This is our development platform and we wanted the fastest start time possible (eliminates XML Load)
|
|
||||||
if (OS == "windows" && Optimise)
|
|
||||||
{
|
|
||||||
MapDictionary = new Dictionary<string, string>();
|
|
||||||
MapDictionary.Add("SDL2", "SDL2.dll");
|
|
||||||
MapDictionary.Add("Refresh", "Refresh.dll");
|
|
||||||
MapDictionary.Add("FAudio", "FAudio.dll");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// For every other platform use XML file
|
|
||||||
// Read in config XML and only store details we're interested in within MapDictionary
|
|
||||||
string xmlPath = Path.Combine(Path.GetDirectoryName(assembly.Location),
|
|
||||||
Path.GetFileNameWithoutExtension(assembly.Location) + ".dll.config");
|
|
||||||
|
|
||||||
if (!File.Exists(xmlPath))
|
|
||||||
{
|
|
||||||
Console.WriteLine($"=== Cannot find XML: " + xmlPath);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
XElement root = XElement.Load(xmlPath);
|
|
||||||
|
|
||||||
MapDictionary = new Dictionary<string, string>();
|
|
||||||
ParseXml(root, true); // Direct match on OS & CPU first
|
|
||||||
ParseXml(root, false); // Loose match on CPU second (won't allow duplicates)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void ParseXml(XElement root, bool matchCPU)
|
|
||||||
{
|
|
||||||
foreach (var el in root.Elements("dllmap"))
|
|
||||||
{
|
|
||||||
// Ignore entries for other OSs
|
|
||||||
if (el.Attribute("os").ToString().IndexOf(OS) < 0)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// Ignore entries for other CPUs
|
|
||||||
if (matchCPU)
|
|
||||||
{
|
|
||||||
if (el.Attribute("cpu") == null)
|
|
||||||
continue;
|
|
||||||
if (el.Attribute("cpu").ToString().IndexOf(CPU) < 0)
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (el.Attribute("cpu") != null && el.Attribute("cpu").ToString().IndexOf(CPU) < 0)
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
string oldLib = el.Attribute("dll").Value;
|
|
||||||
string newLib = el.Attribute("target").Value;
|
|
||||||
if (string.IsNullOrWhiteSpace(oldLib) || string.IsNullOrWhiteSpace(newLib))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// Don't allow duplicates
|
|
||||||
if (MapDictionary.ContainsKey(oldLib))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
MapDictionary.Add(oldLib, newLib);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// The callback: which loads the mapped libray in place of the original
|
|
||||||
private static IntPtr MapAndLoad(string libraryName, Assembly assembly, DllImportSearchPath? dllImportSearchPath)
|
|
||||||
{
|
|
||||||
string mappedName = null;
|
|
||||||
mappedName = MapLibraryName(assembly.Location, libraryName, out mappedName) ? mappedName : libraryName;
|
|
||||||
return NativeLibrary.Load(mappedName, assembly, dllImportSearchPath);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Parse the assembly.xml file, and map the old name to the new name of a library.
|
|
||||||
private static bool MapLibraryName(string assemblyLocation, string originalLibName, out string mappedLibName)
|
|
||||||
{
|
|
||||||
if (MapDictionary.TryGetValue(originalLibName, out mappedLibName))
|
|
||||||
return true;
|
|
||||||
else
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Below pinched from Mono.DllMap project: https://github.com/Firwood-Software/AdvancedDLSupport/tree/1b7394211a655b2f77649ce3b610a3161215cbdc/Mono.DllMap
|
|
||||||
public static DllMapOS GetCurrentPlatform()
|
|
||||||
{
|
|
||||||
if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux))
|
|
||||||
{
|
|
||||||
return DllMapOS.Linux;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
|
|
||||||
{
|
|
||||||
return DllMapOS.Windows;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
|
|
||||||
{
|
|
||||||
return DllMapOS.OSX;
|
|
||||||
}
|
|
||||||
|
|
||||||
var operatingDesc = RuntimeInformation.OSDescription.ToUpperInvariant();
|
|
||||||
foreach (var system in Enum.GetValues(typeof(DllMapOS)).Cast<DllMapOS>()
|
|
||||||
.Except(new[] { DllMapOS.Linux, DllMapOS.Windows, DllMapOS.OSX }))
|
|
||||||
{
|
|
||||||
if (operatingDesc.Contains(system.ToString().ToUpperInvariant()))
|
|
||||||
{
|
|
||||||
return system;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new PlatformNotSupportedException($"Couldn't detect platform: {RuntimeInformation.OSDescription}");
|
|
||||||
}
|
|
||||||
|
|
||||||
public static DllMapArchitecture GetCurrentRuntimeArchitecture()
|
|
||||||
{
|
|
||||||
switch (RuntimeInformation.ProcessArchitecture)
|
|
||||||
{
|
|
||||||
case Architecture.Arm:
|
|
||||||
{
|
|
||||||
return DllMapArchitecture.ARM;
|
|
||||||
}
|
|
||||||
case Architecture.X64:
|
|
||||||
{
|
|
||||||
return DllMapArchitecture.x86_64;
|
|
||||||
}
|
|
||||||
case Architecture.X86:
|
|
||||||
{
|
|
||||||
return DllMapArchitecture.x86;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
typeof(object).Module.GetPEKind(out _, out var machine);
|
|
||||||
switch (machine)
|
|
||||||
{
|
|
||||||
case ImageFileMachine.I386:
|
|
||||||
{
|
|
||||||
return DllMapArchitecture.x86;
|
|
||||||
}
|
|
||||||
case ImageFileMachine.AMD64:
|
|
||||||
{
|
|
||||||
return DllMapArchitecture.x86_64;
|
|
||||||
}
|
|
||||||
case ImageFileMachine.ARM:
|
|
||||||
{
|
|
||||||
return DllMapArchitecture.ARM;
|
|
||||||
}
|
|
||||||
case ImageFileMachine.IA64:
|
|
||||||
{
|
|
||||||
return DllMapArchitecture.IA64;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
throw new PlatformNotSupportedException("Couldn't detect the current architecture.");
|
|
||||||
}
|
|
||||||
|
|
||||||
public enum DllMapOS
|
|
||||||
{
|
|
||||||
Linux = 1 << 0,
|
|
||||||
OSX = 1 << 1,
|
|
||||||
Solaris = 1 << 2,
|
|
||||||
FreeBSD = 1 << 3,
|
|
||||||
OpenBSD = 1 << 4,
|
|
||||||
NetBSD = 1 << 5,
|
|
||||||
Windows = 1 << 6,
|
|
||||||
AIX = 1 << 7,
|
|
||||||
HPUX = 1 << 8
|
|
||||||
}
|
|
||||||
|
|
||||||
public enum DllMapArchitecture
|
|
||||||
{
|
|
||||||
x86 = 1 << 0,
|
|
||||||
x86_64 = 1 << 1,
|
|
||||||
SPARC = 1 << 2,
|
|
||||||
PPC = 1 << 3,
|
|
||||||
S390 = 1 << 4,
|
|
||||||
S390X = 1 << 5,
|
|
||||||
ARM = 1 << 6,
|
|
||||||
ARMV8 = 1 << 7,
|
|
||||||
MIPS = 1 << 8,
|
|
||||||
Alpha = 1 << 9,
|
|
||||||
HPPA = 1 << 10,
|
|
||||||
IA64 = 1 << 11
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,34 +0,0 @@
|
||||||
<Project>
|
|
||||||
<PropertyGroup>
|
|
||||||
<BaseIntermediateOutputPath>obj\$(MSBuildProjectName)</BaseIntermediateOutputPath>
|
|
||||||
<Platforms>x64;x86</Platforms>
|
|
||||||
</PropertyGroup>
|
|
||||||
<Import Sdk="Microsoft.NET.Sdk" Project="Sdk.props" />
|
|
||||||
<PropertyGroup>
|
|
||||||
<OutputType>Exe</OutputType>
|
|
||||||
<TargetFramework>net472</TargetFramework>
|
|
||||||
<TargetName>ProjectName</TargetName>
|
|
||||||
<GenerateAssemblyInfo>false</GenerateAssemblyInfo>
|
|
||||||
<GenerateTargetFrameworkAttribute>false</GenerateTargetFrameworkAttribute>
|
|
||||||
<LangVersion>8.0</LangVersion>
|
|
||||||
<StartupObject>ProjectName.Program</StartupObject>
|
|
||||||
<AssemblyName>ProjectName</AssemblyName>
|
|
||||||
<RootNamespace>ProjectName</RootNamespace>
|
|
||||||
<TargetLatestRuntimePatch>true</TargetLatestRuntimePatch>
|
|
||||||
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
|
|
||||||
<ApplicationIcon />
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup>
|
|
||||||
<DefaultItemExcludes>$(DefaultItemExcludes);DllMap.cs</DefaultItemExcludes>
|
|
||||||
</PropertyGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<Content Include="Content\**\*.*">
|
|
||||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
|
||||||
</Content>
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<ProjectReference Include="..\lib\MoonWorks\MoonWorks.csproj" />
|
|
||||||
</ItemGroup>
|
|
||||||
<Import Project=".\CopyMoonlibs.targets" />
|
|
||||||
<Import Sdk="Microsoft.NET.Sdk" Project="Sdk.targets" />
|
|
||||||
</Project>
|
|
17
install.sh
17
install.sh
|
@ -84,7 +84,7 @@ fi
|
||||||
cp -R "$MY_DIR" "$NEW_PROJECT_DIR"
|
cp -R "$MY_DIR" "$NEW_PROJECT_DIR"
|
||||||
|
|
||||||
cd "$NEW_PROJECT_DIR"
|
cd "$NEW_PROJECT_DIR"
|
||||||
files=(ProjectName.Core.sln ProjectName.Framework.sln .gitignore ProjectName/ProjectName.Core.csproj ProjectName/ProjectName.Framework.csproj ProjectName/ProjectNameGame.cs ProjectName/Program.cs ProjectName/Graphics/GraphicsObjects.cs ProjectName/Graphics/Containers/Framebuffers.cs ProjectName/Graphics/Containers/RenderPasses.cs ProjectName/Graphics/Containers/RenderTargets.cs .vscode/tasks.json .vscode/launch.json)
|
files=(ProjectName.sln .gitignore ProjectName.csproj src/ProjectNameGame.cs src/Program.cs src/Graphics/GraphicsObjects.cs src/Graphics/Containers/Framebuffers.cs src/Graphics/Containers/RenderPasses.cs src/Graphics/Containers/RenderTargets.cs .vscode/tasks.json .vscode/launch.json)
|
||||||
for file in "${files[@]}"; do
|
for file in "${files[@]}"; do
|
||||||
sed -i -e "s/ProjectName/$newProjectName/g" "./$file"
|
sed -i -e "s/ProjectName/$newProjectName/g" "./$file"
|
||||||
if [ "$(uname)" == "Darwin" ]; then
|
if [ "$(uname)" == "Darwin" ]; then
|
||||||
|
@ -92,23 +92,20 @@ for file in "${files[@]}"; do
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
mv ./ProjectName.Core.sln "./$newProjectName.Core.sln"
|
mv ./ProjectName.sln "./$newProjectName.sln"
|
||||||
mv ./ProjectName.Framework.sln "./$newProjectName.Framework.sln"
|
mv ./ProjectName.csproj "./$newProjectName.csproj"
|
||||||
mv ./ProjectName/ProjectName.Core.csproj "./ProjectName/$newProjectName.Core.csproj"
|
mv ./src/ProjectNameGame.cs ./src/${newProjectName}Game.cs
|
||||||
mv ./ProjectName/ProjectName.Framework.csproj "./ProjectName/$newProjectName.Framework.csproj"
|
|
||||||
mv ./ProjectName/ProjectNameGame.cs ./ProjectName/${newProjectName}Game.cs
|
|
||||||
mv ./ProjectName "./$newProjectName"
|
|
||||||
rm ./install.sh
|
rm ./install.sh
|
||||||
rm ./LICENSE
|
rm ./LICENSE
|
||||||
|
|
||||||
rm -rf .git
|
rm -rf .git
|
||||||
git init
|
git init
|
||||||
git branch -m main
|
git checkout -b main
|
||||||
|
git branch -D master
|
||||||
mkdir lib
|
mkdir lib
|
||||||
pullMoonWorks
|
pullMoonWorks
|
||||||
|
|
||||||
dotnet sln ${newProjectName}.Framework.sln add lib/MoonWorks/MoonWorks.csproj
|
dotnet sln ${newProjectName}.sln add lib/MoonWorks/MoonWorks.csproj
|
||||||
dotnet sln ${newProjectName}.Core.sln add lib/MoonWorks/MoonWorks.csproj
|
|
||||||
|
|
||||||
echo "Project $newProjectName created at: "
|
echo "Project $newProjectName created at: "
|
||||||
|
|
||||||
|
|
|
@ -15,18 +15,6 @@ namespace ProjectName
|
||||||
|
|
||||||
static void Main(string[] args)
|
static void Main(string[] args)
|
||||||
{
|
{
|
||||||
#if NETCOREAPP
|
|
||||||
DllMap.Initialise(false);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (Environment.OSVersion.Platform == PlatformID.Win32NT)
|
|
||||||
{
|
|
||||||
SetDllDirectory(Path.Combine(
|
|
||||||
AppDomain.CurrentDomain.BaseDirectory,
|
|
||||||
Environment.Is64BitProcess ? "x64" : "x86"
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
WindowCreateInfo windowCreateInfo = new WindowCreateInfo
|
WindowCreateInfo windowCreateInfo = new WindowCreateInfo
|
||||||
{
|
{
|
||||||
WindowWidth = 1280,
|
WindowWidth = 1280,
|
|
@ -28,12 +28,12 @@ namespace ProjectName
|
||||||
RenderHeight = (int)windowCreateInfo.WindowHeight;
|
RenderHeight = (int)windowCreateInfo.WindowHeight;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void Update(double dt)
|
protected override void Update(System.TimeSpan dt)
|
||||||
{
|
{
|
||||||
// Insert your game update logic here.
|
// Insert your game update logic here.
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void Draw(double dt, double alpha)
|
protected override void Draw(System.TimeSpan dt, double alpha)
|
||||||
{
|
{
|
||||||
// Replace this with your own drawing code.
|
// Replace this with your own drawing code.
|
||||||
|
|
Loading…
Reference in New Issue