71#if defined (_MSC_VER) && (_MSC_VER >= 1400)
73#elif defined (_M_IX86)
74 static void __cpuid(
int* cpuid_data,
int info_type)
102 cpuid_data[0] = 0x00000000;
103 cpuid_data[1] = 0x00000000;
104 cpuid_data[2] = 0x00000000;
105 cpuid_data[3] = 0x00000000;
128 if (
fds_bits->fd_count < FD_SETSIZE-1)
131 ::SysError(
"TFdSet::Set",
"fd_count will exeed FD_SETSIZE");
136 for (i=0; i<
fds_bits->fd_count; i++) {
138 while (i<fds_bits->fd_count-1) {
158 static HANDLE gGlobalEvent;
159 static HANDLE gTimerThreadHandle;
160 typedef NET_API_STATUS (WINAPI *pfn1)(LPVOID);
161 typedef NET_API_STATUS (WINAPI *pfn2)(LPCWSTR, LPCWSTR, DWORD, LPBYTE*);
162 typedef NET_API_STATUS (WINAPI *pfn3)(LPCWSTR, LPCWSTR, DWORD, LPBYTE*,
163 DWORD, LPDWORD, LPDWORD, PDWORD_PTR);
164 typedef NET_API_STATUS (WINAPI *pfn4)(LPCWSTR, DWORD, LPBYTE*, DWORD, LPDWORD,
165 LPDWORD, PDWORD_PTR);
166 static pfn1 p2NetApiBufferFree;
167 static pfn2 p2NetUserGetInfo;
168 static pfn3 p2NetLocalGroupGetMembers;
169 static pfn4 p2NetLocalGroupEnum;
171 static struct signal_map {
177 SIGSEGV, 0,
"segmentation violation",
178 -1 , 0,
"bad argument to system call",
179 -1 , 0,
"write on a pipe with no one to read it",
180 SIGILL, 0,
"illegal instruction",
183 SIGINT, 0,
"interrupt",
184 -1 , 0,
"window size change",
185 -1 , 0,
"alarm clock",
186 -1 , 0,
"death of a child",
187 -1 , 0,
"urgent data arrived on an I/O channel",
188 SIGFPE, 0,
"floating point exception",
189 SIGTERM, 0,
"termination signal",
190 -1 , 0,
"user-defined signal 1",
191 -1 , 0,
"user-defined signal 2"
212 static int WinNTRecv(
int socket,
void *buffer,
int length,
int flag)
214 if (
socket == -1)
return -1;
222 if (flag == MSG_PEEK) {
227 char *buf = (
char *)buffer;
230 if ((nrecv = ::recv(sock, buf+
n, length-
n, flag)) <= 0) {
234 if (flag == MSG_OOB) {
235 if (::WSAGetLastError() == WSAEWOULDBLOCK) {
237 }
else if (::WSAGetLastError() == WSAEINVAL) {
241 if (::WSAGetLastError() == WSAEWOULDBLOCK) {
244 if (::WSAGetLastError() != WSAEINTR)
245 ::SysError(
"TWinNTSystem::WinNTRecv",
"recv");
246 if (::WSAGetLastError() == EPIPE ||
247 ::WSAGetLastError() == WSAECONNRESET)
266 static int WinNTSend(
int socket,
const void *buffer,
int length,
int flag)
268 if (
socket < 0)
return -1;
278 const char *buf = (
const char *)buffer;
281 if ((nsent = ::send(sock, buf+
n, length-
n, flag)) <= 0) {
285 if (::WSAGetLastError() == WSAEWOULDBLOCK) {
288 if (::WSAGetLastError() != WSAEINTR)
289 ::SysError(
"TWinNTSystem::WinNTSend",
"send");
290 if (::WSAGetLastError() == EPIPE ||
291 ::WSAGetLastError() == WSAECONNRESET)
311 fd_set* rbits = readready ? (fd_set*)readready->
GetBits() : 0;
312 fd_set* wbits = writeready ? (fd_set*)writeready->
GetBits() : 0;
316 tv.tv_sec = timeout / 1000;
317 tv.tv_usec = (timeout % 1000) * 1000;
319 retcode = ::select(0, rbits, wbits, 0, &tv);
321 retcode = ::select(0, rbits, wbits, 0, 0);
324 if (retcode == SOCKET_ERROR) {
325 int errcode = ::WSAGetLastError();
329 if (errcode == WSAENOTSOCK) {
331 int result = _fstat64( readready->
GetFd(0), &buf );
339 ::WaitForSingleObject(gGlobalEvent, 1);
340 ::ResetEvent(gGlobalEvent);
345 if ( errcode == WSAEINTR) {
349 if (errcode == EBADF) {
364 if (reset || newpath) {
369 }
else if (dynpath ==
"") {
370 dynpath =
gSystem->Getenv(
"ROOT_LIBRARY_PATH");
371 TString rdynpath =
gEnv ?
gEnv->GetValue(
"Root.DynamicPath", (
char*)0) :
"";
373 if (rdynpath ==
"") {
401 if (signal_map[i].code == sig) {
402 (*signal_map[i].handler)((
ESignals)i);
413 signal_map[sig].handler = handler;
414 if (signal_map[sig].code != -1)
421 static const char *WinNTSigname(
ESignals sig)
423 return signal_map[sig].signame;
429 static BOOL ConsoleSigHandler(DWORD sig)
437 Break(
"TInterruptHandler::Notify",
"keyboard interrupt");
443 case CTRL_BREAK_EVENT:
444 case CTRL_LOGOFF_EVENT:
445 case CTRL_SHUTDOWN_EVENT:
446 case CTRL_CLOSE_EVENT:
448 printf(
"\n *** Break *** keyboard interrupt - ROOT is terminated\n");
454 static CONTEXT *fgXcptContext = 0;
468 LONG WINAPI ExceptionFilter(LPEXCEPTION_POINTERS pXcp)
470 fgXcptContext = pXcp->ContextRecord;
472 return EXCEPTION_CONTINUE_SEARCH;
476#pragma intrinsic(_ReturnAddress)
477#pragma auto_inline(off)
478 DWORD_PTR GetProgramCounter()
483#pragma auto_inline(on)
494 static DWORD WINAPI GUIThreadMessageProcessingLoop(
void *p)
499 ::PeekMessage(&msg, NULL, WM_USER, WM_USER, PM_NOREMOVE);
504 if (gGlobalEvent) ::SetEvent(gGlobalEvent);
505 erret = ::GetMessage(&msg, NULL, NULL, NULL);
506 if (erret <= 0) endLoop =
kTRUE;
507 if (gGUIThreadMsgFunc)
508 endLoop = (*gGUIThreadMsgFunc)(&msg);
515 erret = ::GetLastError();
516 Error(
"MsgLoop",
"Error in GetMessage");
530 typedef BOOL (__stdcall *SYMINITIALIZEPROC)( HANDLE, LPSTR, BOOL );
531 typedef BOOL (__stdcall *SYMCLEANUPPROC)( HANDLE );
532 typedef BOOL (__stdcall *STACKWALK64PROC)
533 ( DWORD, HANDLE, HANDLE, LPSTACKFRAME64, LPVOID,
534 PREAD_PROCESS_MEMORY_ROUTINE,PFUNCTION_TABLE_ACCESS_ROUTINE,
535 PGET_MODULE_BASE_ROUTINE, PTRANSLATE_ADDRESS_ROUTINE );
536 typedef LPVOID (__stdcall *SYMFUNCTIONTABLEACCESS64PROC)( HANDLE, DWORD64 );
537 typedef DWORD (__stdcall *SYMGETMODULEBASE64PROC)( HANDLE, DWORD64 );
538 typedef BOOL (__stdcall *SYMGETMODULEINFO64PROC)(HANDLE, DWORD64, PIMAGEHLP_MODULE64);
539 typedef BOOL (__stdcall *SYMGETSYMFROMADDR64PROC)( HANDLE, DWORD64, PDWORD64, PIMAGEHLP_SYMBOL64);
540 typedef BOOL (__stdcall *SYMGETLINEFROMADDR64PROC)(HANDLE, DWORD64, PDWORD, PIMAGEHLP_LINE64);
541 typedef DWORD (__stdcall *UNDECORATESYMBOLNAMEPROC)(PCSTR, PSTR, DWORD, DWORD);
544 static SYMINITIALIZEPROC _SymInitialize = 0;
545 static SYMCLEANUPPROC _SymCleanup = 0;
546 static STACKWALK64PROC _StackWalk64 = 0;
547 static SYMFUNCTIONTABLEACCESS64PROC _SymFunctionTableAccess64 = 0;
548 static SYMGETMODULEBASE64PROC _SymGetModuleBase64 = 0;
549 static SYMGETMODULEINFO64PROC _SymGetModuleInfo64 = 0;
550 static SYMGETSYMFROMADDR64PROC _SymGetSymFromAddr64 = 0;
551 static SYMGETLINEFROMADDR64PROC _SymGetLineFromAddr64 = 0;
552 static UNDECORATESYMBOLNAMEPROC _UnDecorateSymbolName = 0;
554 BOOL InitImagehlpFunctions()
562 HMODULE hModImagehlp = LoadLibrary(
"IMAGEHLP.DLL" );
566 _SymInitialize = (SYMINITIALIZEPROC) GetProcAddress( hModImagehlp,
"SymInitialize" );
570 _SymCleanup = (SYMCLEANUPPROC) GetProcAddress( hModImagehlp,
"SymCleanup" );
574 _StackWalk64 = (STACKWALK64PROC) GetProcAddress( hModImagehlp,
"StackWalk64" );
578 _SymFunctionTableAccess64 = (SYMFUNCTIONTABLEACCESS64PROC) GetProcAddress(hModImagehlp,
"SymFunctionTableAccess64" );
579 if (!_SymFunctionTableAccess64)
582 _SymGetModuleBase64=(SYMGETMODULEBASE64PROC)GetProcAddress(hModImagehlp,
"SymGetModuleBase64");
583 if (!_SymGetModuleBase64)
586 _SymGetModuleInfo64=(SYMGETMODULEINFO64PROC)GetProcAddress(hModImagehlp,
"SymGetModuleInfo64");
587 if (!_SymGetModuleInfo64)
590 _SymGetSymFromAddr64=(SYMGETSYMFROMADDR64PROC)GetProcAddress(hModImagehlp,
"SymGetSymFromAddr64");
591 if (!_SymGetSymFromAddr64)
594 _SymGetLineFromAddr64=(SYMGETLINEFROMADDR64PROC)GetProcAddress(hModImagehlp,
"SymGetLineFromAddr64");
595 if (!_SymGetLineFromAddr64)
598 _UnDecorateSymbolName=(UNDECORATESYMBOLNAMEPROC)GetProcAddress(hModImagehlp,
"UnDecorateSymbolName");
599 if (!_UnDecorateSymbolName)
602 if (!_SymInitialize(GetCurrentProcess(), 0, TRUE ))
618 std::string GetModuleName(DWORD64 address)
622 std::ostringstream out;
623 HANDLE process = ::GetCurrentProcess();
625 DWORD lineDisplacement = 0;
626 IMAGEHLP_LINE64
line;
629 if(_SymGetLineFromAddr64(process, address, &lineDisplacement, &
line)) {
630 out <<
line.FileName <<
"(" <<
line.LineNumber <<
"): ";
632 IMAGEHLP_MODULE64 module;
633 ::ZeroMemory(&module,
sizeof(module));
634 module.SizeOfStruct = sizeof(module);
635 if(_SymGetModuleInfo64(process, address, &module)) {
636 out << module.ModuleName <<
"!";
638 out <<
"0x" << std::hex << address << std::dec <<
" ";
645 std::string GetFunctionName(DWORD64 address)
649 DWORD64 symbolDisplacement = 0;
650 HANDLE process = ::GetCurrentProcess();
652 const unsigned int SYMBOL_BUFFER_SIZE = 8192;
653 char symbolBuffer[SYMBOL_BUFFER_SIZE];
654 PIMAGEHLP_SYMBOL64 symbol =
reinterpret_cast<PIMAGEHLP_SYMBOL64
>(symbolBuffer);
655 ::ZeroMemory(symbol, SYMBOL_BUFFER_SIZE);
656 symbol->SizeOfStruct = SYMBOL_BUFFER_SIZE;
657 symbol->MaxNameLength = SYMBOL_BUFFER_SIZE -
sizeof(IMAGEHLP_SYMBOL64);
659 if(_SymGetSymFromAddr64(process, address, &symbolDisplacement, symbol)) {
661 const unsigned int NAME_SIZE = 8192;
662 char name[NAME_SIZE];
663 _UnDecorateSymbolName(
668 UNDNAME_NO_THISTYPE |
669 UNDNAME_NO_SPECIAL_SYMS |
670 UNDNAME_NO_MEMBER_TYPE |
671 UNDNAME_NO_MS_KEYWORDS |
672 UNDNAME_NO_ACCESS_SPECIFIERS
690 static BOOL IsShortcut(
const char *filename)
693 const char *extLnk =
".lnk";
694 if (filename != NULL) {
697 if (strfilename.EndsWith(extLnk))
706 static BOOL ResolveShortCut(LPCSTR pszShortcutFile,
char *pszPath,
int maxbuf)
710 char szGotPath[MAX_PATH];
717 typedef HRESULT (__stdcall *COINITIALIZEPROC)( LPVOID );
718 static COINITIALIZEPROC _CoInitialize = 0;
719 typedef void (__stdcall *COUNINITIALIZEPROC)( void );
720 static COUNINITIALIZEPROC _CoUninitialize = 0;
721 typedef HRESULT (__stdcall *COCREATEINSTANCEPROC)( REFCLSID, LPUNKNOWN,
722 DWORD, REFIID, LPVOID );
723 static COCREATEINSTANCEPROC _CoCreateInstance = 0;
725 HMODULE hModImagehlp = LoadLibrary(
"ole32.dll" );
729 _CoInitialize = (COINITIALIZEPROC) GetProcAddress( hModImagehlp,
"CoInitialize" );
732 _CoUninitialize = (COUNINITIALIZEPROC) GetProcAddress( hModImagehlp,
"CoUninitialize");
733 if (!_CoUninitialize)
735 _CoCreateInstance = (COCREATEINSTANCEPROC) GetProcAddress( hModImagehlp,
"CoCreateInstance" );
736 if (!_CoCreateInstance)
741 hres = _CoCreateInstance(CLSID_ShellLink, NULL, CLSCTX_INPROC_SERVER,
742 IID_IShellLink, (
void **) &psl);
743 if (SUCCEEDED(hres)) {
746 hres = psl->QueryInterface(IID_IPersistFile, (
void **) &ppf);
747 if (SUCCEEDED(hres)) {
749 MultiByteToWideChar(CP_ACP, 0, pszShortcutFile, -1, wsz, MAX_PATH);
751 hres = ppf->Load(wsz, STGM_READ);
752 if (SUCCEEDED(hres)) {
753 hres = psl->Resolve(HWND_DESKTOP, SLR_ANY_MATCH | SLR_NO_UI | SLR_UPDATE);
754 if (SUCCEEDED(hres)) {
755 strlcpy(szGotPath, pszShortcutFile,MAX_PATH);
756 hres = psl->GetPath(szGotPath, MAX_PATH, (WIN32_FIND_DATA *)&wfd,
757 SLGP_UNCPRIORITY | SLGP_RAWPATH);
758 strlcpy(pszPath,szGotPath, maxbuf);
759 if (maxbuf) pszPath[maxbuf-1] = 0;
768 return SUCCEEDED(hres);
774 if (strcmp(sys->TWinNTSystem::BaseName(buf),
"root.exe"))
777 if (!::RegOpenKeyEx(HKEY_CURRENT_USER,
"Software", 0, KEY_READ, ®CUS) == ERROR_SUCCESS)
780 if (!::RegOpenKeyEx(regCUS,
"Classes", 0, KEY_READ, ®CUSC) == ERROR_SUCCESS) {
781 ::RegCloseKey(regCUS);
786 bool regROOTwrite =
false;
790 if (::RegOpenKeyEx(regCUSC,
"ROOTDEV.ROOT", 0, KEY_READ, ®ROOT) != ERROR_SUCCESS) {
791 ::RegCloseKey(regCUSC);
792 if (::RegOpenKeyEx(regCUS,
"Classes", 0, KEY_READ | KEY_WRITE, ®CUSC) == ERROR_SUCCESS &&
793 ::RegCreateKeyEx(regCUSC,
"ROOTDEV.ROOT", 0, NULL, 0, KEY_READ | KEY_WRITE,
794 NULL, ®ROOT, NULL) == ERROR_SUCCESS) {
799 if (::RegOpenKeyEx(regROOT,
"DefaultIcon", 0, KEY_READ, ®ROOTIcon) == ERROR_SUCCESS) {
800 char bufIconLoc[1024];
802 DWORD dwSize =
sizeof(bufIconLoc);
804 if (::RegQueryValueEx(regROOTIcon, NULL, NULL, &dwType, (BYTE*)bufIconLoc, &dwSize) == ERROR_SUCCESS)
805 regROOTwrite = (iconloc != bufIconLoc);
808 ::RegCloseKey(regROOTIcon);
813 ::RegCloseKey(regCUSC);
814 ::RegCloseKey(regROOT);
815 if (::RegOpenKeyEx(regCUS,
"Classes", 0, KEY_READ | KEY_WRITE, ®CUSC) != ERROR_SUCCESS) {
817 regROOTwrite =
false;
819 if (::RegOpenKeyEx(regCUSC,
"ROOTDEV.ROOT", 0, KEY_WRITE, ®ROOT) != ERROR_SUCCESS) {
821 regROOTwrite =
false;
822 ::RegCloseKey(regCUSC);
829 TString fileopen =
"fileopen.C";
830 TString rootmacrodir =
"macros";
840 ::RegCloseKey(regROOT);
841 ::RegCloseKey(regCUSC);
842 ::RegCloseKey(regCUS);
846 static const char apptitle[] =
"ROOT data file";
847 ::RegSetValueEx(regROOT, NULL, 0, REG_SZ, (BYTE*)apptitle,
sizeof(apptitle));
848 DWORD editflags = 0x00010000;
849 ::RegSetValueEx(regROOT,
"EditFlags", 0, REG_DWORD, (BYTE*)&editflags,
sizeof(editflags));
852 if (::RegCreateKeyEx(regROOT,
"DefaultIcon", 0, NULL, 0, KEY_READ | KEY_WRITE,
853 NULL, ®ROOTIcon, NULL) == ERROR_SUCCESS) {
856 ::RegSetValueEx(regROOTIcon, NULL, 0, REG_SZ, (BYTE*)iconloc.Data(), iconloc.Length() + 1);
857 ::RegCloseKey(regROOTIcon);
862 if (::RegCreateKeyEx(regROOT,
"shell", 0, NULL, 0, KEY_READ | KEY_WRITE,
863 NULL, ®ROOTshell, NULL) == ERROR_SUCCESS) {
865 if (::RegCreateKeyEx(regROOTshell,
"open", 0, NULL, 0, KEY_READ | KEY_WRITE,
866 NULL, ®ShellOpen, NULL) == ERROR_SUCCESS) {
867 HKEY regShellOpenCmd;
868 if (::RegCreateKeyEx(regShellOpen,
"command", 0, NULL, 0, KEY_READ | KEY_WRITE,
869 NULL, ®ShellOpenCmd, NULL) == ERROR_SUCCESS) {
871 cmd +=
" -l \"%1\" \"";
874 ::RegSetValueEx(regShellOpenCmd, NULL, 0, REG_SZ, (BYTE*)cmd.Data(), cmd.Length() + 1);
875 ::RegCloseKey(regShellOpenCmd);
877 ::RegCloseKey(regShellOpen);
879 ::RegCloseKey(regROOTshell);
881 ::RegCloseKey(regROOT);
883 if (::RegCreateKeyEx(regCUSC,
".root", 0, NULL, 0, KEY_READ | KEY_WRITE,
884 NULL, ®ROOT, NULL) == ERROR_SUCCESS) {
885 static const char appname[] =
"ROOTDEV.ROOT";
886 ::RegSetValueEx(regROOT, NULL, 0, REG_SZ, (BYTE*)appname,
sizeof(appname));
888 ::RegCloseKey(regCUSC);
889 ::RegCloseKey(regCUS);
892 ::SHChangeNotify(SHCNE_ASSOCCHANGED, SHCNF_IDLIST, NULL, NULL);
900 static bool once =
true;
903 if (!once ||
gROOT->IsBatch())
return false;
904 TString cmdline(::GetCommandLine());
905 Int_t i = 0, from = 0;
906 while (cmdline.Tokenize(arg, from,
" ")) {
908 if (i == 0 && ((arg !=
"root") && (arg !=
"rootn") &&
909 (arg !=
"root.exe") && (arg !=
"rootn.exe")))
return false;
910 else if ((arg ==
"-l") || (arg ==
"-b"))
return false;
922 static void SetConsoleWindowName()
924 char pszNewWindowTitle[1024];
925 char pszOldWindowTitle[1024];
927 CONSOLE_SCREEN_BUFFER_INFO csbiInfo;
929 if (!::GetConsoleTitle(pszOldWindowTitle, 1024))
932 wsprintf(pszNewWindowTitle,
"%d/%d", ::GetTickCount(), ::GetCurrentProcessId());
934 if (!::SetConsoleTitle(pszNewWindowTitle))
944 ::SetConsoleTitle(
"ROOT session");
946 hStdout = GetStdHandle(STD_OUTPUT_HANDLE);
949 ::SetConsoleMode(hStdout, ENABLE_PROCESSED_OUTPUT |
950 ENABLE_WRAP_AT_EOL_OUTPUT);
951 if (!::GetConsoleScreenBufferInfo(hStdout, &csbiInfo))
993 if (initwinsock = ::WSAStartup(MAKEWORD(2, 0), &WSAData)) {
994 Error(
"TWinNTSystem()",
"Starting sockets failed");
1005 char *buf =
new char[MAX_MODULE_NAME32 + 1];
1008 if (
gSystem->Getenv(
"ROOTIGNOREPREFIX")) {
1011 HMODULE hModCore = ::GetModuleHandle(
"libCore.dll");
1013 ::GetModuleFileName(hModCore, buf, MAX_MODULE_NAME32 + 1);
1014 char *pLibName = strstr(buf,
"libCore.dll");
1017 while (--pLibName >= buf && *pLibName !=
'\\' && *pLibName !=
'/');
1020 check_path +=
"\\etc";
1022 while (buf[0] && GetFileAttributes(check_path.
Data()) == INVALID_FILE_ATTRIBUTES) {
1023 while (--pLibName >= buf && *pLibName !=
'\\' && *pLibName !=
'/');
1026 check_path +=
"\\etc";
1041 UpdateRegistry(
this, buf);
1052 typedef UINT (WINAPI* LPTIMEENDPERIOD)( UINT uPeriod );
1053 HINSTANCE hInstWinMM = LoadLibrary(
"winmm.dll" );
1055 LPTIMEENDPERIOD pTimeEndPeriod = (LPTIMEENDPERIOD)GetProcAddress( hInstWinMM,
"timeEndPeriod" );
1056 if( NULL != pTimeEndPeriod )
1058 FreeLibrary(hInstWinMM);
1064 ::ResetEvent(gGlobalEvent);
1065 ::CloseHandle(gGlobalEvent);
1068 if (gTimerThreadHandle) {
1069 ::TerminateThread(gTimerThreadHandle, 0);
1070 ::CloseHandle(gTimerThreadHandle);
1103 ::SetUnhandledExceptionFilter(ExceptionFilter);
1111 typedef UINT (WINAPI* LPTIMEBEGINPERIOD)( UINT uPeriod );
1112 HINSTANCE hInstWinMM = LoadLibrary(
"winmm.dll" );
1114 LPTIMEBEGINPERIOD pTimeBeginPeriod = (LPTIMEBEGINPERIOD)GetProcAddress( hInstWinMM,
"timeBeginPeriod" );
1115 if( NULL != pTimeBeginPeriod )
1116 pTimeBeginPeriod(1);
1117 FreeLibrary(hInstWinMM);
1119 gTimerThreadHandle = ::CreateThread(NULL, NULL, (LPTHREAD_START_ROUTINE)
ThreadStub,
1122 gGlobalEvent = ::CreateEvent(NULL, TRUE, FALSE, NULL);
1125 char *buf =
new char[MAX_MODULE_NAME32 + 1];
1126 HMODULE hModCore = ::GetModuleHandle(
"libCore.dll");
1128 ::GetModuleFileName(hModCore, buf, MAX_MODULE_NAME32 + 1);
1129 char *pLibName = strstr(buf,
"libCore.dll");
1136 std::this_thread::sleep_for(std::chrono::duration<double, std::nano>(10));
1137 SetConsoleWindowName();
1160 const char *symbol=
name;
1163 while ( (*symbol ==
' ' || *symbol ==
'\t') && *symbol) symbol++;
1166 if (isalpha(symbol[idx]) && symbol[idx+1] ==
':') idx = 2;
1167 if ( (symbol[idx] ==
'/' || symbol[idx] ==
'\\') && symbol[idx+1] ==
'\0') {
1172 Error(
"BaseName",
"name = 0");
1176 char *bslash = (
char *)strrchr(&symbol[idx],
'\\');
1177 char *rslash = (
char *)strrchr(&symbol[idx],
'/');
1178 if (cp = (std::max)(rslash, bslash)) {
1183 return &symbol[idx];
1185 Error(
"BaseName",
"name = 0");
1196 char *dot =
nullptr;
1198 char *fullname =
nullptr;
1201 size_t namelen =
name ? strlen(
name) : 0;
1202 if (
name && namelen > 0) {
1204 fullname =
new char[namelen+5];
1205 strlcpy(fullname,
name,namelen+5);
1206 if ( !strrchr(fullname,
'.') )
1207 strlcat(fullname,
".exe",namelen+5);
1210 dot = strrchr(progname,
'.');
1211 idot = dot ? (size_t)(dot - progname) : strlen(progname);
1213 char *which =
nullptr;
1216 which =
StrDup(fullname);
1227 dirname.
Form(
"%c:%s", driveletter,
d.Data());
1242 progname[idot] =
'\0';
1244 if (which)
delete [] which;
1248 if (::NeedSplash()) {
1263 error_msg.
Form(
"errno out of range %d",
err);
1266 return sys_errlist[
err];
1275 fHostname = std::getenv(
"COMPUTERNAME");
1279 DWORD il =
sizeof(hn);
1280 ::GetComputerName(hn, &il);
1296 if (freq < 37) freq = 440;
1297 if (duration < 0) duration = 100;
1306 gGUIThreadMsgFunc = func;
1329 int fd =
h->GetFd();
1332 if (
h->HasReadInterest()) {
1335 if (
h->HasWriteInterest()) {
1347 if (!
h)
return nullptr;
1367 set_console =
kTRUE;
1380 ::SetConsoleCtrlHandler((PHANDLER_ROUTINE)ConsoleSigHandler, TRUE);
1391 if (!
h)
return nullptr;
1393 int sig =
h->GetSignal();
1406 ::SetConsoleCtrlHandler((PHANDLER_ROUTINE)ConsoleSigHandler, FALSE);
1447 if (!
gEnv->GetValue(
"Root.Stacktrace", 1))
1450 HANDLE snapshot = ::CreateToolhelp32Snapshot(TH32CS_SNAPTHREAD,::GetCurrentProcessId());
1455 if (!InitImagehlpFunctions()) {
1456 std::cerr <<
"No stack trace: cannot find (functions in) dbghelp.dll!" << std::endl;
1461 SYSTEM_INFO sysInfo;
1462 ::GetSystemInfo(&sysInfo);
1463 DWORD machineType = IMAGE_FILE_MACHINE_I386;
1464 switch (sysInfo.wProcessorArchitecture) {
1465 case PROCESSOR_ARCHITECTURE_AMD64:
1466 machineType = IMAGE_FILE_MACHINE_AMD64;
1468 case PROCESSOR_ARCHITECTURE_IA64:
1469 machineType = IMAGE_FILE_MACHINE_IA64;
1473 DWORD currentThreadID = ::GetCurrentThreadId();
1474 DWORD currentProcessID = ::GetCurrentProcessId();
1478 THREADENTRY32 threadentry;
1479 threadentry.dwSize =
sizeof(THREADENTRY32);
1480 if (!::Thread32First(snapshot, &threadentry))
return;
1482 std::cerr << std::endl <<
"==========================================" << std::endl;
1483 std::cerr <<
"=============== STACKTRACE ===============" << std::endl;
1484 std::cerr <<
"==========================================" << std::endl << std::endl;
1487 if (threadentry.th32OwnerProcessID != currentProcessID)
1489 HANDLE thread = ::OpenThread(THREAD_GET_CONTEXT|THREAD_SUSPEND_RESUME|THREAD_QUERY_INFORMATION,
1490 FALSE, threadentry.th32ThreadID);
1492 memset(&context, 0,
sizeof(CONTEXT));
1494 if (threadentry.th32ThreadID != currentThreadID) {
1495 ::SuspendThread(thread);
1496 context.ContextFlags = CONTEXT_ALL;
1497 ::GetThreadContext(thread, &context);
1498 ::ResumeThread(thread);
1500 if (fgXcptContext) {
1501 context = *fgXcptContext;
1503 typedef void (WINAPI *RTLCCTXT)(PCONTEXT);
1504 RTLCCTXT p2RtlCCtxt = (RTLCCTXT) ::GetProcAddress(
1505 GetModuleHandle(
"kernel32.dll"),
"RtlCaptureContext");
1507 context.ContextFlags = CONTEXT_ALL;
1508 p2RtlCCtxt(&context);
1514 ::ZeroMemory(&frame,
sizeof(frame));
1516 frame.AddrPC.Mode = AddrModeFlat;
1517 frame.AddrFrame.Mode = AddrModeFlat;
1518 frame.AddrStack.Mode = AddrModeFlat;
1520 frame.AddrPC.Offset = context.Eip;
1521 frame.AddrFrame.Offset = context.Ebp;
1522 frame.AddrStack.Offset = context.Esp;
1523#elif defined(_M_X64)
1524 frame.AddrPC.Offset = context.Rip;
1525 frame.AddrFrame.Offset = context.Rsp;
1526 frame.AddrStack.Offset = context.Rsp;
1527#elif defined(_M_IA64)
1528 frame.AddrPC.Offset = context.StIIP;
1529 frame.AddrFrame.Offset = context.IntSp;
1530 frame.AddrStack.Offset = context.IntSp;
1531 frame.AddrBStore.Offset= context.RsBSP;
1533 std::cerr <<
"Stack traces not supported on your architecture yet." << std::endl;
1538 while (_StackWalk64(machineType, (HANDLE)::GetCurrentProcess(), thread, (LPSTACKFRAME64)&frame,
1539 (LPVOID)&context, (PREAD_PROCESS_MEMORY_ROUTINE)NULL, (PFUNCTION_TABLE_ACCESS_ROUTINE)_SymFunctionTableAccess64,
1540 (PGET_MODULE_BASE_ROUTINE)_SymGetModuleBase64, NULL)) {
1542 std::cerr << std::endl <<
"================ Thread " << iThread++ <<
" ================" << std::endl;
1543 if (!bFirst || threadentry.th32ThreadID != currentThreadID) {
1544 const std::string moduleName = GetModuleName(frame.AddrPC.Offset);
1545 const std::string functionName = GetFunctionName(frame.AddrPC.Offset);
1546 std::cerr <<
" " << moduleName << functionName << std::endl;
1550 ::CloseHandle(thread);
1551 }
while (::Thread32Next(snapshot, &threadentry));
1553 std::cerr << std::endl <<
"==========================================" << std::endl;
1554 std::cerr <<
"============= END STACKTRACE =============" << std::endl;
1555 std::cerr <<
"==========================================" << std::endl << std::endl;
1556 ::CloseHandle(snapshot);
1557 _SymCleanup(GetCurrentProcess());
1566 UInt_t oldmask = _statusfp( );
1568 if (oldmask & _EM_INVALID ) mask |=
kInvalid;
1569 if (oldmask & _EM_ZERODIVIDE) mask |=
kDivByZero;
1570 if (oldmask & _EM_OVERFLOW ) mask |=
kOverflow;
1571 if (oldmask & _EM_UNDERFLOW) mask |=
kUnderflow;
1572 if (oldmask & _EM_INEXACT ) mask |=
kInexact;
1586 if (mask &
kInvalid ) newm |= _EM_INVALID;
1587 if (mask &
kDivByZero) newm |= _EM_ZERODIVIDE;
1588 if (mask &
kOverflow ) newm |= _EM_OVERFLOW;
1589 if (mask &
kUnderflow) newm |= _EM_UNDERFLOW;
1590 if (mask &
kInexact ) newm |= _EM_INEXACT;
1592 UInt_t cm = ::_statusfp();
1594 ::_controlfp(cm , _MCW_EM);
1613 if (pendingOnly && gGlobalEvent) ::SetEvent(gGlobalEvent);
1615 Bool_t pollOnce = pendingOnly;
1619 if (
gROOT->GetApplication()) {
1635 ::WaitForSingleObject(gGlobalEvent, 1);
1636 ::ResetEvent(gGlobalEvent);
1662 if (pendingOnly && !pollOnce)
1701 if (!pendingOnly && gGlobalEvent) {
1702 ::WaitForSingleObject(gGlobalEvent, 1);
1703 ::ResetEvent(gGlobalEvent);
1717 for (i = 0; i <
fReadmask->GetCount(); i++) {
1722 rc = WinNTSelect(&t, 0, 0);
1723 if (rc < 0 && rc != -2) {
1724 ::SysError(
"DispatchOneEvent",
"select: read error on %d\n", fd);
1730 for (i = 0; i <
fWritemask->GetCount(); i++) {
1736 rc = WinNTSelect(0, &t, 0);
1737 if (rc < 0 && rc != -2) {
1738 ::SysError(
"DispatchOneEvent",
"select: write error on %d\n", fd);
1800 if (sync == sh->
IsSync()) {
1802 if ((
fSignals->IsSet(sig) && sigdone == -1) || sigdone == sig) {
1803 if (sigdone == -1) {
1813 if (sigdone != -1)
return kTRUE;
1834 if ((
fReadready->IsSet(fd) && fddone == -1) ||
1835 (fddone == fd && read)) {
1845 (fddone == fd && !read)) {
1855 if (fddone != -1)
return kTRUE;
1872 if (dirname.
Length() == 0) {
1889 if (res)
return res;
1909 const char *
proto = (strstr(
name,
"file:///")) ?
"file://" :
"file:";
1912 if (!
name)
return 0;
1916 if (!
name)
return 0;
1939 helper->FreeDirectory(dirp);
1943 ::FindClose(tsfd->fSearchFile);
1955 return helper->GetDirEntry(dirp);
1958 if (tsfd->fFirstFile) {
1962 tsfd->fFirstFile =
kFALSE;
1963 return (
const char *)tsfd->fFindFileData.cFileName;
1965 if (::FindNextFile(tsfd->fSearchFile, &tsfd->fFindFileData)) {
1966 return (
const char *)tsfd->fFindFileData.cFileName;
1990 return (psz[0] == TEXT(
'\\') && psz[1] == TEXT(
'\\'));
2010#pragma data_seg(".text", "CODE")
2025 if (!IsDBCSLeadByte(*pPath)) {
2030 if ((*pPath == TEXT(
'\\')) && (*(pPath + 1) == 0))
2036 int cBackslashes = 0;
2037 for (p = pPath + 2; *p; p = CharNext(p)) {
2038 if (*p == TEXT(
'\\') && (++cBackslashes > 1))
2058 const char *
proto = (strstr(fdir,
"file:///")) ?
"file://" :
"file:";
2061 char *dir =
new char[MAX_PATH];
2062 if (IsShortcut(sdir)) {
2063 if (!ResolveShortCut(sdir, dir, MAX_PATH))
2064 strlcpy(dir, sdir,MAX_PATH);
2067 strlcpy(dir, sdir,MAX_PATH);
2069 size_t nche = strlen(dir)+3;
2070 char *entry =
new char[nche];
2071 struct _stati64 finfo;
2074 strlcpy(entry, dir,nche);
2075 if ((entry[strlen(dir)-1] ==
'/') || (entry[strlen(dir)-1] ==
'\\' )) {
2076 entry[strlen(dir)-1] =
'\0';
2079 strlcat(entry,
"\\",nche);
2081 if (_stati64(entry, &finfo) < 0) {
2087 strlcpy(entry, dir,nche);
2088 if ((entry[strlen(dir)-1] ==
'/') || (entry[strlen(dir)-1] ==
'\\' )) {
2090 entry[strlen(dir)-1] =
'\0';
2092 if (_stati64(entry, &finfo) < 0) {
2099 if (finfo.st_mode & S_IFDIR) {
2100 strlcpy(entry, dir,nche);
2101 if (!(entry[strlen(dir)-1] ==
'/' || entry[strlen(dir)-1] ==
'\\' )) {
2102 strlcat(entry,
"\\",nche);
2104 if (entry[strlen(dir)-1] ==
' ')
2105 entry[strlen(dir)-1] =
'\0';
2106 strlcat(entry,
"*",nche);
2175 char *wdpath =
nullptr;
2176 char drive = driveletter ? toupper( driveletter ) -
'A' + 1 : 0;
2182 if (!(wdpath = ::_getdcwd( (
int)drive, wdpath,
kMAXPATHLEN))) {
2184 Warning(
"WorkingDirectory",
"getcwd() failed");
2208 return std::string(mydir);
2216 const char *
h =
nullptr;
2217 if (!(
h = std::getenv(
"home")))
h = std::getenv(
"HOME");
2224 h = std::getenv(
"HOMESHARE");
2225 if (!
h)
h = std::getenv(
"HOMEDRIVE");
2228 h = std::getenv(
"HOMEPATH");
2233 h = std::getenv(
"USERPROFILE");
2238 if (mydir[1] ==
':')
2239 mydir[0] = toupper(mydir[0]);
2249 const char *dir =
gSystem->Getenv(
"TEMP");
2250 if (!dir) dir =
gSystem->Getenv(
"TEMPDIR");
2251 if (!dir) dir =
gSystem->Getenv(
"TEMP_DIR");
2252 if (!dir) dir =
gSystem->Getenv(
"TMP");
2253 if (!dir) dir =
gSystem->Getenv(
"TMPDIR");
2254 if (!dir) dir =
gSystem->Getenv(
"TMP_DIR");
2255 if (!dir) dir =
"c:\\";
2273 char tmpName[MAX_PATH];
2275 auto res = ::GetTempFileName(dir ? dir :
TempDirectory(), base.
Data(), 0, tmpName);
2277 ::SysError(
"TempFileName",
"Fail to generate temporary file name");
2282 if (suffix && *suffix) {
2286 ::SysError(
"TempFileName",
"Temporary file %s already exists", base.
Data());
2293 ::SysError(
"TempFileName",
"Fail to rename temporary file to %s", base.
Data());
2299 FILE *fp = fopen(base.
Data(),
"w+");
2301 if (!fp)
::SysError(
"TempFileName",
"error opening %s", base.
Data());
2319 if (!opt || !opt[0]) {
2324 UINT nOldErrorMode = ::SetErrorMode(SEM_FAILCRITICALERRORS);
2328 curdrive = _getdrive();
2329 if (strstr(opt,
"cur")) {
2331 sDrive.
Form(
"%c:", (curdrive +
'A' - 1));
2332 sType.
Form(
"Unknown Drive (%s)", sDrive.
Data());
2333 ::GetVolumeInformation(
Form(
"%s\\", sDrive.
Data()), NULL, 0, NULL, NULL,
2334 NULL, (LPSTR)szFs, 32);
2335 type = ::GetDriveType(sDrive.
Data());
2338 case DRIVE_NO_ROOT_DIR:
2340 case DRIVE_REMOVABLE:
2341 sType.
Form(
"Removable Disk (%s)", sDrive.
Data());
2344 sType.
Form(
"Local Disk (%s)", sDrive.
Data());
2347 sType.
Form(
"Network Drive (%s) (%s)", szFs, sDrive.
Data());
2350 sType.
Form(
"CD/DVD Drive (%s)", sDrive.
Data());
2353 sType.
Form(
"RAM Disk (%s)", sDrive.
Data());
2358 else if (strstr(opt,
"all")) {
2361 if (::GetLogicalDriveStrings(511, szTemp)) {
2362 TCHAR szDrive[3] = TEXT(
" :");
2368 sDrive.
Form(
"%s", szDrive);
2370 if ((sDrive ==
"A:") || (sDrive ==
"B:")) {
2374 sType.
Form(
"Unknown Drive (%s)", sDrive.
Data());
2375 ::GetVolumeInformation(
Form(
"%s\\", sDrive.
Data()), NULL, 0, NULL,
2376 NULL, NULL, (LPSTR)szFs, 32);
2377 type = ::GetDriveType(sDrive.
Data());
2380 case DRIVE_NO_ROOT_DIR:
2382 case DRIVE_REMOVABLE:
2383 sType.
Form(
"Removable Disk (%s)", sDrive.
Data());
2386 sType.
Form(
"Local Disk (%s)", sDrive.
Data());
2389 sType.
Form(
"Network Drive (%s) (%s)", szFs, sDrive.
Data());
2392 sType.
Form(
"CD/DVD Drive (%s)", sDrive.
Data());
2395 sType.
Form(
"RAM Disk (%s)", sDrive.
Data());
2405 ::SetErrorMode(nOldErrorMode);
2428 if (strchr(pathname,
'/') || strchr(pathname,
'\\')) {
2429 const char *rslash = strrchr(pathname,
'/');
2430 const char *bslash = strrchr(pathname,
'\\');
2431 const char *
r = std::max(rslash, bslash);
2432 const char *ptr = pathname;
2442 int len =
r - pathname;
2444 return TString(pathname, len);
2467 if (!pathname)
return 0;
2468 if (!pathname[0])
return 0;
2474 while(*lpchar ==
' ') lpchar++;
2476 if (isalpha((
int)*lpchar) && *(lpchar+1) ==
':') {
2480 if ( (*lpchar ==
'\\' || *lpchar ==
'/' ) &&
2481 (*(lpchar+1) ==
'\\' || *(lpchar+1) ==
'/') )
return 0;
2494 if (strchr(dir,
':')) idx = 2;
2495 return (dir[idx] ==
'/' || dir[idx] ==
'\\');
2528 const int kBufSize = 1024;
2529 TTHREAD_TLS_ARRAY(
char, kBufSize, temp);
2531 strlcpy(temp,
name, kBufSize);
2532 char *currentChar = temp;
2535 while (*currentChar !=
'\0') {
2536 if (*currentChar ==
'\\') *currentChar =
'/';
2554 UINT nOldErrorMode = ::SetErrorMode(SEM_FAILCRITICALERRORS);
2558 const char *
proto = (strstr(path,
"file:///")) ?
"file://" :
"file:";
2561 ::SetErrorMode(nOldErrorMode);
2566 ::SetErrorMode(nOldErrorMode);
2589 if (dir && dir[0]) {
2591 char last = dir[strlen(dir) - 1];
2592 if (last !=
'/' && last !=
'\\') {
2596 name.ReplaceAll(
"/",
"\\");
2613 if (!
ret)
return -1;
2622 int ret = std::rename(
f, t);
2639 struct _stati64 sbuf;
2642 const char *
proto = (strstr(path,
"file:///")) ?
"file://" :
"file:";
2644 size_t l = strlen(newpath);
2646 if (newpath[--
l] !=
'\\' || newpath[--
l] !=
'/') {
2652 if (newpath && ::_stati64(newpath, &sbuf) >= 0) {
2654 buf.
fDev = sbuf.st_dev;
2655 buf.
fIno = sbuf.st_ino;
2656 buf.
fMode = sbuf.st_mode;
2657 buf.
fUid = sbuf.st_uid;
2658 buf.
fGid = sbuf.st_gid;
2659 buf.
fSize = sbuf.st_size;
2660 buf.
fMtime = sbuf.st_mtime;
2661 buf.
fIsLink = IsShortcut(newpath);
2663 char *lpath =
new char[MAX_PATH];
2664 if (IsShortcut(newpath)) {
2665 struct _stati64 sbuf2;
2666 if (ResolveShortCut(newpath, lpath, MAX_PATH)) {
2667 if (::_stati64(lpath, &sbuf2) >= 0) {
2668 buf.
fMode = sbuf2.st_mode;
2694 LPCTSTR lpRootPathName = path;
2697 LPTSTR lpVolumeNameBuffer = 0;
2698 DWORD nVolumeNameSize = 0;
2700 DWORD volumeSerialNumber;
2701 DWORD maximumComponentLength;
2704 DWORD fileSystemFlags;
2707 char fileSystemNameBuffer[512];
2708 DWORD nFileSystemNameSize =
sizeof(fileSystemNameBuffer);
2711 UINT nOldErrorMode = ::SetErrorMode(SEM_FAILCRITICALERRORS);
2712 if (!::GetVolumeInformation(lpRootPathName,
2713 lpVolumeNameBuffer, nVolumeNameSize,
2714 &volumeSerialNumber,
2715 &maximumComponentLength,
2717 fileSystemNameBuffer, nFileSystemNameSize)) {
2719 ::SetErrorMode(nOldErrorMode);
2723 const char *fsNames[] = {
"FAT",
"NTFS" };
2725 for (i = 0; i < 2; i++) {
2726 if (!strncmp(fileSystemNameBuffer, fsNames[i], nFileSystemNameSize))
2731 DWORD sectorsPerCluster;
2732 DWORD bytesPerSector;
2733 DWORD numberOfFreeClusters;
2734 DWORD totalNumberOfClusters;
2736 if (!::GetDiskFreeSpace(lpRootPathName,
2739 &numberOfFreeClusters,
2740 &totalNumberOfClusters)) {
2742 ::SetErrorMode(nOldErrorMode);
2746 ::SetErrorMode(nOldErrorMode);
2748 *bsize = sectorsPerCluster * bytesPerSector;
2749 *blocks = totalNumberOfClusters;
2750 *bfree = numberOfFreeClusters;
2760 struct _stati64 finfo;
2765 char linkname[1024];
2766 LPTSTR lpszFilePart;
2767 TCHAR szPath[MAX_PATH];
2770 typedef BOOL (__stdcall *CREATEHARDLINKPROC)( LPCTSTR, LPCTSTR, LPSECURITY_ATTRIBUTES );
2771 static CREATEHARDLINKPROC _CreateHardLink = 0;
2773 HMODULE hModImagehlp = LoadLibrary(
"Kernel32.dll" );
2778 _CreateHardLink = (CREATEHARDLINKPROC) GetProcAddress( hModImagehlp,
"CreateHardLinkW" );
2780 _CreateHardLink = (CREATEHARDLINKPROC) GetProcAddress( hModImagehlp,
"CreateHardLinkA" );
2782 if (!_CreateHardLink)
2785 dwRet = GetFullPathName(from,
sizeof(szPath) /
sizeof(TCHAR),
2786 szPath, &lpszFilePart);
2788 if (_stati64(szPath, &finfo) < 0)
2791 if (finfo.st_mode & S_IFDIR)
2795 _splitpath(linkname,winDrive,winDir,winName,winExt);
2796 if ((!winDrive[0] ) &&
2798 _splitpath(szPath,winDrive,winDir,winName,winExt);
2799 snprintf(linkname,1024,
"%s\\%s\\%s", winDrive, winDir, to);
2801 else if (!winDrive[0]) {
2802 _splitpath(szPath,winDrive,winDir,winName,winExt);
2803 snprintf(linkname,1024,
"%s\\%s", winDrive, to);
2806 if (!_CreateHardLink(linkname, szPath, NULL))
2819 IShellLink* pShellLink;
2820 IPersistFile* pPersistFile;
2821 WCHAR wszLinkfile[MAX_PATH];
2822 int iWideCharsWritten;
2824 LPTSTR lpszFilePart;
2825 TCHAR szPath[MAX_PATH];
2827 hRes = E_INVALIDARG;
2828 if ((from == NULL) || (!from[0]) || (to == NULL) ||
2834 typedef HRESULT (__stdcall *COINITIALIZEPROC)( LPVOID );
2835 static COINITIALIZEPROC _CoInitialize = 0;
2836 typedef void (__stdcall *COUNINITIALIZEPROC)( void );
2837 static COUNINITIALIZEPROC _CoUninitialize = 0;
2838 typedef HRESULT (__stdcall *COCREATEINSTANCEPROC)( REFCLSID, LPUNKNOWN, DWORD, REFIID, LPVOID );
2839 static COCREATEINSTANCEPROC _CoCreateInstance = 0;
2841 HMODULE hModImagehlp = LoadLibrary(
"ole32.dll" );
2845 _CoInitialize = (COINITIALIZEPROC) GetProcAddress( hModImagehlp,
"CoInitialize" );
2848 _CoUninitialize = (COUNINITIALIZEPROC) GetProcAddress( hModImagehlp,
"CoUninitialize" );
2849 if (!_CoUninitialize)
2851 _CoCreateInstance = (COCREATEINSTANCEPROC) GetProcAddress( hModImagehlp,
"CoCreateInstance" );
2852 if (!_CoCreateInstance)
2859 _CoInitialize(NULL);
2862 dwRet = GetFullPathName(from,
sizeof(szPath) /
sizeof(TCHAR),
2863 szPath, &lpszFilePart);
2864 hRes = _CoCreateInstance(CLSID_ShellLink, NULL, CLSCTX_INPROC_SERVER,
2865 IID_IShellLink, (LPVOID *)&pShellLink);
2866 if (SUCCEEDED(hRes)) {
2868 hRes = pShellLink->SetPath(szPath);
2870 hRes = pShellLink->QueryInterface(IID_IPersistFile, (
void **)&pPersistFile);
2871 if (SUCCEEDED(hRes)){
2872 iWideCharsWritten = MultiByteToWideChar(CP_ACP, 0, linkname.
Data(), -1,
2873 wszLinkfile, MAX_PATH);
2874 hRes = pPersistFile->Save(wszLinkfile, TRUE);
2875 pPersistFile->Release();
2877 pShellLink->Release();
2895 struct _stati64 finfo;
2897 if (_stati64(
name, &finfo) < 0) {
2901 if (finfo.st_mode & S_IFDIR) {
2902 return ::_rmdir(
name);
2904 return ::_unlink(
name);
2913 if (::ioctlsocket(fd, FIONBIO, (u_long *)1) == SOCKET_ERROR) {
2932 const char *patbuf = (
const char *)patbuf0;
2934 char *cmd =
nullptr;
2946 const char driveletter =
DriveName(patbuf);
2955 if (!
proto.EqualTo(
"file"))
2963 while (*patbuf ==
' ') {
2968 while (*patbuf ==
':') {
2973 while (*patbuf ==
';') {
2979 for (
q = (
char*)patbuf; *
q;
q++) {
2983 if ( (((
q-2)>patbuf) && ( (*(
q-2)!=
';') || !isalpha(*(
q-1)) )) &&
2990 for (p = patbuf; *p; p++) {
3007 char replacement[4];
3010 for (
int k = 0; k<3; k++) replacement[k] = 0x1;
3012 replacement[3] = 0x0;
3016 while ( (pos = patbuf0.
Index(TildaNum,pos)) !=
kNPOS ) {
3017 patbuf0.
Replace(pos, 1, replacement);
3023 Int_t lbuf = ::ExpandEnvironmentStrings(
3029 cmd =
new char[lbuf+1];
3030 ::ExpandEnvironmentStrings(
3049 char newpath[MAX_PATH];
3050 if (IsShortcut(path)) {
3051 if (!ResolveShortCut(path, newpath, MAX_PATH))
3052 strlcpy(newpath, path, MAX_PATH);
3055 strlcpy(newpath, path, MAX_PATH);
3071 return ::_chmod(file, mode);
3079 return ::umask(mask);
3089 Error(
"Utime",
"need write permission for %s to change utime", file);
3092 if (!actime) actime = modtime;
3095 t.actime = (time_t)actime;
3096 t.modtime = (time_t)modtime;
3097 return ::utime(file, &t);
3112 gSystem->ExpandPathName(infile);
3116 return infile.Data();
3121 gSystem->ExpandPathName(exsearch);
3124 Int_t lastDelim = -1;
3125 for(
int i=0; i < exsearch.
Length(); ++i) {
3126 switch( exsearch[i] ) {
3129 if (i-lastDelim!=2) exsearch[i] =
';';
3132 case ';': lastDelim = i;
break;
3139 char *lpFilePart =
nullptr;
3141 ::access(
name, mode) == 0 && stat(
name, &finfo) == 0 &&
3142 finfo.st_mode & S_IFREG) {
3143 if (
gEnv->GetValue(
"Root.ShowPath", 0)) {
3147 return infile.Data();
3161 if ((
gEnv->GetValue(
"WinNT.UseNetAPI", 0)) && (::GetVersion() < 0x80000000)) {
3164 HINSTANCE netapi = ::LoadLibrary(
"netapi32.DLL");
3165 if (!netapi)
return kFALSE;
3167 p2NetApiBufferFree = (pfn1)::GetProcAddress(netapi,
"NetApiBufferFree");
3168 p2NetUserGetInfo = (pfn2)::GetProcAddress(netapi,
"NetUserGetInfo");
3169 p2NetLocalGroupGetMembers = (pfn3)::GetProcAddress(netapi,
"NetLocalGroupGetMembers");
3170 p2NetLocalGroupEnum = (pfn4)::GetProcAddress(netapi,
"NetLocalGroupEnum");
3172 if (!p2NetApiBufferFree || !p2NetUserGetInfo ||
3173 !p2NetLocalGroupGetMembers || !p2NetLocalGroupEnum)
return kFALSE;
3184 ::FreeLibrary(netapi);
3194 NET_API_STATUS NetStatus = NERR_Success;
3196 DWORD Index = 0, Total = 0;
3197 DWORD_PTR ResumeHandle = 0;
3198 LOCALGROUP_MEMBERS_INFO_1 *MemberInfo;
3199 WCHAR wszGroupName[256];
3201 DWORD dwLastError = 0;
3203 iRetOp = MultiByteToWideChar (
3205 (DWORD)MB_PRECOMPOSED,
3206 (LPCSTR)lpszGroupName,
3208 (LPWSTR)wszGroupName,
3209 (
int)
sizeof(wszGroupName) );
3212 dwLastError = GetLastError();
3214 p2NetApiBufferFree(Data);
3220 NetStatus = p2NetLocalGroupGetMembers (NULL, wszGroupName, 1,
3221 &Data, 8192, &Index, &Total, &ResumeHandle );
3223 if (NetStatus != NERR_Success || Data == NULL) {
3224 dwLastError = GetLastError();
3226 if (dwLastError == ERROR_ENVVAR_NOT_FOUND) {
3232 NetStatus = p2NetLocalGroupGetMembers ( NULL, wszGroupName, 0,
3233 &Data, 8192, &Index, &Total, &ResumeHandle );
3237 p2NetApiBufferFree(Data);
3242 MemberInfo = (LOCALGROUP_MEMBERS_INFO_1 *)Data;
3245 p2NetApiBufferFree(Data);
3254 NET_API_STATUS NetStatus = NERR_Success;
3256 DWORD Index = 0, Total = 0, i;
3257 DWORD_PTR ResumeHandle = 0;
3258 LOCALGROUP_INFO_0 *GroupInfo;
3259 char szAnsiName[256];
3260 DWORD dwLastError = 0;
3263 NetStatus = p2NetLocalGroupEnum(NULL, 0, &Data, 8192, &Index,
3264 &Total, &ResumeHandle );
3266 if (NetStatus != NERR_Success || Data == NULL) {
3267 dwLastError = GetLastError();
3269 p2NetApiBufferFree(Data);
3274 GroupInfo = (LOCALGROUP_INFO_0 *)Data;
3275 for (i=0; i < Total; i++) {
3277 iRetOp = WideCharToMultiByte (
3280 (LPCWSTR)(GroupInfo->lgrpi0_name),
3283 (
int)(
sizeof(szAnsiName)),
3295 p2NetApiBufferFree(Data);
3307 int &groupIdx,
int &memberIdx)
3309 BOOL bRetOp = FALSE;
3311 DWORD dwSidSize, dwDomainNameSize;
3314 SID_NAME_USE sidType;
3315 PUCHAR puchar_SubAuthCount = NULL;
3316 SID_IDENTIFIER_AUTHORITY sid_identifier_authority;
3317 PSID_IDENTIFIER_AUTHORITY psid_identifier_authority = NULL;
3318 unsigned char j = 0;
3319 DWORD dwLastError = 0;
3321 pSid = (PSID)bySidBuffer;
3322 dwSidSize =
sizeof(bySidBuffer);
3323 dwDomainNameSize =
sizeof(szDomainName);
3325 bRetOp = LookupAccountName (
3327 (LPCTSTR)lpszAccountName,
3329 (LPDWORD)&dwSidSize,
3330 (LPTSTR)szDomainName,
3331 (LPDWORD)&dwDomainNameSize,
3332 (PSID_NAME_USE)&sidType );
3334 if (bRetOp == FALSE) {
3335 dwLastError = GetLastError();
3339 bRetOp = IsValidSid((PSID)pSid);
3341 if (bRetOp == FALSE) {
3342 dwLastError = GetLastError();
3347 psid_identifier_authority = GetSidIdentifierAuthority ((PSID)pSid);
3350 memcpy (&sid_identifier_authority, psid_identifier_authority,
3351 sizeof(SID_IDENTIFIER_AUTHORITY));
3354 puchar_SubAuthCount = (PUCHAR)GetSidSubAuthorityCount((PSID)pSid);
3356 j = (
unsigned char)(*puchar_SubAuthCount);
3358 DWORD dwSubAuth = 0;
3359 PDWORD pdwSubAuth = NULL;
3361 pdwSubAuth = (PDWORD)GetSidSubAuthority (
3364 dwSubAuth = *pdwSubAuth;
3371 fGroups[groupIdx].gr_gid = dwSubAuth;
3383 NET_API_STATUS NetStatus = NERR_Success;
3385 DWORD Index = 0, Total = 0, i;
3386 DWORD_PTR ResumeHandle = 0;
3387 LOCALGROUP_MEMBERS_INFO_1 *MemberInfo;
3388 char szAnsiMemberName[256];
3389 char szFullMemberName[256];
3390 char szMemberHomeDir[256];
3391 WCHAR wszGroupName[256];
3394 DWORD length =
sizeof (act_name);
3395 DWORD dwLastError = 0;
3396 LPUSER_INFO_11 pUI11Buf = NULL;
3397 NET_API_STATUS nStatus;
3399 iRetOp = MultiByteToWideChar (
3401 (DWORD)MB_PRECOMPOSED,
3402 (LPCSTR)lpszGroupName,
3404 (LPWSTR)wszGroupName,
3405 (
int)
sizeof(wszGroupName) );
3408 dwLastError = GetLastError();
3410 p2NetApiBufferFree(Data);
3414 GetUserName (act_name, &length);
3418 NetStatus = p2NetLocalGroupGetMembers (NULL, wszGroupName, 1,
3419 &Data, 8192, &Index, &Total, &ResumeHandle );
3421 if (NetStatus != NERR_Success || Data == NULL) {
3422 dwLastError = GetLastError();
3424 if (dwLastError == ERROR_ENVVAR_NOT_FOUND) {
3430 NetStatus = p2NetLocalGroupGetMembers ( NULL, wszGroupName, 0,
3431 &Data, 8192, &Index, &Total, &ResumeHandle );
3435 p2NetApiBufferFree(Data);
3439 MemberInfo = (LOCALGROUP_MEMBERS_INFO_1 *)Data;
3440 for (i=0; i < Total; i++) {
3441 iRetOp = WideCharToMultiByte (
3444 (LPCWSTR)(MemberInfo->lgrmi1_name),
3446 (LPSTR)szAnsiMemberName,
3447 (
int)(
sizeof(szAnsiMemberName)),
3452 dwLastError = GetLastError();
3455 fPasswords[memberIdx].pw_name = strdup(szAnsiMemberName);
3456 fPasswords[memberIdx].pw_passwd = strdup(
"");
3457 fGroups[groupIdx].gr_mem[i] = strdup(szAnsiMemberName);
3463 TCHAR szUserName[255]=TEXT(
"");
3464 MultiByteToWideChar(CP_ACP, 0, szAnsiMemberName, -1, (LPWSTR)szUserName, 255);
3468 nStatus = p2NetUserGetInfo(NULL, (LPCWSTR)szUserName, 11, (LPBYTE *)&pUI11Buf);
3472 if (nStatus == NERR_Success) {
3473 if (pUI11Buf != NULL) {
3474 wsprintf(szFullMemberName,
"%S",pUI11Buf->usri11_full_name);
3475 fPasswords[memberIdx].pw_gecos = strdup(szFullMemberName);
3476 wsprintf(szMemberHomeDir,
"%S",pUI11Buf->usri11_home_dir);
3477 fPasswords[memberIdx].pw_dir = strdup(szMemberHomeDir);
3483 fPasswords[memberIdx].pw_dir = strdup(
"c:\\");
3487 if (pUI11Buf != NULL) {
3488 p2NetApiBufferFree(pUI11Buf);
3493 if (getenv(
"SHELL") == NULL)
3494 putenv ((GetVersion () & 0x80000000) ?
"SHELL=command" :
"SHELL=cmd");
3497 fPasswords[memberIdx].pw_shell = getenv(
"SHELL");
3507 p2NetApiBufferFree(Data);
3517 NET_API_STATUS NetStatus = NERR_Success;
3519 DWORD Index = 0, Total = 0, i;
3520 DWORD_PTR ResumeHandle = 0;
3521 LOCALGROUP_INFO_0 *GroupInfo;
3522 char szAnsiName[256];
3523 DWORD dwLastError = 0;
3524 int iRetOp = 0, iGroupIdx = 0, iMemberIdx = 0;
3526 NetStatus = p2NetLocalGroupEnum(NULL, 0, &Data, 8192, &Index,
3527 &Total, &ResumeHandle );
3529 if (NetStatus != NERR_Success || Data == NULL) {
3530 dwLastError = GetLastError();
3532 p2NetApiBufferFree(Data);
3536 GroupInfo = (LOCALGROUP_INFO_0 *)Data;
3537 for (i=0; i < Total; i++) {
3539 iRetOp = WideCharToMultiByte (
3542 (LPCWSTR)(GroupInfo->lgrpi0_name),
3545 (
int)(
sizeof(szAnsiName)),
3549 fGroups[iGroupIdx].gr_name = strdup(szAnsiName);
3550 fGroups[iGroupIdx].gr_passwd = strdup(
"");
3563 p2NetApiBufferFree(Data);
3577 if ((!
gEnv->GetValue(
"WinNT.UseNetAPI", 0)) || (::GetVersion() >= 0x80000000)) {
3580 DWORD length =
sizeof (
name);
3581 if (::GetUserName (
name, &length)) {
3582 if (stricmp (
"administrator",
name) == 0)
3592 if (!user || !user[0])
3597 if (!stricmp (user,
fPasswords[i].pw_name)) {
3618 if ((!
gEnv->GetValue(
"WinNT.UseNetAPI", 0)) || (::GetVersion() >= 0x80000000)) {
3621 DWORD length =
sizeof (
name);
3622 if (::GetUserName (
name, &length)) {
3623 if (stricmp (
"administrator",
name) == 0)
3645 if ((!
gEnv->GetValue(
"WinNT.UseNetAPI", 0)) || (::GetVersion() >= 0x80000000)) {
3648 DWORD length =
sizeof (
name);
3649 if (::GetUserName (
name, &length)) {
3650 if (stricmp (
"administrator",
name) == 0)
3663 struct group *grp =
nullptr;
3686 if ((!
gEnv->GetValue(
"WinNT.UseNetAPI", 0)) || (::GetVersion() >= 0x80000000)) {
3689 DWORD length =
sizeof (
name);
3690 if (::GetUserName (
name, &length)) {
3691 if (stricmp (
"administrator",
name) == 0)
3714 if ((!
gEnv->GetValue(
"WinNT.UseNetAPI", 0)) || (::GetVersion() >= 0x80000000)) {
3716 DWORD length =
sizeof (
name);
3718 if (::GetUserName (
name, &length)) {
3720 if (stricmp (
"administrator",
name) == 0) {
3722 ug->
fGroup =
"administrators";
3731 ug->
fUser =
"unknown";
3744 for (
int i = 0; i <
fNbUsers; i++) {
3788 if ((!
gEnv->GetValue(
"WinNT.UseNetAPI", 0)) || (::GetVersion() >= 0x80000000)) {
3790 DWORD length =
sizeof (
name);
3792 if (::GetUserName (
name, &length)) {
3793 if (stricmp (
"administrator",
name) == 0) {
3794 gr->fGroup =
"administrators";
3798 gr->fGroup =
"users";
3803 gr->fGroup =
"unknown";
3809 struct group *grp =
nullptr;
3811 if (gid ==
fGroups[i].gr_gid) {
3853 const char *env = std::getenv(
name);
3855 if (::_stricmp(
name,
"home") == 0 ) {
3857 }
else if (::_stricmp(
name,
"rootsys") == 0 ) {
3871 return ::system(shellcmd);
3879 return ::_popen(command, mode);
3887 return ::_pclose(pipe);
3915 gROOT->CloseFiles();
3916 if (
gROOT->GetListOfBrowsers()) {
3919 if (
gROOT->IsBatch())
3920 gROOT->GetListOfBrowsers()->Delete();
3925 if (
b->GetBrowserImp() &&
b->GetBrowserImp()->GetMainFrame())
3927 (((TBrowser*)0x%zx)->GetBrowserImp()->GetMainFrame()->CloseWindow();",
3969 static int fd1=0, fd2=0;
3970 static fpos_t pos1=0, pos2=0;
3980 const char *
m = (mode[0] ==
'a' || mode[0] ==
'w') ? mode :
"a";
3987 if (!
gSystem->GetPathInfo(file, st))
3993 fgetpos(stdout, &pos1);
3994 fd1 = _dup(fileno(stdout));
3996 if ((fout = freopen(file,
m, stdout)) == 0) {
3997 SysError(
"RedirectOutput",
"could not freopen stdout");
3999 _dup2(fd1, fileno(stdout));
4003 fsetpos(stdout, &pos1);
4008 fgetpos(stderr, &pos2);
4009 fd2 = _dup(fileno(stderr));
4010 if ((ferr = freopen(file,
m, stderr)) == 0) {
4011 SysError(
"RedirectOutput",
"could not freopen stderr");
4013 _dup2(fd1, fileno(stdout));
4017 fsetpos(stdout, &pos1);
4019 _dup2(fd2, fileno(stderr));
4023 fsetpos(stderr, &pos2);
4028 fseek(fout, 0, SEEK_END);
4029 fseek(ferr, 0, SEEK_END);
4036 if (_dup2(fd1, fileno(stdout))) {
4037 SysError(
"RedirectOutput",
"could not restore stdout");
4043 fsetpos(stdout, &pos1);
4050 if (_dup2(fd2, fileno(stderr))) {
4051 SysError(
"RedirectOutput",
"could not restore stderr");
4057 fsetpos(stderr, &pos2);
4112 if (len > 4 && (!stricmp(sLib.
Data()+len-4,
".dll"))) {
4125 Error(
"DynamicPathName",
4126 "%s does not exist in %s,\nor has wrong file extension (.dll)",
4143#pragma warning(push)
4144#pragma warning(disable:4200)
4161 if (!linkedLibs.
IsNull())
4174 HANDLE hFile, hMapping;
4177 if((hFile = CreateFile(exe,GENERIC_READ,FILE_SHARE_READ,0,OPEN_EXISTING,FILE_FLAG_SEQUENTIAL_SCAN,0))==
INVALID_HANDLE_VALUE) {
4181 if(!(hMapping = CreateFileMapping(hFile,0,PAGE_READONLY|SEC_COMMIT,0,0,0))) {
4186 if(!(basepointer = MapViewOfFile(hMapping,FILE_MAP_READ,0,0,0))) {
4187 CloseHandle(hMapping);
4194 IMAGE_DOS_HEADER *dos_head = (IMAGE_DOS_HEADER *)basepointer;
4197 IMAGE_FILE_HEADER _head;
4198 IMAGE_OPTIONAL_HEADER opt_head;
4199 IMAGE_SECTION_HEADER section_header[];
4201 struct header *pheader;
4202 const IMAGE_SECTION_HEADER * section_header;
4204 if(dos_head->e_magic!=
'ZM') {
4209 pheader = (
struct header *)((
char*)dos_head + dos_head->e_lfanew);
4211 if(IsBadReadPtr(pheader,
sizeof(
struct header))) {
4215 if(pheader->signature!=IMAGE_NT_SIGNATURE) {
4216 switch((
unsigned short)pheader->signature) {
4217 case IMAGE_DOS_SIGNATURE:
4220 case IMAGE_OS2_SIGNATURE:
4223 case IMAGE_OS2_SIGNATURE_LE:
4231#define isin(address,start,length) ((address)>=(start) && (address)<(start)+(length))
4234 for(sect=0,section_header=pheader->section_header;
4235 sect<pheader->_head.NumberOfSections;sect++,section_header++) {
4237 const void *
const section_data =
4238 (
char*)basepointer + section_header->PointerToRawData;
4239 for(directory=0;directory<IMAGE_NUMBEROF_DIRECTORY_ENTRIES;directory++) {
4240 if(
isin(pheader->opt_head.DataDirectory[directory].VirtualAddress,
4241 section_header->VirtualAddress,
4242 section_header->SizeOfRawData)) {
4243 const IMAGE_IMPORT_DESCRIPTOR *stuff_start =
4244 (IMAGE_IMPORT_DESCRIPTOR *)((
char*)section_data +
4245 (pheader->opt_head.DataDirectory[directory].VirtualAddress -
4246 section_header->VirtualAddress));
4249 const unsigned stuff_length =
4250 pheader->opt_head.DataDirectory[directory].Size;
4251 if(directory == IMAGE_DIRECTORY_ENTRY_IMPORT) {
4252 while(!IsBadReadPtr(stuff_start,
sizeof(*stuff_start)) &&
4253 stuff_start->Name) {
4254 TString dll = (
char*)section_data +
4255 ((DWORD)(stuff_start->Name)) -
4256 section_header->VirtualAddress;
4260 char *winPath = getenv(
"windir");
4261 _splitpath(winPath,winDrive,winDir,winName,winExt);
4262 if(!strstr(dllPath, winDir)) {
4263 if (!linkedLibs.
IsNull())
4265 linkedLibs += dllPath;
4277 UnmapViewOfFile(basepointer);
4278 CloseHandle(hMapping);
4309 char drive[_MAX_DRIVE], dir[_MAX_DIR], fname[_MAX_FNAME], ext[_MAX_EXT];
4312 std::vector<std::string> all_libs, libpaths;
4317 std::stringstream libenv(
gSystem->Getenv(
"LIB"));
4318 while (getline(libenv, str,
';')) {
4319 libpaths.push_back(str);
4322 std::stringstream libraries(libs.
Data());
4323 while (getline(libraries, str,
' ')) {
4324 std::string::size_type first, last;
4327 if (str.rfind(
"-L", 0) == 0) {
4328 first = str.find_first_of(
'%');
4329 last = str.find_last_of(
'%');
4330 if ((first != std::string::npos) && (last != std::string::npos) &&
4335 std::string var = str.substr(first+1, last-first-1);
4336 std::string env(
gSystem->Getenv(var.c_str()));
4340 env += str.substr(last+1);
4341 libpaths.push_back(env);
4345 ntlibs.
Append(str.c_str());
4350 last = str.rfind(
".dll");
4351 if (last != std::string::npos)
4352 str.replace(last, 4,
".lib");
4353 last = str.rfind(
".DLL");
4354 if (last != std::string::npos)
4355 str.replace(last, 4,
".lib");
4356 if (str.rfind(
".lib") != std::string::npos ||
4357 str.rfind(
".LIB") != std::string::npos) {
4359 if (_stat( str.c_str(), &buf ) == 0) {
4361 ntlibs.
Append(str.c_str());
4371 size_t requiredSize;
4372 getenv_s( &requiredSize, NULL, 0,
"WinDir");
4373 if (requiredSize == 0) {
4374 windir = strdup(
":\\WINDOWS");
4376 windir = (
char*)
malloc(requiredSize *
sizeof(
char));
4378 windir = strdup(
":\\WINDOWS");
4380 getenv_s( &requiredSize, windir, requiredSize,
"WinDir" );
4383 if (str.find(windir) == std::string::npos) {
4384 _splitpath(str.c_str(), drive, dir, fname, ext);
4385 std::string libname(fname);
4387 all_libs.push_back(libname);
4391 for (
auto lib : all_libs) {
4393 for (
auto libpath : libpaths) {
4395 std::string path_lib(libpath);
4398 if (_stat( path_lib.c_str(), &buf ) == 0) {
4400 ntlibs.
Append(lib.c_str());
4429 if (!ti)
return nullptr;
4464 if (mode && t->
IsSync()) {
4468 }
else if (!mode && t->
IsAsync()) {
4486 FILETIME ftFileTime;
4490 ::GetSystemTimeAsFileTime(&ftRealTime.ftFileTime);
4499 OSVERSIONINFO OsVersionInfo;
4508 OsVersionInfo.dwOSVersionInfoSize =
sizeof(OSVERSIONINFO);
4509 GetVersionEx(&OsVersionInfo);
4510 if (OsVersionInfo.dwPlatformId == VER_PLATFORM_WIN32_NT) {
4516 FILETIME ftFileTime;
4521 FILETIME ftFileTime;
4525 HANDLE hThread = GetCurrentThread();
4526 ret = GetThreadTimes (hThread, &ftCreate, &ftExit,
4527 &ftKernel.ftFileTime,
4528 &ftUser.ftFileTime);
4530 ret = ::GetLastError();
4531 ::Error(
"GetCPUTime",
" Error on GetProcessTimes 0x%lx", (
int)
ret);
4551 static time_t jan95 = 0;
4562 jan95 = mktime(&tp);
4563 if ((
int)jan95 == -1) {
4564 ::SysError(
"TWinNTSystem::Now",
"error converting 950001 0:00 to time_t");
4571 return TTime((now.time-(
Long_t)jan95)*1000 + now.millitm);
4581 std::this_thread::sleep_for(std::chrono::milliseconds(milliSec));
4597 if (
h->HasReadInterest())
4599 if (
h->HasWriteInterest())
4601 h->ResetReadyMask();
4603 rc = WinNTSelect(&rd, &wr, to);
4632 if (
h->HasReadInterest())
4634 if (
h->HasWriteInterest())
4636 h->ResetReadyMask();
4637 rc = WinNTSelect(&rd, &wr, to);
4659 if ((sp = ::getservbyname(servicename,
kProtocolName)) == 0) {
4660 Error(
"GetServiceByName",
"no service \"%s\" with protocol \"%s\"\n",
4664 return ::ntohs(sp->s_port);
4675 if ((sp = ::getservbyport(::htons(port),
kProtocolName)) == 0) {
4676 return Form(
"%d", port);
4686 struct hostent *host_ptr;
4691 if ((addr = ::inet_addr(hostname)) != INADDR_NONE) {
4693 if ((host_ptr = ::gethostbyaddr((
const char *)&addr,
4694 sizeof(addr), AF_INET))) {
4695 host = host_ptr->h_name;
4699 for (i = 1; host_ptr->h_addr_list[i]; i++) {
4700 memcpy(&addr2, host_ptr->h_addr_list[i], host_ptr->h_length);
4701 a.AddAddress(ntohl(addr2));
4703 for (i = 0; host_ptr->h_aliases[i]; i++)
4704 a.AddAlias(host_ptr->h_aliases[i]);
4707 host =
"UnNamedHost";
4709 }
else if ((host_ptr = ::gethostbyname(hostname))) {
4711 if (host_ptr->h_addrtype != AF_INET) {
4712 Error(
"GetHostByName",
"%s is not an internet host\n", hostname);
4715 memcpy(&addr, host_ptr->h_addr, host_ptr->h_length);
4716 host = host_ptr->h_name;
4717 type = host_ptr->h_addrtype;
4721 for (i = 1; host_ptr->h_addr_list[i]; i++) {
4722 memcpy(&addr2, host_ptr->h_addr_list[i], host_ptr->h_length);
4723 a.AddAddress(ntohl(addr2));
4725 for (i = 0; host_ptr->h_aliases[i]; i++)
4726 a.AddAlias(host_ptr->h_aliases[i]);
4729 if (
gDebug > 0)
Error(
"GetHostByName",
"unknown host %s", hostname);
4742 struct sockaddr_in addr;
4743 int len =
sizeof(addr);
4745 if (::getpeername(sock, (
struct sockaddr *)&addr, &len) == SOCKET_ERROR) {
4750 struct hostent *host_ptr;
4751 const char *hostname;
4755 if ((host_ptr = ::gethostbyaddr((
const char *)&addr.sin_addr,
4756 sizeof(addr.sin_addr), AF_INET))) {
4757 memcpy(&iaddr, host_ptr->h_addr, host_ptr->h_length);
4758 hostname = host_ptr->h_name;
4759 family = host_ptr->h_addrtype;
4761 memcpy(&iaddr, &addr.sin_addr,
sizeof(addr.sin_addr));
4766 return TInetAddress(hostname, ::ntohl(iaddr), family, ::ntohs(addr.sin_port));
4775 struct sockaddr_in addr;
4776 int len =
sizeof(addr);
4778 if (::getsockname(sock, (
struct sockaddr *)&addr, &len) == SOCKET_ERROR) {
4783 struct hostent *host_ptr;
4784 const char *hostname;
4788 if ((host_ptr = ::gethostbyaddr((
const char *)&addr.sin_addr,
4789 sizeof(addr.sin_addr), AF_INET))) {
4790 memcpy(&iaddr, host_ptr->h_addr, host_ptr->h_length);
4791 hostname = host_ptr->h_name;
4792 family = host_ptr->h_addrtype;
4794 memcpy(&iaddr, &addr.sin_addr,
sizeof(addr.sin_addr));
4799 return TInetAddress(hostname, ::ntohl(iaddr), family, ::ntohs(addr.sin_port));
4811 ::SysError(
"TWinNTSystem::AnnounceUnixService",
"socket");
4815 struct sockaddr_in inserver;
4816 memset(&inserver, 0,
sizeof(inserver));
4817 inserver.sin_family = AF_INET;
4818 inserver.sin_addr.s_addr = ::htonl(INADDR_LOOPBACK);
4819 inserver.sin_port = port;
4823 if (::bind(sock, (
struct sockaddr*) &inserver,
sizeof(inserver)) == SOCKET_ERROR) {
4824 ::SysError(
"TWinNTSystem::AnnounceUnixService",
"bind");
4829 if (::listen(sock, backlog)) {
4830 ::SysError(
"TWinNTSystem::AnnounceUnixService",
"listen");
4842 if (!sockpath || strlen(sockpath) <= 0) {
4843 ::SysError(
"TWinNTSystem::AnnounceUnixService",
"socket path undefined");
4847 struct sockaddr_in myaddr;
4849 int len =
sizeof myaddr;
4854 if ((sock =
socket(AF_INET, SOCK_STREAM, 0)) < 0) {
4855 ::SysError(
"TWinNTSystem::AnnounceUnixService",
"socket");
4859 memset(&myaddr, 0,
sizeof(myaddr));
4860 myaddr.sin_port = 0;
4861 myaddr.sin_family = AF_INET;
4862 myaddr.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
4864 rc = bind(sock, (
struct sockaddr *)&myaddr, len);
4866 ::SysError(
"TWinNTSystem::AnnounceUnixService",
"bind");
4869 rc = getsockname(sock, (
struct sockaddr *)&myaddr, &len);
4871 ::SysError(
"TWinNTSystem::AnnounceUnixService",
"getsockname");
4874 TString socketpath = sockpath;
4876 fp = fopen(socketpath,
"wb");
4878 ::SysError(
"TWinNTSystem::AnnounceUnixService",
"fopen");
4881 fprintf(fp,
"%d", myaddr.sin_port);
4885 if (listen(sock, backlog)) {
4886 ::SysError(
"TWinNTSystem::AnnounceUnixService",
"listen");
4898 if (
socket == -1)
return;
4902 ::shutdown(sock, 2);
4904 struct linger linger = {0, 0};
4905 ::setsockopt(sock, SOL_SOCKET, SO_LINGER, (
char *) &linger,
sizeof(linger));
4906 while (
::closesocket(sock) == SOCKET_ERROR && WSAGetLastError() == WSAEINTR) {
4920 if (WinNTRecv(sock, &header,
sizeof(header), 0) > 0) {
4921 int count = ::ntohl(header);
4923 if (count > length) {
4924 Error(
"RecvBuf",
"record header exceeds buffer size");
4926 }
else if (count > 0) {
4927 if (WinNTRecv(sock, buf, count, 0) < 0) {
4928 Error(
"RecvBuf",
"cannot receive buffer");
4943 Int_t header = ::htonl(length);
4945 if (WinNTSend(sock, &header,
sizeof(header), 0) < 0) {
4946 Error(
"SendBuf",
"cannot send header");
4950 if (WinNTSend(sock, buf, length, 0) < 0) {
4951 Error(
"SendBuf",
"cannot send buffer");
4991 if ((
n = WinNTRecv(sock, buf, length, flag)) <= 0) {
4993 Error(
"RecvRaw",
"cannot receive buffer");
5027 if ((
n = WinNTSend(sock, buf, length, flag)) <= 0) {
5029 Error(
"SendRaw",
"cannot send buffer");
5042 if (
socket == -1)
return -1;
5047 if (::setsockopt(sock, SOL_SOCKET, SO_SNDBUF, (
char*)&val,
sizeof(val)) == SOCKET_ERROR) {
5048 ::SysError(
"SetSockOpt",
"setsockopt(SO_SNDBUF)");
5053 if (::setsockopt(sock, SOL_SOCKET, SO_RCVBUF, (
char*)&val,
sizeof(val)) == SOCKET_ERROR) {
5054 ::SysError(
"SetSockOpt",
"setsockopt(SO_RCVBUF)");
5059 if (::setsockopt(sock, SOL_SOCKET, SO_OOBINLINE, (
char*)&val,
sizeof(val)) == SOCKET_ERROR) {
5060 SysError(
"SetSockOpt",
"setsockopt(SO_OOBINLINE)");
5065 if (::setsockopt(sock, SOL_SOCKET, SO_KEEPALIVE, (
char*)&val,
sizeof(val)) == SOCKET_ERROR) {
5066 ::SysError(
"SetSockOpt",
"setsockopt(SO_KEEPALIVE)");
5071 if (::setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, (
char*)&val,
sizeof(val)) == SOCKET_ERROR) {
5072 ::SysError(
"SetSockOpt",
"setsockopt(SO_REUSEADDR)");
5077 if (::setsockopt(sock, IPPROTO_TCP, TCP_NODELAY, (
char*)&val,
sizeof(val)) == SOCKET_ERROR) {
5078 ::SysError(
"SetSockOpt",
"setsockopt(TCP_NODELAY)");
5083 if (::ioctlsocket(sock, FIONBIO, &val) == SOCKET_ERROR) {
5090 if (::ioctl(sock, SIOCSPGRP, &val) == -1) {
5091 ::SysError(
"SetSockOpt",
"ioctl(SIOCSPGRP)");
5099 Error(
"SetSockOpt",
"illegal option (%d)", opt);
5111 if (
socket == -1)
return -1;
5114 int optlen =
sizeof(*val);
5118 if (::getsockopt(sock, SOL_SOCKET, SO_SNDBUF, (
char*)val, &optlen) == SOCKET_ERROR) {
5119 ::SysError(
"GetSockOpt",
"getsockopt(SO_SNDBUF)");
5124 if (::getsockopt(sock, SOL_SOCKET, SO_RCVBUF, (
char*)val, &optlen) == SOCKET_ERROR) {
5125 ::SysError(
"GetSockOpt",
"getsockopt(SO_RCVBUF)");
5130 if (::getsockopt(sock, SOL_SOCKET, SO_OOBINLINE, (
char*)val, &optlen) == SOCKET_ERROR) {
5131 ::SysError(
"GetSockOpt",
"getsockopt(SO_OOBINLINE)");
5136 if (::getsockopt(sock, SOL_SOCKET, SO_KEEPALIVE, (
char*)val, &optlen) == SOCKET_ERROR) {
5137 ::SysError(
"GetSockOpt",
"getsockopt(SO_KEEPALIVE)");
5142 if (::getsockopt(sock, SOL_SOCKET, SO_REUSEADDR, (
char*)val, &optlen) == SOCKET_ERROR) {
5143 ::SysError(
"GetSockOpt",
"getsockopt(SO_REUSEADDR)");
5148 if (::getsockopt(sock, IPPROTO_TCP, TCP_NODELAY, (
char*)val, &optlen) == SOCKET_ERROR) {
5149 ::SysError(
"GetSockOpt",
"getsockopt(TCP_NODELAY)");
5165 if (::ioctlsocket(sock, SIOCGPGRP, (u_long*)val) == SOCKET_ERROR) {
5166 ::SysError(
"GetSockOpt",
"ioctl(SIOCGPGRP)");
5172 if (::ioctlsocket(sock, SIOCATMARK, (u_long*)val) == SOCKET_ERROR) {
5173 ::SysError(
"GetSockOpt",
"ioctl(SIOCATMARK)");
5178 if (::ioctlsocket(sock, FIONREAD, (u_long*)val) == SOCKET_ERROR) {
5184 Error(
"GetSockOpt",
"illegal option (%d)", opt);
5196 int tcpwindowsize,
const char *protocol)
5201 if (!strcmp(servername,
"unix")) {
5204 else if (!
gSystem->AccessPathName(servername) || servername[0] ==
'/' ||
5205 (servername[1] ==
':' && servername[2] ==
'/')) {
5209 if (!strcmp(protocol,
"udp")){
5216 sport = ::htons(port);
5220 if (!addr.
IsValid())
return -1;
5223 struct sockaddr_in server;
5224 memset(&server, 0,
sizeof(server));
5225 memcpy(&server.sin_addr, &adr,
sizeof(adr));
5227 server.sin_port = sport;
5232 ::SysError(
"TWinNTSystem::WinNTConnectTcp",
"socket");
5236 if (tcpwindowsize > 0) {
5241 if (::connect(sock, (
struct sockaddr*) &server,
sizeof(server)) ==
INVALID_SOCKET) {
5254 struct sockaddr_in myaddr;
5257 memset(&myaddr, 0,
sizeof(myaddr));
5258 myaddr.sin_family = AF_INET;
5259 myaddr.sin_port = port;
5260 myaddr.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
5263 if ((sock =
socket(AF_INET, SOCK_STREAM, 0)) < 0) {
5264 ::SysError(
"TWinNTSystem::WinNTUnixConnect",
"socket");
5268 while ((connect(sock, (
struct sockaddr *)&myaddr,
sizeof myaddr)) == -1) {
5272 ::SysError(
"TWinNTSystem::WinNTUnixConnect",
"connect");
5288 if (!sockpath || strlen(sockpath) <= 0) {
5289 ::SysError(
"TWinNTSystem::WinNTUnixConnect",
"socket path undefined");
5292 TString socketpath = sockpath;
5294 fp = fopen(socketpath.
Data(),
"rb");
5296 ::SysError(
"TWinNTSystem::WinNTUnixConnect",
"fopen");
5299 fscanf(fp,
"%d", &port);
5302 if (port < 0 || port > 65535) {
5303 ::SysError(
"TWinNTSystem::WinNTUnixConnect",
"invalid port");
5321 sport = htons(port);
5324 if (!addr.
IsValid())
return -1;
5327 struct sockaddr_in server;
5328 memset(&server, 0,
sizeof(server));
5329 memcpy(&server.sin_addr, &adr,
sizeof(adr));
5331 server.sin_port = sport;
5335 if ((sock =
socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP)) < 0) {
5336 ::SysError(
"TWinNTSystem::WinNTUdpConnect",
"socket (%s:%d)",
5341 while (connect(sock, (
struct sockaddr*) &server,
sizeof(server)) == -1) {
5345 ::SysError(
"TWinNTSystem::WinNTUdpConnect",
"connect (%s:%d)",
5363 const char *protocol)
5386 const short kSOCKET_MINPORT = 5000, kSOCKET_MAXPORT = 15000;
5387 short tryport = kSOCKET_MINPORT;
5392 sport = ::htons(port);
5395 if (port == 0 && reuse) {
5396 ::Error(
"TWinNTSystem::WinNTTcpService",
"cannot do a port scan while reuse is true");
5403 sport = ::htons(port);
5408 if ((sock =
::socket(AF_INET, SOCK_STREAM, 0)) < 0) {
5409 ::SysError(
"TWinNTSystem::WinNTTcpService",
"socket");
5417 if (tcpwindowsize > 0) {
5422 struct sockaddr_in inserver;
5423 memset(&inserver, 0,
sizeof(inserver));
5424 inserver.sin_family = AF_INET;
5426 inserver.sin_port = sport;
5430 if (::bind(sock, (
struct sockaddr*) &inserver,
sizeof(inserver)) == SOCKET_ERROR) {
5431 ::SysError(
"TWinNTSystem::WinNTTcpService",
"bind");
5437 inserver.sin_port = ::htons(tryport);
5438 bret = ::bind(sock, (
struct sockaddr*) &inserver,
sizeof(inserver));
5440 }
while (bret == SOCKET_ERROR && WSAGetLastError() == WSAEADDRINUSE &&
5441 tryport < kSOCKET_MAXPORT);
5442 if (bret == SOCKET_ERROR) {
5443 ::SysError(
"TWinNTSystem::WinNTTcpService",
"bind (port scan)");
5449 if (::listen(sock, backlog) == SOCKET_ERROR) {
5450 ::SysError(
"TWinNTSystem::WinNTTcpService",
"listen");
5469 const short kSOCKET_MINPORT = 5000, kSOCKET_MAXPORT = 15000;
5470 short sport, tryport = kSOCKET_MINPORT;
5476 sport = htons(port);
5480 if ((sock =
socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP)) < 0) {
5481 ::SysError(
"TUnixSystem::UnixUdpService",
"socket");
5485 struct sockaddr_in inserver;
5486 memset(&inserver, 0,
sizeof(inserver));
5487 inserver.sin_family = AF_INET;
5489 inserver.sin_port = sport;
5493 if (bind(sock, (
struct sockaddr*) &inserver,
sizeof(inserver))) {
5494 ::SysError(
"TWinNTSystem::AnnounceUdpService",
"bind");
5500 inserver.sin_port = htons(tryport);
5501 bret = bind(sock, (
struct sockaddr*) &inserver,
sizeof(inserver));
5503 }
while (bret == SOCKET_ERROR && WSAGetLastError() == WSAEADDRINUSE &&
5504 tryport < kSOCKET_MAXPORT);
5506 ::SysError(
"TWinNTSystem::AnnounceUdpService",
"bind (port scan)");
5512 if (listen(sock, backlog)) {
5513 ::SysError(
"TWinNTSystem::AnnounceUdpService",
"listen");
5531 (::WSAGetLastError() == WSAEINTR)) {
5536 if (::WSAGetLastError() == WSAEWOULDBLOCK) {
5550#define SystemBasicInformation 0
5551#define SystemPerformanceInformation 2
5578#define Li2Double(x) ((double)((x).HighPart) * 4.294967296E9 + (double)((x).LowPart))
5586 LARGE_INTEGER ulFreq, ulTicks, ulValue, ulStartCounter;
5590 if (QueryPerformanceFrequency(&ulFreq)) {
5592 QueryPerformanceCounter(&ulTicks);
5595 ulValue.QuadPart = ulTicks.QuadPart + ulFreq.QuadPart/10;
5596 ulStartCounter.QuadPart =
__rdtsc();
5600 QueryPerformanceCounter(&ulTicks);
5601 }
while (ulTicks.QuadPart <= ulValue.QuadPart);
5603 return (DWORD)((
__rdtsc() - ulStartCounter.QuadPart)/100000);
5611#define SM_SERVERR2 89
5612typedef void (WINAPI *
PGNSI)(LPSYSTEM_INFO);
5618 OSVERSIONINFOEX osvi;
5621 BOOL bOsVersionInfoEx;
5622 static char *strReturn =
nullptr;
5626 strReturn =
new char[2048];
5630 ZeroMemory(&si,
sizeof(SYSTEM_INFO));
5631 ZeroMemory(&osvi,
sizeof(OSVERSIONINFOEX));
5636 osvi.dwOSVersionInfoSize =
sizeof(OSVERSIONINFOEX);
5638 if (!(bOsVersionInfoEx = GetVersionEx ((OSVERSIONINFO *) &osvi))) {
5639 osvi.dwOSVersionInfoSize =
sizeof (OSVERSIONINFO);
5640 if (!GetVersionEx((OSVERSIONINFO *) &osvi))
5644 NTSTATUS(WINAPI *RtlGetVersion)(LPOSVERSIONINFOEXW);
5645 OSVERSIONINFOEXW osInfo;
5646 *(FARPROC*)&RtlGetVersion = GetProcAddress(GetModuleHandleA(
"ntdll"),
"RtlGetVersion");
5648 if (NULL != RtlGetVersion) {
5649 osInfo.dwOSVersionInfoSize =
sizeof(osInfo);
5650 RtlGetVersion(&osInfo);
5654 pGNSI = (
PGNSI)GetProcAddress(GetModuleHandle(
"kernel32.dll"),
"GetNativeSystemInfo");
5657 else GetSystemInfo(&si);
5659 switch (osvi.dwPlatformId) {
5661 case VER_PLATFORM_WIN32_NT:
5663 if (osInfo.dwMajorVersion == 10 && osInfo.dwMinorVersion == 0) {
5664 if (osvi.wProductType == VER_NT_WORKSTATION)
5665 strlcpy(strReturn,
"Microsoft Windows 10 ", 2048);
5666 else strlcpy(strReturn,
"Windows Server 2016 ", 2048);
5668 if (osInfo.dwMajorVersion == 6 && osInfo.dwMinorVersion == 3) {
5669 if (osvi.wProductType == VER_NT_WORKSTATION)
5670 strlcpy(strReturn,
"Microsoft Windows 8.1 ", 2048);
5671 else strlcpy(strReturn,
"Windows Server 2012 R2 ", 2048);
5673 if (osInfo.dwMajorVersion == 6 && osInfo.dwMinorVersion == 2) {
5674 if (osvi.wProductType == VER_NT_WORKSTATION)
5675 strlcpy(strReturn,
"Microsoft Windows 8 ", 2048);
5676 else strlcpy(strReturn,
"Windows Server 2012 ", 2048);
5678 if (osInfo.dwMajorVersion == 6 && osInfo.dwMinorVersion == 1) {
5679 if (osvi.wProductType == VER_NT_WORKSTATION)
5680 strlcpy(strReturn,
"Microsoft Windows 7 ", 2048);
5681 else strlcpy(strReturn,
"Windows Server 2008 R2 ", 2048);
5683 if (osInfo.dwMajorVersion == 6 && osInfo.dwMinorVersion == 0) {
5684 if (osvi.wProductType == VER_NT_WORKSTATION)
5685 strlcpy(strReturn,
"Microsoft Windows Vista ", 2048);
5686 else strlcpy(strReturn,
"Windows Server \"Longhorn\" ", 2048);
5688 if (osvi.dwMajorVersion == 5 && osvi.dwMinorVersion == 2) {
5690 strlcpy(strReturn,
"Microsoft Windows Server 2003 \"R2\" ", 2048);
5691 else if (osvi.wProductType == VER_NT_WORKSTATION &&
5692 si.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_AMD64) {
5693 strlcpy(strReturn,
"Microsoft Windows XP Professional x64 Edition ", 2048);
5695 strlcpy(strReturn,
"Microsoft Windows Server 2003, ", 2048);
5697 if (osvi.dwMajorVersion == 5 && osvi.dwMinorVersion == 1)
5698 strlcpy(strReturn,
"Microsoft Windows XP ", 2048);
5700 if (osvi.dwMajorVersion == 5 && osvi.dwMinorVersion == 0)
5701 strlcpy(strReturn,
"Microsoft Windows 2000 ", 2048);
5703 if (osvi.dwMajorVersion <= 4)
5704 strlcpy(strReturn,
"Microsoft Windows NT ", 2048);
5707 if (bOsVersionInfoEx) {
5709 if (osvi.wProductType == VER_NT_WORKSTATION &&
5710 si.wProcessorArchitecture!=PROCESSOR_ARCHITECTURE_AMD64) {
5711 if (osvi.dwMajorVersion == 4)
5712 strlcat(strReturn,
"Workstation 4.0 ", 2048);
5713 else if (osvi.wSuiteMask & VER_SUITE_PERSONAL)
5714 strlcat(strReturn,
"Home Edition " , 2048);
5716 strlcat(strReturn,
"Professional ", 2048);
5719 else if (osvi.wProductType == VER_NT_SERVER ||
5720 osvi.wProductType == VER_NT_DOMAIN_CONTROLLER) {
5721 if (osvi.dwMajorVersion == 5 && osvi.dwMinorVersion == 2) {
5722 if (si.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_IA64) {
5723 if (osvi.wSuiteMask & VER_SUITE_DATACENTER)
5724 strlcat(strReturn,
"Datacenter Edition for Itanium-based Systems", 2048);
5725 else if (osvi.wSuiteMask & VER_SUITE_ENTERPRISE)
5726 strlcat(strReturn,
"Enterprise Edition for Itanium-based Systems", 2048);
5727 }
else if (si.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_AMD64) {
5728 if (osvi.wSuiteMask & VER_SUITE_DATACENTER)
5729 strlcat(strReturn,
"Datacenter x64 Edition ", 2048);
5730 else if (osvi.wSuiteMask & VER_SUITE_ENTERPRISE)
5731 strlcat(strReturn,
"Enterprise x64 Edition ", 2048);
5733 strlcat(strReturn,
"Standard x64 Edition ", 2048);
5735 if (osvi.wSuiteMask & VER_SUITE_DATACENTER)
5736 strlcat(strReturn,
"Datacenter Edition ", 2048);
5737 else if (osvi.wSuiteMask & VER_SUITE_ENTERPRISE)
5738 strlcat(strReturn,
"Enterprise Edition ", 2048);
5739 else if (osvi.wSuiteMask == VER_SUITE_BLADE)
5740 strlcat(strReturn,
"Web Edition " , 2048);
5742 strlcat(strReturn,
"Standard Edition ", 2048);
5744 }
else if (osvi.dwMajorVersion == 5 && osvi.dwMinorVersion == 0) {
5745 if (osvi.wSuiteMask & VER_SUITE_DATACENTER)
5746 strlcat(strReturn,
"Datacenter Server ", 2048);
5747 else if( osvi.wSuiteMask & VER_SUITE_ENTERPRISE)
5748 strlcat(strReturn,
"Advanced Server ", 2048);
5750 strlcat(strReturn,
"Server ", 2048);
5752 if (osvi.wSuiteMask & VER_SUITE_ENTERPRISE)
5753 strlcat(strReturn,
"Server 4.0, Enterprise Edition " , 2048);
5755 strlcat(strReturn,
"Server 4.0 ", 2048);
5761 DWORD dwBufLen=
BUFSIZE*
sizeof(TCHAR);
5764 lRet = RegOpenKeyEx(HKEY_LOCAL_MACHINE,
5765 "SYSTEM\\CurrentControlSet\\Control\\ProductOptions",
5766 0, KEY_QUERY_VALUE, &hKey );
5767 if (lRet != ERROR_SUCCESS)
5770 lRet = RegQueryValueEx(hKey,
"ProductType", NULL, NULL,
5771 (LPBYTE) szProductType, &dwBufLen);
5772 RegCloseKey( hKey );
5774 if ((lRet != ERROR_SUCCESS) || (dwBufLen >
BUFSIZE*
sizeof(TCHAR)))
5777 if (lstrcmpi(
"WINNT", szProductType) == 0)
5778 strlcat(strReturn,
"Workstation " , 2048);
5779 if (lstrcmpi(
"LANMANNT", szProductType) == 0)
5780 strlcat(strReturn,
"Server " , 2048);
5781 if (lstrcmpi(
"SERVERNT", szProductType) == 0)
5782 strlcat(strReturn,
"Advanced Server " , 2048);
5783 snprintf(temp, 512,
"%d.%d ", osvi.dwMajorVersion, osvi.dwMinorVersion);
5784 strlcat(strReturn, temp, 2048);
5787 if ( osvi.dwMajorVersion == 4 && lstrcmpi(osvi.szCSDVersion,
"Service Pack 6" ) == 0) {
5792 lRet = RegOpenKeyEx(HKEY_LOCAL_MACHINE,
5793 "SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\Hotfix\\Q246009",
5794 0, KEY_QUERY_VALUE, &hKey );
5795 if (lRet == ERROR_SUCCESS) {
5796 snprintf(temp, 512,
"Service Pack 6a (Build %d)", osvi.dwBuildNumber & 0xFFFF);
5797 strlcat(strReturn, temp, 2048);
5799 snprintf(temp, 512,
"%s (Build %d)", osvi.szCSDVersion, osvi.dwBuildNumber & 0xFFFF);
5800 strlcat(strReturn, temp, 2048);
5802 RegCloseKey( hKey );
5804 snprintf(temp, 512,
"%s (Build %d)", osvi.szCSDVersion, osvi.dwBuildNumber & 0xFFFF);
5805 strlcat(strReturn, temp, 2048);
5810 case VER_PLATFORM_WIN32_WINDOWS:
5811 if (osvi.dwMajorVersion == 4 && osvi.dwMinorVersion == 0) {
5812 strlcpy(strReturn,
"Microsoft Windows 95 ", 2048);
5813 if (osvi.szCSDVersion[1]==
'C' || osvi.szCSDVersion[1]==
'B')
5814 strlcat(strReturn,
"OSR2 " , 2048);
5816 if (osvi.dwMajorVersion == 4 && osvi.dwMinorVersion == 10) {
5817 strlcpy(strReturn,
"Microsoft Windows 98 ", 2048);
5818 if (osvi.szCSDVersion[1]==
'A' || osvi.szCSDVersion[1]==
'B')
5819 strlcat(strReturn,
"SE ", 2048);
5821 if (osvi.dwMajorVersion == 4 && osvi.dwMinorVersion == 90) {
5822 strlcpy(strReturn,
"Microsoft Windows Millennium Edition", 2048);
5826 case VER_PLATFORM_WIN32s:
5827 strlcpy(strReturn,
"Microsoft Win32s", 2048);
5838 unsigned nHighestFeatureEx;
5842 nHighestFeatureEx = (unsigned)nBuff[0];
5844 if (nHighestFeatureEx >= 0x80000006) {
5846 return (((
unsigned)nBuff[2])>>16);
5857 SYSTEM_INFO sysInfo;
5858 MEMORYSTATUSEX statex;
5859 OSVERSIONINFO OsVersionInfo;
5861 char szKeyValueString[80];
5862 DWORD szKeyValueDword;
5867 NtQuerySystemInformation = (
PROCNTQSI)GetProcAddress(
5868 GetModuleHandle(
"ntdll"),
"NtQuerySystemInformation");
5870 if (!NtQuerySystemInformation) {
5872 "Error on GetProcAddress(NtQuerySystemInformation)");
5877 &SysPerfInfo,
sizeof(SysPerfInfo),
5879 OsVersionInfo.dwOSVersionInfoSize =
sizeof(OSVERSIONINFO);
5880 GetVersionEx(&OsVersionInfo);
5881 GetSystemInfo(&sysInfo);
5882 statex.dwLength =
sizeof(statex);
5883 if (!GlobalMemoryStatusEx(&statex)) {
5884 ::Error(
"GetWinNTSysInfo",
"Error on GlobalMemoryStatusEx()");
5887 sysinfo->
fCpus = sysInfo.dwNumberOfProcessors;
5896 status = RegOpenKeyEx(HKEY_LOCAL_MACHINE,
"HARDWARE\\DESCRIPTION\\System",
5897 0, KEY_QUERY_VALUE, &hKey);
5898 if (status == ERROR_SUCCESS) {
5899 dwBufLen =
sizeof(szKeyValueString);
5900 RegQueryValueEx(hKey,
"Identifier", NULL, NULL,(LPBYTE)szKeyValueString,
5902 sysinfo->
fModel = szKeyValueString;
5905 status = RegOpenKeyEx(HKEY_LOCAL_MACHINE,
5906 "Hardware\\Description\\System\\CentralProcessor\\0",
5907 0, KEY_QUERY_VALUE, &hKey);
5908 if (status == ERROR_SUCCESS) {
5909 dwBufLen =
sizeof(szKeyValueString);
5910 status = RegQueryValueEx(hKey,
"ProcessorNameString", NULL, NULL,
5911 (LPBYTE)szKeyValueString, &dwBufLen);
5912 if (status == ERROR_SUCCESS)
5913 sysinfo->
fCpuType = szKeyValueString;
5914 dwBufLen =
sizeof(DWORD);
5915 status = RegQueryValueEx(hKey,
"~MHz",NULL,NULL,(LPBYTE)&szKeyValueDword,
5917 if ((status == ERROR_SUCCESS) && ((sysinfo->
fCpuSpeed <= 0) ||
5918 (sysinfo->
fCpuSpeed < (szKeyValueDword >> 1))))
5932 SYSTEM_INFO sysInfo;
5933 Float_t idle_ratio, kernel_ratio, user_ratio, total_ratio;
5934 FILETIME ft_sys_idle, ft_sys_kernel, ft_sys_user, ft_fun_time;
5935 SYSTEMTIME st_fun_time;
5937 ULARGE_INTEGER ul_sys_idle, ul_sys_kernel, ul_sys_user;
5938 static ULARGE_INTEGER ul_sys_idleold = {0, 0};
5939 static ULARGE_INTEGER ul_sys_kernelold = {0, 0};
5940 static ULARGE_INTEGER ul_sys_userold = {0, 0};
5941 ULARGE_INTEGER ul_sys_idle_diff, ul_sys_kernel_diff, ul_sys_user_diff;
5943 ULARGE_INTEGER ul_fun_time;
5944 ULARGE_INTEGER ul_fun_timeold = {0, 0};
5945 ULARGE_INTEGER ul_fun_time_diff;
5947 typedef BOOL (__stdcall *GetSystemTimesProc)( LPFILETIME lpIdleTime,
5948 LPFILETIME lpKernelTime, LPFILETIME lpUserTime );
5949 static GetSystemTimesProc pGetSystemTimes = 0;
5951 HMODULE hModImagehlp = LoadLibrary(
"Kernel32.dll" );
5952 if (!hModImagehlp) {
5953 ::Error(
"GetWinNTCpuInfo",
"Error on LoadLibrary(Kernel32.dll)");
5957 pGetSystemTimes = (GetSystemTimesProc) GetProcAddress( hModImagehlp,
5959 if (!pGetSystemTimes) {
5960 ::Error(
"GetWinNTCpuInfo",
"Error on GetProcAddress(GetSystemTimes)");
5963 GetSystemInfo(&sysInfo);
5966 pGetSystemTimes(&ft_sys_idle,&ft_sys_kernel,&ft_sys_user);
5967 GetSystemTime(&st_fun_time);
5968 SystemTimeToFileTime(&st_fun_time,&ft_fun_time);
5970 memcpy(&ul_sys_idle, &ft_sys_idle,
sizeof(FILETIME));
5971 memcpy(&ul_sys_kernel, &ft_sys_kernel,
sizeof(FILETIME));
5972 memcpy(&ul_sys_user, &ft_sys_user,
sizeof(FILETIME));
5973 memcpy(&ul_fun_time, &ft_fun_time,
sizeof(FILETIME));
5975 ul_sys_idle_diff.QuadPart = ul_sys_idle.QuadPart -
5976 ul_sys_idleold.QuadPart;
5977 ul_sys_kernel_diff.QuadPart = ul_sys_kernel.QuadPart -
5978 ul_sys_kernelold.QuadPart;
5979 ul_sys_user_diff.QuadPart = ul_sys_user.QuadPart -
5980 ul_sys_userold.QuadPart;
5982 ul_fun_time_diff.QuadPart = ul_fun_time.QuadPart -
5983 ul_fun_timeold.QuadPart;
5985 ul_sys_idleold.QuadPart = ul_sys_idle.QuadPart;
5986 ul_sys_kernelold.QuadPart = ul_sys_kernel.QuadPart;
5987 ul_sys_userold.QuadPart = ul_sys_user.QuadPart;
5989 if (ul_fun_timeold.QuadPart == 0) {
5991 ul_fun_timeold.QuadPart = ul_fun_time.QuadPart;
5994 ul_fun_timeold.QuadPart = ul_fun_time.QuadPart;
6002 idle_ratio /= (
Float_t)sysInfo.dwNumberOfProcessors;
6003 user_ratio /= (
Float_t)sysInfo.dwNumberOfProcessors;
6004 kernel_ratio /= (
Float_t)sysInfo.dwNumberOfProcessors;
6005 total_ratio = 100.0 - idle_ratio;
6010 cpuinfo->
fUser = user_ratio;
6011 cpuinfo->
fSys = kernel_ratio;
6012 cpuinfo->
fTotal = total_ratio;
6013 cpuinfo->
fIdle = idle_ratio;
6022 MEMORYSTATUSEX statex;
6023 PERFORMANCE_INFORMATION statex2;
6024 statex.dwLength =
sizeof(statex);
6025 statex2.cb =
sizeof(statex2);
6026 if (!GlobalMemoryStatusEx(&statex)) {
6027 ::Error(
"GetWinNTMemInfo",
"Error on GlobalMemoryStatusEx()");
6030 if (!GetPerformanceInfo(&statex2, statex2.cb)) {
6031 ::Error(
"GetWinNTMemInfo",
"Error on GetPerformanceInfo()");
6034 used = (
Long64_t)(statex.ullTotalPhys - statex.ullAvailPhys);
6037 sys_cache = (
Long64_t)(statex2.SystemCache * statex2.PageSize);
6045 swap_total = (
Long64_t)(statex.ullTotalPageFile - statex.ullTotalPhys);
6046 swap_avail = (
Long64_t)(statex.ullAvailPageFile - statex.ullAvailPhys);
6047 swap_used = swap_total - swap_avail;
6059 PROCESS_MEMORY_COUNTERS pmc;
6060 FILETIME starttime, exittime, kerneltime, usertime;
6061 timeval ru_stime, ru_utime;
6064 if (GetProcessMemoryInfo(GetCurrentProcess(), &pmc,
sizeof(pmc))) {
6068 if (GetProcessTimes(GetCurrentProcess(), &starttime, &exittime, &kerneltime, &usertime)) {
6070 memcpy(&li, &kerneltime,
sizeof(FILETIME));
6072 ru_stime.tv_sec = li.QuadPart / 1000000L;
6073 ru_stime.tv_usec = li.QuadPart % 1000000L;
6075 memcpy(&li, &usertime,
sizeof(FILETIME));
6077 ru_utime.tv_sec = li.QuadPart / 1000000L;
6078 ru_utime.tv_usec = li.QuadPart % 1000000L;
6081 ((
Float_t)(ru_utime.tv_usec) / 1000000.);
6083 ((
Float_t)(ru_stime.tv_usec) / 1000000.);
6094 if (!info)
return -1;
6106 if (!info)
return -1;
6117 if (!info)
return -1;
6128 if (!info)
return -1;
The file contains utilities which are foundational and could be used across the core component of ROO...
int Int_t
Signed integer 4 bytes (int).
int Ssiz_t
String size (currently int).
unsigned long ULongptr_t
Unsigned integer large enough to hold a pointer (platform-dependent).
unsigned int UInt_t
Unsigned integer 4 bytes (unsigned int).
long Long_t
Signed long integer 4 bytes (long). Size depends on architecture.
bool Bool_t
Boolean (0=false, 1=true) (bool).
double Double_t
Double 8 bytes.
constexpr Ssiz_t kNPOS
The equivalent of std::string::npos for the ROOT class TString.
long long Long64_t
Portable signed long integer 8 bytes.
float Float_t
Float 4 bytes (float).
const char Option_t
Option string (const char).
@ kItimerResolution
interval-timer resolution in ms (used for TThread, TTimer, Emit, Connect, etc.)
externTApplication * gApplication
Error("WriteTObject","The current directory (%s) is not associated with a file. The object (%s) has not been written.", GetName(), objname)
void SysError(const char *location, const char *msgfmt,...)
Use this function in case a system (OS or GUI) related error occurred.
void Break(const char *location, const char *msgfmt,...)
Use this function in case an error occurred.
externInt_t gErrorIgnoreLevel
errors with level below this value will be ignored. Default is kUnset.
R__EXTERN TExceptionHandler * gExceptionHandler
R__EXTERN void Throw(int code)
If an exception context has been set (using the TRY and RETRY macros) jump back to where it was set.
static unsigned int total
#define INVALID_HANDLE_VALUE
char * Form(const char *fmt,...)
Formats a string in a circular formatting buffer.
void Printf(const char *fmt,...)
Formats a string in a circular formatting buffer and prints the string.
char * StrDup(const char *str)
Duplicate the string str.
@ kSigSegmentationViolation
externconst char * gRootDir
externconst char * gProgName
externTFileHandler * gXDisplay
externconst char * gProgPath
ESocketBindOption
Options for binging the sockets created.
@ kInaddrAny
Any address for socket binding.
static void sighandler(int sig)
Call the signal handler associated with the signal.
static const char * DynamicPath(const char *newpath=nullptr, Bool_t reset=kFALSE)
Get shared library search path.
static void SigHandler(ESignals sig)
Unix signal handler.
const char * kProtocolName
void(* SigHandler_t)(ESignals)
externTWin32SplashThread * gSplash
static void __cpuid(int *cpuid_data, int)
static const char * shellMeta
BOOL PathIsRoot(LPCTSTR pPath)
check if a path is a root
static void GetWinNTProcInfo(ProcInfo_t *procinfo)
Get process info for this process on Windows NT.
static int GetL2CacheSize()
Use assembly to retrieve the L2 cache information ...
static void GetWinNTCpuInfo(CpuInfo_t *cpuinfo, Int_t sampleTime)
Get CPU stat for Window.
void Gl_setwidth(int width)
void(WINAPI * PGNSI)(LPSYSTEM_INFO)
#define SystemPerformanceInformation
BOOL PathIsUNC(LPCTSTR pszPath)
Returns TRUE if the given string is a UNC path.
static const char shellEscape
const TCHAR c_szColonSlash[]
static void GetWinNTMemInfo(MemInfo_t *meminfo)
Get VM stat for Windows NT.
static DWORD GetCPUSpeed()
Calculate the CPU clock speed using the 'rdtsc' instruction.
#define isin(address, start, length)
static const char * shellStuff
__inline BOOL DBL_BSLASH(LPCTSTR psz)
Inline function to check for a double-backslash at the beginning of a string.
static void GetWinNTSysInfo(SysInfo_t *sysinfo)
Get system info for Windows NT.
static const char * GetWindowsVersion()
void * _ReturnAddress(void)
LONG(WINAPI * PROCNTQSI)(UINT, PVOID, ULONG, PULONG)
externULongptr_t gConsoleWindow
Using a TBrowser one can browse all ROOT objects.
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
ULong_t fds_bits[(((kFDSETSIZE)+((kNFDBITS) -1))/(kNFDBITS))]
TFdSet & operator=(const TFdSet &fd)
void Copy(TFdSet &fd) const
virtual Bool_t WriteNotify()
Notify when something can be written to the descriptor associated with this handler.
virtual Bool_t ReadNotify()
Notify when something can be read from the descriptor associated with this handler.
This class represents an Internet Protocol (IP) address.
UInt_t GetAddress() const
TObject * Next() override
Return next object in the list. Returns 0 when no more objects in list.
void Add(TObject *obj) override
virtual void SysError(const char *method, const char *msgfmt,...) const
Issue system error message.
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
Iterator of ordered collection.
TObject * Next() override
Return next object in collection.
static const TString & GetBinDir()
Get the binary directory in the installation. Static utility function.
static Bool_t Initialized()
Return kTRUE if the TROOT object has been initialized.
static const TString & GetLibDir()
Get the library directory in the installation.
Regular expression class.
Bool_t Notify() override
Notify when signal occurs.
ESignals GetSignal() const
Bool_t EndsWith(const char *pat, ECaseCompare cmp=kExact) const
Return true if string ends with the specified string.
TSubString Strip(EStripType s=kTrailing, char c=' ') const
Return a substring of self stripped at beginning and/or end.
TString & Replace(Ssiz_t pos, Ssiz_t n, const char *s)
Ssiz_t First(char c) const
Find first occurrence of a character c.
const char * Data() const
TString & ReplaceAll(const TString &s1, const TString &s2)
Bool_t BeginsWith(const char *s, ECaseCompare cmp=kExact) const
TString & Prepend(const char *cs)
TString & Swap(TString &other)
TString & Remove(Ssiz_t pos)
TString & Append(const char *cs)
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString.
void Form(const char *fmt,...)
Formats a string using a printf style format descriptor.
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
TSeqCollection * fFileHandler
virtual void AddFileHandler(TFileHandler *fh)
Add a file handler to the list of system file handlers.
TString & GetLastErrorString()
Return the thread local storage for the custom last error message.
void Beep(Int_t freq=-1, Int_t duration=-1, Bool_t setDefault=kFALSE)
Beep for duration milliseconds with a tone of frequency freq.
static void ResetErrno()
Static function resetting system error number.
static Int_t GetErrno()
Static function returning system error number.
TFdSet * fReadmask
!Files that should be checked for read events
virtual void * OpenDirectory(const char *name)
Open a directory.
virtual Long_t NextTimeOut(Bool_t mode)
Time when next timer of mode (synchronous=kTRUE or asynchronous=kFALSE) will time-out (in ms).
TFdSet * fWritemask
!Files that should be checked for write events
TFdSet * fSignals
!Signals that were trapped
virtual Bool_t IsPathLocal(const char *path)
Returns TRUE if the url in 'path' points to the local file system.
virtual int MakeDirectory(const char *name)
Make a directory.
virtual const char * ExpandFileName(const char *fname)
Expand a pathname getting rid of special shell characters like ~.
TSystem(const TSystem &)=delete
virtual TFileHandler * RemoveFileHandler(TFileHandler *fh)
Remove a file handler from the list of file handlers.
virtual int Load(const char *module, const char *entry="", Bool_t system=kFALSE)
Load a shared library.
int GetPathInfo(const char *path, Long_t *id, Long_t *size, Long_t *flags, Long_t *modtime)
Get info about a file: id, size, flags, modification time.
virtual Bool_t AccessPathName(const char *path, EAccessMode mode=kFileExists)
Returns FALSE if one can access a file using the specified access mode.
virtual void ExitLoop()
Exit from event loop.
virtual Bool_t Init()
Initialize the OS interface.
virtual void AddTimer(TTimer *t)
Add timer to list of system timers.
TFdSet * fWriteready
!Files with writes waiting
virtual void AddSignalHandler(TSignalHandler *sh)
Add a signal handler to list of system signal handlers.
TSeqCollection * fSignalHandler
TFdSet * fReadready
!Files with reads waiting
TSystem * FindHelper(const char *path, void *dirptr=nullptr)
Create helper TSystem to handle file and directory operations that might be special for remote file a...
std::atomic< Bool_t > fInsideNotify
virtual char * Which(const char *search, const char *file, EAccessMode mode=kFileExists)
Find location of file in a search path.
virtual const char * GetLibraries(const char *regexp="", const char *option="", Bool_t isRegexp=kTRUE)
Return a space separated list of loaded shared libraries.
virtual TSignalHandler * RemoveSignalHandler(TSignalHandler *sh)
Remove a signal handler from list of signal handlers.
static const char * StripOffProto(const char *path, const char *proto)
Strip off protocol string from specified path.
virtual Bool_t ProcessEvents()
Process pending events (GUI, timers, sockets).
virtual TTimer * RemoveTimer(TTimer *t)
Remove timer from list of system timers.
virtual int Unlink(const char *name)
Unlink, i.e.
char * DynamicPathName(const char *lib, Bool_t quiet=kFALSE)
Find a dynamic library called lib using the system search paths.
Basic time type with millisecond precision.
Handles synchronous and a-synchronous timer events.
Bool_t CheckTimer(const TTime &now)
Check if timer timed out.
This class represents a WWW compatible URL.
const char * GetProtocol() const
Class providing an interface to the Windows NT Operating System.
void CloseConnection(int sock, Bool_t force=kFALSE) override
Close socket.
TList * GetVolumes(Option_t *opt="") const override
Get list of volumes (drives) mounted on the system.
FILE * OpenPipe(const char *shellcmd, const char *mode) override
Open a pipe.
void IgnoreSignal(ESignals sig, Bool_t ignore=kTRUE) override
If ignore is true ignore the specified signal, else restore previous behaviour.
Bool_t HandleConsoleEvent()
int Utime(const char *file, Long_t modtime, Long_t actime) override
Set a files modification and access times.
void Sleep(UInt_t milliSec) override
Sleep milliSec milli seconds.
TTime Now() override
Get current time in milliseconds since 0:00 Jan 1 1995.
int AnnounceUdpService(int port, int backlog, ESocketBindOption socketBindOption=ESocketBindOption::kInaddrAny) override
Announce UDP service.
const char * HostName() override
Return the system's host name.
virtual ~TWinNTSystem()
dtor
FILE * TempFileName(TString &base, const char *dir=nullptr, const char *suffix=nullptr) override
Create a secure temporary file by appending a unique 6 letter string to base.
void ExitLoop() override
Exit from event loop.
int SetNonBlock(int fd)
Make descriptor fd non-blocking.
int AnnounceUnixService(int port, int backlog) override
Announce unix domain service.
const char * GetLinkedLibraries() override
Get list of shared libraries loaded at the start of the executable.
void AddSignalHandler(TSignalHandler *sh) override
Add a signal handler to list of system signal handlers.
const char * PrependPathName(const char *dir, TString &name) override
Concatenate a directory and a file name.
void SetGUIThreadMsgHandler(ThreadMsgFunc_t func)
Set the (static part of) the event handler func for GUI messages.
Bool_t ProcessEvents() override
process pending events, i.e. DispatchOneEvent(kTRUE)
const char DriveName(const char *pathname="/")
Return the drive letter in pathname.
int SetSockOpt(int sock, int opt, int val) override
Set socket option.
struct passwd * fPasswords
Int_t GetCpuInfo(CpuInfo_t *info, Int_t sampleTime=1000) const override
Returns cpu load average and load info into the CpuInfo_t structure.
Int_t SetFPEMask(Int_t mask=kDefaultMask) override
Set which conditions trigger a floating point exception.
int GetPathInfo(const char *path, FileStat_t &buf) override
Get info about a file.
static void ThreadStub(void *Parameter)
void FreeDirectory(void *dirp) override
Close a WinNT file system directory.
static int WinNTUdpConnect(const char *hostname, int port)
Creates a UDP socket connection Is called via the TSocket constructor.
Int_t GetSysInfo(SysInfo_t *info) const override
Returns static system info, like OS type, CPU type, number of CPUs RAM size, etc into the SysInfo_t s...
void * OpenDirectory(const char *name) override
Open a directory. Returns 0 if directory does not exist.
const char * Getenv(const char *name) override
Get environment variable.
UserGroup_t * GetGroupInfo(Int_t gid) override
Returns all group info in the UserGroup_t structure.
void AddTimer(TTimer *ti) override
Add timer to list of system timers.
int RecvBuf(int sock, void *buffer, int length) override
Receive a buffer headed by a length indicator.
void DoBeep(Int_t freq=-1, Int_t duration=-1) const override
Beep.
void TimerThread()
Special Thread to check asynchronous timers.
const char * GetDynamicPath() override
Return the dynamic path (used to find shared libraries).
Bool_t ExpandPathName(TString &patbuf) override
Expand a pathname getting rid of special shell characaters like ~.$, etc.
int GetServiceByName(const char *service) override
Get port # of internet service.
int OpenConnection(const char *server, int port, int tcpwindowsize=-1, const char *protocol="tcp") override
Open a connection to a service on a server.
int ConnectService(const char *servername, int port, int tcpwindowsize, const char *protocol="tcp")
Connect to service servicename on server servername.
TString GetDirName(const char *pathname) override
Return the directory name in pathname.
int SendRaw(int sock, const void *buffer, int length, int flag) override
Send exactly length bytes from buffer.
const char * TempDirectory() const override
Return a user configured or systemwide directory to create temporary files in.
void DispatchSignals(ESignals sig)
Handle and dispatch signals.
int Exec(const char *shellcmd) override
Execute a command.
Long_t LookupSID(const char *lpszAccountName, int what, int &groupIdx, int &memberIdx)
Take the name and look up a SID so that we can get full domain/user information.
Int_t GetEffectiveUid() override
Returns the effective user id.
void NotifyApplicationCreated() override
Hook to tell TSystem that the TApplication object has been created.
void Abort(int code=0) override
Abort the application.
Int_t Select(TList *active, Long_t timeout) override
Select on file descriptors. The timeout to is in millisec.
Int_t GetMemInfo(MemInfo_t *info) const override
Returns ram and swap memory usage info into the MemInfo_t structure.
Int_t GetProcInfo(ProcInfo_t *info) const override
Returns cpu and memory used by this process into the ProcInfo_t structure.
TFileHandler * RemoveFileHandler(TFileHandler *fh) override
Remove a file handler from the list of file handlers.
Bool_t DispatchTimers(Bool_t mode)
Handle and dispatch timers.
const char * DirName(const char *pathname) override
Return the directory name in pathname.
Bool_t IsPathLocal(const char *path) override
Returns TRUE if the url in 'path' points to the local file system.
int SendBuf(int sock, const void *buffer, int length) override
Send a buffer headed by a length indicator.
TInetAddress GetHostByName(const char *server) override
Get Internet Protocol (IP) address of host.
Bool_t ChangeDirectory(const char *path) override
Change directory.
int AcceptConnection(int sock) override
Accept a connection.
int GetPid() override
Get process id.
const char * WorkingDirectory() override
Return the working directory for the default drive.
void SetProgname(const char *name) override
Set the application name (from command line, argv[0]) and copy it in gProgName.
int GetSockOpt(int sock, int opt, int *val) override
Get socket option.
int GetFsInfo(const char *path, Long_t *id, Long_t *bsize, Long_t *blocks, Long_t *bfree) override
Get info about a file system: id, bsize, bfree, blocks.
int AnnounceTcpService(int port, Bool_t reuse, int backlog, int tcpwindowsize=-1, ESocketBindOption socketBindOption=ESocketBindOption::kInaddrAny) override
Announce TCP/IP service.
int CopyFile(const char *from, const char *to, Bool_t overwrite=kFALSE) override
Copy a file.
Int_t RedirectOutput(const char *name, const char *mode="a", RedirectHandle_t *h=nullptr) override
Redirect standard output (stdout, stderr) to the specified file.
Bool_t IsAbsoluteFileName(const char *dir) override
Return true if dir is an absolute pathname.
int mkdir(const char *name, Bool_t recursive=kFALSE) override
Make a file system directory.
const char * UnixPathName(const char *unixpathname) override
Convert a pathname to a unix pathname.
Bool_t CheckSignals(Bool_t sync)
Check if some signals were raised and call their Notify() member.
int Symlink(const char *from, const char *to) override
Create a symlink from file1 to file2.
void DispatchOneEvent(Bool_t pendingOnly=kFALSE) override
Dispatch a single event in TApplication::Run() loop.
int Load(const char *module, const char *entry="", Bool_t system=kFALSE) override
Load a shared library.
TSignalHandler * RemoveSignalHandler(TSignalHandler *sh) override
Remove a signal handler from list of signal handlers.
const char * GetError() override
Return system error string.
void StackTrace() override
Print a stack trace, if gEnv entry "Root.Stacktrace" is unset or 1, and if the image helper functions...
int Unlink(const char *name) override
Unlink, i.e.
void ResetSignals() override
Reset signals handlers to previous behaviour.
int RecvRaw(int sock, void *buffer, int length, int flag) override
Receive exactly length bytes into buffer.
const char * BaseName(const char *name) override
Base name of a file name.
TTimer * RemoveTimer(TTimer *ti) override
Remove timer from list of system timers.
void Exit(int code, Bool_t mode=kTRUE) override
Exit the application.
void AddDynamicPath(const char *dir) override
Add a new directory to the dynamic path.
int Umask(Int_t mask) override
Set the process file creation mode mask.
void AddFileHandler(TFileHandler *fh) override
Add a file handler to the list of system file handlers.
std::string fDirNameBuffer
Bool_t CheckDescriptors()
Check if there is activity on some file descriptors and call their Notify() member.
static int WinNTUnixConnect(int port)
Connect to a Unix domain socket.
int Chmod(const char *file, UInt_t mode) override
Set the file permission bits.
Bool_t Init() override
Initialize WinNT system interface.
const char * GetDirEntry(void *dirp) override
Returns the next directory entry.
TInetAddress GetSockName(int sock) override
Get Internet Protocol (IP) address of host and port #.
Bool_t(* ThreadMsgFunc_t)(MSG *)
TInetAddress GetPeerName(int sock) override
Get Internet Protocol (IP) address of remote host and port #.
Int_t GetUid(const char *user=nullptr) override
Returns the user's id. If user = 0, returns current user's id.
const char * FindFile(const char *search, TString &file, EAccessMode mode=kFileExists) override
Find location of file in a search path.
const char * FindDynamicLibrary(TString &lib, Bool_t quiet=kFALSE) override
Returns and updates sLib to the path of a dynamic library (searches for library in the dynamic librar...
void ResetSignal(ESignals sig, Bool_t reset=kTRUE) override
If reset is true reset the signal handler for the specified signal to the default handler,...
Bool_t CollectMembers(const char *lpszGroupName, int &groupIdx, int &memberIdx)
Bool_t CountMembers(const char *lpszGroupName)
std::string GetHomeDirectory(const char *userName=nullptr) const override
Return the user's home directory.
Bool_t AccessPathName(const char *path, EAccessMode mode=kFileExists) override
Returns FALSE if one can access a file using the specified access mode.
void FillWithHomeDirectory(const char *userName, char *mydir) const
Fill buffer with user's home directory.
char * GetServiceByPort(int port) override
Get name of internet service.
Bool_t InitUsersGroups()
Collect local users and groups accounts information.
Int_t GetGid(const char *group=nullptr) override
Returns the group's id. If group = 0, returns current user's group.
const char * HomeDirectory(const char *userName=0) override
Return the user's home directory.
Int_t GetEffectiveGid() override
Returns the effective group id.
void Setenv(const char *name, const char *value) override
Set environment variable.
void SetDynamicPath(const char *path) override
Set the dynamic path to a new value.
std::string GetWorkingDirectory() const override
Return the working directory for the default drive.
HANDLE GetProcess()
Get current process handle.
UserGroup_t * GetUserInfo(Int_t uid) override
Returns all user info in the UserGroup_t structure.
int Rename(const char *from, const char *to) override
Rename a file. Returns 0 when successful, -1 in case of failure.
int MakeDirectory(const char *name) override
Make a WinNT file system directory.
int Link(const char *from, const char *to) override
Create a link from file1 to file2.
const char * GetLibraries(const char *regexp="", const char *option="", Bool_t isRegexp=kTRUE) override
Return a space separated list of loaded shared libraries.
int ClosePipe(FILE *pipe) override
Close the pipe.
Int_t GetFPEMask() override
Return the bitmap of conditions that trigger a floating point exception.
const std::string & GetFallbackRootSys()
BVH_ALWAYS_INLINE T length(const Vec< T, N > &v)
Struct used to pass information between OpenDirectory and GetDirEntry in a thread safe way (each thre...
WIN32_FIND_DATA fFindFileData