Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(306)

Unified Diff: public.bzl

Issue 1584563004: Reland of Move BUILD.public to public.bzl. (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « BUILD.public ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: public.bzl
diff --git a/public.bzl b/public.bzl
new file mode 100644
index 0000000000000000000000000000000000000000..33ba89b6fbe510b4eaa69ab3e0eace6928c9f8e5
--- /dev/null
+++ b/public.bzl
@@ -0,0 +1,506 @@
+################################################################################
+# Skylark macros
+################################################################################
+
+is_bazel = not hasattr(native, "genmpm")
+
+def portable_select(select_dict, bazel_condition, default_condition):
+ """Replaces select() with a Bazel-friendly wrapper.
+
+ Args:
+ select_dict: Dictionary in the same format as select().
+ Returns:
+ If Blaze platform, returns select() using select_dict.
+ If Bazel platform, returns dependencies for condition
+ bazel_condition, or empty list if none specified.
+ """
+ if is_bazel:
+ return select_dict.get(bazel_condition, select_dict[default_condition])
+ else:
+ return select(select_dict)
+
+def skia_select(conditions, results):
+ """Replaces select() for conditions [UNIX, ANDROID, IOS]
+
+ Args:
+ conditions: [CONDITION_UNIX, CONDITION_ANDROID, CONDITION_IOS]
+ results: [RESULT_UNIX, RESULT_ANDROID, RESULT_IOS]
+ Returns:
+ The result matching the platform condition.
+ """
+ if len(conditions) != 3 or len(results) != 3:
+ fail("Must provide exactly 3 conditions and 3 results")
+
+ selector = {}
+ for i in range(3):
+ selector[conditions[i]] = results[i]
+ return portable_select(selector, conditions[2], conditions[0])
+
+def skia_glob(srcs):
+ """Replaces glob() with a version that accepts a struct.
+
+ Args:
+ srcs: struct(include=[], exclude=[])
+ Returns:
+ Equivalent of glob(srcs.include, exclude=srcs.exclude)
+ """
+ if hasattr(srcs, 'include'):
+ if hasattr(srcs, 'exclude'):
+ return native.glob(srcs.include, exclude=srcs.exclude)
+ else:
+ return native.glob(srcs.include)
+ return []
+
+################################################################################
+## BASE_SRCS
+################################################################################
+
+# All platform-independent SRCS.
+BASE_SRCS_ALL = struct(
+ include = [
+ "include/private/*.h",
+ "src/**/*.h",
+ "src/**/*.cpp",
+
+ # Third Party
+ "third_party/etc1/*.cpp",
+ "third_party/etc1/*.h",
+ "third_party/ktx/*.cpp",
+ "third_party/ktx/*.h",
+ ],
+ exclude = [
+ # Exclude platform-dependent files.
+ "src/codec/*",
+ "src/device/xps/*", # Windows-only. Move to ports?
+ "src/doc/*_XPS.cpp", # Windows-only. Move to ports?
+ "src/fonts/SkFontMgr_fontconfig.cpp",
+ "src/gpu/gl/android/*",
+ "src/gpu/gl/egl/*",
+ "src/gpu/gl/glx/*",
+ "src/gpu/gl/iOS/*",
+ "src/gpu/gl/mac/*",
+ "src/gpu/gl/win/*",
+ "src/images/*",
+ "src/opts/**/*",
+ "src/ports/**/*",
+ "src/utils/android/**/*",
+ "src/utils/mac/**/*",
+ "src/utils/SkThreadUtils_win.cpp", # Windows-only. Move to ports?
+ "src/utils/win/**/*",
+ "src/views/sdl/*",
+ "src/views/win/*",
+ "src/views/unix/*",
+
+ # Exclude multiple definitions.
+ # TODO(mtklein): Move to opts?
+ "src/doc/SkDocument_PDF_None.cpp", # We use SkDocument_PDF.cpp.
+ "src/gpu/gl/GrGLCreateNativeInterface_none.cpp",
+ "src/gpu/gl/GrGLDefaultInterface_native.cpp",
+
+ # Exclude files that don't compile with the current DEFINES.
+ "src/gpu/gl/angle/*", # Requires SK_ANGLE define.
+ "src/gpu/gl/command_buffer/*", # unknown type name 'HMODULE'
+ "src/gpu/gl/mesa/*", # Requires SK_MESA define.
+ "src/svg/parser/*", # Missing SkSVG.h.
+
+ # Conflicting dependencies among Lua versions. See cl/107087297.
+ "src/utils/SkLua*",
+
+ # Not used.
+ "src/animator/**/*",
+ "src/views/**/*",
+ "src/xml/SkBML_Verbs.h",
+ "src/xml/SkBML_XMLParser.cpp",
+ "src/xml/SkXMLPullParser.cpp",
+ ],
+)
+
+# Platform-dependent SRCS for google3-default platform.
+BASE_SRCS_UNIX = struct(
+ include = [
+ "src/codec/*",
+ "src/fonts/SkFontMgr_fontconfig.cpp",
+ "src/images/*",
+ "src/opts/**/*.cpp",
+ "src/opts/**/*.h",
+ "src/ports/**/*.cpp",
+ "src/ports/**/*.h",
+ ],
+ exclude = [
+ "src/codec/SkJpegCodec.cpp", # libjpeg_turbo version mismatch.
+ "src/opts/*arm*",
+ "src/opts/*mips*",
+ "src/opts/*NEON*",
+ "src/opts/*neon*",
+ # Included in :opts_ssse3 library.
+ "src/opts/*SSSE3*",
+ "src/opts/*ssse3*",
+ # Included in :opts_sse4 library.
+ "src/opts/*SSE4*",
+ "src/opts/*sse4*",
+ # Included in :opts_avx or :opts_avx2
+ "src/opts/*avx*",
+ "src/opts/SkBitmapProcState_opts_none.cpp",
+ "src/opts/SkBlitMask_opts_none.cpp",
+ "src/opts/SkBlitRow_opts_none.cpp",
+ "src/ports/*android*",
+ "src/ports/*chromium*",
+ "src/ports/*mac*",
+ "src/ports/*mozalloc*",
+ "src/ports/*nacl*",
+ "src/ports/*win*",
+ "src/ports/SkFontConfigInterface_direct_factory.cpp",
+ "src/ports/SkFontMgr_custom_directory_factory.cpp",
+ "src/ports/SkFontMgr_custom_embedded_factory.cpp",
+ "src/ports/SkFontMgr_empty_factory.cpp",
+ "src/ports/SkFontMgr_fontconfig.cpp",
+ "src/ports/SkImageDecoder_CG.cpp",
+ "src/ports/SkFontMgr_fontconfig_factory.cpp",
+ "src/ports/SkImageDecoder_WIC.cpp",
+ "src/ports/SkImageDecoder_empty.cpp",
+ "src/ports/SkImageGenerator_none.cpp",
+ "src/ports/SkTLS_none.cpp",
+ ],
+)
+
+# Platform-dependent SRCS for google3-default Android.
+BASE_SRCS_ANDROID = struct(
+ include = [
+ "src/codec/*",
+ "src/images/*",
+ # TODO(benjaminwagner): Figure out how to compile with EGL.
+ "src/opts/**/*.cpp",
+ "src/opts/**/*.h",
+ "src/ports/**/*.cpp",
+ "src/ports/**/*.h",
+ ],
+ exclude = [
+ "src/codec/SkJpegCodec.cpp", # libjpeg_turbo version mismatch.
+ "src/opts/*mips*",
+ "src/opts/*SSE2*",
+ "src/opts/*SSSE3*",
+ "src/opts/*ssse3*",
+ "src/opts/*SSE4*",
+ "src/opts/*sse4*",
+ "src/opts/*avx*",
+ "src/opts/*x86*",
+ "src/opts/SkBitmapProcState_opts_none.cpp",
+ "src/opts/SkBlitMask_opts_none.cpp",
+ "src/opts/SkBlitRow_opts_none.cpp",
+ "src/ports/*chromium*",
+ "src/ports/*fontconfig*",
+ "src/ports/*FontConfig*",
+ "src/ports/*mac*",
+ "src/ports/*mozalloc*",
+ "src/ports/*nacl*",
+ "src/ports/*win*",
+ "src/ports/SkDebug_stdio.cpp",
+ "src/ports/SkFontConfigInterface_direct_factory.cpp",
+ "src/ports/SkFontConfigInterface_direct_google3_factory.cpp",
+ "src/ports/SkFontMgr_custom_directory_factory.cpp",
+ "src/ports/SkFontMgr_custom_embedded_factory.cpp",
+ "src/ports/SkFontMgr_empty_factory.cpp",
+ "src/ports/SkImageDecoder_CG.cpp",
+ "src/ports/SkImageDecoder_WIC.cpp",
+ "src/ports/SkImageDecoder_empty.cpp",
+ "src/ports/SkImageGenerator_none.cpp",
+ "src/ports/SkTLS_none.cpp",
+ ],
+)
+
+# Platform-dependent SRCS for google3-default iOS.
+BASE_SRCS_IOS = struct(
+ include = [
+ "src/opts/**/*.cpp",
+ "src/opts/**/*.h",
+ "src/ports/**/*.cpp",
+ "src/ports/**/*.h",
+ ],
+ exclude = [
+ "src/opts/*mips*",
+ "src/opts/*NEON*",
+ "src/opts/*neon*",
+ "src/opts/*SSE2*",
+ "src/opts/*SSSE3*",
+ "src/opts/*ssse3*",
+ "src/opts/*SSE4*",
+ "src/opts/*sse4*",
+ "src/opts/*avx*",
+ "src/opts/*x86*",
+ "src/opts/SkBitmapProcState_opts_none.cpp",
+ "src/opts/SkBlitMask_opts_none.cpp",
+ "src/opts/SkBlitRow_opts_none.cpp",
+ "src/ports/*android*",
+ "src/ports/*chromium*",
+ "src/ports/*fontconfig*",
+ "src/ports/*FontConfig*",
+ "src/ports/*FreeType*",
+ "src/ports/*mozalloc*",
+ "src/ports/*nacl*",
+ "src/ports/*win*",
+ "src/ports/SkDebug_stdio.cpp",
+ "src/ports/SkFontMgr_custom.cpp",
+ "src/ports/SkFontConfigInterface_direct_factory.cpp",
+ "src/ports/SkFontConfigInterface_direct_google3_factory.cpp",
+ "src/ports/SkFontMgr_custom_directory_factory.cpp",
+ "src/ports/SkFontMgr_custom_embedded_factory.cpp",
+ "src/ports/SkFontMgr_empty_factory.cpp",
+ "src/ports/SkImageDecoder_CG.cpp",
+ "src/ports/SkImageDecoder_WIC.cpp",
+ "src/ports/SkImageDecoder_empty.cpp",
+ "src/ports/SkImageGenerator_none.cpp",
+ "src/ports/SkTLS_none.cpp",
+ ],
+)
+
+################################################################################
+## SSSE3/SSE4/AVX/AVX2 SRCS
+################################################################################
+
+SSSE3_SRCS = struct(
+ include = [
+ "src/opts/*SSSE3*.cpp",
+ "src/opts/*ssse3*.cpp",
+ ])
+
+SSE4_SRCS = struct(
+ include = [
+ "src/opts/*SSE4*.cpp",
+ "src/opts/*sse4*.cpp",
+ ])
+
+AVX_SRCS = struct(
+ include = [
+ "src/opts/*_avx.cpp",
+ ])
+
+AVX2_SRCS = struct(
+ include = [
+ "src/opts/*_avx2.cpp",
+ ])
+
+################################################################################
+## BASE_HDRS
+################################################################################
+
+BASE_HDRS = struct(
+ include = [
+ "include/**/*.h",
+ ],
+ exclude = [
+ "include/private/**/*",
+
+ # Not used.
+ "include/animator/**/*",
+ "include/views/**/*",
+ "include/xml/SkBML_WXMLParser.h",
+ "include/xml/SkBML_XMLParser.h",
+ ])
+
+################################################################################
+## BASE_DEPS
+################################################################################
+
+BASE_DEPS_ALL = []
+
+BASE_DEPS_UNIX = [
+ ":opts_ssse3",
+ ":opts_sse4",
+ ":opts_avx",
+ ":opts_avx2",
+]
+
+BASE_DEPS_ANDROID = []
+
+BASE_DEPS_IOS = []
+
+################################################################################
+## INCLUDES
+################################################################################
+
+# Includes needed by Skia implementation. Not public includes.
+INCLUDES = [
+ "include/android",
+ "include/c",
+ "include/codec",
+ "include/config",
+ "include/core",
+ "include/effects",
+ "include/gpu",
+ "include/images",
+ "include/pathops",
+ "include/pipe",
+ "include/ports",
+ "include/private",
+ "include/utils",
+ "include/utils/mac",
+ "include/utils/win",
+ "include/svg",
+ "include/xml",
+ "src/codec",
+ "src/core",
+ "src/gpu",
+ "src/image",
+ "src/lazy",
+ "src/opts",
+ "src/ports",
+ "src/pdf",
+ "src/sfnt",
+ "src/utils",
+ "third_party/etc1",
+ "third_party/ktx",
+]
+
+################################################################################
+## DM_SRCS
+################################################################################
+
+DM_SRCS_ALL = struct(
+ include = [
+ "dm/*.cpp",
+ "dm/*.h",
+ "gm/*.c",
+ "gm/*.cpp",
+ "gm/*.h",
+ "tests/*.cpp",
+ "tests/*.h",
+ "tools/CrashHandler.cpp",
+ "tools/CrashHandler.h",
+ "tools/LazyDecodeBitmap.cpp",
+ "tools/LazyDecodeBitmap.h",
+ "tools/ProcStats.cpp",
+ "tools/ProcStats.h",
+ "tools/Resources.cpp",
+ "tools/Resources.h",
+ "tools/SkBitmapRegionCanvas.cpp",
+ "tools/SkBitmapRegionCanvas.h",
+ "tools/SkBitmapRegionCodec.cpp",
+ "tools/SkBitmapRegionCodec.h",
+ "tools/SkBitmapRegionDecoder.cpp",
+ "tools/SkBitmapRegionDecoder.h",
+ "tools/SkBitmapRegionSampler.cpp",
+ "tools/SkBitmapRegionSampler.h",
+ "tools/flags/*.cpp",
+ "tools/flags/*.h",
+ "tools/sk_tool_utils.cpp",
+ "tools/sk_tool_utils.h",
+ "tools/sk_tool_utils_font.cpp",
+ "tools/timer/*.cpp",
+ "tools/timer/*.h",
+ ],
+ exclude = [
+ "dm/DMSrcSinkAndroid.cpp", # Android-only.
+ "tests/FontMgrAndroidParserTest.cpp", # Android-only.
+ "tests/PathOpsSkpClipTest.cpp", # Alternate main.
+ "tests/skia_test.cpp", # Old main.
+ "tests/SkpSkGrTest.cpp", # Alternate main.
+ "tools/timer/SysTimer_mach.cpp",
+ "tools/timer/SysTimer_windows.cpp",
+ ],
+)
+
+DM_SRCS_UNIX = struct()
+
+DM_SRCS_ANDROID = struct(
+ include = [
+ # Depends on Android HWUI library that is not available in google3.
+ #"dm/DMSrcSinkAndroid.cpp",
+ "tests/FontMgrAndroidParserTest.cpp",
+ ],
+)
+
+DM_SRCS_IOS = struct()
+
+################################################################################
+## DM_INCLUDES
+################################################################################
+
+DM_INCLUDES = [
+ "gm",
+ "src/codec",
+ "src/effects",
+ "src/fonts",
+ "src/pathops",
+ "src/pipe/utils",
+ "src/ports",
+ "src/utils/debugger",
+ "tests",
+ "tools",
+ "tools/flags",
+ "tools/timer",
+]
+
+################################################################################
+## DM_ARGS
+################################################################################
+
+def DM_ARGS(base_dir):
+ return [
+ "--nogpu",
+ "--verbose",
+ # TODO(mtklein): maybe investigate why these fail?
+ "--match ~FontMgr ~Scalar ~Canvas ~Codec_stripes ~Codec_Dimensions ~Codec ~Stream ~skps ~RecordDraw_TextBounds",
+ "--resourcePath %s/resources" % base_dir,
+ "--images %s/resources" % base_dir,
+ ]
+
+################################################################################
+## COPTS
+################################################################################
+
+COPTS_UNIX = [
+ "-Wno-implicit-fallthrough", # Some intentional fallthrough.
+ "-Wno-deprecated-declarations", # Internal use of deprecated methods. :(
+]
+
+COPTS_ANDROID = ["-mfpu=neon"]
+
+COPTS_IOS = []
+
+COPTS_ALL = []
+
+################################################################################
+## DEFINES
+################################################################################
+
+DEFINES_UNIX = [
+ "SK_BUILD_FOR_UNIX",
+ "SK_SAMPLES_FOR_X",
+ "SK_SFNTLY_SUBSETTER",
+]
+
+DEFINES_ANDROID = [
+ "SK_BUILD_FOR_ANDROID",
+ # TODO(benjaminwagner): Try to get png library updated?
+ "SK_PNG_NO_INDEX_SUPPORTED",
+]
+
+DEFINES_IOS = [
+ "SK_BUILD_FOR_IOS",
+ "SK_IGNORE_ETC1_SUPPORT",
+]
+
+DEFINES_ALL = [
+ # Chrome DEFINES.
+ "SK_USE_FLOATBITS",
+ "SK_USE_FREETYPE_EMBOLDEN",
+ # Turn on a few Google3-specific build fixes.
+ "GOOGLE3",
+]
+
+################################################################################
+## LINKOPTS
+################################################################################
+
+LINKOPTS_UNIX = []
+
+LINKOPTS_ANDROID = [
+ "-lEGL",
+]
+
+LINKOPTS_IOS = []
+
+LINKOPTS_ALL = [
+ "-ldl",
+]
+
« no previous file with comments | « BUILD.public ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698