mirror of
https://github.com/nefarius/ViGEmBus.git
synced 2025-08-10 00:52:17 +00:00
Merge branch 'master' into feature/core/stack-memory-usage
This commit is contained in:
@@ -5,14 +5,7 @@ install:
|
||||
build_script:
|
||||
- ps: .\build.ps1 -configuration release
|
||||
after_build:
|
||||
- ps: |
|
||||
Invoke-WebRequest "https://downloads.vigem.org/other/pavel-a/ddverpatch/verpatch-1.0.15.1-x86-codeplex.zip" -OutFile verpatch-1.0.15.1-x86-codeplex.zip
|
||||
Expand-Archive verpatch-1.0.15.1-x86-codeplex.zip -DestinationPath .
|
||||
.\verpatch.exe .\artifacts\x64\ViGEmBus.sys "$env:APPVEYOR_BUILD_VERSION"
|
||||
.\verpatch.exe .\artifacts\x64\ViGEmBus.sys /pv "$env:APPVEYOR_BUILD_VERSION"
|
||||
.\verpatch.exe .\artifacts\x86\ViGEmBus.sys "$env:APPVEYOR_BUILD_VERSION"
|
||||
.\verpatch.exe .\artifacts\x86\ViGEmBus.sys /pv "$env:APPVEYOR_BUILD_VERSION"
|
||||
makecab.exe /f ViGEmBus.ddf
|
||||
- cmd: makecab.exe /f ViGEmBus.ddf
|
||||
artifacts:
|
||||
- path: disk1\ViGEmBus.cab
|
||||
name: ViGEmBus_unsigned_x86_amd64
|
||||
|
||||
@@ -1,45 +1,45 @@
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using JsonConfig;
|
||||
using Nuke.Common;
|
||||
using Nuke.Common.BuildServers;
|
||||
using Nuke.Common.Git;
|
||||
using Nuke.Common.ProjectModel;
|
||||
using Nuke.Common.Tools.GitVersion;
|
||||
using Nuke.Common.Tools.MSBuild;
|
||||
using Vestris.ResourceLib;
|
||||
using static Nuke.Common.EnvironmentInfo;
|
||||
using static Nuke.Common.IO.FileSystemTasks;
|
||||
using static Nuke.Common.IO.PathConstruction;
|
||||
using static Nuke.Common.Tools.MSBuild.MSBuildTasks;
|
||||
|
||||
class Build : NukeBuild
|
||||
internal class Build : NukeBuild
|
||||
{
|
||||
public static int Main () => Execute<Build>(x => x.Compile);
|
||||
[GitRepository] private readonly GitRepository GitRepository;
|
||||
[GitVersion] private readonly GitVersion GitVersion;
|
||||
|
||||
[Solution] readonly Solution Solution;
|
||||
[GitRepository] readonly GitRepository GitRepository;
|
||||
[Solution("ViGEmBus.sln")] private readonly Solution Solution;
|
||||
|
||||
AbsolutePath ArtifactsDirectory => RootDirectory / "artifacts";
|
||||
private AbsolutePath ArtifactsDirectory => RootDirectory / "artifacts";
|
||||
|
||||
Target Clean => _ => _
|
||||
.Executes(() =>
|
||||
{
|
||||
EnsureCleanDirectory(ArtifactsDirectory);
|
||||
});
|
||||
private Target Clean => _ => _
|
||||
.Executes(() => { EnsureCleanDirectory(ArtifactsDirectory); });
|
||||
|
||||
Target Restore => _ => _
|
||||
private Target Restore => _ => _
|
||||
.DependsOn(Clean)
|
||||
.Executes(() =>
|
||||
{
|
||||
MSBuild(s => s
|
||||
.SetTargetPath(SolutionFile)
|
||||
.SetTargetPath(Solution)
|
||||
.SetTargets("Restore"));
|
||||
});
|
||||
|
||||
Target Compile => _ => _
|
||||
private Target Compile => _ => _
|
||||
.DependsOn(Restore)
|
||||
.Executes(() =>
|
||||
{
|
||||
MSBuild(s => s
|
||||
.SetTargetPath(SolutionFile)
|
||||
.SetTargetPath(Solution)
|
||||
.SetTargets("Rebuild")
|
||||
.SetConfiguration(Configuration)
|
||||
.SetMaxCpuCount(Environment.ProcessorCount)
|
||||
@@ -47,7 +47,7 @@ class Build : NukeBuild
|
||||
.SetTargetPlatform(MSBuildTargetPlatform.x64));
|
||||
|
||||
MSBuild(s => s
|
||||
.SetTargetPath(SolutionFile)
|
||||
.SetTargetPath(Solution)
|
||||
.SetTargets("Rebuild")
|
||||
.SetConfiguration(Configuration)
|
||||
.SetMaxCpuCount(Environment.ProcessorCount)
|
||||
@@ -55,6 +55,7 @@ class Build : NukeBuild
|
||||
.SetTargetPlatform(MSBuildTargetPlatform.x86));
|
||||
|
||||
#region Ugly hack, fix me!
|
||||
|
||||
EnsureExistingDirectory(Path.Combine(ArtifactsDirectory, @"x64"));
|
||||
EnsureExistingDirectory(Path.Combine(ArtifactsDirectory, @"x86"));
|
||||
|
||||
@@ -88,7 +89,22 @@ class Build : NukeBuild
|
||||
Path.Combine(WorkingDirectory, @"bin\x86\ViGEmBus\WdfCoinstaller01009.dll"),
|
||||
Path.Combine(ArtifactsDirectory, @"x86\WdfCoinstaller01009.dll")
|
||||
);
|
||||
|
||||
#endregion
|
||||
|
||||
if (Configuration.Equals("release", StringComparison.InvariantCultureIgnoreCase))
|
||||
{
|
||||
var version =
|
||||
new Version(IsLocalBuild ? GitVersion.GetNormalizedFileVersion() : AppVeyor.Instance.BuildVersion);
|
||||
|
||||
StampVersion(
|
||||
Path.Combine(ArtifactsDirectory, @"x64\ViGEmBus.sys"),
|
||||
version);
|
||||
|
||||
StampVersion(
|
||||
Path.Combine(ArtifactsDirectory, @"x86\ViGEmBus.sys"),
|
||||
version);
|
||||
}
|
||||
});
|
||||
|
||||
private Target Pack => _ => _
|
||||
@@ -96,10 +112,49 @@ class Build : NukeBuild
|
||||
.Executes(() =>
|
||||
{
|
||||
MSBuild(s => s
|
||||
.SetTargetPath(SolutionFile)
|
||||
.SetTargetPath(Solution)
|
||||
.SetTargets("Restore", "Pack")
|
||||
.SetPackageOutputPath(ArtifactsDirectory)
|
||||
.SetConfiguration(Configuration)
|
||||
.EnableIncludeSymbols());
|
||||
});
|
||||
}
|
||||
|
||||
public static int Main()
|
||||
{
|
||||
return Execute<Build>(x => x.Compile);
|
||||
}
|
||||
|
||||
private static void StampVersion(string path, Version version)
|
||||
{
|
||||
var versionResource = new VersionResource
|
||||
{
|
||||
FileVersion = version.ToString(),
|
||||
ProductVersion = version.ToString()
|
||||
};
|
||||
|
||||
var stringFileInfo = new StringFileInfo();
|
||||
versionResource[stringFileInfo.Key] = stringFileInfo;
|
||||
var stringFileInfoStrings = new StringTable
|
||||
{
|
||||
LanguageID = 1033,
|
||||
CodePage = 1200
|
||||
};
|
||||
stringFileInfo.Strings.Add(stringFileInfoStrings.Key, stringFileInfoStrings);
|
||||
stringFileInfoStrings["CompanyName"] = Config.Global.Version.CompanyName;
|
||||
stringFileInfoStrings["FileDescription"] = Config.Global.Version.FileDescription;
|
||||
stringFileInfoStrings["FileVersion"] = version.ToString();
|
||||
stringFileInfoStrings["InternalName"] = Config.Global.Version.InternalName;
|
||||
stringFileInfoStrings["LegalCopyright"] = Config.Global.Version.LegalCopyright;
|
||||
stringFileInfoStrings["OriginalFilename"] = Config.Global.Version.OriginalFilename;
|
||||
stringFileInfoStrings["ProductName"] = Config.Global.Version.ProductName;
|
||||
stringFileInfoStrings["ProductVersion"] = version.ToString();
|
||||
|
||||
var varFileInfo = new VarFileInfo();
|
||||
versionResource[varFileInfo.Key] = varFileInfo;
|
||||
var varFileInfoTranslation = new VarTable("Translation");
|
||||
varFileInfo.Vars.Add(varFileInfoTranslation.Key, varFileInfoTranslation);
|
||||
varFileInfoTranslation[ResourceUtil.USENGLISHLANGID] = 1300;
|
||||
|
||||
versionResource.SaveTo(path);
|
||||
}
|
||||
}
|
||||
@@ -10,14 +10,19 @@
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="Nuke.Common" Version="0.9.0" />
|
||||
<PackageReference Include="Nefarius.JsonConfig" Version="1.0.2" />
|
||||
<PackageReference Include="Nuke.Common" Version="0.9.1" />
|
||||
<PackageReference Include="GitVersion.CommandLine" Version="3.6.5" />
|
||||
<PackageReference Include="Vestris.ResourceLib" Version="2.0.0" />
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<NukeMetadata Include="**\*.json" Exclude="bin\**;obj\**" />
|
||||
<NukeExternalFiles Include="**\*.*.ext" Exclude="bin\**;obj\**" />
|
||||
<None Remove="*.csproj.DotSettings;*.ref.*.txt" />
|
||||
<None Remove="default.json" />
|
||||
<NukeMetadata Remove="default.json" />
|
||||
<EmbeddedResource Include="default.json" />
|
||||
|
||||
<!-- Common build related files -->
|
||||
<None Include="..\build.ps1" />
|
||||
|
||||
10
build/default.json
Normal file
10
build/default.json
Normal file
@@ -0,0 +1,10 @@
|
||||
{
|
||||
"Version": {
|
||||
"CompanyName": "Benjamin Hoeglinger-Stelzer",
|
||||
"FileDescription": "Virtual Gamepad Emulation Framework Bus Driver",
|
||||
"InternalName": "ViGEmBus.sys",
|
||||
"LegalCopyright": "Copyright (C) 2016-2018 Benjamin Hoeglinger-Stelzer All Rights Reserved",
|
||||
"OriginalFilename": "ViGEmBus.sys",
|
||||
"ProductName": "Virtual Gamepad Emulation Framework Bus Driver"
|
||||
}
|
||||
}
|
||||
2
client
2
client
Submodule client updated: e8bbbe6e82...cb3d90f2fc
100
sys/ViGEmBus.rc
100
sys/ViGEmBus.rc
@@ -1,100 +0,0 @@
|
||||
// Microsoft Visual C++ generated resource script.
|
||||
//
|
||||
#include "resource.h"
|
||||
|
||||
#define APSTUDIO_READONLY_SYMBOLS
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Generated from the TEXTINCLUDE 2 resource.
|
||||
//
|
||||
#include "winres.h"
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
#undef APSTUDIO_READONLY_SYMBOLS
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// German (Austria) resources
|
||||
|
||||
#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_DEA)
|
||||
LANGUAGE LANG_GERMAN, SUBLANG_GERMAN_AUSTRIAN
|
||||
#pragma code_page(1252)
|
||||
|
||||
#ifdef APSTUDIO_INVOKED
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// TEXTINCLUDE
|
||||
//
|
||||
|
||||
1 TEXTINCLUDE
|
||||
BEGIN
|
||||
"resource.h\0"
|
||||
END
|
||||
|
||||
2 TEXTINCLUDE
|
||||
BEGIN
|
||||
"#include ""winres.h""\r\n"
|
||||
"\0"
|
||||
END
|
||||
|
||||
3 TEXTINCLUDE
|
||||
BEGIN
|
||||
"\r\n"
|
||||
"\0"
|
||||
END
|
||||
|
||||
#endif // APSTUDIO_INVOKED
|
||||
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Version
|
||||
//
|
||||
|
||||
VS_VERSION_INFO VERSIONINFO
|
||||
FILEVERSION 1,14,3,0
|
||||
PRODUCTVERSION 1,14,3,0
|
||||
FILEFLAGSMASK 0x3fL
|
||||
#ifdef _DEBUG
|
||||
FILEFLAGS 0x1L
|
||||
#else
|
||||
FILEFLAGS 0x0L
|
||||
#endif
|
||||
FILEOS 0x40004L
|
||||
FILETYPE 0xe9L
|
||||
FILESUBTYPE 0x0L
|
||||
BEGIN
|
||||
BLOCK "StringFileInfo"
|
||||
BEGIN
|
||||
BLOCK "000904b0"
|
||||
BEGIN
|
||||
VALUE "CompanyName", "Benjamin H<>glinger-Stelzer"
|
||||
VALUE "FileDescription", "Virtual Gamepad Emulation Bus Driver"
|
||||
VALUE "FileVersion", "1.14.3.0"
|
||||
VALUE "InternalName", "Virtual Gamepad Emulation Bus Driver"
|
||||
VALUE "LegalCopyright", "Copyright (C) Benjamin H<>glinger-Stelzer 2016"
|
||||
VALUE "OriginalFilename", "vigembus.sys"
|
||||
VALUE "ProductName", "Virtual Gamepad Emulation Bus Driver"
|
||||
VALUE "ProductVersion", "1.14.3.0"
|
||||
END
|
||||
END
|
||||
BLOCK "VarFileInfo"
|
||||
BEGIN
|
||||
VALUE "Translation", 0x9, 1200
|
||||
END
|
||||
END
|
||||
|
||||
#endif // German (Austria) resources
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
|
||||
#ifndef APSTUDIO_INVOKED
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Generated from the TEXTINCLUDE 3 resource.
|
||||
//
|
||||
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
#endif // not APSTUDIO_INVOKED
|
||||
|
||||
@@ -185,16 +185,12 @@
|
||||
<ClInclude Include="Context.h" />
|
||||
<ClInclude Include="Ds4.h" />
|
||||
<ClInclude Include="Queue.h" />
|
||||
<ClInclude Include="resource.h" />
|
||||
<ClInclude Include="trace.h" />
|
||||
<ClInclude Include="UsbPdo.h" />
|
||||
<ClInclude Include="Util.h" />
|
||||
<ClInclude Include="Xgip.h" />
|
||||
<ClInclude Include="Xusb.h" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ResourceCompile Include="ViGEmBus.rc" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ClCompile Include="busenum.c" />
|
||||
<ClCompile Include="buspdo.c" />
|
||||
|
||||
@@ -27,9 +27,6 @@
|
||||
</Inf>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ClInclude Include="resource.h">
|
||||
<Filter>Header Files</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="busenum.h">
|
||||
<Filter>Header Files</Filter>
|
||||
</ClInclude>
|
||||
@@ -67,11 +64,6 @@
|
||||
<Filter>Header Files\Common</Filter>
|
||||
</ClInclude>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ResourceCompile Include="ViGEmBus.rc">
|
||||
<Filter>Resource Files</Filter>
|
||||
</ResourceCompile>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ClCompile Include="busenum.c">
|
||||
<Filter>Source Files</Filter>
|
||||
|
||||
@@ -1,14 +0,0 @@
|
||||
//{{NO_DEPENDENCIES}}
|
||||
// Microsoft Visual C++ generated include file.
|
||||
// Used by ViGEmBus.rc
|
||||
|
||||
// Next default values for new objects
|
||||
//
|
||||
#ifdef APSTUDIO_INVOKED
|
||||
#ifndef APSTUDIO_READONLY_SYMBOLS
|
||||
#define _APS_NEXT_RESOURCE_VALUE 101
|
||||
#define _APS_NEXT_COMMAND_VALUE 40001
|
||||
#define _APS_NEXT_CONTROL_VALUE 1001
|
||||
#define _APS_NEXT_SYMED_VALUE 101
|
||||
#endif
|
||||
#endif
|
||||
Reference in New Issue
Block a user