mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2025-01-12 05:25:56 +01:00
parent
386cdfdb5b
commit
733d8e8f99
45
.github/workflows/build.yml
vendored
45
.github/workflows/build.yml
vendored
@ -8,7 +8,6 @@ on:
|
|||||||
jobs:
|
jobs:
|
||||||
build_unix:
|
build_unix:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
outputs:
|
outputs:
|
||||||
ytdlp_version: ${{ steps.bump_version.outputs.ytdlp_version }}
|
ytdlp_version: ${{ steps.bump_version.outputs.ytdlp_version }}
|
||||||
upload_url: ${{ steps.create_release.outputs.upload_url }}
|
upload_url: ${{ steps.create_release.outputs.upload_url }}
|
||||||
@ -69,6 +68,7 @@ jobs:
|
|||||||
- name: Get SHA2-512SUMS for yt-dlp.tar.gz
|
- name: Get SHA2-512SUMS for yt-dlp.tar.gz
|
||||||
id: sha512_tar
|
id: sha512_tar
|
||||||
run: echo "::set-output name=sha512_tar::$(sha512sum yt-dlp.tar.gz | awk '{print $1}')"
|
run: echo "::set-output name=sha512_tar::$(sha512sum yt-dlp.tar.gz | awk '{print $1}')"
|
||||||
|
|
||||||
- name: Install dependencies for pypi
|
- name: Install dependencies for pypi
|
||||||
env:
|
env:
|
||||||
PYPI_TOKEN: ${{ secrets.PYPI_TOKEN }}
|
PYPI_TOKEN: ${{ secrets.PYPI_TOKEN }}
|
||||||
@ -85,6 +85,7 @@ jobs:
|
|||||||
rm -rf dist/*
|
rm -rf dist/*
|
||||||
python setup.py sdist bdist_wheel
|
python setup.py sdist bdist_wheel
|
||||||
twine upload dist/*
|
twine upload dist/*
|
||||||
|
|
||||||
- name: Install SSH private key
|
- name: Install SSH private key
|
||||||
env:
|
env:
|
||||||
BREW_TOKEN: ${{ secrets.BREW_TOKEN }}
|
BREW_TOKEN: ${{ secrets.BREW_TOKEN }}
|
||||||
@ -103,6 +104,7 @@ jobs:
|
|||||||
git -C taps/ config user.email github-actions@example.com
|
git -C taps/ config user.email github-actions@example.com
|
||||||
git -C taps/ commit -am 'yt-dlp: ${{ steps.bump_version.outputs.ytdlp_version }}'
|
git -C taps/ commit -am 'yt-dlp: ${{ steps.bump_version.outputs.ytdlp_version }}'
|
||||||
git -C taps/ push
|
git -C taps/ push
|
||||||
|
|
||||||
- name: Create Release
|
- name: Create Release
|
||||||
id: create_release
|
id: create_release
|
||||||
uses: actions/create-release@v1
|
uses: actions/create-release@v1
|
||||||
@ -113,7 +115,9 @@ jobs:
|
|||||||
release_name: yt-dlp ${{ steps.bump_version.outputs.ytdlp_version }}
|
release_name: yt-dlp ${{ steps.bump_version.outputs.ytdlp_version }}
|
||||||
commitish: ${{ steps.push_update.outputs.head_sha }}
|
commitish: ${{ steps.push_update.outputs.head_sha }}
|
||||||
body: |
|
body: |
|
||||||
Changelog:
|
See [this](https://github.com/yt-dlp/yt-dlp#release-files) for a description of the files
|
||||||
|
|
||||||
|
#### Changelog:
|
||||||
${{ env.changelog }}
|
${{ env.changelog }}
|
||||||
draft: false
|
draft: false
|
||||||
prerelease: false
|
prerelease: false
|
||||||
@ -140,7 +144,6 @@ jobs:
|
|||||||
build_macos:
|
build_macos:
|
||||||
runs-on: macos-11
|
runs-on: macos-11
|
||||||
needs: build_unix
|
needs: build_unix
|
||||||
|
|
||||||
outputs:
|
outputs:
|
||||||
sha256_macos: ${{ steps.sha256_macos.outputs.sha256_macos }}
|
sha256_macos: ${{ steps.sha256_macos.outputs.sha256_macos }}
|
||||||
sha512_macos: ${{ steps.sha512_macos.outputs.sha512_macos }}
|
sha512_macos: ${{ steps.sha512_macos.outputs.sha512_macos }}
|
||||||
@ -153,17 +156,15 @@ jobs:
|
|||||||
- name: Install Requirements
|
- name: Install Requirements
|
||||||
run: |
|
run: |
|
||||||
brew install coreutils
|
brew install coreutils
|
||||||
/usr/bin/pip3 install --user Pyinstaller mutagen pycryptodomex websockets
|
/usr/bin/python3 -m pip install -U --user pip Pyinstaller mutagen pycryptodomex websockets
|
||||||
- name: Bump version
|
- name: Bump version
|
||||||
id: bump_version
|
id: bump_version
|
||||||
run: python devscripts/update-version.py
|
run: /usr/bin/python3 devscripts/update-version.py
|
||||||
- name: Print version
|
|
||||||
run: echo "${{ steps.bump_version.outputs.ytdlp_version }}"
|
|
||||||
- name: Build lazy extractors
|
- name: Build lazy extractors
|
||||||
id: lazy_extractors
|
id: lazy_extractors
|
||||||
run: /usr/bin/python3 devscripts/make_lazy_extractors.py yt_dlp/extractor/lazy_extractors.py
|
run: /usr/bin/python3 devscripts/make_lazy_extractors.py yt_dlp/extractor/lazy_extractors.py
|
||||||
- name: Run PyInstaller Script
|
- name: Run PyInstaller Script
|
||||||
run: /usr/bin/python3 ./pyinst.py --target-architecture universal2 --onefile
|
run: /usr/bin/python3 pyinst.py --target-architecture universal2 --onefile
|
||||||
- name: Upload yt-dlp MacOS binary
|
- name: Upload yt-dlp MacOS binary
|
||||||
id: upload-release-macos
|
id: upload-release-macos
|
||||||
uses: actions/upload-release-asset@v1
|
uses: actions/upload-release-asset@v1
|
||||||
@ -182,7 +183,7 @@ jobs:
|
|||||||
run: echo "::set-output name=sha512_macos::$(sha512sum dist/yt-dlp_macos | awk '{print $1}')"
|
run: echo "::set-output name=sha512_macos::$(sha512sum dist/yt-dlp_macos | awk '{print $1}')"
|
||||||
|
|
||||||
- name: Run PyInstaller Script with --onedir
|
- name: Run PyInstaller Script with --onedir
|
||||||
run: /usr/bin/python3 ./pyinst.py --target-architecture universal2 --onedir
|
run: /usr/bin/python3 pyinst.py --target-architecture universal2 --onedir
|
||||||
- uses: papeloto/action-zip@v1
|
- uses: papeloto/action-zip@v1
|
||||||
with:
|
with:
|
||||||
files: ./dist/yt-dlp_macos
|
files: ./dist/yt-dlp_macos
|
||||||
@ -207,7 +208,6 @@ jobs:
|
|||||||
build_windows:
|
build_windows:
|
||||||
runs-on: windows-latest
|
runs-on: windows-latest
|
||||||
needs: build_unix
|
needs: build_unix
|
||||||
|
|
||||||
outputs:
|
outputs:
|
||||||
sha256_win: ${{ steps.sha256_win.outputs.sha256_win }}
|
sha256_win: ${{ steps.sha256_win.outputs.sha256_win }}
|
||||||
sha512_win: ${{ steps.sha512_win.outputs.sha512_win }}
|
sha512_win: ${{ steps.sha512_win.outputs.sha512_win }}
|
||||||
@ -231,8 +231,6 @@ jobs:
|
|||||||
- name: Bump version
|
- name: Bump version
|
||||||
id: bump_version
|
id: bump_version
|
||||||
run: python devscripts/update-version.py
|
run: python devscripts/update-version.py
|
||||||
- name: Print version
|
|
||||||
run: echo "${{ steps.bump_version.outputs.ytdlp_version }}"
|
|
||||||
- name: Build lazy extractors
|
- name: Build lazy extractors
|
||||||
id: lazy_extractors
|
id: lazy_extractors
|
||||||
run: python devscripts/make_lazy_extractors.py yt_dlp/extractor/lazy_extractors.py
|
run: python devscripts/make_lazy_extractors.py yt_dlp/extractor/lazy_extractors.py
|
||||||
@ -254,6 +252,7 @@ jobs:
|
|||||||
- name: Get SHA2-512SUMS for yt-dlp.exe
|
- name: Get SHA2-512SUMS for yt-dlp.exe
|
||||||
id: sha512_win
|
id: sha512_win
|
||||||
run: echo "::set-output name=sha512_win::$((Get-FileHash dist\yt-dlp.exe -Algorithm SHA512).Hash.ToLower())"
|
run: echo "::set-output name=sha512_win::$((Get-FileHash dist\yt-dlp.exe -Algorithm SHA512).Hash.ToLower())"
|
||||||
|
|
||||||
- name: Run PyInstaller Script with --onedir
|
- name: Run PyInstaller Script with --onedir
|
||||||
run: python pyinst.py --onedir
|
run: python pyinst.py --onedir
|
||||||
- uses: papeloto/action-zip@v1
|
- uses: papeloto/action-zip@v1
|
||||||
@ -319,8 +318,6 @@ jobs:
|
|||||||
- name: Bump version
|
- name: Bump version
|
||||||
id: bump_version
|
id: bump_version
|
||||||
run: python devscripts/update-version.py
|
run: python devscripts/update-version.py
|
||||||
- name: Print version
|
|
||||||
run: echo "${{ steps.bump_version.outputs.ytdlp_version }}"
|
|
||||||
- name: Build lazy extractors
|
- name: Build lazy extractors
|
||||||
id: lazy_extractors
|
id: lazy_extractors
|
||||||
run: python devscripts/make_lazy_extractors.py yt_dlp/extractor/lazy_extractors.py
|
run: python devscripts/make_lazy_extractors.py yt_dlp/extractor/lazy_extractors.py
|
||||||
@ -350,23 +347,23 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Make SHA2-256SUMS file
|
- name: Make SHA2-256SUMS file
|
||||||
env:
|
env:
|
||||||
|
SHA256_BIN: ${{ needs.build_unix.outputs.sha256_bin }}
|
||||||
|
SHA256_TAR: ${{ needs.build_unix.outputs.sha256_tar }}
|
||||||
SHA256_WIN: ${{ needs.build_windows.outputs.sha256_win }}
|
SHA256_WIN: ${{ needs.build_windows.outputs.sha256_win }}
|
||||||
SHA256_PY2EXE: ${{ needs.build_windows.outputs.sha256_py2exe }}
|
SHA256_PY2EXE: ${{ needs.build_windows.outputs.sha256_py2exe }}
|
||||||
SHA256_WIN_ZIP: ${{ needs.build_windows.outputs.sha256_win_zip }}
|
SHA256_WIN_ZIP: ${{ needs.build_windows.outputs.sha256_win_zip }}
|
||||||
SHA256_WIN32: ${{ needs.build_windows32.outputs.sha256_win32 }}
|
SHA256_WIN32: ${{ needs.build_windows32.outputs.sha256_win32 }}
|
||||||
SHA256_MACOS: ${{ needs.build_macos.outputs.sha256_macos }}
|
SHA256_MACOS: ${{ needs.build_macos.outputs.sha256_macos }}
|
||||||
SHA256_MACOS_ZIP: ${{ needs.build_macos.outputs.sha256_macos_zip }}
|
SHA256_MACOS_ZIP: ${{ needs.build_macos.outputs.sha256_macos_zip }}
|
||||||
SHA256_BIN: ${{ needs.build_unix.outputs.sha256_bin }}
|
|
||||||
SHA256_TAR: ${{ needs.build_unix.outputs.sha256_tar }}
|
|
||||||
run: |
|
run: |
|
||||||
|
echo "${{ env.SHA256_BIN }} yt-dlp" >> SHA2-256SUMS
|
||||||
|
echo "${{ env.SHA256_TAR }} yt-dlp.tar.gz" >> SHA2-256SUMS
|
||||||
echo "${{ env.SHA256_WIN }} yt-dlp.exe" >> SHA2-256SUMS
|
echo "${{ env.SHA256_WIN }} yt-dlp.exe" >> SHA2-256SUMS
|
||||||
echo "${{ env.SHA256_PY2EXE }} yt-dlp_min.exe" >> SHA2-256SUMS
|
echo "${{ env.SHA256_PY2EXE }} yt-dlp_min.exe" >> SHA2-256SUMS
|
||||||
echo "${{ env.SHA256_WIN32 }} yt-dlp_x86.exe" >> SHA2-256SUMS
|
echo "${{ env.SHA256_WIN32 }} yt-dlp_x86.exe" >> SHA2-256SUMS
|
||||||
|
echo "${{ env.SHA256_WIN_ZIP }} yt-dlp_win.zip" >> SHA2-256SUMS
|
||||||
echo "${{ env.SHA256_MACOS }} yt-dlp_macos" >> SHA2-256SUMS
|
echo "${{ env.SHA256_MACOS }} yt-dlp_macos" >> SHA2-256SUMS
|
||||||
echo "${{ env.SHA256_MACOS_ZIP }} yt-dlp_macos.zip" >> SHA2-256SUMS
|
echo "${{ env.SHA256_MACOS_ZIP }} yt-dlp_macos.zip" >> SHA2-256SUMS
|
||||||
echo "${{ env.SHA256_BIN }} yt-dlp" >> SHA2-256SUMS
|
|
||||||
echo "${{ env.SHA256_TAR }} yt-dlp.tar.gz" >> SHA2-256SUMS
|
|
||||||
echo "${{ env.SHA256_WIN_ZIP }} yt-dlp_win.zip" >> SHA2-256SUMS
|
|
||||||
- name: Upload 256SUMS file
|
- name: Upload 256SUMS file
|
||||||
id: upload-sums
|
id: upload-sums
|
||||||
uses: actions/upload-release-asset@v1
|
uses: actions/upload-release-asset@v1
|
||||||
@ -379,23 +376,23 @@ jobs:
|
|||||||
asset_content_type: text/plain
|
asset_content_type: text/plain
|
||||||
- name: Make SHA2-512SUMS file
|
- name: Make SHA2-512SUMS file
|
||||||
env:
|
env:
|
||||||
|
SHA512_BIN: ${{ needs.build_unix.outputs.sha512_bin }}
|
||||||
|
SHA512_TAR: ${{ needs.build_unix.outputs.sha512_tar }}
|
||||||
SHA512_WIN: ${{ needs.build_windows.outputs.sha512_win }}
|
SHA512_WIN: ${{ needs.build_windows.outputs.sha512_win }}
|
||||||
SHA512_PY2EXE: ${{ needs.build_windows.outputs.sha512_py2exe }}
|
SHA512_PY2EXE: ${{ needs.build_windows.outputs.sha512_py2exe }}
|
||||||
SHA512_WIN_ZIP: ${{ needs.build_windows.outputs.sha512_win_zip }}
|
SHA512_WIN_ZIP: ${{ needs.build_windows.outputs.sha512_win_zip }}
|
||||||
SHA512_WIN32: ${{ needs.build_windows32.outputs.sha512_win32 }}
|
SHA512_WIN32: ${{ needs.build_windows32.outputs.sha512_win32 }}
|
||||||
SHA512_MACOS: ${{ needs.build_macos.outputs.sha512_macos }}
|
SHA512_MACOS: ${{ needs.build_macos.outputs.sha512_macos }}
|
||||||
SHA512_MACOS_ZIP: ${{ needs.build_macos.outputs.sha512_macos_zip }}
|
SHA512_MACOS_ZIP: ${{ needs.build_macos.outputs.sha512_macos_zip }}
|
||||||
SHA512_BIN: ${{ needs.build_unix.outputs.sha512_bin }}
|
|
||||||
SHA512_TAR: ${{ needs.build_unix.outputs.sha512_tar }}
|
|
||||||
run: |
|
run: |
|
||||||
|
echo "${{ env.SHA512_BIN }} yt-dlp" >> SHA2-512SUMS
|
||||||
|
echo "${{ env.SHA512_TAR }} yt-dlp.tar.gz" >> SHA2-512SUMS
|
||||||
echo "${{ env.SHA512_WIN }} yt-dlp.exe" >> SHA2-512SUMS
|
echo "${{ env.SHA512_WIN }} yt-dlp.exe" >> SHA2-512SUMS
|
||||||
|
echo "${{ env.SHA512_WIN_ZIP }} yt-dlp_win.zip" >> SHA2-512SUMS
|
||||||
echo "${{ env.SHA512_PY2EXE }} yt-dlp_min.exe" >> SHA2-512SUMS
|
echo "${{ env.SHA512_PY2EXE }} yt-dlp_min.exe" >> SHA2-512SUMS
|
||||||
echo "${{ env.SHA512_WIN32 }} yt-dlp_x86.exe" >> SHA2-512SUMS
|
echo "${{ env.SHA512_WIN32 }} yt-dlp_x86.exe" >> SHA2-512SUMS
|
||||||
echo "${{ env.SHA512_MACOS }} yt-dlp_macos" >> SHA2-512SUMS
|
echo "${{ env.SHA512_MACOS }} yt-dlp_macos" >> SHA2-512SUMS
|
||||||
echo "${{ env.SHA512_MACOS_ZIP }} yt-dlp_macos.zip" >> SHA2-512SUMS
|
echo "${{ env.SHA512_MACOS_ZIP }} yt-dlp_macos.zip" >> SHA2-512SUMS
|
||||||
echo "${{ env.SHA512_BIN }} yt-dlp" >> SHA2-512SUMS
|
|
||||||
echo "${{ env.SHA512_TAR }} yt-dlp.tar.gz" >> SHA2-512SUMS
|
|
||||||
echo "${{ env.SHA512_WIN_ZIP }} yt-dlp_win.zip" >> SHA2-512SUMS
|
|
||||||
- name: Upload 512SUMS file
|
- name: Upload 512SUMS file
|
||||||
id: upload-512sums
|
id: upload-512sums
|
||||||
uses: actions/upload-release-asset@v1
|
uses: actions/upload-release-asset@v1
|
||||||
|
6
Makefile
6
Makefile
@ -40,9 +40,9 @@ SYSCONFDIR = $(shell if [ $(PREFIX) = /usr -o $(PREFIX) = /usr/local ]; then ech
|
|||||||
# set markdown input format to "markdown-smart" for pandoc version 2 and to "markdown" for pandoc prior to version 2
|
# set markdown input format to "markdown-smart" for pandoc version 2 and to "markdown" for pandoc prior to version 2
|
||||||
MARKDOWN = $(shell if [ `pandoc -v | head -n1 | cut -d" " -f2 | head -c1` = "2" ]; then echo markdown-smart; else echo markdown; fi)
|
MARKDOWN = $(shell if [ `pandoc -v | head -n1 | cut -d" " -f2 | head -c1` = "2" ]; then echo markdown-smart; else echo markdown; fi)
|
||||||
|
|
||||||
install: lazy_extractors yt-dlp yt-dlp.1 completions
|
install: lazy-extractors yt-dlp yt-dlp.1 completions
|
||||||
install -Dm755 yt-dlp $(DESTDIR)$(BINDIR)
|
install -Dm755 yt-dlp $(DESTDIR)$(BINDIR)/yt-dlp
|
||||||
install -Dm644 yt-dlp.1 $(DESTDIR)$(MANDIR)/man1
|
install -Dm644 yt-dlp.1 $(DESTDIR)$(MANDIR)/man1/yt-dlp.1
|
||||||
install -Dm644 completions/bash/yt-dlp $(DESTDIR)$(SHAREDIR)/bash-completion/completions/yt-dlp
|
install -Dm644 completions/bash/yt-dlp $(DESTDIR)$(SHAREDIR)/bash-completion/completions/yt-dlp
|
||||||
install -Dm644 completions/zsh/_yt-dlp $(DESTDIR)$(SHAREDIR)/zsh/site-functions/_yt-dlp
|
install -Dm644 completions/zsh/_yt-dlp $(DESTDIR)$(SHAREDIR)/zsh/site-functions/_yt-dlp
|
||||||
install -Dm644 completions/fish/yt-dlp.fish $(DESTDIR)$(SHAREDIR)/fish/vendor_completions.d/yt-dlp.fish
|
install -Dm644 completions/fish/yt-dlp.fish $(DESTDIR)$(SHAREDIR)/fish/vendor_completions.d/yt-dlp.fish
|
||||||
|
38
README.md
38
README.md
@ -155,11 +155,10 @@ # INSTALLATION
|
|||||||
yt-dlp is not platform specific. So it should work on your Unix box, on Windows or on macOS
|
yt-dlp is not platform specific. So it should work on your Unix box, on Windows or on macOS
|
||||||
|
|
||||||
You can install yt-dlp using one of the following methods:
|
You can install yt-dlp using one of the following methods:
|
||||||
* Download the binary from the [latest release](https://github.com/yt-dlp/yt-dlp/releases/latest)
|
* Download [the binary](#release-files) from the [latest release](https://github.com/yt-dlp/yt-dlp/releases/latest)
|
||||||
* With Homebrew, `brew install yt-dlp/taps/yt-dlp`
|
* With Homebrew, `brew install yt-dlp/taps/yt-dlp`
|
||||||
* Use [PyPI package](https://pypi.org/project/yt-dlp): `python3 -m pip install --upgrade yt-dlp`
|
* Use [PyPI package](https://pypi.org/project/yt-dlp): `python3 -m pip install --upgrade yt-dlp`
|
||||||
* Use pip+git: `python3 -m pip install --upgrade git+https://github.com/yt-dlp/yt-dlp.git@release`
|
* Install master branch: `python3 -m pip3 install -U https://github.com/yt-dlp/yt-dlp/archive/master.zip`
|
||||||
* Install master branch: `python3 -m pip install --upgrade git+https://github.com/yt-dlp/yt-dlp`
|
|
||||||
|
|
||||||
Note that on some systems, you may need to use `py` or `python` instead of `python3`
|
Note that on some systems, you may need to use `py` or `python` instead of `python3`
|
||||||
|
|
||||||
@ -193,15 +192,27 @@ ### UPDATE
|
|||||||
|
|
||||||
### RELEASE FILES
|
### RELEASE FILES
|
||||||
|
|
||||||
|
#### Recommended
|
||||||
|
|
||||||
|
File|Description
|
||||||
|
:---|:---
|
||||||
|
[yt-dlp](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp)|Platform independant binary. Needs Python (Recommended for **UNIX-like systems**)
|
||||||
|
[yt-dlp.exe](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp.exe)|Windows standalone x64 binary (Recommended for **Windows**)
|
||||||
|
|
||||||
|
#### Alternatives
|
||||||
|
|
||||||
File|Description
|
File|Description
|
||||||
:---|:---
|
:---|:---
|
||||||
[yt-dlp](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp)|Platform independant binary. Needs Python (Recommended for UNIX like OSes)
|
|
||||||
[yt-dlp.exe](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp.exe)|Windows standalone x64 binary (Recommended for Windows)
|
|
||||||
[yt-dlp_x86.exe](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp_x86.exe)|Windows standalone x86 (32bit) binary
|
|
||||||
[yt-dlp_win.zip](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp_win.zip)|Unpackaged windows executable
|
|
||||||
[yt-dlp_macos](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp_macos)|MacOS standalone executable
|
[yt-dlp_macos](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp_macos)|MacOS standalone executable
|
||||||
[yt-dlp_macos.zip](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp_macos.zip)|Unpackaged MacOS executable
|
[yt-dlp_x86.exe](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp_x86.exe)|Windows standalone x86 (32bit) binary
|
||||||
[yt-dlp_min.exe](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp_x86.exe)|Windows standalone x64 binary built with `py2exe`. Does not contain `pycryptodomex`, needs VC++14
|
[yt-dlp_min.exe](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp_x86.exe)|Windows standalone x64 binary built with `py2exe`.<br/> Does not contain `pycryptodomex`, needs VC++14
|
||||||
|
[yt-dlp_win.zip](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp_win.zip)|Unpackaged windows executable (No auto-update)
|
||||||
|
[yt-dlp_macos.zip](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp_macos.zip)|Unpackaged MacOS executable (No auto-update)
|
||||||
|
|
||||||
|
#### Misc
|
||||||
|
|
||||||
|
File|Description
|
||||||
|
:---|:---
|
||||||
[yt-dlp.tar.gz](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp.tar.gz)|Source tarball. Also contains manpages, completions, etc
|
[yt-dlp.tar.gz](https://github.com/yt-dlp/yt-dlp/releases/latest/download/yt-dlp.tar.gz)|Source tarball. Also contains manpages, completions, etc
|
||||||
[SHA2-512SUMS](https://github.com/yt-dlp/yt-dlp/releases/latest/download/SHA2-512SUMS)|GNU-style SHA512 sums
|
[SHA2-512SUMS](https://github.com/yt-dlp/yt-dlp/releases/latest/download/SHA2-512SUMS)|GNU-style SHA512 sums
|
||||||
[SHA2-256SUMS](https://github.com/yt-dlp/yt-dlp/releases/latest/download/SHA2-256SUMS)|GNU-style SHA256 sums
|
[SHA2-256SUMS](https://github.com/yt-dlp/yt-dlp/releases/latest/download/SHA2-256SUMS)|GNU-style SHA256 sums
|
||||||
@ -239,13 +250,10 @@ ### COMPILE
|
|||||||
**For Windows**:
|
**For Windows**:
|
||||||
To build the Windows executable, you must have pyinstaller (and optionally mutagen, pycryptodomex, websockets)
|
To build the Windows executable, you must have pyinstaller (and optionally mutagen, pycryptodomex, websockets)
|
||||||
|
|
||||||
python3 -m pip install -U -r requirements.txt
|
Once you have all the necessary dependencies installed, just run `pyinst.py`. The executable will be built for the same architecture (32/64 bit) as the python used to build it.
|
||||||
|
|
||||||
Once you have all the necessary dependencies installed, just run `py pyinst.py`. The executable will be built for the same architecture (32/64 bit) as the python used to build it.
|
py -m pip install -U pyinstaller -r requirements.txt
|
||||||
|
py pyinst.py
|
||||||
You can also build the executable without any version info or metadata by using:
|
|
||||||
|
|
||||||
pyinstaller.exe yt_dlp\__main__.py --onefile --name yt-dlp
|
|
||||||
|
|
||||||
Note that pyinstaller [does not support](https://github.com/pyinstaller/pyinstaller#requirements-and-tested-platforms) Python installed from the Windows store without using a virtual environment
|
Note that pyinstaller [does not support](https://github.com/pyinstaller/pyinstaller#requirements-and-tested-platforms) Python installed from the Windows store without using a virtual environment
|
||||||
|
|
||||||
|
177
pyinst.py
177
pyinst.py
@ -1,84 +1,85 @@
|
|||||||
#!/usr/bin/env python3
|
#!/usr/bin/env python3
|
||||||
# coding: utf-8
|
# coding: utf-8
|
||||||
|
import os
|
||||||
from __future__ import unicode_literals
|
|
||||||
import sys
|
|
||||||
import platform
|
import platform
|
||||||
|
import sys
|
||||||
from PyInstaller.utils.hooks import collect_submodules
|
from PyInstaller.utils.hooks import collect_submodules
|
||||||
|
|
||||||
if platform.system() == 'Windows':
|
|
||||||
|
OS_NAME = platform.system()
|
||||||
|
if OS_NAME == 'Windows':
|
||||||
from PyInstaller.utils.win32.versioninfo import (
|
from PyInstaller.utils.win32.versioninfo import (
|
||||||
VarStruct, VarFileInfo, StringStruct, StringTable,
|
VarStruct, VarFileInfo, StringStruct, StringTable,
|
||||||
StringFileInfo, FixedFileInfo, VSVersionInfo, SetVersion,
|
StringFileInfo, FixedFileInfo, VSVersionInfo, SetVersion,
|
||||||
)
|
)
|
||||||
import PyInstaller.__main__
|
elif OS_NAME == 'Darwin':
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
raise Exception('{OS_NAME} is not supported')
|
||||||
|
|
||||||
suffix = ''
|
ARCH = platform.architecture()[0][:2]
|
||||||
arch = platform.architecture()[0][:2]
|
|
||||||
assert arch in ('32', '64')
|
|
||||||
_x86 = '_x86' if arch == '32' else ''
|
|
||||||
|
|
||||||
if platform.system() == 'Windows':
|
|
||||||
suffix = _x86
|
|
||||||
if platform.system() == 'Darwin':
|
|
||||||
suffix = '_macos'
|
|
||||||
|
|
||||||
# Compatability with older arguments
|
def main():
|
||||||
opts = sys.argv[1:]
|
opts = parse_options()
|
||||||
if opts[0:1] in (['32'], ['64']):
|
version = read_version()
|
||||||
if arch != opts[0]:
|
|
||||||
raise Exception(f'{opts[0]}bit executable cannot be built on a {arch}bit system')
|
|
||||||
opts = opts[1:]
|
|
||||||
opts = opts or ['--onefile']
|
|
||||||
|
|
||||||
print(f'Building {arch}bit version with options {opts}')
|
suffix = '_x86' if ARCH == '32' else '_macos' if OS_NAME == 'Darwin' else ''
|
||||||
|
final_file = 'dist/%syt-dlp%s%s' % (
|
||||||
|
'yt-dlp/' if '--onedir' in opts else '', suffix, '.exe' if OS_NAME == 'Windows' else '')
|
||||||
|
|
||||||
FILE_DESCRIPTION = 'yt-dlp%s' % (' (32 Bit)' if _x86 else '')
|
print(f'Building yt-dlp v{version} {ARCH}bit for {OS_NAME} with options {opts}')
|
||||||
|
print('Remember to update the version using "devscripts/update-version.py"')
|
||||||
|
if not os.path.isfile('yt_dlp/extractor/lazy_extractors.py'):
|
||||||
|
print('WARNING: Building without lazy_extractors. Run '
|
||||||
|
'"devscripts/make_lazy_extractors.py" "yt_dlp/extractor/lazy_extractors.py" '
|
||||||
|
'to build lazy extractors', file=sys.stderr)
|
||||||
|
print(f'Destination: {final_file}\n')
|
||||||
|
|
||||||
exec(compile(open('yt_dlp/version.py').read(), 'yt_dlp/version.py', 'exec'))
|
opts = [
|
||||||
VERSION = locals()['__version__']
|
f'--name=yt-dlp{suffix}',
|
||||||
|
'--icon=devscripts/logo.ico',
|
||||||
|
'--upx-exclude=vcruntime140.dll',
|
||||||
|
'--noconfirm',
|
||||||
|
*dependancy_options(),
|
||||||
|
*opts,
|
||||||
|
'yt_dlp/__main__.py',
|
||||||
|
]
|
||||||
|
print(f'Running PyInstaller with {opts}')
|
||||||
|
|
||||||
VERSION_LIST = VERSION.split('.')
|
import PyInstaller.__main__
|
||||||
VERSION_LIST = list(map(int, VERSION_LIST)) + [0] * (4 - len(VERSION_LIST))
|
|
||||||
|
|
||||||
print('Version: %s%s' % (VERSION, _x86))
|
PyInstaller.__main__.run(opts)
|
||||||
print('Remember to update the version using devscipts\\update-version.py')
|
|
||||||
|
|
||||||
if platform.system() == 'Windows':
|
set_version_info(final_file, version)
|
||||||
VERSION_FILE = VSVersionInfo(
|
|
||||||
ffi=FixedFileInfo(
|
|
||||||
filevers=VERSION_LIST,
|
def parse_options():
|
||||||
prodvers=VERSION_LIST,
|
# Compatability with older arguments
|
||||||
mask=0x3F,
|
opts = sys.argv[1:]
|
||||||
flags=0x0,
|
if opts[0:1] in (['32'], ['64']):
|
||||||
OS=0x4,
|
if ARCH != opts[0]:
|
||||||
fileType=0x1,
|
raise Exception(f'{opts[0]}bit executable cannot be built on a {ARCH}bit system')
|
||||||
subtype=0x0,
|
opts = opts[1:]
|
||||||
date=(0, 0),
|
return opts or ['--onefile']
|
||||||
),
|
|
||||||
kids=[
|
|
||||||
StringFileInfo([
|
def read_version():
|
||||||
StringTable(
|
exec(compile(open('yt_dlp/version.py').read(), 'yt_dlp/version.py', 'exec'))
|
||||||
'040904B0', [
|
return locals()['__version__']
|
||||||
StringStruct('Comments', 'yt-dlp%s Command Line Interface.' % _x86),
|
|
||||||
StringStruct('CompanyName', 'https://github.com/yt-dlp'),
|
|
||||||
StringStruct('FileDescription', FILE_DESCRIPTION),
|
def version_to_list(version):
|
||||||
StringStruct('FileVersion', VERSION),
|
version_list = version.split('.')
|
||||||
StringStruct('InternalName', 'yt-dlp%s' % _x86),
|
return list(map(int, version_list)) + [0] * (4 - len(version_list))
|
||||||
StringStruct(
|
|
||||||
'LegalCopyright',
|
|
||||||
'pukkandan.ytdlp@gmail.com | UNLICENSE',
|
def dependancy_options():
|
||||||
),
|
dependancies = [pycryptodome_module(), 'mutagen'] + collect_submodules('websockets')
|
||||||
StringStruct('OriginalFilename', 'yt-dlp%s.exe' % _x86),
|
excluded_modules = ['test', 'ytdlp_plugins', 'youtube-dl', 'youtube-dlc']
|
||||||
StringStruct('ProductName', 'yt-dlp%s' % _x86),
|
|
||||||
StringStruct(
|
yield from (f'--hidden-import={module}' for module in dependancies)
|
||||||
'ProductVersion',
|
yield from (f'--exclude-module={module}' for module in excluded_modules)
|
||||||
'%s%s on Python %s' % (VERSION, _x86, platform.python_version())),
|
|
||||||
])]),
|
|
||||||
VarFileInfo([VarStruct('Translation', [0, 1200])])
|
|
||||||
]
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
def pycryptodome_module():
|
def pycryptodome_module():
|
||||||
@ -95,19 +96,41 @@ def pycryptodome_module():
|
|||||||
return 'Cryptodome'
|
return 'Cryptodome'
|
||||||
|
|
||||||
|
|
||||||
dependancies = [pycryptodome_module(), 'mutagen'] + collect_submodules('websockets')
|
def set_version_info(exe, version):
|
||||||
excluded_modules = ['test', 'ytdlp_plugins', 'youtube-dl', 'youtube-dlc']
|
if OS_NAME == 'Windows':
|
||||||
|
windows_set_version(exe, version)
|
||||||
|
|
||||||
PyInstaller.__main__.run([
|
|
||||||
'--name=yt-dlp%s' % suffix,
|
|
||||||
'--icon=devscripts/logo.ico',
|
|
||||||
*[f'--exclude-module={module}' for module in excluded_modules],
|
|
||||||
*[f'--hidden-import={module}' for module in dependancies],
|
|
||||||
'--upx-exclude=vcruntime140.dll',
|
|
||||||
'--noconfirm',
|
|
||||||
*opts,
|
|
||||||
'yt_dlp/__main__.py',
|
|
||||||
])
|
|
||||||
|
|
||||||
if platform.system() == 'Windows':
|
def windows_set_version(exe, version):
|
||||||
SetVersion('dist/%syt-dlp%s.exe' % ('yt-dlp/' if '--onedir' in opts else '', _x86), VERSION_FILE)
|
version_list = version_to_list(version)
|
||||||
|
suffix = '_x86' if ARCH == '32' else ''
|
||||||
|
SetVersion(exe, VSVersionInfo(
|
||||||
|
ffi=FixedFileInfo(
|
||||||
|
filevers=version_list,
|
||||||
|
prodvers=version_list,
|
||||||
|
mask=0x3F,
|
||||||
|
flags=0x0,
|
||||||
|
OS=0x4,
|
||||||
|
fileType=0x1,
|
||||||
|
subtype=0x0,
|
||||||
|
date=(0, 0),
|
||||||
|
),
|
||||||
|
kids=[
|
||||||
|
StringFileInfo([StringTable('040904B0', [
|
||||||
|
StringStruct('Comments', 'yt-dlp%s Command Line Interface.' % suffix),
|
||||||
|
StringStruct('CompanyName', 'https://github.com/yt-dlp'),
|
||||||
|
StringStruct('FileDescription', 'yt-dlp%s' % (' (32 Bit)' if ARCH == '32' else '')),
|
||||||
|
StringStruct('FileVersion', version),
|
||||||
|
StringStruct('InternalName', f'yt-dlp{suffix}'),
|
||||||
|
StringStruct('LegalCopyright', 'pukkandan.ytdlp@gmail.com | UNLICENSE'),
|
||||||
|
StringStruct('OriginalFilename', f'yt-dlp{suffix}.exe'),
|
||||||
|
StringStruct('ProductName', f'yt-dlp{suffix}'),
|
||||||
|
StringStruct(
|
||||||
|
'ProductVersion', f'{version}{suffix} on Python {platform.python_version()}'),
|
||||||
|
])]), VarFileInfo([VarStruct('Translation', [0, 1200])])
|
||||||
|
]
|
||||||
|
))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
||||||
|
@ -167,35 +167,35 @@ def get_sha256sum(bin_or_exe, version):
|
|||||||
return report_network_error('download latest version')
|
return report_network_error('download latest version')
|
||||||
|
|
||||||
try:
|
try:
|
||||||
with open(exe + '.new', 'wb') as outf:
|
with open(filename + '.new', 'wb') as outf:
|
||||||
outf.write(newcontent)
|
outf.write(newcontent)
|
||||||
except (IOError, OSError):
|
except (IOError, OSError):
|
||||||
return report_permission_error(f'{exe}.new')
|
return report_permission_error(f'{filename}.new')
|
||||||
|
|
||||||
expected_sum = get_sha256sum('exe', arch)
|
expected_sum = get_sha256sum(variant, arch)
|
||||||
if not expected_sum:
|
if not expected_sum:
|
||||||
ydl.report_warning('no hash information found for the release')
|
ydl.report_warning('no hash information found for the release')
|
||||||
elif calc_sha256sum(exe + '.new') != expected_sum:
|
elif calc_sha256sum(filename + '.new') != expected_sum:
|
||||||
report_network_error('verify the new executable')
|
report_network_error('verify the new executable')
|
||||||
try:
|
try:
|
||||||
os.remove(exe + '.new')
|
os.remove(filename + '.new')
|
||||||
except OSError:
|
except OSError:
|
||||||
return report_unable('remove corrupt download')
|
return report_unable('remove corrupt download')
|
||||||
|
|
||||||
try:
|
try:
|
||||||
os.rename(exe, exe + '.old')
|
os.rename(filename, filename + '.old')
|
||||||
except (IOError, OSError):
|
except (IOError, OSError):
|
||||||
return report_unable('move current version')
|
return report_unable('move current version')
|
||||||
try:
|
try:
|
||||||
os.rename(exe + '.new', exe)
|
os.rename(filename + '.new', filename)
|
||||||
except (IOError, OSError):
|
except (IOError, OSError):
|
||||||
report_unable('overwrite current version')
|
report_unable('overwrite current version')
|
||||||
os.rename(exe + '.old', exe)
|
os.rename(filename + '.old', filename)
|
||||||
return
|
return
|
||||||
try:
|
try:
|
||||||
# Continues to run in the background
|
# Continues to run in the background
|
||||||
Popen(
|
Popen(
|
||||||
'ping 127.0.0.1 -n 5 -w 1000 & del /F "%s.old"' % exe,
|
'ping 127.0.0.1 -n 5 -w 1000 & del /F "%s.old"' % filename,
|
||||||
shell=True, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
|
shell=True, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
|
||||||
ydl.to_screen('Updated yt-dlp to version %s' % version_id)
|
ydl.to_screen('Updated yt-dlp to version %s' % version_id)
|
||||||
return True # Exit app
|
return True # Exit app
|
||||||
|
Loading…
Reference in New Issue
Block a user