mirror of
https://github.com/microsoft/vcpkg.git
synced 2025-01-13 06:28:41 +08:00
11b4a16bca
* fix build issues occurring from default bazel config being used because customized bazel config is stored in wrong directory * [tensorflow-cc] Update CONTROL and ci.baseline.txt * fix also applies to windows static build * fix debug and static builds as well as library naming for non-linux - add patch to fix debug builds - add patch to fix exports for static linking - really build debug (instead of cloning release) - override bazel build options for debug (work around bazel bug) - bazel doesn't support static libraries: work around by building dynamic library and constructing static linkage commands from build log - Windows .pdb file can't be >4GB even on x64: work around using reduced debug information - Windows doesn't support .lib files >4GB even on x64, so split into multiple libs - vcpkg requires equal amount of libs for debug and release: work around using handcrafted empty dummy libs - fix naming of libs (.dll on Windows and .dylib on macOS) * upgrade tensorflow from v1.14 to v2.3 - adapt patch files to tensorflow code changes - update bazel from v0.25.2 to v3.1 - on Windows use python installed on the host instead of embedded python obtained via vcpkg because embedded python lacks pip, which we need to obtain numpy - on Windows add MSYS2 to the PATH so that bazel tools can access MSYS2 GIT - add support for custom CA certificates when using HTTPS_PROXY * fix execute process macro The existing implementation totally screwed up commands if the command's arguments contained semicolons (this is the case, e.g., in the FindPython modules of the cmake distribution). * extend overriden execute_process to more than one COMMAND as there actually are use cases for this * added another patch required for tensorflow v2.3, fixed path and working directory * Revert "incorporate changes from microsoft:master" * Revert "Revert "incorporate changes from microsoft:master"" * final fixes for static build + improving out messages * enabling linux and osx in CI to see if it works now * simplified code, fixed version numbers, fixed generated include cmake file * fix failing postbuild check on handcrafted empty dummy library by spreading the last real libraries contents over the required number of libraries * remove dead code commit by mistake again * improvements from code review * cleaner fix for debug code * find pip3 in PATH (PYTHON3_DIR apparently not valid for pip3) * fix error in python helper script * fix wrong libname in postbuild script * fix python detection + switch to python on msys2 (instead of embedded python) for Windows as we need numpy * fix order of arguments * fix command (it may contain spaces such as C:\Program Files\...) * revert last commit (root cause for CI failures is something different: there are line breaks in path) * fix regex comparision (value needs to be escaped as it may contains regex special characters such as brackets, eg C:/Program Files (x86)/...) * fix linebreaks in generated file * fix CRT linkage (macOS doesn't support static CRT linkage; it's set to dynamic even static target triplets for macOS and linux) * refactor implemenation to avoid as much code duplication as possible -- algorithmically identical * fix version numbers in helper scripts * enable work-around for Windows until bazel fix is available * install missing python3-pip on linux * fix linux build by patching * apply timeout feature now available via merged master branch * correct linux build patch * improve debug build patches (no functional difference because LOG(FATAL, ...) macro internally anyway calls abort(), which the compiler doesn't detect in debug mode... * improve linux patch * temporarily add debug to inspect what's going on on macOS CI * remove temporary debug code and fix static linking scripts for linux and macOS * fix regex escaping * fix ambiguous match while grepping for the framework link command * extend fix of ambiguous match while grepping for the framework link command * fix what merge of master broke * fix more what got broken by merging master (all packages and their dependencies are now maintained manually instead of using pacman...) * remove "unofficial" from filename * added switch do distinct classic and manifest mode when generating config.cmake file * create symlinks for libraries without version number * fix linux postbuild script * temporarily disable code making problems * add note for linking on Linux and macOS * forget to add README file in previous commit * add file forgotton in macro fixing patch * fix python library path * fix macOS static link command * update linkage instructions in README * Update ports/tensorflow-cc/CONTROL * Update ports/tensorflow-cc/portfile.cmake * Update scripts/ci.baseline.txt * use vcpkg_execute_required_process * pass C_FLAGS and CXX_FLAGS to bazel * fix INTERFACE_INCLUDE_DIRECTORIES * fix optional c/cxx arguments * also add linker opts * update README * merge static libs into one to support force_load (cannot force_load both due to duplicate symbols) * update README * quote python path (it might contain spaces that don't get escaped inside outer quotes of bash command) * fix python path also for static build * add arm(64) as currently unsupported arch * bazel 3.7 is available -> remove workaround * update README, remove necessary c-ares from deps * update msys package * add uwp specific options, and minor general improvements * fix string replace * fix control file and windows path separator * revert backslashes-fix -- the root cause was missing .exe extension * upgrade to tf 2.3.1 * fix hard-coded version * remove uwp work-in-progress code so that PR can be merged * update README and print out usage info in portfile * Update ports/tensorflow-cc/README-linux Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/README-linux Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/README-linux Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/README-linux Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/README-linux Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/README-windows Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/portfile.cmake Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/portfile.cmake Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/portfile.cmake Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/portfile.cmake Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/portfile.cmake Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * improve usage hints as discussed in review * add comment * apply changes from review * make additional compiler / linker args space-proof * Update ports/tensorflow-cc/README-macos Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/tensorflow-cc-config-shared.cmake.in Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/tensorflow-cc-config-shared.cmake.in Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/README-linux Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * Update ports/tensorflow-cc/README-macos Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * apply changes from code review * maybe fix the config files * rob.maynard CRs * fix windows static lib naming for first part * Update ports/tensorflow-cc/generate_static_link_cmd_windows.py Co-authored-by: nicole mazzuca <mazzucan@outlook.com> * apply rob maynards 1st suggestion * nicole CRs * format/fix-compile * fix missing string termination * prefer IMPORTED_LOCATION over IMPORTED_LOCATION_RELEASE to have default fall-back * hopefully fix the issue where no libraries are generated * final stuff Co-authored-by: Gehweiler <Joachim_Gehweiler@McAfee.com> Co-authored-by: wangli28 <wangli28@beyondsoft.com> Co-authored-by: Jack·Boos·Yu <47264268+JackBoosY@users.noreply.github.com> Co-authored-by: Joachim Gehweiler <joachim@Joachims-iMac.local> Co-authored-by: nicole mazzuca <mazzucan@outlook.com>
267 lines
7.3 KiB
Diff
267 lines
7.3 KiB
Diff
diff --git a/tensorflow/core/platform/macros.h b/tensorflow/core/platform/macros.h
|
|
--- a/tensorflow/core/platform/macros.h
|
|
+++ b/tensorflow/core/platform/macros.h
|
|
@@ -57,16 +57,7 @@
|
|
#define TF_SCANF_ATTRIBUTE(string_index, first_to_check)
|
|
#endif
|
|
|
|
-// Control visibility outside .so
|
|
-#if defined(_WIN32)
|
|
-#ifdef TF_COMPILE_LIBRARY
|
|
-#define TF_EXPORT __declspec(dllexport)
|
|
-#else
|
|
-#define TF_EXPORT __declspec(dllimport)
|
|
-#endif // TF_COMPILE_LIBRARY
|
|
-#else
|
|
-#define TF_EXPORT __attribute__((visibility("default")))
|
|
-#endif // _WIN32
|
|
+#define TF_EXPORT
|
|
|
|
#ifdef __has_builtin
|
|
#define TF_HAS_BUILTIN(x) __has_builtin(x)
|
|
|
|
diff --git a/tensorflow/c/c_api.h b/tensorflow/c/c_api.h
|
|
--- a/tensorflow/c/c_api.h
|
|
+++ b/tensorflow/c/c_api.h
|
|
@@ -70,24 +70,7 @@
|
|
// and the API just provides high level controls over the number of
|
|
// devices of each type.
|
|
|
|
-// Macro to control visibility of exported symbols in the shared library (.so,
|
|
-// .dylib, .dll).
|
|
-// This duplicates the TF_EXPORT macro definition in
|
|
-// tensorflow/core/platform/macros.h in order to keep this .h file independent
|
|
-// of any other includes.
|
|
-#ifdef SWIG
|
|
#define TF_CAPI_EXPORT
|
|
-#else
|
|
-#if defined(_WIN32)
|
|
-#ifdef TF_COMPILE_LIBRARY
|
|
-#define TF_CAPI_EXPORT __declspec(dllexport)
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __declspec(dllimport)
|
|
-#endif // TF_COMPILE_LIBRARY
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __attribute__((visibility("default")))
|
|
-#endif // _WIN32
|
|
-#endif // SWIG
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
|
|
diff --git a/tensorflow/c/c_api_experimental.h b/tensorflow/c/c_api_experimental.h
|
|
--- a/tensorflow/c/c_api_experimental.h
|
|
+++ b/tensorflow/c/c_api_experimental.h
|
|
@@ -28,24 +28,7 @@
|
|
// The API here is subject to changes in the future.
|
|
// --------------------------------------------------------------------------
|
|
|
|
-// Macro to control visibility of exported symbols in the shared library (.so,
|
|
-// .dylib, .dll).
|
|
-// This duplicates the TF_EXPORT macro definition in
|
|
-// tensorflow/core/platform/macros.h in order to keep this .h file independent
|
|
-// of any other includes.$a
|
|
-#ifdef SWIG
|
|
#define TF_CAPI_EXPORT
|
|
-#else
|
|
-#if defined(_WIN32)
|
|
-#ifdef TF_COMPILE_LIBRARY
|
|
-#define TF_CAPI_EXPORT __declspec(dllexport)
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __declspec(dllimport)
|
|
-#endif // TF_COMPILE_LIBRARY
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __attribute__((visibility("default")))
|
|
-#endif // _WIN32
|
|
-#endif // SWIG
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
|
|
diff --git a/tensorflow/c/c_api_macros.h b/tensorflow/c/c_api_macros.h
|
|
--- a/tensorflow/c/c_api_macros.h
|
|
+++ b/tensorflow/c/c_api_macros.h
|
|
@@ -16,18 +16,6 @@
|
|
#ifndef TENSORFLOW_C_C_API_MACROS_H_
|
|
#define TENSORFLOW_C_C_API_MACROS_H_
|
|
|
|
-#ifdef SWIG
|
|
#define TF_CAPI_EXPORT
|
|
-#else
|
|
-#if defined(_WIN32)
|
|
-#ifdef TF_COMPILE_LIBRARY
|
|
-#define TF_CAPI_EXPORT __declspec(dllexport)
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __declspec(dllimport)
|
|
-#endif // TF_COMPILE_LIBRARY
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __attribute__((visibility("default")))
|
|
-#endif // _WIN32
|
|
-#endif // SWIG
|
|
|
|
#endif // TENSORFLOW_C_C_API_MACROS_H_
|
|
|
|
diff --git a/tensorflow/c/kernels.h b/tensorflow/c/kernels.h
|
|
--- a/tensorflow/c/kernels.h
|
|
+++ b/tensorflow/c/kernels.h
|
|
@@ -21,24 +21,7 @@
|
|
#include "tensorflow/c/tf_datatype.h"
|
|
#include "tensorflow/c/tf_status.h"
|
|
|
|
-// Macro to control visibility of exported symbols in the shared library (.so,
|
|
-// .dylib, .dll).
|
|
-// This duplicates the TF_EXPORT macro definition in
|
|
-// tensorflow/core/platform/macros.h in order to keep this .h file independent
|
|
-// of any other includes.
|
|
-#ifdef SWIG
|
|
#define TF_CAPI_EXPORT
|
|
-#else
|
|
-#if defined(_WIN32)
|
|
-#ifdef TF_COMPILE_LIBRARY
|
|
-#define TF_CAPI_EXPORT __declspec(dllexport)
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __declspec(dllimport)
|
|
-#endif // TF_COMPILE_LIBRARY
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __attribute__((visibility("default")))
|
|
-#endif // _WIN32
|
|
-#endif // SWIG
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
|
|
diff --git a/tensorflow/c/ops.h b/tensorflow/c/ops.h
|
|
--- a/tensorflow/c/ops.h
|
|
+++ b/tensorflow/c/ops.h
|
|
@@ -76,19 +76,7 @@
|
|
#include "tensorflow/c/tf_datatype.h"
|
|
#include "tensorflow/c/tf_status.h"
|
|
|
|
-#ifdef SWIG
|
|
#define TF_CAPI_EXPORT
|
|
-#else
|
|
-#if defined(_WIN32)
|
|
-#ifdef TF_COMPILE_LIBRARY
|
|
-#define TF_CAPI_EXPORT __declspec(dllexport)
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __declspec(dllimport)
|
|
-#endif // TF_COMPILE_LIBRARY
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __attribute__((visibility("default")))
|
|
-#endif // _WIN32
|
|
-#endif // SWIG
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
|
|
diff --git a/tensorflow/c/tf_datatype.h b/tensorflow/c/tf_datatype.h
|
|
--- a/tensorflow/c/tf_datatype.h
|
|
+++ b/tensorflow/c/tf_datatype.h
|
|
@@ -18,24 +18,7 @@
|
|
|
|
#include <stddef.h>
|
|
|
|
-// Macro to control visibility of exported symbols in the shared library (.so,
|
|
-// .dylib, .dll).
|
|
-// This duplicates the TF_EXPORT macro definition in
|
|
-// tensorflow/core/platform/macros.h in order to keep this .h file independent
|
|
-// of any other includes.
|
|
-#ifdef SWIG
|
|
#define TF_CAPI_EXPORT
|
|
-#else
|
|
-#if defined(_WIN32)
|
|
-#ifdef TF_COMPILE_LIBRARY
|
|
-#define TF_CAPI_EXPORT __declspec(dllexport)
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __declspec(dllimport)
|
|
-#endif // TF_COMPILE_LIBRARY
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __attribute__((visibility("default")))
|
|
-#endif // _WIN32
|
|
-#endif // SWIG
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
|
|
diff --git a/tensorflow/c/tf_status.h b/tensorflow/c/tf_status.h
|
|
--- a/tensorflow/c/tf_status.h
|
|
+++ b/tensorflow/c/tf_status.h
|
|
@@ -16,19 +16,7 @@
|
|
#ifndef TENSORFLOW_C_TF_STATUS_H_
|
|
#define TENSORFLOW_C_TF_STATUS_H_
|
|
|
|
-#ifdef SWIG
|
|
#define TF_CAPI_EXPORT
|
|
-#else
|
|
-#if defined(_WIN32)
|
|
-#ifdef TF_COMPILE_LIBRARY
|
|
-#define TF_CAPI_EXPORT __declspec(dllexport)
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __declspec(dllimport)
|
|
-#endif // TF_COMPILE_LIBRARY
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __attribute__((visibility("default")))
|
|
-#endif // _WIN32
|
|
-#endif // SWIG
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
|
|
diff --git a/tensorflow/c/tf_tensor.h b/tensorflow/c/tf_tensor.h
|
|
--- a/tensorflow/c/tf_tensor.h
|
|
+++ b/tensorflow/c/tf_tensor.h
|
|
@@ -22,24 +22,7 @@
|
|
#include "tensorflow/c/tf_datatype.h"
|
|
#include "tensorflow/c/tf_status.h"
|
|
|
|
-// Macro to control visibility of exported symbols in the shared library (.so,
|
|
-// .dylib, .dll).
|
|
-// This duplicates the TF_EXPORT macro definition in
|
|
-// tensorflow/core/platform/macros.h in order to keep this .h file independent
|
|
-// of any other includes.
|
|
-#ifdef SWIG
|
|
#define TF_CAPI_EXPORT
|
|
-#else
|
|
-#if defined(_WIN32)
|
|
-#ifdef TF_COMPILE_LIBRARY
|
|
-#define TF_CAPI_EXPORT __declspec(dllexport)
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __declspec(dllimport)
|
|
-#endif // TF_COMPILE_LIBRARY
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __attribute__((visibility("default")))
|
|
-#endif // _WIN32
|
|
-#endif // SWIG
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
|
|
diff --git a/tensorflow/c/eager/c_api.h b/tensorflow/c/eager/c_api.h
|
|
--- a/tensorflow/c/eager/c_api.h
|
|
+++ b/tensorflow/c/eager/c_api.h
|
|
@@ -22,24 +22,7 @@
|
|
|
|
#include "tensorflow/c/c_api.h"
|
|
|
|
-// Macro to control visibility of exported symbols in the shared library (.so,
|
|
-// .dylib, .dll).
|
|
-// This duplicates the TF_EXPORT macro definition in
|
|
-// tensorflow/core/platform/macros.h in order to keep this .h file independent
|
|
-// of any other includes.$a
|
|
-#ifdef SWIG
|
|
#define TF_CAPI_EXPORT
|
|
-#else
|
|
-#if defined(_WIN32)
|
|
-#ifdef TF_COMPILE_LIBRARY
|
|
-#define TF_CAPI_EXPORT __declspec(dllexport)
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __declspec(dllimport)
|
|
-#endif // TF_COMPILE_LIBRARY
|
|
-#else
|
|
-#define TF_CAPI_EXPORT __attribute__((visibility("default")))
|
|
-#endif // _WIN32
|
|
-#endif // SWIG
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|