From 2c9c623d633f85dabb90a7aa5ae4cbe6d59df6f7 Mon Sep 17 00:00:00 2001 From: mikx Date: Thu, 29 Jan 2026 20:19:13 -0500 Subject: [PATCH] (1.0.0) first commit/release --- .gitignore | 261 ++++++++++++++++++++++++ MxValUpdater.slnx | 3 + MxValUpdater/App.config | 6 + MxValUpdater/FodyWeavers.xml | 3 + MxValUpdater/FodyWeavers.xsd | 176 ++++++++++++++++ MxValUpdater/Message.cs | 93 +++++++++ MxValUpdater/MxValUpdater.csproj | 88 ++++++++ MxValUpdater/Program.cs | 89 ++++++++ MxValUpdater/Properties/AssemblyInfo.cs | 33 +++ MxValUpdater/favicon.ico | Bin 0 -> 15406 bytes MxValUpdater/packages.config | 8 + README.md | 14 ++ 12 files changed, 774 insertions(+) create mode 100644 .gitignore create mode 100644 MxValUpdater.slnx create mode 100644 MxValUpdater/App.config create mode 100644 MxValUpdater/FodyWeavers.xml create mode 100644 MxValUpdater/FodyWeavers.xsd create mode 100644 MxValUpdater/Message.cs create mode 100644 MxValUpdater/MxValUpdater.csproj create mode 100644 MxValUpdater/Program.cs create mode 100644 MxValUpdater/Properties/AssemblyInfo.cs create mode 100644 MxValUpdater/favicon.ico create mode 100644 MxValUpdater/packages.config create mode 100644 README.md diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..3c4efe2 --- /dev/null +++ b/.gitignore @@ -0,0 +1,261 @@ +## Ignore Visual Studio temporary files, build results, and +## files generated by popular Visual Studio add-ons. + +# User-specific files +*.suo +*.user +*.userosscache +*.sln.docstates + +# User-specific files (MonoDevelop/Xamarin Studio) +*.userprefs + +# Build results +[Dd]ebug/ +[Dd]ebugPublic/ +[Rr]elease/ +[Rr]eleases/ +x64/ +x86/ +bld/ +[Bb]in/ +[Oo]bj/ +[Ll]og/ + +# Visual Studio 2015 cache/options directory +.vs/ +# Uncomment if you have tasks that create the project's static files in wwwroot +#wwwroot/ + +# MSTest test Results +[Tt]est[Rr]esult*/ +[Bb]uild[Ll]og.* + +# NUNIT +*.VisualState.xml +TestResult.xml + +# Build Results of an ATL Project +[Dd]ebugPS/ +[Rr]eleasePS/ +dlldata.c + +# DNX +project.lock.json +project.fragment.lock.json +artifacts/ + +*_i.c +*_p.c +*_i.h +*.ilk +*.meta +*.obj +*.pch +*.pdb +*.pgc +*.pgd +*.rsp +*.sbr +*.tlb +*.tli +*.tlh +*.tmp +*.tmp_proj +*.log +*.vspscc +*.vssscc +.builds +*.pidb +*.svclog +*.scc + +# Chutzpah Test files +_Chutzpah* + +# Visual C++ cache files +ipch/ +*.aps +*.ncb +*.opendb +*.opensdf +*.sdf +*.cachefile +*.VC.db +*.VC.VC.opendb + +# Visual Studio profiler +*.psess +*.vsp +*.vspx +*.sap + +# TFS 2012 Local Workspace +$tf/ + +# Guidance Automation Toolkit +*.gpState + +# ReSharper is a .NET coding add-in +_ReSharper*/ +*.[Rr]e[Ss]harper +*.DotSettings.user + +# JustCode is a .NET coding add-in +.JustCode + +# TeamCity is a build add-in +_TeamCity* + +# DotCover is a Code Coverage Tool +*.dotCover + +# NCrunch +_NCrunch_* +.*crunch*.local.xml +nCrunchTemp_* + +# MightyMoose +*.mm.* +AutoTest.Net/ + +# Web workbench (sass) +.sass-cache/ + +# Installshield output folder +[Ee]xpress/ + +# DocProject is a documentation generator add-in +DocProject/buildhelp/ +DocProject/Help/*.HxT +DocProject/Help/*.HxC +DocProject/Help/*.hhc +DocProject/Help/*.hhk +DocProject/Help/*.hhp +DocProject/Help/Html2 +DocProject/Help/html + +# Click-Once directory +publish/ + +# Publish Web Output +*.[Pp]ublish.xml +*.azurePubxml +# TODO: Comment the next line if you want to checkin your web deploy settings +# but database connection strings (with potential passwords) will be unencrypted +#*.pubxml +*.publishproj + +# Microsoft Azure Web App publish settings. Comment the next line if you want to +# checkin your Azure Web App publish settings, but sensitive information contained +# in these scripts will be unencrypted +PublishScripts/ + +# NuGet Packages +*.nupkg +# The packages folder can be ignored because of Package Restore +**/packages/* +# except build/, which is used as an MSBuild target. +!**/packages/build/ +# Uncomment if necessary however generally it will be regenerated when needed +#!**/packages/repositories.config +# NuGet v3's project.json files produces more ignoreable files +*.nuget.props +*.nuget.targets + +# Microsoft Azure Build Output +csx/ +*.build.csdef + +# Microsoft Azure Emulator +ecf/ +rcf/ + +# Windows Store app package directories and files +AppPackages/ +BundleArtifacts/ +Package.StoreAssociation.xml +_pkginfo.txt + +# Visual Studio cache files +# files ending in .cache can be ignored +*.[Cc]ache +# but keep track of directories ending in .cache +!*.[Cc]ache/ + +# Others +ClientBin/ +~$* +*~ +*.dbmdl +*.dbproj.schemaview +*.jfm +*.pfx +*.publishsettings +node_modules/ +orleans.codegen.cs + +# Since there are multiple workflows, uncomment next line to ignore bower_components +# (https://github.com/github/gitignore/pull/1529#issuecomment-104372622) +#bower_components/ + +# RIA/Silverlight projects +Generated_Code/ + +# Backup & report files from converting an old project file +# to a newer Visual Studio version. Backup files are not needed, +# because we have git ;-) +_UpgradeReport_Files/ +Backup*/ +UpgradeLog*.XML +UpgradeLog*.htm + +# SQL Server files +*.mdf +*.ldf + +# Business Intelligence projects +*.rdl.data +*.bim.layout +*.bim_*.settings + +# Microsoft Fakes +FakesAssemblies/ + +# GhostDoc plugin setting file +*.GhostDoc.xml + +# Node.js Tools for Visual Studio +.ntvs_analysis.dat + +# Visual Studio 6 build log +*.plg + +# Visual Studio 6 workspace options file +*.opt + +# Visual Studio LightSwitch build output +**/*.HTMLClient/GeneratedArtifacts +**/*.DesktopClient/GeneratedArtifacts +**/*.DesktopClient/ModelManifest.xml +**/*.Server/GeneratedArtifacts +**/*.Server/ModelManifest.xml +_Pvt_Extensions + +# Paket dependency manager +.paket/paket.exe +paket-files/ + +# FAKE - F# Make +.fake/ + +# JetBrains Rider +.idea/ +*.sln.iml + +# CodeRush +.cr/ + +# Python Tools for Visual Studio (PTVS) +__pycache__/ +*.pyc \ No newline at end of file diff --git a/MxValUpdater.slnx b/MxValUpdater.slnx new file mode 100644 index 0000000..1e781b6 --- /dev/null +++ b/MxValUpdater.slnx @@ -0,0 +1,3 @@ + + + diff --git a/MxValUpdater/App.config b/MxValUpdater/App.config new file mode 100644 index 0000000..aee9adf --- /dev/null +++ b/MxValUpdater/App.config @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/MxValUpdater/FodyWeavers.xml b/MxValUpdater/FodyWeavers.xml new file mode 100644 index 0000000..5029e70 --- /dev/null +++ b/MxValUpdater/FodyWeavers.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/MxValUpdater/FodyWeavers.xsd b/MxValUpdater/FodyWeavers.xsd new file mode 100644 index 0000000..f2dbece --- /dev/null +++ b/MxValUpdater/FodyWeavers.xsd @@ -0,0 +1,176 @@ + + + + + + + + + + + + A list of assembly names to exclude from the default action of "embed all Copy Local references", delimited with line breaks + + + + + A list of assembly names to include from the default action of "embed all Copy Local references", delimited with line breaks. + + + + + A list of runtime assembly names to exclude from the default action of "embed all Copy Local references", delimited with line breaks + + + + + A list of runtime assembly names to include from the default action of "embed all Copy Local references", delimited with line breaks. + + + + + Obsolete, use UnmanagedWinX86Assemblies instead + + + + + A list of unmanaged X86 (32 bit) assembly names to include, delimited with line breaks. + + + + + Obsolete, use UnmanagedWinX64Assemblies instead. + + + + + A list of unmanaged X64 (64 bit) assembly names to include, delimited with line breaks. + + + + + A list of unmanaged Arm64 (64 bit) assembly names to include, delimited with line breaks. + + + + + The order of preloaded assemblies, delimited with line breaks. + + + + + + This will copy embedded files to disk before loading them into memory. This is helpful for some scenarios that expected an assembly to be loaded from a physical file. + + + + + Controls if .pdbs for reference assemblies are also embedded. + + + + + Controls if runtime assemblies are also embedded. + + + + + Controls whether the runtime assemblies are embedded with their full path or only with their assembly name. + + + + + Embedded assemblies are compressed by default, and uncompressed when they are loaded. You can turn compression off with this option. + + + + + As part of Costura, embedded assemblies are no longer included as part of the build. This cleanup can be turned off. + + + + + The attach method no longer subscribes to the `AppDomain.AssemblyResolve` (.NET 4.x) and `AssemblyLoadContext.Resolving` (.NET 6.0+) events. + + + + + Costura by default will load as part of the module initialization. This flag disables that behavior. Make sure you call CosturaUtility.Initialize() somewhere in your code. + + + + + Costura will by default use assemblies with a name like 'resources.dll' as a satellite resource and prepend the output path. This flag disables that behavior. + + + + + A list of assembly names to exclude from the default action of "embed all Copy Local references", delimited with | + + + + + A list of assembly names to include from the default action of "embed all Copy Local references", delimited with |. + + + + + A list of runtime assembly names to exclude from the default action of "embed all Copy Local references", delimited with | + + + + + A list of runtime assembly names to include from the default action of "embed all Copy Local references", delimited with |. + + + + + Obsolete, use UnmanagedWinX86Assemblies instead + + + + + A list of unmanaged X86 (32 bit) assembly names to include, delimited with |. + + + + + Obsolete, use UnmanagedWinX64Assemblies instead + + + + + A list of unmanaged X64 (64 bit) assembly names to include, delimited with |. + + + + + A list of unmanaged Arm64 (64 bit) assembly names to include, delimited with |. + + + + + The order of preloaded assemblies, delimited with |. + + + + + + + + 'true' to run assembly verification (PEVerify) on the target assembly after all weavers have been executed. + + + + + A comma-separated list of error codes that can be safely ignored in assembly verification. + + + + + 'false' to turn off automatic generation of the XML Schema file. + + + + + \ No newline at end of file diff --git a/MxValUpdater/Message.cs b/MxValUpdater/Message.cs new file mode 100644 index 0000000..b2483a4 --- /dev/null +++ b/MxValUpdater/Message.cs @@ -0,0 +1,93 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace MxValUpdater +{ + internal class Message + { + public static void CMW(string msg, bool time, int color) + { + DateTime now; + string str1; + int num; + if (DateTime.Now.Second < 10) + { + now = DateTime.Now; + str1 = string.Format("0{0}", (object)now.Second); + } + else + { + num = DateTime.Now.Second; + str1 = num.ToString(); + } + now = DateTime.Now; + string str2; + if (now.Minute < 10) + { + now = DateTime.Now; + str2 = string.Format("0{0}", (object)now.Minute); + } + else + { + now = DateTime.Now; + num = now.Minute; + str2 = num.ToString(); + } + now = DateTime.Now; + string str3; + if (now.Hour < 10) + { + now = DateTime.Now; + str3 = string.Format("0{0}", (object)now.Hour); + } + else + { + now = DateTime.Now; + num = now.Hour; + str3 = num.ToString(); + } + string str4 = string.Format("{0}:{1}:{2}", (object)str3, (object)str2, (object)str1); + ConsoleColor consoleColor = ConsoleColor.White; + switch (color) + { + case 1: + consoleColor = ConsoleColor.Cyan; + break; + case 2: + consoleColor = ConsoleColor.Green; + break; + case 3: + consoleColor = ConsoleColor.Red; + break; + } + if (time) + { + Console.ForegroundColor = consoleColor; + Console.WriteLine(string.Format("[{0}] {1}", (object)str4, (object)msg)); + } + else + { + Console.ForegroundColor = consoleColor; + Console.WriteLine(string.Format("")); + } + Console.ForegroundColor = ConsoleColor.White; + } + + public static void Splash(string progname, string dev) + { + Console.ForegroundColor = ConsoleColor.Cyan; + Console.WriteLine(""); + Console.WriteLine($"#### {progname}"); + Console.WriteLine(string.Format("#### VERSION: {0}", (object)Program.version)); + Console.WriteLine($"#### DEV: {dev}"); + Console.WriteLine("#### POWERED BY: MxMini"); + Console.WriteLine(""); + Console.ForegroundColor = ConsoleColor.White; + } + + + } +} diff --git a/MxValUpdater/MxValUpdater.csproj b/MxValUpdater/MxValUpdater.csproj new file mode 100644 index 0000000..044124c --- /dev/null +++ b/MxValUpdater/MxValUpdater.csproj @@ -0,0 +1,88 @@ + + + + + + Debug + AnyCPU + {2D00AA0A-025D-4CA0-9A91-0D3562A5912C} + Exe + MxValUpdater + MxValUpdater + v4.8.1 + 512 + true + true + + + + + AnyCPU + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + + + AnyCPU + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + + + favicon.ico + + + + ..\packages\Costura.Fody.6.0.0\lib\netstandard2.0\Costura.dll + + + ..\packages\Newtonsoft.Json.13.0.4\lib\net45\Newtonsoft.Json.dll + + + ..\packages\NuGet.Versioning.6.14.0\lib\net472\NuGet.Versioning.dll + + + + + + + + + + + + + ..\packages\Velopack.0.0.1298\lib\net462\Velopack.dll + + + + + + + + + + + + + + + + + + + This project references NuGet package(s) that are missing on this computer. Use NuGet Package Restore to download them. For more information, see http://go.microsoft.com/fwlink/?LinkID=322105. The missing file is {0}. + + + + + + + \ No newline at end of file diff --git a/MxValUpdater/Program.cs b/MxValUpdater/Program.cs new file mode 100644 index 0000000..5650abb --- /dev/null +++ b/MxValUpdater/Program.cs @@ -0,0 +1,89 @@ +using Newtonsoft.Json; +using System; +using System.Collections.Generic; +using System.IO; +using System.Linq; +using System.Net; +using System.Text; +using System.Threading.Tasks; +using Velopack; + +namespace MxValUpdater +{ + public class File + { + public string name { get; set; } + } + + public class ModList + { + public string name { get; set; } + public string url { get; set; } + public List files { get; set; } + public string config { get; set; } + public bool directory { get; set; } + public string dir_name { get; set; } + } + + public class ListRoot + { + public string url { get; set; } + public List ModList { get; set; } + } + + internal class Program + { + public static string version = "1.0.0"; + static void Main(string[] args) + { + VelopackApp.Build().Run(); + + string path = @"BepInEx\plugins\"; + + WebClient wc = new WebClient(); + var RemoteList = wc.DownloadString("https://mxio.ovh/gaming/valheim/mxvalheim_updater.json"); + + ListRoot jls = JsonConvert.DeserializeObject(RemoteList); + + Message.Splash("MxValUpdater","mikx"); + + foreach (var m in jls.ModList) + { + Message.CMW($"Updating mod {m.name}...",true,1); + if (m.directory) { if (!Directory.Exists($"{path}{m.dir_name}")) { Directory.CreateDirectory($"{path}{m.dir_name}"); } } + foreach (var f in m.files) + { + if (m.directory) + { + Message.CMW($"Downloading {f.name}...", true, 2); + wc.DownloadFile($"{jls.url}{f.name}", $"{path}{m.dir_name}\\{f.name}"); + } else + { + Message.CMW($"Downloading {f.name}...", true, 2); + wc.DownloadFile($"{jls.url}{f.name}", $"{path}{f.name}"); + } + } + if (m.config != "") + { + Message.CMW($"Downloading {m.name} config(s)...", true, 2); + wc.DownloadFile($"{jls.url}config/{m.config}", $@"BepInEx\config\{m.config}"); + } + } + } + + public async Task UpdateApp() + { + var mgr = new UpdateManager("https://your-update-server.com/releases"); + var newVersion = await mgr.CheckForUpdatesAsync(); + + if (newVersion != null) + { + await mgr.DownloadUpdatesAsync(newVersion); + + // For .NET Framework, it's polite to ask the user first + // because the restart is immediate. + mgr.ApplyUpdatesAndRestart(newVersion); + } + } + } +} diff --git a/MxValUpdater/Properties/AssemblyInfo.cs b/MxValUpdater/Properties/AssemblyInfo.cs new file mode 100644 index 0000000..24efbe1 --- /dev/null +++ b/MxValUpdater/Properties/AssemblyInfo.cs @@ -0,0 +1,33 @@ +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +// General Information about an assembly is controlled through the following +// set of attributes. Change these attribute values to modify the information +// associated with an assembly. +[assembly: AssemblyTitle("MxValUpdater")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("MxValUpdater")] +[assembly: AssemblyCopyright("Copyright © 2026")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// Setting ComVisible to false makes the types in this assembly not visible +// to COM components. If you need to access a type in this assembly from +// COM, set the ComVisible attribute to true on that type. +[assembly: ComVisible(false)] + +// The following GUID is for the ID of the typelib if this project is exposed to COM +[assembly: Guid("2d00aa0a-025d-4ca0-9a91-0d3562a5912c")] + +// Version information for an assembly consists of the following four values: +// +// Major Version +// Minor Version +// Build Number +// Revision +// +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/MxValUpdater/favicon.ico b/MxValUpdater/favicon.ico new file mode 100644 index 0000000000000000000000000000000000000000..dde634d1eca2240999683aff3865e461b19e3569 GIT binary patch literal 15406 zcmeI3*K!=ma)z-X-7lAmrCS07JqUpCc7Vamz|6pV@4Yu93_*f^m+Rt4p*PUu=(S4! zmyINwIFureZgmh*(LLQ&=_@lUvyqqgUEaUsUAdB{Yf;|TzvkuD=jG)U6-B>`f5^-G zPd%%wymF}6 z2xBAt_Iq@wH%w0qYmC@C<{a&Bh5=oF{PD+d`}Xbd;K74%|Ni}O>(;IC(@#HzqN1X3 z@7}#oSXgLt3JMDBJitKo$%)|Hl)hUNLG(Ak#K z+y{mOxZsA@;^N0)Y`EX}KR(zDUAd0%OH^ax*leZ8LN%sxg0uRYUh>&IjtLjygUHyN^>ZK1ZNCM?cRhIYve_zU8D zQ19C`e@yn&)0GR|U7cY>a&Jv0WM6}#N%EN+w`aT?*Sx--Y{-fp;EssC>B-U1(%dAP zszYOAW9Vqln9VYe^%G+QVPZwggaRpIX4yQU-VD=RBa zcSGU_TI)1QN=i&_4dS=4p~3Fa1G0Sj^r`6vyTtaG8_}6In7rqi+ZMX!8TRt?&p(?@ zUbfTjTzg2jCc@2|H%;g04jXeDWIh9X;~D$QZ4f)oq?(QQ)|SSQ)_t}!6LK2uZArUnr~eiS~uJ`Nw>9NYCB&n})b|IOL6@cPBU-;K9=&bnyriPnD^AI^^r#(Tm3 z_3df+_dni+*TP#`QmnmQ7|P1nA5Uci6`@L_x~kId%VhsWcM8M3yG7DnS*WZi*F45k z8|CF?;feNrVPS#IDc2ld4-A8&`6W+^ZO;9BcSEAFK716NFP`s6$M?;L#r+sMb)Sc= zU|;$9`8M!}*sS|IuJ|Tw0T}Mfut(tdV2#g#7vy*HY%7$>FJNomfB${BcI}$kDr>!-}yV22fxwR+3{{T+*u73g@Ld=1 zcv)YLADGzAi=&;eFCSeYpWt$44m_eq&oeHIUrAXfd=H{ys#%u zWqUiyGiqz96>q!4{LFah&UJ*RWo0%GJI7ub@BqH}!CK^iEP(}n-V=A3f3UqG zS(a<=LyMEh5r5A-mlbf}9ho9GO2p#^)LQS4>@!SCjeO3Aa-7c<`5u0roTRxqA^B9B{gK~o z$^KHUEn!VEIg>w}8Xq$Lur+uFr_=I9m*tihoe3s6TC4CjC@*PFB$Rt}87y+a&i1rM zCM?ZODzBWgcg!QtX{fK0?Ku8qSXrF5SU@h1t$?4sf(*!4e30|hD4!!gWdE!!%^FYS zU+{)3prDZW?2-e#18HZ&-A(j0O|);CEm2jG|d;h&uH=wQQgN$e%^Lk~<&YKFIn;&p0LAJ<=0Dd%8`{@BZpbp^nz@! z<0AisfA#}=7yD!Xk*Dr$FUv*-#Y?^M3cm5t0n6jT&pOkc-m{0v@4*i&_E}S7Ll{tw zyD6JkS)4IBq*AS6NwUShbL8TZU5)IIHP0mf9q9-EN3OiRv0(U`q$hBZ>yC>ad#>{y zc7g5ko?LxrbJ6g3>KxK8KcLZ?hZS9vhU%qPWuqM0VlqzP&o$! z|7H70&v}P0K}W>i9oaCtW^ZyHOK1Rt{qOUD&2#ja6p!GuIg&BCE3o;^V1MwN^~4Ku z2Vw>>%wZA_YZQMrWN%viN9wKxS$dE%=0`A+#V~Tf%TpTA}@T&s`e0P`~uZt z$Yr6Qb>Q{EZ*;(W=#R@VJ_q`L_~8ee2hGTi0S#PTPMiyXRiZN=z5x7>#6Pgn6SOfO zye>yzpaXbhZG4XN={)k@;qWX@1ALG}F$bRKXGWDbO;|4U@B!~`Ne@NB{n+G#uZzx_ z#NSf!pgFfRNAl+U!a38pm=jI&vtwaFazQpe_|2TzujY(>e$TuGt%Ikp;e2}z^RWMKlmz}?J)%yc z5^dg+#&`cqo#b!7zYTx>dLDjze-=KyJJoohd&XJ#?ZeCP`$xvB@W(IbHt(-b=YiVF zU%$S#-+%tXyI0|Njo&oa;AlN?sD=Fc_Qb9Z`xCG~oP|FGn|0u3{KWw7eNxKdU|q1^+S!%xCU+BKyOwwX2XbL9Ph|+ z|MuIP@JTY_{B%?CBtQR0+sF7B{7SUP@iq7j&Iz28z1DmuT$kTq%?&#P7n#51y!fpF zJbc;Bo78fy%2(t^zE{4(eTn1n>tp#Vd<*p_d=I#w6Tc4Me@fpUUmqzq&6{c+zkAd-}CO4d=7BEw#09IAn%X?gY|w-3~)aOF4hu<@u4m=hwoRO1Cx1< zi+gmAt-d>dZfD%P@{jmxd_8q0?ul=49-!X`bU}~vz#91AH}u4LfChdupat1DF7QDQ z&zTpO7d$xsz$6ZW1O4@Ob=bb5wn;vPPJl}cAQmwXxbOg6r`xZ<<{loH#~KDQ0#BR= zr``E*Juvq&F6Kh>w+1jR9*VXe)uKPXKC${NeFbb5xX=qdaa%$*E*GaCn`Q7kP7m^Q zJwS`o>{oxrn#+2?Zk=zR$2!N&J+!bN=tI4KeH>n@)<u%ys(Rp14xG!1m9cZyWud4>>Ka2kZ%5 z02khQ56#Yl>x1X62h*`=LI%zQ@0=Fqau0nxhi~ROAFTJi=WC$Z2YJ(od@=R<7pnCQ z^mZw4iE>isk#*<+x{(chI4$6J`u!T$1Gt?Y*7F-WS$BDWhj+-FHLeHtkn_MA=yF*V zi+*AWb*AG(^)!2PstrZG7`F+otV8C&0ycwto;lr@ui$_ta5I;IeEAJL-n)#P7v=*K z`8eOm%W?TSr=MCQu@B#Kq&hn_G0scWHEMKDq9#J!fIQmyfCk?W-~lIe@ZR%zuIQ0` z)ACcnE7ra$5^czrHBLjE2c9#~1AJmX*sSXuJM(qmBmahe`V`PlUk!RY+tT)&J~Z{> zhWc8Y%Nn;+U^C!{XV77EU!0Gq!BTe|R=r|Iai02fz3L#$MaIqpFnzdAoDbI>c(6a0 z7xUSt$aU<3e)=5rXsKb4_i*l~UP=$x>H*RVYrugVfQ4MxYw+N*ak$ig`+9O#|D(1@ zznTM1Z{8z&^h;m(_3452X^?fD=%=3e{?)Vai|WtR zps1&E7IZw|fCgj&{m94d0vb3&*4Ncq51agoJoc4pslw481 z$@5>Su70@7{>_CZ$%i^T&xi{fEAx_9o579K@3x8_+(y|GZb$eo_AYyfKI-YS9n*Ct z)hgVh>Z`3-eRFw!I%HJ?r`}?<&x;z7_az!c4>fwe4M3Lk0O*U&t7c1$uupsT?0C=U zXAX5}YQ^Le_*K5w=urI*zj~Q|=Yjo%&tOl$1N?AqACS*E+*#9JdT!^8QQ1>#vc+o1 zd`~kkJoGKl6W_#8qoY<${f9aibwT_Vwa^*Kn|-;ex-UHxYQ5A5u)i1dIVC4*nZT#V zb0&S$b6-_YCf(X>Ho^Xa2j5rF?*n`CJ%J5TN8pBM7cncMf8BB+>=XIFP(DQecuBCS z?;~Sqg?9LGy8Y_UdB7OU~44y=F_@lYR=l6M8fFDsp)GYkbo} z{5g@WAV>N**hh0SwaMyek7&=3ztQKVSHNCKN&eVBu<+aTF!|=iZ3G!3Yv_#+=ysoh zjoJ+4#n4*ls=i^&_i@VJTG-JYNq+TDlXH`t5B!_CzNlP!Hb z_OsK^m3nVRy+!N@y0IntGx!$9xcn9N&*;i_hLrkvjqJ%gHYpKO!9ZPdqJG<$a2iTVyv{{dd8 zai`^*=BCF@ZrCs1)HMoDRaI19W-Y_(%h(Y<`2_maD?|p=>e=fDyQ|hOqyND-U(ke% zu_Nk)^f$?i@E3_hqsiN8kJG=dzR;26!2Tq@&>O;byl;XIyzbuKmJ$8Z{o#h<-iG{b zpY@KcFC=+W!)JIO!05L<@ienVvl1#oPV1oOK9S|33534PS8(}1=_F?_=YxW`|wFzfzvwd5F5yU_`VaK>7TKe z$vx_nPePZ|hRv*se&)<6-$ORoX#}^{dWh^_`gqW`CLd4l6uKB`%_oM@f1A+vuke7~ z^yqs>dYb44e@P8-PWnNn*b;c~uT9b~`J2DAzh<->QLYrcyo#a*-q$7+kR$$ zr)5KYL&`U*{i=;{Rv#VdlN`G28$o1>zVJUs`c?&dgD?7n&_=(OUMRNRBwc&lNh(I5 z+hxfXJjTr5Ur;^T#Uy{@%))oX#9;U%hTzM~2XeuN;ep=HtYphP`Z1Shuu6DCCArQsNi8<=YwP^*QiO?+O{LTMui}d=~S4(DNtm;*X)5 z{DeV%g)V%*amCh&Dfne#JKv`fPw{cYmt)nh*vr%ms431&4Vw&!Uz{hAJA>XCdz$YZ z=*wfH#7%4ryNu7DQ7?_T)066RNI&R``Peo#!G2<|L+~jO>E+fjsL(;V|T!eMwd~6$9SO*`#bGo6)>Bo-1 zLEY`zwWwwcKklEv$vVEVAqUtM55xrUu$Fh=^?d_w(MQp5bz0Zhn5$A4G@nz&pW=n(rrvNUz zx}8D~^j;p|0yeVuHOPr)tnm?F$1`xEJ81Ww9lW#7X=YCRKCTDWFyH}s@qZs1IwKKh z{eMcJANarpm&+zj6Zh}{Z0M#IeYsB0dtc*M=Nmh6n~3WHKH~Jl2fx9C9*`A#nzh(c zMmA%yUOe#K;62$EHi52~2W{{G+;7nXeC!ce&`;k7dcXxvr-ii)rw5qGhq>SZU);8R zozDk9@^+hre){muiF(Uh&;jw4J;C=oH*Q4V8{J}miWchj^i=Rq@xix*Jomk6x|599 zNB8s{5B*GJAK8(v+-rabn(oMs;emCAtBC(6;5#e%ri-~g-@jWxUdZ+O^=mrIK)=2p zRgN{OZ$$0?h%!mr3(ZY+s=YNRr{nuT&P!=~&z!G^as=rvrT=MaR$hoqT9Zwt+m3df zK|Zfzy~E(!<&^mhaD0VJusSle8qJaF#%l0$x-Px6jj o^zw+-d~03w{oen$PI&)eT(;)RI%t7zeIE4Bzkf>L|15$32A&mxJ^%m! literal 0 HcmV?d00001 diff --git a/MxValUpdater/packages.config b/MxValUpdater/packages.config new file mode 100644 index 0000000..6e22fcc --- /dev/null +++ b/MxValUpdater/packages.config @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/README.md b/README.md new file mode 100644 index 0000000..2a8e48c --- /dev/null +++ b/README.md @@ -0,0 +1,14 @@ +![logo](https://mxdev.ovh/wp-content/uploads/2025/09/mxdev-1.png) + +## MxValheim +Official MxValheim Mod & Config Updater. + +## Features +- Get the latest mod(s) and config(s) to play on **MxValheim**. + +## How-To Install +1. Download the latest zip. +2. Copy it to your client root dir. +3. Make a shortcut (MxValUpdater.exe) to your desktop, for faster updating. +4. Run it before launching Valheim in Steam. You will always be up-to-date! +5. Enjoy! \ No newline at end of file