From a828620c6447e8c51f6e9d1767eabe0fc5ade0a0 Mon Sep 17 00:00:00 2001
From: jbzdarkid <jbzdarkid@gmail.com>
Date: Mon, 5 Nov 2018 08:15:23 -0800
Subject: moving stuff so I can test

---
 App/App.ico             | Bin 0 -> 46227 bytes
 App/App.vcxproj         | 186 ++++++++++++++++++++++++++++++++++++++++++++++
 App/App.vcxproj.filters |  43 +++++++++++
 App/Main.cpp            | 193 ++++++++++++++++++++++++++++++++++++++++++++++++
 App/Version.h           |  14 ++++
 App/Version.rc          |   6 ++
 App/small.ico           | Bin 0 -> 46227 bytes
 7 files changed, 442 insertions(+)
 create mode 100644 App/App.ico
 create mode 100644 App/App.vcxproj
 create mode 100644 App/App.vcxproj.filters
 create mode 100644 App/Main.cpp
 create mode 100644 App/Version.h
 create mode 100644 App/Version.rc
 create mode 100644 App/small.ico

(limited to 'App')

diff --git a/App/App.ico b/App/App.ico
new file mode 100644
index 0000000..b3ec03b
Binary files /dev/null and b/App/App.ico differ
diff --git a/App/App.vcxproj b/App/App.vcxproj
new file mode 100644
index 0000000..b17f7a6
--- /dev/null
+++ b/App/App.vcxproj
@@ -0,0 +1,186 @@
+<?xml version="1.0" encoding="utf-8"?>
+<Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
+  <ItemGroup Label="ProjectConfigurations">
+    <ProjectConfiguration Include="Debug|Win32">
+      <Configuration>Debug</Configuration>
+      <Platform>Win32</Platform>
+    </ProjectConfiguration>
+    <ProjectConfiguration Include="Release|Win32">
+      <Configuration>Release</Configuration>
+      <Platform>Win32</Platform>
+    </ProjectConfiguration>
+    <ProjectConfiguration Include="Debug|x64">
+      <Configuration>Debug</Configuration>
+      <Platform>x64</Platform>
+    </ProjectConfiguration>
+    <ProjectConfiguration Include="Release|x64">
+      <Configuration>Release</Configuration>
+      <Platform>x64</Platform>
+    </ProjectConfiguration>
+  </ItemGroup>
+  <PropertyGroup Label="Globals">
+    <VCProjectVersion>15.0</VCProjectVersion>
+    <ProjectGuid>{CED79182-F36B-4D07-AD0E-249C15BFAD73}</ProjectGuid>
+    <Keyword>Win32Proj</Keyword>
+    <RootNamespace>App</RootNamespace>
+    <WindowsTargetPlatformVersion>10.0.17134.0</WindowsTargetPlatformVersion>
+    <ProjectName>App</ProjectName>
+  </PropertyGroup>
+  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
+    <ConfigurationType>Application</ConfigurationType>
+    <UseDebugLibraries>true</UseDebugLibraries>
+    <PlatformToolset>v141</PlatformToolset>
+    <CharacterSet>Unicode</CharacterSet>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
+    <ConfigurationType>Application</ConfigurationType>
+    <UseDebugLibraries>false</UseDebugLibraries>
+    <PlatformToolset>v141</PlatformToolset>
+    <WholeProgramOptimization>true</WholeProgramOptimization>
+    <CharacterSet>Unicode</CharacterSet>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="Configuration">
+    <ConfigurationType>Application</ConfigurationType>
+    <UseDebugLibraries>true</UseDebugLibraries>
+    <PlatformToolset>v141</PlatformToolset>
+    <CharacterSet>Unicode</CharacterSet>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
+    <ConfigurationType>Application</ConfigurationType>
+    <UseDebugLibraries>false</UseDebugLibraries>
+    <PlatformToolset>v141</PlatformToolset>
+    <WholeProgramOptimization>true</WholeProgramOptimization>
+    <CharacterSet>Unicode</CharacterSet>
+  </PropertyGroup>
+  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
+  <ImportGroup Label="ExtensionSettings">
+  </ImportGroup>
+  <ImportGroup Label="Shared">
+  </ImportGroup>
+  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
+    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+  </ImportGroup>
+  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
+    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+  </ImportGroup>
+  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
+    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+  </ImportGroup>
+  <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+    <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+  </ImportGroup>
+  <PropertyGroup Label="UserMacros" />
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
+    <LinkIncremental>true</LinkIncremental>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
+    <LinkIncremental>true</LinkIncremental>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
+    <LinkIncremental>false</LinkIncremental>
+  </PropertyGroup>
+  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+    <LinkIncremental>false</LinkIncremental>
+    <TargetName>WitnessRandomizer</TargetName>
+  </PropertyGroup>
+  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
+    <ClCompile>
+      <PrecompiledHeader>NotUsing</PrecompiledHeader>
+      <WarningLevel>Level3</WarningLevel>
+      <Optimization>Disabled</Optimization>
+      <SDLCheck>true</SDLCheck>
+      <PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
+      <ConformanceMode>true</ConformanceMode>
+      <TreatWarningAsError>true</TreatWarningAsError>
+      <LanguageStandard>stdcpp17</LanguageStandard>
+      <RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
+    </ClCompile>
+    <Link>
+      <SubSystem>Windows</SubSystem>
+      <GenerateDebugInformation>true</GenerateDebugInformation>
+    </Link>
+  </ItemDefinitionGroup>
+  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
+    <ClCompile>
+      <PrecompiledHeader>NotUsing</PrecompiledHeader>
+      <WarningLevel>Level2</WarningLevel>
+      <Optimization>Disabled</Optimization>
+      <SDLCheck>true</SDLCheck>
+      <PreprocessorDefinitions>_DEBUG;_WINDOWS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
+      <ConformanceMode>true</ConformanceMode>
+      <TreatWarningAsError>true</TreatWarningAsError>
+      <LanguageStandard>stdcpp17</LanguageStandard>
+      <RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
+      <AdditionalIncludeDirectories>C:\Users\localhost\Documents\GitHub\witness-randomizer\Source;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
+    </ClCompile>
+    <Link>
+      <SubSystem>Windows</SubSystem>
+      <GenerateDebugInformation>true</GenerateDebugInformation>
+    </Link>
+  </ItemDefinitionGroup>
+  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
+    <ClCompile>
+      <PrecompiledHeader>NotUsing</PrecompiledHeader>
+      <WarningLevel>Level3</WarningLevel>
+      <Optimization>MaxSpeed</Optimization>
+      <FunctionLevelLinking>true</FunctionLevelLinking>
+      <IntrinsicFunctions>true</IntrinsicFunctions>
+      <SDLCheck>true</SDLCheck>
+      <PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
+      <ConformanceMode>true</ConformanceMode>
+      <TreatWarningAsError>true</TreatWarningAsError>
+      <DebugInformationFormat>EditAndContinue</DebugInformationFormat>
+      <LanguageStandard>stdcpp17</LanguageStandard>
+      <RuntimeLibrary>MultiThreaded</RuntimeLibrary>
+    </ClCompile>
+    <Link>
+      <SubSystem>Windows</SubSystem>
+      <EnableCOMDATFolding>true</EnableCOMDATFolding>
+      <OptimizeReferences>true</OptimizeReferences>
+      <GenerateDebugInformation>true</GenerateDebugInformation>
+    </Link>
+  </ItemDefinitionGroup>
+  <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+    <ClCompile>
+      <PrecompiledHeader>NotUsing</PrecompiledHeader>
+      <WarningLevel>Level2</WarningLevel>
+      <Optimization>MaxSpeed</Optimization>
+      <FunctionLevelLinking>true</FunctionLevelLinking>
+      <IntrinsicFunctions>true</IntrinsicFunctions>
+      <SDLCheck>true</SDLCheck>
+      <PreprocessorDefinitions>NDEBUG;_WINDOWS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
+      <ConformanceMode>true</ConformanceMode>
+      <TreatWarningAsError>true</TreatWarningAsError>
+      <LanguageStandard>stdcpp17</LanguageStandard>
+      <DebugInformationFormat>None</DebugInformationFormat>
+      <RuntimeLibrary>MultiThreaded</RuntimeLibrary>
+      <AdditionalIncludeDirectories>C:\Users\localhost\Documents\GitHub\witness-randomizer\Source;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
+    </ClCompile>
+    <Link>
+      <SubSystem>Windows</SubSystem>
+      <EnableCOMDATFolding>true</EnableCOMDATFolding>
+      <OptimizeReferences>true</OptimizeReferences>
+      <GenerateDebugInformation>true</GenerateDebugInformation>
+    </Link>
+  </ItemDefinitionGroup>
+  <ItemGroup>
+    <ClInclude Include="Version.h" />
+  </ItemGroup>
+  <ItemGroup>
+    <ClCompile Include="Main.cpp" />
+  </ItemGroup>
+  <ItemGroup>
+    <ResourceCompile Include="Version.rc" />
+  </ItemGroup>
+  <ItemGroup>
+    <Image Include="small.ico" />
+    <Image Include="App.ico" />
+  </ItemGroup>
+  <ItemGroup>
+    <None Include="App.aps" />
+  </ItemGroup>
+  <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
+  <ImportGroup Label="ExtensionTargets">
+  </ImportGroup>
+</Project>
\ No newline at end of file
diff --git a/App/App.vcxproj.filters b/App/App.vcxproj.filters
new file mode 100644
index 0000000..26b3d34
--- /dev/null
+++ b/App/App.vcxproj.filters
@@ -0,0 +1,43 @@
+<?xml version="1.0" encoding="utf-8"?>
+<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
+  <ItemGroup>
+    <Filter Include="Source Files">
+      <UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>
+      <Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>
+    </Filter>
+    <Filter Include="Header Files">
+      <UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>
+      <Extensions>h;hh;hpp;hxx;hm;inl;inc;ipp;xsd</Extensions>
+    </Filter>
+    <Filter Include="Resource Files">
+      <UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>
+      <Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>
+    </Filter>
+  </ItemGroup>
+  <ItemGroup>
+    <ClInclude Include="Version.h">
+      <Filter>Header Files</Filter>
+    </ClInclude>
+  </ItemGroup>
+  <ItemGroup>
+    <ClCompile Include="Main.cpp">
+      <Filter>Source Files</Filter>
+    </ClCompile>
+  </ItemGroup>
+  <ItemGroup>
+    <ResourceCompile Include="Version.rc">
+      <Filter>Resource Files</Filter>
+    </ResourceCompile>
+  </ItemGroup>
+  <ItemGroup>
+    <Image Include="small.ico">
+      <Filter>Resource Files</Filter>
+    </Image>
+    <Image Include="App.ico">
+      <Filter>Resource Files</Filter>
+    </Image>
+  </ItemGroup>
+  <ItemGroup>
+    <None Include="App.aps" />
+  </ItemGroup>
+</Project>
\ No newline at end of file
diff --git a/App/Main.cpp b/App/Main.cpp
new file mode 100644
index 0000000..ce0e550
--- /dev/null
+++ b/App/Main.cpp
@@ -0,0 +1,193 @@
+#include "windows.h"
+#include <Richedit.h>
+
+#include <string>
+
+#include "Randomizer.h"
+#include "Version.h"
+#include "Random.h"
+#include "Panel.h"
+
+#define IDC_RANDOMIZE 0x401
+#define IDC_TOGGLESPEED 0x402
+#define IDC_SPEEDRUNNER 0x403
+#define IDC_HARDMODE 0x404
+#define IDC_READ 0x405
+#define IDC_RANDOM 0x406
+#define IDC_WRITE 0x407
+#define IDC_DUMP 0x408
+
+HWND hwndSeed, hwndRandomize;
+// int panel = 0x18AF;
+int panel = 0x33D4;
+std::shared_ptr<Panel> _panel;
+
+LRESULT CALLBACK WndProc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
+{
+	static bool wasSeedRandomlyGenerated;
+
+	if (message == WM_DESTROY) {
+		PostQuitMessage(0);
+	} else if (message == WM_COMMAND) {
+		switch (LOWORD(wParam)) {
+			// Speed checkbox
+			case IDC_TOGGLESPEED:
+				if (IsDlgButtonChecked(hwnd, IDC_TOGGLESPEED)) {
+					CheckDlgButton(hwnd, IDC_TOGGLESPEED, BST_UNCHECKED);
+				} else {
+					CheckDlgButton(hwnd, IDC_TOGGLESPEED, BST_CHECKED);
+				}
+				break;
+
+			// Randomize button
+			case IDC_RANDOMIZE:
+			{
+				std::wstring text(100, '\0');
+				GetWindowText(hwndSeed, &text[0], 100);
+				int seed = 0;
+				if (wasSeedRandomlyGenerated || wcslen(text.c_str()) == 0) {
+					seed = Random::RandInt(0, 100000);
+					wasSeedRandomlyGenerated = true;
+				} else {
+					seed = _wtoi(text.c_str());
+					wasSeedRandomlyGenerated = false;
+				}
+
+				Randomizer randomizer;
+				short metadata = randomizer.Randomize(seed);
+				if (metadata & 0x1) break; // Was already randomized
+
+				std::wstring seedString = std::to_wstring(seed);
+				SetWindowText(hwndSeed, seedString.c_str());
+				if (IsDlgButtonChecked(hwnd, IDC_TOGGLESPEED)) {
+					randomizer.AdjustSpeed();
+				}
+				SetWindowText(hwndRandomize, L"Randomized!");
+				break;
+			}
+			case IDC_READ:
+				_panel = std::make_shared<Panel>(panel);
+				break;
+			case IDC_RANDOM:
+				_panel->Random();
+				break;
+			case IDC_WRITE:
+				_panel->Write(panel);
+				break;
+			case IDC_DUMP:
+				_panel->Serialize();
+				break;
+		}
+	}
+    return DefWindowProc(hwnd, message, wParam, lParam);
+}
+
+int APIENTRY wWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPWSTR lpCmdLine, int nCmdShow)
+{
+	LoadLibrary(L"Msftedit.dll");
+
+	WNDCLASSW wndClass = {
+		CS_HREDRAW | CS_VREDRAW,
+		WndProc,
+		0,
+		0,
+		hInstance,
+		NULL,
+		LoadCursor(nullptr, IDC_ARROW),
+		(HBRUSH)(COLOR_WINDOW+1),
+		WINDOW_CLASS,
+		WINDOW_CLASS,
+	};
+	RegisterClassW(&wndClass);
+
+	RECT rect;
+    GetClientRect(GetDesktopWindow(), &rect);
+	HWND hwnd = CreateWindow(WINDOW_CLASS, PRODUCT_NAME, WS_OVERLAPPEDWINDOW,
+      rect.right - 550, 200, 500, 500, nullptr, nullptr, hInstance, nullptr);
+
+	CreateWindow(L"STATIC", L"Version: " VERSION_STR,
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | SS_LEFT,
+		390, 15, 90, 16, hwnd, NULL, hInstance, NULL);
+
+	CreateWindow(L"STATIC", L"Enter a seed:",
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | SS_LEFT,
+		10, 15, 90, 16, hwnd, NULL, hInstance, NULL);
+	hwndSeed = CreateWindow(MSFTEDIT_CLASS, L"",
+        WS_TABSTOP | WS_VISIBLE | WS_CHILD | WS_BORDER, 
+        100, 10, 50, 26, hwnd, NULL, hInstance, NULL);
+	hwndRandomize = CreateWindow(L"BUTTON", L"Randomize",
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | BS_DEFPUSHBUTTON,
+		160, 10, 100, 26, hwnd, (HMENU)IDC_RANDOMIZE, hInstance, NULL);
+
+#if GLOBALS == 0x5B28C0
+	CreateWindow(L"BUTTON", L"READ",
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | BS_DEFPUSHBUTTON,
+		160, 100, 100, 26, hwnd, (HMENU)IDC_READ, hInstance, NULL);
+	CreateWindow(L"BUTTON", L"RANDOM",
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | BS_DEFPUSHBUTTON,
+		160, 130, 100, 26, hwnd, (HMENU)IDC_RANDOM, hInstance, NULL);
+	CreateWindow(L"BUTTON", L"WRITE",
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | BS_DEFPUSHBUTTON,
+		160, 160, 100, 26, hwnd, (HMENU)IDC_WRITE, hInstance, NULL);
+	CreateWindow(L"BUTTON", L"DUMP",
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | BS_DEFPUSHBUTTON,
+		160, 190, 100, 26, hwnd, (HMENU)IDC_DUMP, hInstance, NULL);
+#endif
+
+	CreateWindow(L"BUTTON", L"",
+		WS_VISIBLE | WS_CHILD | BS_CHECKBOX,
+		10, 52, 12, 12, hwnd, (HMENU)IDC_TOGGLESPEED, hInstance, NULL);
+	CreateWindow(L"STATIC", L"Speed up various autoscrollers",
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | SS_LEFT,
+		27, 50, 205, 16, hwnd, NULL, hInstance, NULL);
+
+	/*
+	CreateWindow(L"BUTTON", L"",
+		WS_VISIBLE | WS_CHILD | BS_CHECKBOX,
+		10, 52, 12, 12, hwnd, (HMENU)IDC_SPEEDRUNNER, hInstance, NULL);
+	CreateWindow(L"STATIC", L"Allow hard-to-identify panels to be shuffled",
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | SS_LEFT,
+		27, 50, 205, 16, hwnd, NULL, hInstance, NULL);
+
+	CreateWindow(L"BUTTON", L"",
+		WS_VISIBLE | WS_CHILD | BS_CHECKBOX,
+		10, 52, 12, 12, hwnd, (HMENU)IDC_HARDMODE, hInstance, NULL);
+	CreateWindow(L"STATIC", L"Place harder puzzles in annoying spots",
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | SS_LEFT,
+		27, 50, 205, 16, hwnd, NULL, hInstance, NULL);
+
+	CreateWindow(L"BUTTON", L"",
+		WS_VISIBLE | WS_CHILD | BS_CHECKBOX,
+		10, 52, 12, 12, hwnd, (HMENU)IDC_NORANDOMIZE, hInstance, NULL);
+	CreateWindow(L"STATIC", L"Do not randomize any puzzles",
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | SS_LEFT,
+		27, 50, 205, 16, hwnd, NULL, hInstance, NULL);
+
+	CreateWindow(L"BUTTON", L"",
+		WS_VISIBLE | WS_CHILD | BS_CHECKBOX,
+		10, 52, 12, 12, hwnd, (HMENU)IDC_CASUAL, hInstance, NULL);
+	CreateWindow(L"STATIC", L"Don't randomize context-based puzzles",
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | SS_LEFT,
+		27, 50, 205, 16, hwnd, NULL, hInstance, NULL);
+
+	CreateWindow(L"BUTTON", L"",
+		WS_VISIBLE | WS_CHILD | BS_CHECKBOX,
+		10, 52, 12, 12, hwnd, (HMENU)IDC_BANSNIPES, hInstance, NULL);
+	CreateWindow(L"STATIC", L"Prevent sniping certain puzzles",
+		WS_TABSTOP | WS_VISIBLE | WS_CHILD | SS_LEFT,
+		27, 50, 205, 16, hwnd, NULL, hInstance, NULL);
+		
+*/
+
+	ShowWindow(hwnd, nCmdShow);
+	UpdateWindow(hwnd);
+
+    MSG msg;
+    while (!GetMessage(&msg, nullptr, 0, 0) == 0)
+    {
+        TranslateMessage(&msg);
+        DispatchMessage(&msg);
+    }
+
+    return (int) msg.wParam;
+}
diff --git a/App/Version.h b/App/Version.h
new file mode 100644
index 0000000..05696d6
--- /dev/null
+++ b/App/Version.h
@@ -0,0 +1,14 @@
+#pragma once
+
+#define TO_STRING2(s) L#s
+#define TO_STRING(s) TO_STRING2(s)
+
+#define MAJOR 4
+#define MINOR 0
+#define PATCH 0
+
+#define VERSION_STR     TO_STRING(MAJOR) L"." TO_STRING(MINOR) L"." TO_STRING(PATCH)
+#define VERSION			MAJOR, MINOR, PATCH
+
+#define PRODUCT_NAME L"Witness Randomizer"
+#define WINDOW_CLASS L"WitnessRandomizer"
diff --git a/App/Version.rc b/App/Version.rc
new file mode 100644
index 0000000..9b90884
--- /dev/null
+++ b/App/Version.rc
@@ -0,0 +1,6 @@
+#include "version.h"
+
+VS_VERSION_INFO VERSIONINFO
+	FILEVERSION VERSION
+BEGIN
+END
diff --git a/App/small.ico b/App/small.ico
new file mode 100644
index 0000000..b3ec03b
Binary files /dev/null and b/App/small.ico differ
-- 
cgit 1.4.1