mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-30 22:25:19 +00:00 
			
		
		
		
	Fix packaging bugs (#129)
* Autogenerate `AUTHORS` * Fix `setup.py` using wrong completion files * Complete `ChangeLog` -> `Changelog.md` rename * Make `make tar` respect DESTDIR * Remove `bin/` `yt-dlp` and `docs/` from tar and sdist * Make `pypi-files` build all files needed for `python setup.py` * Add `completions` alias * Add `devscripts/` and `supportedsites.md` to pip sdist * Remove `man` target * Remove `README.txt` from sdist * Make `clean` more granular * Move aliases to top Authored by: hseg <gesh@gesh.uni.cx>
This commit is contained in:
		
							
								
								
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -25,7 +25,9 @@ updates_key.pem | |||||||
| *.class | *.class | ||||||
|  |  | ||||||
| # Generated | # Generated | ||||||
|  | AUTHORS | ||||||
| README.txt | README.txt | ||||||
|  | .mailmap | ||||||
| *.1 | *.1 | ||||||
| *.bash-completion | *.bash-completion | ||||||
| *.fish | *.fish | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								MANIFEST.in
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								MANIFEST.in
									
									
									
									
									
								
							| @@ -1,9 +1,9 @@ | |||||||
| include README.md |  | ||||||
| include LICENSE |  | ||||||
| include AUTHORS | include AUTHORS | ||||||
| include ChangeLog | include Changelog.md | ||||||
| include yt-dlp.bash-completion | include LICENSE | ||||||
| include yt-dlp.fish | include README.md | ||||||
|  | include completions/*/* | ||||||
|  | include supportedsites.md | ||||||
| include yt-dlp.1 | include yt-dlp.1 | ||||||
| recursive-include docs Makefile conf.py *.rst | recursive-include devscripts * | ||||||
| recursive-include test * | recursive-include test * | ||||||
|   | |||||||
							
								
								
									
										58
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										58
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,12 +1,28 @@ | |||||||
| all: yt-dlp doc man | all: yt-dlp doc man | ||||||
|  | clean: clean-test clean-dist clean-cache | ||||||
|  | completions: completion-bash completion-fish completion-zsh | ||||||
| doc: README.md CONTRIBUTING.md issuetemplates supportedsites | doc: README.md CONTRIBUTING.md issuetemplates supportedsites | ||||||
| man: README.txt yt-dlp.1 bash-completion zsh-completion fish-completion | ot: offlinetest | ||||||
|  | tar: yt-dlp.tar.gz | ||||||
|  |  | ||||||
|  | # Keep this list in sync with MANIFEST.in | ||||||
|  | # intended use: when building a source distribution, | ||||||
|  | # make pypi-files && python setup.py sdist | ||||||
|  | pypi-files: AUTHORS Changelog.md LICENSE README.md README.txt supportedsites completions yt-dlp.1 devscripts/* test/* | ||||||
|  |  | ||||||
| clean: | .PHONY: all clean install test tar pypi-files completions ot offlinetest codetest supportedsites | ||||||
| 	rm -rf yt-dlp.1.temp.md yt-dlp.1 README.txt MANIFEST build/ dist/ .coverage cover/ yt-dlp.tar.gz completions/ yt_dlp/extractor/lazy_extractors.py *.dump *.part* *.ytdl *.info.json *.mp4 *.m4a *.flv *.mp3 *.avi *.mkv *.webm *.3gp *.wav *.ape *.swf *.jpg *.png *.spec *.frag *.frag.urls *.frag.aria2 CONTRIBUTING.md.tmp yt-dlp yt-dlp.exe |  | ||||||
| 	find . -name "*.pyc" -delete | clean-test: | ||||||
| 	find . -name "*.class" -delete | 	rm -rf *.dump *.part* *.ytdl *.info.json *.mp4 *.m4a *.flv *.mp3 *.avi *.mkv *.webm *.3gp *.wav *.ape *.swf *.jpg *.png *.frag *.frag.urls *.frag.aria2 | ||||||
|  | clean-dist: | ||||||
|  | 	rm -rf yt-dlp.1.temp.md yt-dlp.1 README.txt MANIFEST build/ dist/ .coverage cover/ yt-dlp.tar.gz completions/ yt_dlp/extractor/lazy_extractors.py *.spec CONTRIBUTING.md.tmp yt-dlp yt-dlp.exe yt_dlp.egg-info/ AUTHORS .mailmap | ||||||
|  | clean-cache: | ||||||
|  | 	find . -name "*.pyc" -o -name "*.class" -delete | ||||||
|  |  | ||||||
|  | completion-bash: completions/bash/yt-dlp | ||||||
|  | completion-fish: completions/fish/yt-dlp.fish | ||||||
|  | completion-zsh: completions/zsh/_yt-dlp | ||||||
|  | lazy-extractors: yt_dlp/extractor/lazy_extractors.py | ||||||
|  |  | ||||||
| PREFIX ?= /usr/local | PREFIX ?= /usr/local | ||||||
| BINDIR ?= $(PREFIX)/bin | BINDIR ?= $(PREFIX)/bin | ||||||
| @@ -21,7 +37,7 @@ 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: yt-dlp yt-dlp.1 bash-completion zsh-completion fish-completion | install: yt-dlp yt-dlp.1 completions | ||||||
| 	install -Dm755 yt-dlp $(DESTDIR)$(BINDIR) | 	install -Dm755 yt-dlp $(DESTDIR)$(BINDIR) | ||||||
| 	install -Dm644 yt-dlp.1 $(DESTDIR)$(MANDIR)/man1 | 	install -Dm644 yt-dlp.1 $(DESTDIR)$(MANDIR)/man1 | ||||||
| 	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 | ||||||
| @@ -36,8 +52,6 @@ test: | |||||||
| 	nosetests --verbose test | 	nosetests --verbose test | ||||||
| 	$(MAKE) codetest | 	$(MAKE) codetest | ||||||
|  |  | ||||||
| ot: offlinetest |  | ||||||
|  |  | ||||||
| # Keep this list in sync with devscripts/run_tests.sh | # Keep this list in sync with devscripts/run_tests.sh | ||||||
| offlinetest: codetest | offlinetest: codetest | ||||||
| 	$(PYTHON) -m nose --verbose test \ | 	$(PYTHON) -m nose --verbose test \ | ||||||
| @@ -52,12 +66,6 @@ offlinetest: codetest | |||||||
| 		--exclude test_youtube_signature.py \ | 		--exclude test_youtube_signature.py \ | ||||||
| 		--exclude test_post_hooks.py | 		--exclude test_post_hooks.py | ||||||
|  |  | ||||||
| tar: yt-dlp.tar.gz |  | ||||||
|  |  | ||||||
| .PHONY: all clean install test tar bash-completion pypi-files zsh-completion fish-completion ot offlinetest codetest supportedsites |  | ||||||
|  |  | ||||||
| pypi-files: README.txt yt-dlp.1 bash-completion zsh-completion fish-completion |  | ||||||
|  |  | ||||||
| yt-dlp: yt_dlp/*.py yt_dlp/*/*.py | yt-dlp: yt_dlp/*.py yt_dlp/*/*.py | ||||||
| 	mkdir -p zip | 	mkdir -p zip | ||||||
| 	for d in yt_dlp yt_dlp/downloader yt_dlp/extractor yt_dlp/postprocessor ; do \ | 	for d in yt_dlp yt_dlp/downloader yt_dlp/extractor yt_dlp/postprocessor ; do \ | ||||||
| @@ -101,28 +109,20 @@ completions/bash/yt-dlp: yt_dlp/*.py yt_dlp/*/*.py devscripts/bash-completion.in | |||||||
| 	mkdir -p completions/bash | 	mkdir -p completions/bash | ||||||
| 	$(PYTHON) devscripts/bash-completion.py | 	$(PYTHON) devscripts/bash-completion.py | ||||||
|  |  | ||||||
| bash-completion: completions/bash/yt-dlp |  | ||||||
|  |  | ||||||
| completions/zsh/_yt-dlp: yt_dlp/*.py yt_dlp/*/*.py devscripts/zsh-completion.in | completions/zsh/_yt-dlp: yt_dlp/*.py yt_dlp/*/*.py devscripts/zsh-completion.in | ||||||
| 	mkdir -p completions/zsh | 	mkdir -p completions/zsh | ||||||
| 	$(PYTHON) devscripts/zsh-completion.py | 	$(PYTHON) devscripts/zsh-completion.py | ||||||
|  |  | ||||||
| zsh-completion: completions/zsh/_yt-dlp |  | ||||||
|  |  | ||||||
| completions/fish/yt-dlp.fish: yt_dlp/*.py yt_dlp/*/*.py devscripts/fish-completion.in | completions/fish/yt-dlp.fish: yt_dlp/*.py yt_dlp/*/*.py devscripts/fish-completion.in | ||||||
| 	mkdir -p completions/fish | 	mkdir -p completions/fish | ||||||
| 	$(PYTHON) devscripts/fish-completion.py | 	$(PYTHON) devscripts/fish-completion.py | ||||||
|  |  | ||||||
| fish-completion: completions/fish/yt-dlp.fish |  | ||||||
|  |  | ||||||
| lazy-extractors: yt_dlp/extractor/lazy_extractors.py |  | ||||||
|  |  | ||||||
| _EXTRACTOR_FILES = $(shell find yt_dlp/extractor -iname '*.py' -and -not -iname 'lazy_extractors.py') | _EXTRACTOR_FILES = $(shell find yt_dlp/extractor -iname '*.py' -and -not -iname 'lazy_extractors.py') | ||||||
| yt_dlp/extractor/lazy_extractors.py: devscripts/make_lazy_extractors.py devscripts/lazy_load_template.py $(_EXTRACTOR_FILES) | yt_dlp/extractor/lazy_extractors.py: devscripts/make_lazy_extractors.py devscripts/lazy_load_template.py $(_EXTRACTOR_FILES) | ||||||
| 	$(PYTHON) devscripts/make_lazy_extractors.py $@ | 	$(PYTHON) devscripts/make_lazy_extractors.py $@ | ||||||
|  |  | ||||||
| yt-dlp.tar.gz: yt-dlp README.md README.txt yt-dlp.1 bash-completion zsh-completion fish-completion ChangeLog AUTHORS | yt-dlp.tar.gz: README.md yt-dlp.1 completions Changelog.md AUTHORS | ||||||
| 	@tar -czf yt-dlp.tar.gz --transform "s|^|yt-dlp/|" --owner 0 --group 0 \ | 	@tar -czf $(DESTDIR)/yt-dlp.tar.gz --transform "s|^|yt-dlp/|" --owner 0 --group 0 \ | ||||||
| 		--exclude '*.DS_Store' \ | 		--exclude '*.DS_Store' \ | ||||||
| 		--exclude '*.kate-swp' \ | 		--exclude '*.kate-swp' \ | ||||||
| 		--exclude '*.pyc' \ | 		--exclude '*.pyc' \ | ||||||
| @@ -132,7 +132,13 @@ yt-dlp.tar.gz: yt-dlp README.md README.txt yt-dlp.1 bash-completion zsh-completi | |||||||
| 		--exclude '.git' \ | 		--exclude '.git' \ | ||||||
| 		--exclude 'docs/_build' \ | 		--exclude 'docs/_build' \ | ||||||
| 		-- \ | 		-- \ | ||||||
| 		bin devscripts test yt_dlp docs \ | 		devscripts test \ | ||||||
| 		ChangeLog AUTHORS LICENSE README.md supportedsites.md README.txt \ | 		Changelog.md AUTHORS LICENSE README.md supportedsites.md \ | ||||||
| 		Makefile MANIFEST.in yt-dlp.1 completions \ | 		Makefile MANIFEST.in yt-dlp.1 completions \ | ||||||
| 		setup.py setup.cfg yt-dlp | 		setup.py setup.cfg yt-dlp | ||||||
|  |  | ||||||
|  | AUTHORS: .mailmap | ||||||
|  | 	git shortlog -s -n | cut -f2 | sort > AUTHORS | ||||||
|  |  | ||||||
|  | .mailmap: | ||||||
|  | 	git shortlog -s -e -n | awk '!(out[$$NF]++) { $$1="";sub(/^[ \t]+/,""); print}' > .mailmap | ||||||
|   | |||||||
| @@ -61,7 +61,7 @@ if ! type pandoc >/dev/null 2>/dev/null; then echo 'ERROR: pandoc is missing'; e | |||||||
| if ! python3 -c 'import rsa' 2>/dev/null; then echo 'ERROR: python3-rsa is missing'; exit 1; fi | if ! python3 -c 'import rsa' 2>/dev/null; then echo 'ERROR: python3-rsa is missing'; exit 1; fi | ||||||
| if ! python3 -c 'import wheel' 2>/dev/null; then echo 'ERROR: wheel is missing'; exit 1; fi | if ! python3 -c 'import wheel' 2>/dev/null; then echo 'ERROR: wheel is missing'; exit 1; fi | ||||||
|  |  | ||||||
| read -p "Is ChangeLog up to date? (y/n) " -n 1 | read -p "Is Changelog up to date? (y/n) " -n 1 | ||||||
| if [[ ! $REPLY =~ ^[Yy]$ ]]; then exit 1; fi | if [[ ! $REPLY =~ ^[Yy]$ ]]; then exit 1; fi | ||||||
|  |  | ||||||
| /bin/echo -e "\n### First of all, testing..." | /bin/echo -e "\n### First of all, testing..." | ||||||
| @@ -75,12 +75,12 @@ fi | |||||||
| /bin/echo -e "\n### Changing version in version.py..." | /bin/echo -e "\n### Changing version in version.py..." | ||||||
| sed -i "s/__version__ = '.*'/__version__ = '$version'/" yt_dlp/version.py | sed -i "s/__version__ = '.*'/__version__ = '$version'/" yt_dlp/version.py | ||||||
|  |  | ||||||
| /bin/echo -e "\n### Changing version in ChangeLog..." | /bin/echo -e "\n### Changing version in Changelog..." | ||||||
| sed -i "s/<unreleased>/$version/" ChangeLog | sed -i "s/<unreleased>/$version/" Changelog.md | ||||||
|  |  | ||||||
| /bin/echo -e "\n### Committing documentation, templates and yt_dlp/version.py..." | /bin/echo -e "\n### Committing documentation, templates and yt_dlp/version.py..." | ||||||
| make README.md CONTRIBUTING.md issuetemplates supportedsites | make README.md CONTRIBUTING.md issuetemplates supportedsites | ||||||
| git add README.md CONTRIBUTING.md .github/ISSUE_TEMPLATE/1_broken_site.md .github/ISSUE_TEMPLATE/2_site_support_request.md .github/ISSUE_TEMPLATE/3_site_feature_request.md .github/ISSUE_TEMPLATE/4_bug_report.md .github/ISSUE_TEMPLATE/5_feature_request.md .github/ISSUE_TEMPLATE/6_question.md docs/supportedsites.md yt_dlp/version.py ChangeLog | git add README.md CONTRIBUTING.md .github/ISSUE_TEMPLATE/1_broken_site.md .github/ISSUE_TEMPLATE/2_site_support_request.md .github/ISSUE_TEMPLATE/3_site_feature_request.md .github/ISSUE_TEMPLATE/4_bug_report.md .github/ISSUE_TEMPLATE/5_feature_request.md .github/ISSUE_TEMPLATE/6_question.md docs/supportedsites.md yt_dlp/version.py Changelog.md | ||||||
| git commit $gpg_sign_commits -m "release $version" | git commit $gpg_sign_commits -m "release $version" | ||||||
|  |  | ||||||
| /bin/echo -e "\n### Now tagging, signing and pushing..." | /bin/echo -e "\n### Now tagging, signing and pushing..." | ||||||
| @@ -111,7 +111,7 @@ RELEASE_FILES="yt-dlp yt-dlp.exe yt-dlp-$version.tar.gz" | |||||||
| for f in $RELEASE_FILES; do gpg --passphrase-repeat 5 --detach-sig "build/$version/$f"; done | for f in $RELEASE_FILES; do gpg --passphrase-repeat 5 --detach-sig "build/$version/$f"; done | ||||||
|  |  | ||||||
| ROOT=$(pwd) | ROOT=$(pwd) | ||||||
| python devscripts/create-github-release.py ChangeLog $version "$ROOT/build/$version" | python devscripts/create-github-release.py Changelog.md $version "$ROOT/build/$version" | ||||||
|  |  | ||||||
| ssh ytdl@yt-dl.org "sh html/update_latest.sh $version" | ssh ytdl@yt-dl.org "sh html/update_latest.sh $version" | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								setup.py
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								setup.py
									
									
									
									
									
								
							| @@ -27,9 +27,9 @@ if len(sys.argv) >= 2 and sys.argv[1] == 'py2exe': | |||||||
|     print("inv") |     print("inv") | ||||||
| else: | else: | ||||||
|     files_spec = [ |     files_spec = [ | ||||||
|         ('share/bash-completion/completions', ['completions/bash/*']), |         ('share/bash-completion/completions', ['completions/bash/yt-dlp']), | ||||||
|         ('share/zsh/site-functions', ['completions/zsh/*']), |         ('share/zsh/site-functions', ['completions/zsh/_yt-dlp']), | ||||||
|         ('share/fish/vendor_completions.d', ['completions/fish/*']), |         ('share/fish/vendor_completions.d', ['completions/fish/yt-dlp.fish']), | ||||||
|         ('share/doc/yt_dlp', ['README.txt']), |         ('share/doc/yt_dlp', ['README.txt']), | ||||||
|         ('share/man/man1', ['yt-dlp.1']) |         ('share/man/man1', ['yt-dlp.1']) | ||||||
|     ] |     ] | ||||||
| @@ -39,7 +39,7 @@ else: | |||||||
|         resfiles = [] |         resfiles = [] | ||||||
|         for fn in files: |         for fn in files: | ||||||
|             if not os.path.exists(fn): |             if not os.path.exists(fn): | ||||||
|                 warnings.warn('Skipping file %s since it is not present. Type  make  to build all automatically generated files.' % fn) |                 warnings.warn('Skipping file %s since it is not present. Try running `make pypi-files` first.' % fn) | ||||||
|             else: |             else: | ||||||
|                 resfiles.append(fn) |                 resfiles.append(fn) | ||||||
|         data_files.append((dirname, resfiles)) |         data_files.append((dirname, resfiles)) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 hseg
					hseg