/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ #include #include #include #include #define WIN32_LEAN_AND_MEAN #if defined _MSC_VER #pragma warning(push, 1) #endif #include #if defined _MSC_VER #pragma warning(pop) #endif #include "tools/pathutils.hxx" #define MY_LENGTH(s) (sizeof (s) / sizeof *(s) - 1) #define MY_STRING(s) (s), MY_LENGTH(s) namespace { wchar_t * getBrandPath(wchar_t * path) { DWORD n = GetModuleFileNameW(NULL, path, MAX_PATH); if (n == 0 || n >= MAX_PATH) { exit(EXIT_FAILURE); } return tools::filename(path); } void writeNull() { if (fwrite("\0\0", 1, 2, stdout) != 2) { exit(EXIT_FAILURE); } } void writePath( wchar_t const * frontBegin, wchar_t const * frontEnd, wchar_t const * backBegin, std::size_t backLength) { wchar_t path[MAX_PATH]; wchar_t * end = tools::buildPath( path, frontBegin, frontEnd, backBegin, backLength); if (end == NULL) { exit(EXIT_FAILURE); } std::size_t n = (end - path) * sizeof (wchar_t); if (fwrite(path, 1, n, stdout) != n) { exit(EXIT_FAILURE); } } } #ifdef __MINGW32__ int main(int argc, char ** argv, char **) { if (argc == 2 && strcmp(argv[1], "c++") == 0) { #else int wmain(int argc, wchar_t ** argv, wchar_t **) { if (argc == 2 && wcscmp(argv[1], L"c++") == 0) { #endif wchar_t path[MAX_PATH]; wchar_t * pathEnd = getBrandPath(path); if (tools::buildPath(path, path, pathEnd, MY_STRING(L"..\\basis-link")) == NULL) { exit(EXIT_FAILURE); } pathEnd = tools::resolveLink(path); if (pathEnd == NULL || (tools::buildPath(path, path, pathEnd, MY_STRING(L"\\ure-link")) == NULL)) { exit(EXIT_FAILURE); } pathEnd = tools::resolveLink(path); if (pathEnd == NULL) { exit(EXIT_FAILURE); } writePath(path, pathEnd, MY_STRING(L"\\bin")); #ifdef __MINGW32__ } else if (argc == 2 && strcmp(argv[1], "java") == 0) { #else } else if (argc == 2 && wcscmp(argv[1], L"java") == 0) { #endif if (fwrite("1", 1, 1, stdout) != 1) { exit(EXIT_FAILURE); } wchar_t path[MAX_PATH]; wchar_t * pathEnd = getBrandPath(path); writePath(path, pathEnd, MY_STRING(L"")); if (tools::buildPath(path, path, pathEnd, MY_STRING(L"..\\basis-link")) == NULL) { exit(EXIT_FAILURE); } pathEnd = tools::resolveLink(path); if (pathEnd == NULL) { exit(EXIT_FAILURE); } writeNull(); writePath(path, pathEnd, MY_STRING(L"\\program\\classes\\unoil.jar")); if (tools::buildPath(path, path, pathEnd, MY_STRING(L"\\ure-link")) == NULL) { exit(EXIT_FAILURE); } pathEnd = tools::resolveLink(path); if (pathEnd == NULL) { exit(EXIT_FAILURE); } writeNull(); writePath(path, pathEnd, MY_STRING(L"\\java\\ridl.jar")); writeNull(); writePath(path, pathEnd, MY_STRING(L"\\java\\jurt.jar")); writeNull(); writePath(path, pathEnd, MY_STRING(L"\\java\\juh.jar")); } else { exit(EXIT_FAILURE); } exit(EXIT_SUCCESS); }