summaryrefslogtreecommitdiffstats
path: root/source/core/slang-test-tool-util.h
blob: 24116611192f4682eb460f96089f853c7b7a8c6f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#ifndef SLANG_CORE_TEST_TOOL_UTIL_H
#define SLANG_CORE_TEST_TOOL_UTIL_H

#include "slang-std-writers.h"

namespace Slang
{

#ifdef SLANG_SHARED_LIBRARY_TOOL
#define SLANG_TEST_TOOL_API SLANG_EXTERN_C SLANG_DLL_EXPORT
#else
#define SLANG_TEST_TOOL_API
#endif

/* When a tool is run as an executable the return code is the code returned from
the last return of main. On unix this can be up to 8 bits.
By normal command line tool conventions returning 0 means success. */
enum class ToolReturnCode
{
    CompilationFailed = -1, ///< Compilation failure (-1 to maintain compatibility). This may still
                            ///< produce output and may mean a test was successful.
    Success = 0,            ///< Tool ran normally
    Failed,                 ///< Tool failed
    Ignored, ///< The run was ignored because it couldn't be run (because some optional feature was
             ///< not present for example)
    FailedToRun, ///< Could not even run the test
};

enum class ToolReturnCodeSpan
{
    // Span of all valid values
    First = int(ToolReturnCode::CompilationFailed),
    Last = int(ToolReturnCode::FailedToRun),
    // Span of all values that indicate the test is 'done'
    FirstIsDone = int(ToolReturnCode::Ignored),
    LastIsDone = int(ToolReturnCode::FailedToRun)
};

/* Utility functions for 'test tools' */
struct TestToolUtil
{
    typedef SlangResult (*InnerMainFunc)(
        Slang::StdWriters* stdWriters,
        SlangSession* session,
        int argc,
        const char* const* argv);

    /// If the test failed to run or was ignored then we are done
    static bool isDone(ToolReturnCode code)
    {
        return int(code) >= int(ToolReturnCodeSpan::FirstIsDone) &&
               int(code) <= int(ToolReturnCodeSpan::LastIsDone);
    }

    /// Convert from an int
    static ToolReturnCode getReturnCodeFromInt(int code);

    /// Given a slang result, returns a return code that can be returned from an executable
    static ToolReturnCode getReturnCode(SlangResult res);

    /// Given the executable path (as located in Slang directory hierarchy), works out the absolute
    /// path to the root
    static SlangResult getRootPath(const char* exePath, String& outRootPath);

    /// Given the exePath, give return the absolute path to the directory the exe is in
    static SlangResult getExeDirectoryPath(const char* exePath, String& outExeDirectoryPath);

    /// Sets the default preludes on the session based on an explicit path
    static SlangResult setSessionDefaultPreludeFromRootPath(
        const String& rootPath,
        slang::IGlobalSession* session);

    /// Calculates the path that is the combination of parentPath, and relPath
    /// And converts such that can be used as an include path (handling slashes)
    static SlangResult getIncludePath(
        const String& parentPath,
        const char* relPath,
        String& outIncludePath);


    /// Sets the default preludes on the session based on the executable path
    static SlangResult setSessionDefaultPreludeFromExePath(
        const char* exePath,
        slang::IGlobalSession* session);

    /// Returns true if the core module should not be initialized immediately (eg when doing a
    /// -load-core-module).
    static bool hasDeferredCoreModule(Index numArgs, const char* const* args);

    static SlangResult getDllDirectoryPath(const char* exePath, String& outDllDirectoryPath);
};

} // namespace Slang

#endif // SLANG_TEST_TOOL_H