Edit

kc3-lang/angle/src/common/system_utils_win.cpp

Branch :

  • Show log

    Commit

  • Author : Jamie Madill
    Date : 2019-10-09 10:26:25
    Hash : 95a736bd
    Message : Reland "Add more test_utils functions." This is a reland of 5fcfcea4a9379633a83a67fc1d94938cb31f2a9c Re-land uses static linking with angle_util. The root cause of the CFI error wasn't solved. Static linking works around the problem by not using any export rules. Second re-land fixes missing imports for libEGL and libGLESv2 static varieties. Original change's description: > Add more test_utils functions. > > Includes methods for creating temporary files, deleting files, and > reading files into a string. Also renames GetPathSeparator to mention > it's only used for environment variables. Includes a new virtual type > angle::Process that will be used to implement cross-platform async > Process launching for tests. Also includes a way to specify a custom > crash handler callback. > > Also adds a few unit tests for the new functionality. They are disabled > on Android because the functions are not needed by the new test runner. > > Bug: angleproject:3162 > Change-Id: I3e2c2e9837608884c98379fa0f78c9ffbe158d73 > Reviewed-on: https://chromium-review.googlesource.com/c/angle/angle/+/1821940 > Commit-Queue: Jamie Madill <jmadill@chromium.org> > Reviewed-by: Jonah Ryan-Davis <jonahr@google.com> Bug: chromium:1015810 Bug: angleproject:3162 Change-Id: I2a18b819b0f91df610ad12ffedea2b38349fe7cf Reviewed-on: https://chromium-review.googlesource.com/c/angle/angle/+/1879859 Commit-Queue: Jamie Madill <jmadill@chromium.org> Reviewed-by: Yuly Novikov <ynovikov@chromium.org>

  • src/common/system_utils_win.cpp
  • //
    // Copyright 2014 The ANGLE Project Authors. All rights reserved.
    // Use of this source code is governed by a BSD-style license that can be
    // found in the LICENSE file.
    //
    
    // system_utils_win.cpp: Implementation of OS-specific functions for Windows
    
    #include "system_utils.h"
    
    #include <stdarg.h>
    #include <windows.h>
    #include <array>
    #include <vector>
    
    namespace angle
    {
    std::string GetExecutablePath()
    {
        std::array<char, MAX_PATH> executableFileBuf;
        DWORD executablePathLen = GetModuleFileNameA(nullptr, executableFileBuf.data(),
                                                     static_cast<DWORD>(executableFileBuf.size()));
        return (executablePathLen > 0 ? std::string(executableFileBuf.data()) : "");
    }
    
    std::string GetExecutableDirectory()
    {
        std::string executablePath = GetExecutablePath();
        size_t lastPathSepLoc      = executablePath.find_last_of("\\/");
        return (lastPathSepLoc != std::string::npos) ? executablePath.substr(0, lastPathSepLoc) : "";
    }
    
    const char *GetSharedLibraryExtension()
    {
        return "dll";
    }
    
    Optional<std::string> GetCWD()
    {
        std::array<char, MAX_PATH> pathBuf;
        DWORD result = GetCurrentDirectoryA(static_cast<DWORD>(pathBuf.size()), pathBuf.data());
        if (result == 0)
        {
            return Optional<std::string>::Invalid();
        }
        return std::string(pathBuf.data());
    }
    
    bool SetCWD(const char *dirName)
    {
        return (SetCurrentDirectoryA(dirName) == TRUE);
    }
    
    bool UnsetEnvironmentVar(const char *variableName)
    {
        return (SetEnvironmentVariableA(variableName, nullptr) == TRUE);
    }
    
    bool SetEnvironmentVar(const char *variableName, const char *value)
    {
        return (SetEnvironmentVariableA(variableName, value) == TRUE);
    }
    
    std::string GetEnvironmentVar(const char *variableName)
    {
        std::array<char, MAX_PATH> oldValue;
        DWORD result =
            GetEnvironmentVariableA(variableName, oldValue.data(), static_cast<DWORD>(oldValue.size()));
        if (result == 0)
        {
            return std::string();
        }
        else
        {
            return std::string(oldValue.data());
        }
    }
    
    const char *GetPathSeparatorForEnvironmentVar()
    {
        return ";";
    }
    
    double GetCurrentTime()
    {
        LARGE_INTEGER frequency = {};
        QueryPerformanceFrequency(&frequency);
    
        LARGE_INTEGER curTime;
        QueryPerformanceCounter(&curTime);
    
        return static_cast<double>(curTime.QuadPart) / frequency.QuadPart;
    }
    
    class Win32Library : public Library
    {
      public:
        Win32Library(const char *libraryName, SearchType searchType)
        {
            char buffer[MAX_PATH];
            int ret = snprintf(buffer, MAX_PATH, "%s.%s", libraryName, GetSharedLibraryExtension());
            if (ret > 0 && ret < MAX_PATH)
            {
                switch (searchType)
                {
                    case SearchType::ApplicationDir:
                        mModule = LoadLibraryA(buffer);
                        break;
                    case SearchType::SystemDir:
                        mModule = LoadLibraryExA(buffer, nullptr, LOAD_LIBRARY_SEARCH_SYSTEM32);
                        break;
                }
            }
        }
    
        ~Win32Library() override
        {
            if (mModule)
            {
                FreeLibrary(mModule);
            }
        }
    
        void *getSymbol(const char *symbolName) override
        {
            if (!mModule)
            {
                return nullptr;
            }
    
            return reinterpret_cast<void *>(GetProcAddress(mModule, symbolName));
        }
    
        void *getNative() const override { return reinterpret_cast<void *>(mModule); }
    
      private:
        HMODULE mModule = nullptr;
    };
    
    Library *OpenSharedLibrary(const char *libraryName, SearchType searchType)
    {
        return new Win32Library(libraryName, searchType);
    }
    
    bool IsDirectory(const char *filename)
    {
        WIN32_FILE_ATTRIBUTE_DATA fileInformation;
    
        BOOL result = GetFileAttributesExA(filename, GetFileExInfoStandard, &fileInformation);
        if (result)
        {
            DWORD attribs = fileInformation.dwFileAttributes;
            return (attribs != INVALID_FILE_ATTRIBUTES) && ((attribs & FILE_ATTRIBUTE_DIRECTORY) > 0);
        }
    
        return false;
    }
    
    bool IsDebuggerAttached()
    {
        return !!::IsDebuggerPresent();
    }
    
    void BreakDebugger()
    {
        __debugbreak();
    }
    
    }  // namespace angle