summaryrefslogtreecommitdiff
path: root/UMain.c
blob: 752f640c21cdb41b22eb481e664ec4f35281feb4 (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
96
97
98
99
100
101
102
#include "includes/mwcc_decomp.h"

// TODO split main off into CLStaticMain.c
int main(int argc, const char **argv) {
    CWDataType cpu;
    CWDataType os;
    CWDataType lang;
    CWDataType type;
    CWDataType style;
    int ret;

    if (CmdLine_Initialize(argc, argv, CMDLINE_BUILD_DATE, CMDLINE_BUILD_TIME))
        exit(1);

    if (!RegisterStaticParserResources() || !RegisterStaticTargetResources()) {
        fprintf(stderr, "\nFATAL ERROR:  Could not initialize resource strings\n");
        exit(1);
    }

    if (!RegisterStaticParserPlugins() || !RegisterStaticTargetPlugins()) {
        fprintf(stderr, "\nFATAL ERROR:  Could not initialize built-in plugins\n");
        exit(1);
    }

    if (!RegisterStaticParserToolInfo()) {
        fprintf(stderr, "\nFATAL ERROR:  Could not initialize options\n");
        exit(1);
    }

    GetStaticTarget(&cpu, &os);
    SetBuildTarget(cpu, os);
    GetStaticPluginType(&lang, &type);
    SetPluginType(lang, type);
    GetStaticParserPluginType(&style);
    SetParserType(style);

    ret = CmdLine_Driver();
    if (ret) {
        if (ret == 2)
            fprintf(stderr, "\nUser break, cancelled...\n");
        else
            fprintf(stderr, "\nErrors caused tool to abort.\n");
    }
    CmdLine_Terminate(ret);
    return ret;
}

int RegisterResource(const char *name, short rsrcid, Handle list) {
    Handle h;

    if (data == 0) {
        h = GetResource('STR#', rsrcid);
        if (h == 0) {
            CLFatalError("Resource ('STR#',%d) '%s' not found in executable\n", rsrcid, name);
            return 0;
        }
        ReleaseResource(h);
        return 1;
    } else {
        return Res_AddResource(name, rsrcid, list);
    }
}

int RegisterStaticPlugin(const BasePluginCallbacks *callbacks) {
    return Plugins_Add(Plugin_New(callbacks, 0, 0));
}

int RegisterStaticCompilerLinkerPlugin(const BasePluginCallbacks *callbacks, const CompilerLinkerPluginCallbacks *cl_callbacks) {
    return Plugins_Add(Plugin_New(callbacks, cl_callbacks, 0));
}

int RegisterStaticParserPlugin(const BasePluginCallbacks *callbacks, const ParserPluginCallbacks *pr_callbacks) {
    return Plugins_Add(Plugin_New(callbacks, 0, pr_callbacks));
}

void SetBuildTarget(CWDataType cpu, CWDataType os) {
    clState.cpu = cpu;
    clState.os = os;
}

void SetParserType(CWDataType plang) {
    clState.parserstyle = plang;
}

void SetPluginType(CWDataType lang, CWDataType type) {
    clState.language = lang;
    clState.plugintype = type;
}

int CmdLine_Initialize(int argc, const char **argv, const char *builddate, const char *buildtime) {
    strncpy(cmdline_build_date, builddate, sizeof(cmdline_build_date));
    strncpy(cmdline_build_time, buildtime, sizeof(cmdline_build_time));
    return Main_Initialize(argc, argv);
}

int CmdLine_Driver() {
    return Main_Driver();
}

int CmdLine_Terminate(int exitcode) {
    return Main_Terminate(exitcode);
}