processor name to @widepid and @osver macros

This commit is contained in:
Ianos Gnatiuc 2005-10-05 21:58:34 +00:00
parent f6281d694a
commit 97ed80ae89
2 changed files with 255 additions and 8 deletions

View File

@ -10,6 +10,9 @@ ______________________________________________________________________
Notes for GoldED+ 1.1.5, /snapshot/ Notes for GoldED+ 1.1.5, /snapshot/
______________________________________________________________________ ______________________________________________________________________
+ Win32-MSVC version: processor name will be used instead of "x86" in
@widepid and @osver macros.
+ EditToggleCase, EditToUpper and EditToLower keys will work on selected text. + EditToggleCase, EditToUpper and EditToLower keys will work on selected text.
+ Added MenuNextArea (yes/no/unread) config file token that set default + Added MenuNextArea (yes/no/unread) config file token that set default

View File

@ -40,6 +40,242 @@
#include <AppFileInfo.h> #include <AppFileInfo.h>
#endif #endif
// ------------------------------------------------------------------
#define _MAX_VNAME_LEN 13
#define _MAX_MNAME_LEN 30
// ------------------------------------------------------------------
struct gcpu_info
{
char v_name[_MAX_VNAME_LEN]; // vendor name
char m_name[_MAX_MNAME_LEN]; // model name
int family;
int model;
int stepping;
};
// ------------------------------------------------------------------
static bool HaveCPUID()
{
// TO_PORT_TAG: CPUID
#if defined(_MSC_VER)
__try
{
__asm
{
xor eax, eax
cpuid
}
}
__except(EXCEPTION_EXECUTE_HANDLER)
{
return false;
}
return true;
#else
return false;
#endif
}
// ------------------------------------------------------------------
static void cpuname(int family, int model, const char *v_name, char *m_name)
{
if (!strcmp("AuthenticAMD", v_name))
{
switch (family)
{
case 4:
strcpy(m_name, "AMD_486");
break;
case 5:
switch (model)
{
case 0:
case 1:
case 2:
case 3:
strcpy(m_name, "AMD_K5");
break;
case 6:
case 7:
strcpy(m_name, "AMD_K6");
break;
case 8:
strcpy(m_name, "AMD_K6-2");
break;
case 9:
case 10:
case 11:
case 12:
case 13:
case 14:
case 15:
strcpy(m_name, "AMD_K6-3");
break;
default:
sprintf(m_name, "AMD_F%dM%d", family, model);
}
break;
case 6:
strcpy(m_name, "AMD_K7");
break;
case 15:
strcpy(m_name, "AMD_K8");
break;
default:
sprintf(m_name, "AMD_F%dM%d", family, model);
}
}
else if (!strcmp("GenuineIntel", v_name))
{
switch (family)
{
case 4:
switch (model)
{
case 0:
case 1:
strcpy(m_name, "i486DX");
break;
case 2:
strcpy(m_name, "i486SX");
break;
case 3:
strcpy(m_name, "i486DX2");
break;
case 4:
strcpy(m_name, "i486SL");
break;
case 5:
strcpy(m_name, "i486SX2");
break;
case 7:
strcpy(m_name, "i486DX2E");
break;
case 8:
strcpy(m_name, "i486DX4");
break;
default:
sprintf(m_name, "iF%dM%d", family, model);
}
break;
case 5:
switch (model)
{
case 1:
case 2:
case 3:
strcpy(m_name, "iPentium");
break;
case 4:
strcpy(m_name, "iP-MMX");
break;
default:
sprintf(m_name, "iF%dM%d", family, model);
}
break;
case 6:
switch (model)
{
case 1:
strcpy(m_name, "iP-Pro");
break;
case 3:
case 5:
strcpy(m_name, "iP-II");
break;
case 6:
strcpy(m_name, "iCeleron");
break;
case 7:
case 8:
case 11:
strcpy(m_name, "iP-III");
break;
default:
sprintf(m_name, "iF%dM%d", family, model);
}
break;
case 15:
strcpy(m_name, "iP-4");
break;
default:
sprintf(m_name, "iF%dM%d", family, model);
}
}
else if (!strcmp("CyrixInstead", v_name))
sprintf(m_name, "CyrF%dM%d", family, model);
else if (!strcmp("CentaurHauls", v_name))
sprintf(m_name, "CenF%dM%d", family, model);
else
sprintf(m_name, "%3sF%dM%d", v_name, family, model);
}
// ------------------------------------------------------------------
void gcpuid(gcpu_info *pinfo)
{
union
{
char buff[_MAX_VNAME_LEN];
struct
{
DWORD dw0;
DWORD dw1;
DWORD dw2;
};
} vendor;
DWORD standard = 0;
vendor.buff[_MAX_VNAME_LEN-1] = 0;
// TO_PORT_TAG: CPUID
#if defined(_MSC_VER)
__asm
{
// get the vendor string
xor eax, eax
cpuid
mov vendor.dw0, ebx
mov vendor.dw1, edx
mov vendor.dw2, ecx
// get the standard bits
mov eax, 1
cpuid
mov standard, eax
}
#else
strcpy(vendor.buff, "UNKNOUN_CPU!");
#endif
pinfo->family = (standard >> 8) & 0xF; // retriving family
pinfo->model = (standard >> 4) & 0xF; // retriving model
pinfo->stepping = standard & 0xF; // retriving stepping
strncpy(pinfo->v_name, vendor.buff, _MAX_VNAME_LEN);
cpuname(pinfo->family, pinfo->model, pinfo->v_name, pinfo->m_name);
}
// ------------------------------------------------------------------ // ------------------------------------------------------------------
char* ggetosstring(void) { char* ggetosstring(void) {
@ -76,7 +312,7 @@ char* ggetosstring(void) {
OSVERSIONINFO info; OSVERSIONINFO info;
SYSTEM_INFO si; SYSTEM_INFO si;
char ostype[16]; char ostype[16];
char processor[16]; char processor[_MAX_MNAME_LEN];
GetSystemInfo(&si); GetSystemInfo(&si);
info.dwOSVersionInfoSize = sizeof(OSVERSIONINFO); info.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
@ -94,9 +330,16 @@ char* ggetosstring(void) {
} }
switch(*((WORD*)&si)) { switch(*((WORD*)&si)) {
case PROCESSOR_ARCHITECTURE_INTEL: case PROCESSOR_ARCHITECTURE_INTEL:
{
if (HaveCPUID())
{
gcpu_info pinfo;
gcpuid(&pinfo);
strcpy(processor, pinfo.m_name);
}
else
{ {
int cpu; int cpu;
if(info.dwPlatformId == VER_PLATFORM_WIN32_NT) if(info.dwPlatformId == VER_PLATFORM_WIN32_NT)
cpu = si.wProcessorLevel; cpu = si.wProcessorLevel;
else { else {
@ -114,6 +357,7 @@ char* ggetosstring(void) {
} }
sprintf(processor, "i%d86", cpu); sprintf(processor, "i%d86", cpu);
} }
}
break; break;
case PROCESSOR_ARCHITECTURE_MIPS: case PROCESSOR_ARCHITECTURE_MIPS:
sprintf(processor, "mips%d000", si.wProcessorLevel); sprintf(processor, "mips%d000", si.wProcessorLevel);