aboutsummaryrefslogtreecommitdiff
path: root/Src/Mastering/VerCtrl/verctrl.cpp
diff options
context:
space:
mode:
authorJean-Francois Mauguit <jfmauguit@mac.com>2024-09-24 09:03:25 -0400
committerGitHub <noreply@github.com>2024-09-24 09:03:25 -0400
commitbab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch)
tree12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/Mastering/VerCtrl/verctrl.cpp
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/Mastering/VerCtrl/verctrl.cpp')
-rw-r--r--Src/Mastering/VerCtrl/verctrl.cpp878
1 files changed, 878 insertions, 0 deletions
diff --git a/Src/Mastering/VerCtrl/verctrl.cpp b/Src/Mastering/VerCtrl/verctrl.cpp
new file mode 100644
index 00000000..658a6a94
--- /dev/null
+++ b/Src/Mastering/VerCtrl/verctrl.cpp
@@ -0,0 +1,878 @@
+// verctrl.cpp : Defines the entry point for the console application.
+//
+
+#include "verctrl.h"
+
+static char *branding = 0;
+
+int _tmain(int argc, _TCHAR* argv[])
+{
+ _tprintf(_T("Version Control Utility ver 1.0\n"));
+ _tprintf(_T("Patching version information in the winamp project source files\n\n"));
+
+ bool setted = false;
+ if (argc > 1)
+ {
+ if (0 == _tcsicmp(argv[1], _T("QA")))
+ {
+ type = Beta;
+ setted = true;
+ }
+ else if (0 == _tcsicmp(argv[1], _T("BETA")))
+ {
+ type = Beta;
+ setted = true;
+ }
+ else if (0 == _tcsicmp(argv[1], _T("NIGHT")))
+ {
+ type = Night;
+ setted = true;
+ }
+ else if (0 == _tcsicmp(argv[1], _T("FINAL")))
+ {
+ type = Final;
+ setted = true;
+ }
+ }
+ if (argc > 2)
+ {
+ branding = strdup(argv[2]);
+ }
+ else
+ branding=_T("");
+
+
+ if (!setted)
+ {
+ Help();
+ _tprintf(_T("\nError! Not enough arguments.\n"));
+ return 1;
+ }
+ else
+ {
+
+ _tprintf(_T("Build Type: "));
+
+ switch(type)
+ {
+ case Final:
+ _tprintf(_T("FINAL"));
+ break;
+ case Beta:
+ _tprintf(_T("BETA"));
+ break;
+ case Night:
+ _tprintf(_T("NIGHT"));
+ break;
+ }
+ _tprintf(_T("\n"));
+ _tprintf(_T("Branding: %s\n"), branding);
+ _tprintf(_T("\n"));
+ }
+ InitData();
+ _tprintf(_T("Reading version info... "));
+ if (!LoadInfoFile())
+ {
+ _tprintf(_T("Failed\n\nError! Unable to load version data from '%s'.\n\n"), verInfoFileName);
+ return 1;
+ }
+ _tprintf(_T("Ok\n"));
+ _tprintf(_T("Reading build info... "));
+ if (!LoadBuildNumber())
+ {
+ _tprintf(_T("Failed\n\nError! Unable to load version data from '%s'.\n\n"), verBuildFileName);
+ return 1;
+
+ }
+ _tprintf(_T("Ok\n"));
+
+ if (argc > 3 && (0 == _tcsicmp(argv[3], _T("inc")))) ver_build++; // increment build number
+
+ _tprintf(_T("Checking version info data... "));
+ if (!AllValuesSet())
+ {
+ _tprintf(_T("Failed\n\nError! Not all version data is set. Check version information files syntax.\n\n"));
+ return 1;
+ }
+ _tprintf(_T("Ok\n"));
+
+ bool success[9];
+ for(int i = 0; i < sizeof(success)/sizeof(success[0]); i++) success[i] = true;
+
+ _tprintf(_T("\nPatching '%s' "), fileConstantsH);
+ if (!PatchConstantsH()) { _tprintf(_T("Failed\n")); success[0] = false;}
+ else _tprintf(_T("Ok\n"));
+
+ _tprintf(_T("Patching '%s' "), fileVerInfoNSH);
+ if (!PatchVerInfoNSH()) { _tprintf(_T("Failed\n")); success[1] = false;}
+ else _tprintf(_T("Ok\n"));
+
+ _tprintf(_T("Patching '%s' "), fileMainH);
+ if (!PatchMainH()) { _tprintf(_T("Failed\n")); success[2] = false;}
+ else _tprintf("Ok\n");
+
+
+ _tprintf(_T("Patching '%s' "), fileBuildTypeH);
+ if (!PatchBuildTypeH()) { _tprintf(_T("Failed\n")); success[3] = false;}
+ else _tprintf("Ok\n");
+
+
+ _tprintf(_T("Patching '%s' "), fileWasabiCfgH);
+ if (!PatchWasabiCfgH()) { _tprintf(_T("Failed\n")); success[4] = false;}
+ else _tprintf("Ok\n");
+
+ _tprintf(_T("Patching '%s' "), fileManifest);
+ if (!PatchManifest(fileManifest)) { _tprintf(_T("Failed\n")); success[5] = false;}
+ else _tprintf("Ok\n");
+
+ _tprintf(_T("Patching '%s' "), fileManifest64);
+ if (!PatchManifest(fileManifest64)) { _tprintf(_T("Failed\n")); success[6] = false;}
+ else _tprintf("Ok\n");
+
+ _tprintf(_T("Patching '%s' "), fileFileNamesCmd);
+ if (!PatchFileNamesCmd()) { _tprintf(_T("Failed\n")); success[7] = false;}
+ else _tprintf("Ok\n");
+
+ _tprintf(_T("Patching '%s' "), fileMakeNsisCmd);
+ if (!PatchMakeNsisCmd()) { _tprintf(_T("Failed\n")); success[8] = false;}
+ else _tprintf("Ok\n");
+
+ _tprintf(_T("Patching '%s' "), fileTalkbackIni);
+ if (!PatchTalkbackIni()) { _tprintf(_T("Failed\n")); success[9] = false;}
+ else _tprintf("Ok\n");
+
+
+ _tprintf(_T("\n"));
+ bool iserr = false;
+ for (int i = 0 ; i <9 ; i++)
+ {
+ if (!success[i])
+ {
+ iserr = true;
+ TCHAR const *fn;
+ switch(i)
+ {
+ case 0:
+ fn = fileConstantsH;
+ break;
+ case 1:
+ fn = fileVerInfoNSH;
+ break;
+ case 2:
+ fn = fileMainH;
+ break;
+ case 3:
+ fn = fileBuildTypeH;
+ break;
+ case 4:
+ fn = fileWasabiCfgH;
+ break;
+ case 5:
+ fn = fileManifest;
+ break;
+ case 6:
+ fn = fileManifest64;
+ break;
+ case 7:
+ fn = fileFileNamesCmd;
+ break;
+ case 8:
+ fn = fileMakeNsisCmd;
+ break;
+ case 9:
+ fn = fileTalkbackIni;
+ break;
+ }
+ _tprintf(_T("Error! Unable to patch file - '%s'.\n"), fn);
+
+ }
+ }
+
+ if (iserr)
+ {
+ _tprintf(_T("\nData patched with errors.\n\n"));
+ }
+ else
+ {
+ _tprintf(_T("Data patched successfully.\n\n"));
+ }
+
+ return 0;
+}
+void InitData(void)
+{
+ ver_major = 5;
+ ver_minor = 0;
+ ver_minor2 = 0;
+ ver_build = 0;
+ ver_api[0] = 0;
+}
+
+bool LoadInfoFile(void)
+{
+ FILE* pstream;
+ if( (pstream = _tfsopen( verInfoFileName, "r", 0x20 )) == NULL )
+ return false;
+ fseek( pstream, 0L, SEEK_SET );
+
+ TCHAR line[LINE_LENGTH];
+ while( !feof(pstream) )
+ {
+ _fgetts(line,LINE_LENGTH,pstream);
+ RemoveCrap(line, (int)_tcslen(line));
+ ParseLine(line);
+ }
+ fclose(pstream);
+
+ return true;
+}
+
+
+bool LoadBuildNumber(void)
+{
+ FILE* pstream;
+ if( (pstream = _tfsopen( verBuildFileName, "r", 0x20 )) == NULL )
+ return false;
+ fseek( pstream, 0L, SEEK_SET );
+
+ TCHAR line[LINE_LENGTH];
+
+ while( !feof(pstream) )
+ {
+ _fgetts(line,LINE_LENGTH,pstream);
+ if (_tcsstr(line, _T("DG_BUILD_NUMBER")) != NULL)
+ {
+ TCHAR *end;
+ end = line + (int)_tcslen(line) -1;
+ while (end[0] <= 32) {end[0] = 0; end--;}
+ while ( end[0] >= _T('0') && end[0] <= _T('9') ) end--;
+ if ((int)_tcslen(line) > 0)
+ {
+ _stscanf(end, "%d", &ver_build);
+ }
+
+ }
+
+ }
+ fclose(pstream);
+
+ return true;
+}
+void ParseLine(TCHAR* line)
+{
+ TCHAR *name, *value;
+ int pos = 0;
+ while (line[pos] != _T('=') && line[pos] != 0) pos++;
+ if (pos == 0) return; // no name
+ name = line;
+ line[pos] = 0;
+ value = line + pos +1;
+
+ if (0 == _tcscmp(name, _T("VERSION_MAJOR"))) _stscanf(value, "%d", &ver_major);
+ else if (0 == _tcscmp(name, _T("VERSION_MINOR"))) _stscanf(value, "%d", &ver_minor);
+
+ // look if VERSION_MINOR_SECOND more than one char length only first one goes to the number
+ else if (0 == _tcscmp(name, _T("VERSION_MINOR_SECOND")))
+ {
+ _tcscpy(ver_minor2_full, value);
+ if (_tcslen(value) > 1) value[1] = 0x00;
+
+ if (!_tcscmp(ver_minor2_full, _T("0")))
+ _tcscpy(ver_minor2_full, _T(""));
+
+ _stscanf(value, "%d", &ver_minor2);
+ }
+
+ else if (0 == _tcscmp(name, _T("VERSION_API"))) _tcscpy(ver_api, value);
+
+}
+
+TCHAR* RemoveCrap(TCHAR* str, int len)
+{
+ int pos = 0;
+ while (pos < len)
+ {
+ if (str[pos] < 33)
+ {
+ for (int i = pos + 1; i < len; i++) str[i -1] = str[i];
+ str[len-1] = 0;
+ len --;
+ }
+ else pos++;
+ }
+ return str;
+}
+
+bool AllValuesSet(void)
+{
+ return !((ver_major > -1) && (ver_minor > -1) && (ver_minor2 > -1) && (ver_build > -1) > (ver_api[0] > 0));
+}
+
+bool PatchConstantsH(void)
+{
+ FILE *streamIn, *streamOut;
+ if( (streamIn = _tfsopen( fileConstantsH, "r", 0x20 )) == NULL ) return false;
+ fseek( streamIn, 0L, SEEK_SET );
+
+ streamOut = tmpfile();
+ fseek( streamOut, 0L, SEEK_SET );
+
+ const TCHAR* lookFor = _T("#define DG_VERSION /*CFGMGMT_VERSION*/");
+ TCHAR line[LINE_LENGTH];
+ while( !feof(streamIn) )
+ {
+ if (NULL == _fgetts(line,LINE_LENGTH, streamIn)) continue;
+ if (NULL != _tcsstr(line, lookFor))
+ {
+ TCHAR *data;
+ data = line + (int)_tcslen(lookFor);
+ const TCHAR ending[128] = _T("\"\n\0");
+
+ TCHAR newStr[256];
+ _stprintf(newStr, _T(" \"%d.%d.%d"), ver_major, ver_minor, ver_minor2);
+
+ switch(type)
+ {
+ case Beta:
+ _tcscat(newStr,_T(" Beta"));
+ break;
+ case Night:
+ _tcscat(newStr,_T(" Nightly"));
+ break;
+ }
+
+ _tcscat(newStr, ending);
+ _tcscpy(data, newStr);
+ }
+ _fputts(line, streamOut);
+ }
+ _fputts( _T("\n\0"), streamOut);
+ fflush(streamOut);
+ if( _tfreopen(fileConstantsH, "w+", streamIn) == NULL ) return false;
+
+ fcopy(streamIn, streamOut);
+ fclose(streamOut);
+ fclose(streamIn);
+ return true;
+}
+bool PatchVerInfoNSH(void)
+{
+ FILE *streamIn, *streamOut;
+ if( (streamIn = _tfsopen( fileVerInfoNSH, "rb", 0x20 )) == NULL ) return false;
+ fseek( streamIn, 0L, SEEK_SET );
+
+ streamOut = tmpfile();
+ fseek( streamOut, 0L, SEEK_SET );
+
+
+ wchar_t line[LINE_LENGTH];
+ wchar_t *data;
+ const wchar_t ending[] = L"\"\n\0";
+ wchar_t newStr[256];
+ const wchar_t lookMajor[] = L"VERSION_MAJOR";
+ const wchar_t lookMin[] = L"VERSION_MINOR";
+ const wchar_t lookMin2[] = L"VERSION_MINOR_SECOND";
+ const wchar_t lookMin3[] = L"VERSION_MINOR_SECOND_SHORT";
+ const wchar_t lookBuild[] = L"BUILD_NUM";
+ wchar_t *start;
+ wchar_t BOM = 0xFEFF;
+ fwrite(&BOM, sizeof(BOM), 1, streamOut);
+ switch(type)
+ {
+ case Beta:
+ fputws(L"!define BETA\n\0", streamOut);
+ break;
+ case Night:
+ fputws(L"!define NIGHT\n\0", streamOut);
+ break;
+ }
+ fread(&BOM, 2, 1, streamIn);
+ while( !feof(streamIn) )
+ {
+ if (NULL == fgetws(line,LINE_LENGTH, streamIn)) continue;
+ if (NULL != wcsstr(line, L"!define"))
+ {
+
+ if (NULL != (start = wcsstr(line, lookMajor)))
+ {
+ data = start + (int)wcslen(lookMajor);
+ swprintf(newStr, L" \"%d%s", ver_major, ending);
+ wcscpy(data, newStr);
+ }
+ else if (NULL != (start = wcsstr(line, lookMin3)))
+ {
+ data = start + (int)wcslen(lookMin3);
+ swprintf(newStr, L" \"%d%s", ver_minor2, ending);
+ wcscpy(data, newStr);
+ }
+ else if (NULL != (start = wcsstr(line, lookMin2)))
+ {
+ data = start + (int)wcslen(lookMin2);
+ swprintf(newStr, L" \"%S%s", ver_minor2_full, ending);
+ wcscpy(data, newStr);
+ }
+ else if (NULL != (start = wcsstr(line, lookMin)))
+ {
+ data = start + (int)wcslen(lookMin);
+ if (L' ' == data[0])
+ {
+ swprintf(newStr, L" \"%d%s", ver_minor, ending);
+ wcscpy(data, newStr);
+ }
+ }
+ else if (NULL != (start = wcsstr(line, lookBuild)))
+ {
+ data = start + (int)wcslen(lookBuild);
+ swprintf(newStr, L" \"%d%s", ver_build, ending);
+ wcscpy(data, newStr);
+ }
+ else if (NULL != wcsstr(line, L"BETA") || NULL != wcsstr(line, L"NIGHT")) continue; // ignore it - we will define it on our one :)
+ }
+ fputws(line, streamOut);
+ }
+ fputws( L"\n\0", streamOut);
+ fflush(streamOut);
+ if( _tfreopen(fileVerInfoNSH, "w+b", streamIn) == NULL ) return false;
+
+ fwcopy(streamIn, streamOut);
+ fclose(streamOut);
+ fclose(streamIn);
+ return true;
+}
+bool PatchMainH(void)
+{
+ FILE *streamIn, *streamOut;
+ if( (streamIn = _tfsopen( fileMainH, "r", 0x20 )) == NULL ) return false;
+ fseek( streamIn, 0L, SEEK_SET );
+
+ streamOut = tmpfile();
+ fseek( streamOut, 0L, SEEK_SET );
+
+
+ TCHAR line[LINE_LENGTH];
+ TCHAR *data;
+ const TCHAR ending[128] = _T("\"\n\0");
+ TCHAR version[128];
+ TCHAR versionStr[128];
+
+ TCHAR newStr[256];
+ const TCHAR lookBuildNumber[128] = _T("#define BUILD_NUMBER");
+ const TCHAR lookVer[128] = _T("#define APP_VERSION");
+ const TCHAR lookAPI[128] = _T("_NUM");
+ const TCHAR lookStr[128] = _T("_STRING");
+ TCHAR *start;
+
+ _stprintf(version, _T("%d.%d%s"), ver_major, ver_minor, ver_minor2_full);
+ /*if (Final == type)
+ {
+ _stprintf(versionStr, _T("%d.%d%s"), ver_major, ver_minor, ver_minor2_full);
+ }
+ else*/
+ {
+ _stprintf(versionStr, _T("%d.%d%s Build %d"), ver_major, ver_minor, ver_minor2_full, ver_build);
+ }
+
+ switch(type)
+ {
+ case Beta:
+ _tcscat(versionStr,_T(" Beta"));
+ break;
+ case Night:
+ _tcscat(versionStr,_T(" Nightly"));
+ break;
+ }
+
+
+ while( !feof(streamIn) )
+ {
+ if (NULL == _fgetts(line,LINE_LENGTH, streamIn)) continue;
+ if (NULL != _tcsstr(line, lookVer) )
+ {
+if (NULL != (start = _tcsstr(line, lookAPI)))
+ {
+ data = start + (int)_tcslen(lookAPI);
+ _stprintf(newStr, _T(" %s\n\0"), ver_api);
+ _tcscpy(data, newStr);
+ }
+ else if (NULL != (start = _tcsstr(line, lookStr)))
+ {
+ data = start + (int)_tcslen(lookStr);
+ _stprintf(newStr, _T(" \"%s%s"), versionStr, ending);
+ _tcscpy(data, newStr);
+ }
+ else
+ {
+ data = line + (int)_tcslen(lookVer);
+ if (_T(' ') == data[0] ) // just a version
+ {
+ _stprintf(newStr, _T(" \"%s%s"), version, ending);
+ _tcscpy(data, newStr);
+ }
+ }
+ }
+ else if (NULL != _tcsstr(line, lookBuildNumber))
+ {
+ data = line + (int)_tcslen(lookBuildNumber);
+ if (_T(' ') == data[0] ) // just a version
+ {
+ _stprintf(newStr, _T(" %d"), ver_build);
+ _tcscpy(data, newStr);
+ }
+ }
+ _fputts(line, streamOut);
+ }
+ _fputts( _T("\n\0"), streamOut);
+ fflush(streamOut);
+ if( _tfreopen(fileMainH, "w+", streamIn) == NULL ) return false;
+ fcopy(streamIn, streamOut);
+ fclose(streamOut);
+ fclose(streamIn);
+ return true;
+}
+
+
+
+
+bool PatchTalkbackIni(void)
+{
+FILE *streamIn, *streamOut;
+ if( (streamIn = _tfsopen( fileTalkbackIni, "r", 0x20 )) == NULL ) return false;
+ fseek( streamIn, 0L, SEEK_SET );
+
+ streamOut = tmpfile();
+ fseek( streamOut, 0L, SEEK_SET );
+
+
+ TCHAR line[LINE_LENGTH];
+ const TCHAR ending[128] = _T("\"\n\0");
+
+
+ while( !feof(streamIn) )
+ {
+ if (NULL == _fgetts(line,LINE_LENGTH, streamIn)) continue;
+ if (line == _tcsstr(line, _T("BuildID = \"")))
+ {
+ _stprintf(line, _T("BuildID = \"%d\"\n\0"), ver_build);
+
+ }
+ _fputts(line, streamOut);
+ }
+ _fputts( _T("\n\0"), streamOut);
+ fflush(streamOut);
+ if( _tfreopen(fileTalkbackIni, "w+", streamIn) == NULL ) return false;
+ fcopy(streamIn, streamOut);
+ fclose(streamOut);
+ fclose(streamIn);
+ return true;
+}
+
+
+
+bool PatchBuildTypeH(void)
+{
+ FILE *streamIn, *streamOut;
+ if( (streamIn = _tfsopen( fileBuildTypeH, "r", 0x20 )) == NULL ) return false;
+ fseek( streamIn, 0L, SEEK_SET );
+
+ streamOut = tmpfile();
+ fseek( streamOut, 0L, SEEK_SET );
+
+
+ TCHAR line[LINE_LENGTH];
+ const TCHAR ending[128] = _T("\"\n\0");
+
+ const TCHAR lookBeta[128] = _T("#define BETA");
+ const TCHAR lookNight[128] = _T("#define NIGHT");
+ const TCHAR lookInternal[128] = _T("#define INTERNAL");
+ const TCHAR lookNokia[128] = _T("#define NOKIA");
+
+ while( !feof(streamIn) )
+ {
+ if (NULL == _fgetts(line,LINE_LENGTH, streamIn)) continue;
+ if (NULL != _tcsstr(line, lookBeta))
+ {
+ if (Beta == type) _stprintf(line, _T("%s\n\0"), lookBeta);
+ else _stprintf(line, _T("/*%s*/\n\0"), lookBeta);
+
+ }
+ else if (NULL != _tcsstr(line, lookNight))
+ {
+ if (Night == type) _stprintf(line, _T("%s\n\0"), lookNight);
+ else _stprintf(line, _T("/*%s*/\n\0"), lookNight);
+
+ }
+ else if (NULL != _tcsstr(line, lookInternal))
+ {
+ if (Night == type) _stprintf(line, _T("%s\n\0"), lookInternal);
+ else _stprintf(line, _T("/*%s*/\n\0"), lookInternal);
+
+ }
+ else if (NULL != _tcsstr(line, lookNokia))
+ {
+ if (!stricmp(branding, "NOKIA")) _stprintf(line, _T("%s\n\0"), lookNokia);
+ else _stprintf(line, _T("/*%s*/\n\0"), lookNokia);
+
+ }
+ _fputts(line, streamOut);
+ }
+ _fputts( _T("\n\0"), streamOut);
+ fflush(streamOut);
+ if( _tfreopen(fileBuildTypeH, "w+", streamIn) == NULL ) return false;
+ fcopy(streamIn, streamOut);
+ fclose(streamOut);
+ fclose(streamIn);
+ return true;
+
+}
+
+
+
+bool PatchWasabiCfgH(void)
+{
+ FILE *streamIn, *streamOut;
+ if( (streamIn = _tfsopen( fileWasabiCfgH, "r", 0x20 )) == NULL ) return false;
+ fseek( streamIn, 0L, SEEK_SET );
+
+ streamOut = tmpfile();
+ fseek( streamOut, 0L, SEEK_SET );
+
+
+ TCHAR line[LINE_LENGTH];
+ const TCHAR ending[128] = _T("\"\n\0");
+
+ const TCHAR lookBeta[128] = _T("#define BETA");
+ const TCHAR lookNight[128] = _T("#define NIGHT");
+ const TCHAR lookNokia[128] = _T("#define NOKIA");
+
+ while( !feof(streamIn) )
+ {
+ if (NULL == _fgetts(line,LINE_LENGTH, streamIn)) continue;
+ if (NULL != _tcsstr(line, lookBeta))
+ {
+ if (Beta == type) _stprintf(line, _T("%s\n\0"), lookBeta);
+ else _stprintf(line, _T("/*%s*/\n\0"), lookBeta);
+
+ }
+ else if (NULL != _tcsstr(line, lookNight))
+ {
+ if (Night == type) _stprintf(line, _T("%s\n\0"), lookNight);
+ else _stprintf(line, _T("/*%s*/\n\0"), lookNight);
+
+ }
+ else if (NULL != _tcsstr(line, lookNokia))
+ {
+ if (!stricmp(branding, "NOKIA")) _stprintf(line, _T("%s\n\0"), lookNokia);
+ else _stprintf(line, _T("/*%s*/\n\0"), lookNokia);
+
+ }
+ _fputts(line, streamOut);
+ }
+ _fputts( _T("\n\0"), streamOut);
+ fflush(streamOut);
+ if( _tfreopen(fileWasabiCfgH, "w+", streamIn) == NULL ) return false;
+ fcopy(streamIn, streamOut);
+ fclose(streamOut);
+ fclose(streamIn);
+ return true;
+}
+
+
+
+bool PatchFileNamesCmd(void)
+{
+ FILE *streamIn, *streamOut;
+ if( (streamIn = _tfsopen( fileFileNamesCmd, "r", 0x20 )) == NULL ) return false;
+ fseek( streamIn, 0L, SEEK_SET );
+
+ streamOut = tmpfile();
+ fseek( streamOut, 0L, SEEK_SET );
+
+ TCHAR *data;
+ TCHAR newStr[LINE_LENGTH];
+ TCHAR line[LINE_LENGTH];
+ const TCHAR ending[] = _T("\n\0");
+
+ const TCHAR lookStr[] = _T("SET INSTALL_NAME");
+ while( !feof(streamIn) )
+ {
+ if (NULL == _fgetts(line,LINE_LENGTH, streamIn)) continue;
+ if (NULL != _tcsstr(line, lookStr))
+ {
+ data = line + (int)_tcslen(lookStr);
+ _stprintf(newStr, _T("=winamp%d%d%s"), ver_major, ver_minor, ver_minor2_full);
+ TCHAR tmp[64];
+ switch(type)
+ {
+ case Beta:
+ case Night:
+ _stprintf(tmp, ((Beta == type) ? "_%04d_beta" : "_%04d_nightly"), ver_build);
+ _tcscat(newStr,tmp);
+ break;
+ }
+ _tcscat(newStr, ending);
+ _tcscpy(data, newStr);
+
+ }
+ _fputts(line, streamOut);
+ }
+ _fputts( _T("\n\0"), streamOut);
+ fflush(streamOut);
+ if( _tfreopen(fileFileNamesCmd, "w+", streamIn) == NULL ) return false;
+ fcopy(streamIn, streamOut);
+ fclose(streamOut);
+ fclose(streamIn);
+ return true;
+}
+
+
+
+bool PatchMakeNsisCmd(void)
+{
+ FILE *streamIn, *streamOut;
+ if( (streamIn = _tfsopen( fileMakeNsisCmd, "r", 0x20 )) == NULL ) return false;
+ fseek( streamIn, 0L, SEEK_SET );
+
+ streamOut = tmpfile();
+ fseek( streamOut, 0L, SEEK_SET );
+
+ TCHAR *data;
+ TCHAR newStr[LINE_LENGTH];
+ TCHAR line[LINE_LENGTH];
+ const TCHAR ending[] = _T("\n\0");
+
+ const TCHAR *szLookTable[] =
+ {
+ _T("SET WINAMP_VERSION_MAJOR"),
+ _T("SET WINAMP_VERSION_MINOR_SECOND"),
+ _T("SET WINAMP_VERSION_MINOR"),
+
+ };
+
+ while( !feof(streamIn) )
+ {
+ if (NULL == _fgetts(line,LINE_LENGTH, streamIn)) continue;
+
+ for (int i = 0; i < sizeof(szLookTable)/sizeof(szLookTable[0]); i++)
+ {
+ TCHAR *p = _tcsstr(line, szLookTable[i]);
+ if (NULL != p && *(p + _tcslen(szLookTable[i])) != _T('_'))
+ {
+ data = line + (int)_tcslen( szLookTable[i]);
+ switch(i)
+ {
+ case 0: _stprintf(newStr, _T("=%d"), ver_major); break;
+ case 1: _stprintf(newStr, _T("=%s"), ver_minor2_full); break;
+ case 2: _stprintf(newStr, _T("=%d"), ver_minor); break;
+ }
+ _tcscat(newStr, ending);
+ _tcscpy(data, newStr);
+ }
+ }
+ _fputts(line, streamOut);
+ }
+ _fputts( _T("\n\0"), streamOut);
+ fflush(streamOut);
+ if( _tfreopen(fileMakeNsisCmd, "w+", streamIn) == NULL ) return false;
+ fcopy(streamIn, streamOut);
+ fclose(streamOut);
+ fclose(streamIn);
+ return true;
+}
+
+bool PatchManifest(const TCHAR *fn)
+{
+ FILE *streamIn, *streamOut;
+ if( (streamIn = _tfsopen( fn, "r", 0x20 )) == NULL ) return false;
+ fseek( streamIn, 0L, SEEK_SET );
+
+ streamOut = tmpfile();
+ fseek( streamOut, 0L, SEEK_SET );
+
+
+ TCHAR line[LINE_LENGTH];
+ TCHAR *data;
+ const TCHAR ending[128] = _T("\"\n\0");
+ TCHAR version[128];
+
+ TCHAR newStr[256];
+ const TCHAR lookSec[128] = _T("<assemblyIdentity");
+ const TCHAR lookSecEnd[4] = _T("/>");
+ const TCHAR lookVer[128] = _T("version");
+
+ _stprintf(version, _T("%d.%d.%d.%d"), ver_major, ver_minor, ver_minor2, ver_build);
+
+ bool fixed = false;
+ bool inSection = false;
+ TCHAR *start;
+ while( !feof(streamIn) )
+ {
+ if (NULL == _fgetts(line,LINE_LENGTH, streamIn)) continue;
+ if (!fixed)
+ {
+ if (NULL != _tcsstr(line, lookSec) )
+ {
+ inSection = true;
+ }
+ else if(NULL != _tcsstr(line, lookSecEnd) )
+ {
+ if (inSection) fixed = true; // protection allows only ones to came to the section
+
+ inSection = false;
+ }
+ else if (inSection && (NULL != (start = _tcsstr(line, lookVer))))
+ {
+ data = start + (int)_tcslen(lookVer);
+ _stprintf(newStr, _T("=\"%s%s"), version, ending);
+ _tcscpy(data, newStr);
+ fixed = true;
+ }
+
+ }
+ _fputts(line, streamOut);
+ }
+ _fputts( _T("\n\0"), streamOut);
+ fflush(streamOut);
+ if( _tfreopen(fn, "w+", streamIn) == NULL ) return false;
+ fcopy(streamIn, streamOut);
+ fclose(streamOut);
+ fclose(streamIn);
+ return true;
+}
+
+
+void fcopy (FILE *dest, FILE *source)
+{
+ char line[LINE_LENGTH];
+ fseek(source, 0L, SEEK_SET );
+ fseek(dest, 0L, SEEK_SET );
+ _fgetts( line, LINE_LENGTH, source );
+ while(!feof(source))
+ {
+ _fputts(line,dest);
+ _fgetts( line, LINE_LENGTH, source );
+ }
+}
+
+void fwcopy (FILE *dest, FILE *source)
+{
+ wchar_t line[LINE_LENGTH];
+ fseek(source, 0L, SEEK_SET );
+ fseek(dest, 0L, SEEK_SET );
+ fgetws( line, LINE_LENGTH, source );
+ while(!feof(source))
+ {
+ fputws(line,dest);
+ fgetws( line, LINE_LENGTH, source );
+ }
+}
+
+void Help(void)
+{
+ _tprintf(_T("Usage: verctrl..exe NIGHT|BETA|FINAL [INC]\n"));
+ _tprintf(_T(" NIGHT - night build\n"));
+ _tprintf(_T(" BETA - beta build\n"));
+ _tprintf(_T(" FINAL - final build\n\n"));
+ _tprintf(_T(" INC - increment build number\n"));
+
+
+} \ No newline at end of file