2021-11-29 22:02:23 +01:00
|
|
|
if(OS_WINDOWS)
|
|
|
|
if(NOT MINGW)
|
|
|
|
add_subdirectory(w32-pthreads)
|
|
|
|
endif()
|
|
|
|
add_subdirectory(ipc-util)
|
|
|
|
|
|
|
|
add_subdirectory(blake2)
|
|
|
|
add_subdirectory(lzma)
|
2015-02-04 05:07:11 +00:00
|
|
|
endif()
|
|
|
|
|
2014-04-14 23:27:52 +02:00
|
|
|
add_subdirectory(glad)
|
2017-03-19 15:31:12 -07:00
|
|
|
add_subdirectory(media-playback)
|
deps/file-updater: Add file updater util. lib
This allows plugins to update and cache data files from a remote source.
Here are the steps that occur when the API initiates an update check:
1.) It checks to see if the local files are greater than the cached
files. If the local version is newer (for whatever reason), it
replaces the cached version(s) with the local version.
2.) A packages.json file is downloaded from the specified URL. That
packages.json file contains a version number and a list of files to
be updated.
3.) If the downloaded package version is greater than the cached
version, executes step 4-5 on each file.
4.) Checks the version for the file to update in packages.json, and if
the version is greater than the cached version, proceeds to step 5,
otherwise repeat step 4-5 for other files.
5.) Calls the callback given to the update function (if any) with the
file information (file name, buffer, etc), and if the callback
returns true, allows the cached file to be updated and replaced,
otherwise goes back to step 4-6 for the rest of the files.
NOTE: Files are never modified directly. All file saving/modification
is performed in a temporary directory, and then files are moved to their
destination. This should eliminate any possibility of file corruption
(or at least dramatically reduce the possibility).
2015-08-19 15:48:04 -07:00
|
|
|
add_subdirectory(file-updater)
|
2017-12-25 14:09:11 -08:00
|
|
|
add_subdirectory(obs-scripting)
|
2021-10-23 05:30:46 -07:00
|
|
|
add_subdirectory(opts-parser)
|
2020-11-02 22:46:55 -06:00
|
|
|
add_subdirectory(libcaption)
|
2016-12-23 09:17:31 -08:00
|
|
|
|
2021-11-29 22:02:23 +01:00
|
|
|
# Use bundled jansson version as fallback
|
2014-05-24 15:46:22 +02:00
|
|
|
find_package(Jansson 2.5 QUIET)
|
2021-11-29 22:02:23 +01:00
|
|
|
if(NOT TARGET Jansson::Jansson)
|
2022-03-25 18:51:41 +01:00
|
|
|
obs_status(STATUS "Jansson >=2.5 not found, building bundled version.")
|
2014-05-24 15:46:22 +02:00
|
|
|
|
2021-11-29 22:02:23 +01:00
|
|
|
add_subdirectory(jansson)
|
|
|
|
add_library(Jansson::Jansson ALIAS jansson)
|
2014-05-24 15:46:22 +02:00
|
|
|
else()
|
2022-03-25 18:51:41 +01:00
|
|
|
obs_status(STATUS "Using system Jansson library.")
|
2014-07-17 18:02:43 +02:00
|
|
|
endif()
|