depsync
v1.4.5
Published
Automatically synchronize the dependencies of a project by the DEPS configuration file.
Readme
Introduction
A command line tool for automatically synchronizing the dependencies of a project by the DEPS configuration file.
Advantages
The depsync tool provides a convenient way to download git repositories and files from the Internet, offering several key advantages over similar capabilities like git-submodules and git-lfs:
- Repositories are always checked out with a depth of 1 without any extra command arguments, ensuring that the main project maintains a relatively compact size at all times.
- Automatically download git-submodules and git-lfs files for your main project and third-party repositories without the need to run commands on each one individually.
- During downloading process, git-lfs files that already exist in the local cache can be skipped. This approach works even for the shallow cloned repositories.
- Enable the execution of custom actions after synchronization. For instance, you can include commands in the DEPS file to facilitate cleaning tasks and other operations.
- Repositories and files can be configured separately for each platform to avoid downloading unnecessary dependencies and only acquire platform-specific ones.
With all the advantages described above, all it takes is one straightforward command depsync. Execute it in the root of your main project, and you're good to go!
Installation
npm install depsync -g
Usage
Run the following command in the directory with a DEPS file:
depsync [platform] [options]Basic Usage
For example, if you want to synchronize the mac platform, run:
depsync macIf you don't pass any platform parameter, it will automatically choose the host platform as the target platform. So the result of running depsync in macOS is the same to running depsync mac.
The available platform names are defined in the DEPS file, you can also define any other platform names as you want, such as ios, android... but only the mac, win and linux can be automatically chosen.
Command Line Options
-h, --help
Print help message with available options.
depsync --help-v, --version
Print the current version of depsync.
depsync --version-p, --project <directory>
Synchronize the project in the specified directory instead of the current directory.
depsync --project /path/to/your/project
depsync mac --project /usr/local/myproject-c, --clean
Clean the repos and files in current directory that do not exist in the DEPS file. This helps remove outdated dependencies.
depsync --clean--non-recursive
Skip synchronizing the sub-projects. By default, depsync will recursively process DEPS files in all sub-repositories.
depsync --non-recursive
depsync mac --non-recursive--mirror <mappings>
Redirect repository and file URLs to mirror sources. This is particularly useful when:
- Using mirror repositories instead of original ones
- Redirecting to internal corporate repositories
- The replacement applies recursively to all sub-repositories
Format: 'old_prefix->new_prefix' for single mapping, or 'old1->new1,old2->new2' for multiple mappings.
# Single mirror
depsync --mirror 'https://github.com/->https://gitee.com/'
# Multiple mirrors (comma-separated)
depsync --mirror 'https://github.com/->https://gitee.com/,https://gitlab.com/->https://internal.company.com/'
# With platform
depsync mac --mirror 'https://github.com/->https://mirror.example.com/'The mirror option will replace URL prefixes for both repository URLs and file download URLs throughout the entire dependency tree.
DEPS File Format
Here is an example of DEPS file:
{
"version": "1.4.5",
"vars": {
"GIT_DOMAIN": "github.com",
"SKIA_ROOT": "https://github.com/domchen/depsync/releases/download/1.0.1",
"V8_ROOT": "https://github.com/domchen/depsync/releases/download/1.0.2"
},
"repos": {
"common": [
{
"url": "https://${GIT_DOMAIN}/webmproject/libwebp.git",
"commit": "1fe3162541ab2f5ce69aca2e2b593fab60520d34",
"dir": "third_party/libwebp"
},
{
"url": "https://${GIT_DOMAIN}/libjpeg-turbo/libjpeg-turbo.git",
"commit": "129f0cb76346ceede8f4d8d87dea8acb0809056c",
"dir": "third_party/libjpeg-turbo"
},
{
"url": "https://${GIT_DOMAIN}/Tencent/tgfx.git",
"commit": "5948d72a0a5320a1ea055f23bc8312b07ab6d72c",
"dir": "third_party/tgfx"
}
]
},
"files": {
"common": [
{
"url": "${SKIA_ROOT}/include.zip",
"dir": "third_party/skia",
"unzip": true
},
{
"url": "${V8_ROOT}/include.zip",
"dir": "third_party/v8",
"unzip": "true"
}
],
"mac": [
{
"url": "${SKIA_ROOT}/darwin-x64.zip",
"dir": "third_party/skia",
"unzip": true
},
{
"url": "${V8_ROOT}/darwin-x64.zip",
"multipart": [
".001",
".002",
".003"
],
"dir": "third_party/v8",
"unzip": true
}
],
"win": [
{
"url": "${SKIA_ROOT}/win-ia32.zip",
"dir": "third_party/skia",
"unzip": true
},
{
"url": "${V8_ROOT}/win-ia32.zip",
"dir": "third_party/v8",
"unzip": true
}
]
},
"actions": {
"common": [
{
"command": "depsync --clean",
"dir": "third_party"
}
]
}
}