shaka-packager/docs/source
Joey Parrish 68b50f656d build: Stop using hermetic clang, libc++, etc
This brings our default build config more in line with what is
necessary for some platforms anyway: using the system-installed
toolchain and sysroot to build everything.

We will no longer fetch source or binaries for any specific build
tools, such as libc++, clang, gold, binutils, or valgrind.

The main part of this change is the changing of default gyp settings
in gyp_packager.py.  For this, a bug in gyp_packager.py had to be
fixed, in which similar GYP_DEFINE key names (such as clang and
host_clang) would conflict, causing some defaults not to be installed
properly.

In order to enable clang=0 by default, some changes had to be made in
common.gypi:
  - compiler macros added to fix a compatibility issue between
    Chromium's base/mac/ folder and the actual OSX SDK
	- replaced clang_warning_flags variables with standard cflags
	  settings, plus xcode_settings for OSX
  - turned off warnings-as-errors for non-shaka code, rather than
		allow-listing specific warning types, since we can't actually fix
    those warnings on any platform
  - disabled two specific warnings in shaka code, both of which are
    caused by headers from our non-shaka dependencies

Also, one warning (missing "override" keyword) has been fixed in
vod_media_info_dump_muxer_listener.h.

Although these changes were done to make building simpler on a wider
array of platforms (arm64, for example), it seems to make the build a
bit faster, too.  For me, at least, on my main Linux workstation:
  - "gclient sync" now runs 20-30% faster
  - "ninja -C out/Release" now runs 5-13% faster

The following environment variables are no longer required:
  - DEPOT_TOOLS_WIN_TOOLCHAIN
  - MACOSX_DEPLOYMENT_TARGET
Documentation, Dockerfiles, and GitHub Actions workflows have been
updated to reflect this.

The following GYP_DEFINES are no longer required for anyone:
  - clang=0
  - host_clang=0
  - clang_xcode=1
  - use_allocator=none
  - use_experimental_allocator_shim=0
Documentation, Dockerfiles, and GitHub Actions workflows have been
updated to reflect this.

The following repos are no longer dependencies in gclient:
  - binutils
  - clang
  - gold
  - libc++
  - libc++abi
  - valgrind

The following gclient hooks have been removed:
  - clang
  - mac_toolchain
  - sysroot

Change-Id: Ie94ccbeec722ab73c291cb7df897d20761a09a70
2021-07-29 13:54:44 -07:00
..
_static Updated style for option list and field list 2017-09-19 14:52:25 -07:00
options Update documentation for text support. 2021-02-17 18:39:07 +00:00
tutorials Properly format the documentation for dash_only and hls_only 2021-06-10 14:21:23 -07:00
build_instructions.md build: Stop using hermetic clang, libc++, etc 2021-07-29 13:54:44 -07:00
conf.py Update Sphinx config for markdown handling 2021-04-09 21:18:06 -07:00
design.rst Added architecture diagram 2017-12-01 00:29:50 +00:00
docker_instructions.md Default multicast interface address to "0.0.0.0" if absent 2017-12-04 19:21:52 +00:00
documentation.rst Add --quiet to suppress LOG(INFO) outputs 2019-10-08 10:20:51 -07:00
index.rst Added architecture diagram 2017-12-01 00:29:50 +00:00
library.rst Update ffmpeg piping with udp and rtp 2017-09-22 15:28:59 -07:00
library_details.rst Update the tutorial and documentation for multi-DRM support. 2018-07-26 06:13:37 +00:00