2023-07-02 16:48:26 +02:00
|
|
|
# Generic Makefile for building and packaging a Nextcloud app which uses npm and
|
|
|
|
# Composer.
|
|
|
|
#
|
|
|
|
# Dependencies:
|
|
|
|
# * make
|
|
|
|
# * which
|
|
|
|
# * curl: used if phpunit and composer are not installed to fetch them from the web
|
|
|
|
# * tar: for building the archive
|
|
|
|
# * npm: for building and testing everything JS
|
|
|
|
#
|
|
|
|
# If no composer.json is in the app root directory, the Composer step
|
|
|
|
# will be skipped. The same goes for the package.json which can be located in
|
|
|
|
# the app root or the js/ directory.
|
|
|
|
#
|
|
|
|
# The npm command by launches the npm build script:
|
|
|
|
#
|
|
|
|
# npm run build
|
|
|
|
#
|
|
|
|
# The npm test command launches the npm test script:
|
|
|
|
#
|
|
|
|
# npm run test
|
|
|
|
#
|
|
|
|
# The idea behind this is to be completely testing and build tool agnostic. All
|
|
|
|
# build tools and additional package managers should be installed locally in
|
|
|
|
# your project, since this won't pollute people's global namespace.
|
|
|
|
#
|
|
|
|
# The following npm scripts in your package.json install and update the bower
|
|
|
|
# and npm dependencies and use gulp as build system (notice how everything is
|
|
|
|
# run from the node_modules folder):
|
|
|
|
#
|
|
|
|
# "scripts": {
|
|
|
|
# "test": "node node_modules/gulp-cli/bin/gulp.js karma",
|
|
|
|
# "prebuild": "npm install && node_modules/bower/bin/bower install && node_modules/bower/bin/bower update",
|
|
|
|
# "build": "node node_modules/gulp-cli/bin/gulp.js"
|
|
|
|
# },
|
|
|
|
|
2023-06-22 20:10:30 +02:00
|
|
|
app_name=$(notdir $(CURDIR))
|
|
|
|
build_tools_directory=$(CURDIR)/build/tools
|
|
|
|
source_build_directory=$(CURDIR)/build/artifacts/source
|
|
|
|
source_package_name=$(source_build_directory)/$(app_name)
|
2023-12-23 18:31:00 +01:00
|
|
|
appstore_build_directory=$(CURDIR)/build/artifacts
|
2023-06-22 20:10:30 +02:00
|
|
|
appstore_package_name=$(appstore_build_directory)/$(app_name)
|
2023-06-23 09:44:48 +02:00
|
|
|
npm=$(shell which npm 2> /dev/null)
|
2023-06-22 20:10:30 +02:00
|
|
|
composer=$(shell which composer 2> /dev/null)
|
|
|
|
|
|
|
|
all: build
|
|
|
|
|
|
|
|
# Fetches the PHP and JS dependencies and compiles the JS. If no composer.json
|
|
|
|
# is present, the composer step is skipped, if no package.json or js/package.json
|
|
|
|
# is present, the npm step is skipped
|
|
|
|
.PHONY: build
|
|
|
|
build:
|
|
|
|
ifneq (,$(wildcard $(CURDIR)/composer.json))
|
|
|
|
make composer
|
|
|
|
endif
|
|
|
|
ifneq (,$(wildcard $(CURDIR)/package.json))
|
|
|
|
make npm
|
|
|
|
endif
|
|
|
|
|
|
|
|
# Installs and updates the composer dependencies. If composer is not installed
|
|
|
|
# a copy is fetched from the web
|
|
|
|
.PHONY: composer
|
|
|
|
composer:
|
|
|
|
ifeq (, $(composer))
|
|
|
|
@echo "No composer command available, downloading a copy from the web"
|
|
|
|
mkdir -p $(build_tools_directory)
|
|
|
|
curl -sS https://getcomposer.org/installer | php
|
|
|
|
mv composer.phar $(build_tools_directory)
|
|
|
|
php $(build_tools_directory)/composer.phar install --prefer-dist
|
|
|
|
else
|
|
|
|
composer install --prefer-dist
|
|
|
|
endif
|
|
|
|
|
|
|
|
# Installs npm dependencies
|
|
|
|
.PHONY: npm
|
|
|
|
npm:
|
2024-01-11 08:56:30 +01:00
|
|
|
npm ci
|
2023-06-22 20:10:30 +02:00
|
|
|
npm run build
|
|
|
|
|
|
|
|
# Removes the appstore build
|
|
|
|
.PHONY: clean
|
|
|
|
clean:
|
|
|
|
rm -rf ./build
|
|
|
|
|
|
|
|
# Same as clean but also removes dependencies installed by composer, bower and
|
|
|
|
# npm
|
|
|
|
.PHONY: distclean
|
|
|
|
distclean: clean
|
|
|
|
rm -rf vendor
|
|
|
|
rm -rf node_modules
|
|
|
|
rm -rf js/vendor
|
|
|
|
rm -rf js/node_modules
|
2023-07-02 16:48:26 +02:00
|
|
|
|
|
|
|
# Builds the source and appstore package
|
|
|
|
.PHONY: dist
|
|
|
|
dist: build
|
|
|
|
make source
|
|
|
|
make appstore
|
|
|
|
|
|
|
|
# Builds the source package
|
|
|
|
.PHONY: source
|
|
|
|
source:
|
|
|
|
rm -rf $(source_build_directory)
|
|
|
|
mkdir -p $(source_build_directory)
|
2023-12-23 18:31:00 +01:00
|
|
|
tar cvzf $(source_package_name).tar.gz \
|
2023-08-28 20:33:17 +02:00
|
|
|
--exclude-vcs \
|
2023-07-02 16:48:26 +02:00
|
|
|
--exclude="../$(app_name)/build" \
|
2023-12-23 18:31:00 +01:00
|
|
|
--exclude="../$(app_name)/js/node_modules" \
|
2023-07-02 16:48:26 +02:00
|
|
|
--exclude="../$(app_name)/node_modules" \
|
|
|
|
--exclude="../$(app_name)/*.log" \
|
|
|
|
--exclude="../$(app_name)/js/*.log" \
|
2023-12-23 18:31:00 +01:00
|
|
|
../$(app_name)
|
2023-07-02 16:48:26 +02:00
|
|
|
|
2023-12-23 18:31:00 +01:00
|
|
|
# Builds the source package for the app store, ignores php tests, js tests
|
|
|
|
# and build related folders that are unnecessary for an appstore release
|
2023-07-02 16:48:26 +02:00
|
|
|
.PHONY: appstore
|
|
|
|
appstore:
|
|
|
|
rm -rf $(appstore_build_directory)
|
|
|
|
mkdir -p $(appstore_build_directory)
|
2023-12-23 18:31:00 +01:00
|
|
|
tar cvzf $(appstore_package_name).tar.gz \
|
2023-08-28 20:33:17 +02:00
|
|
|
--exclude-vcs \
|
2023-07-02 16:48:26 +02:00
|
|
|
--exclude="../$(app_name)/build" \
|
|
|
|
--exclude="../$(app_name)/tests" \
|
|
|
|
--exclude="../$(app_name)/Makefile" \
|
|
|
|
--exclude="../$(app_name)/*.log" \
|
|
|
|
--exclude="../$(app_name)/phpunit*xml" \
|
|
|
|
--exclude="../$(app_name)/composer.*" \
|
2023-08-28 20:33:17 +02:00
|
|
|
--exclude="../$(app_name)/node_modules" \
|
2023-12-23 18:31:00 +01:00
|
|
|
--exclude="../$(app_name)/js/node_modules" \
|
2023-07-02 16:48:26 +02:00
|
|
|
--exclude="../$(app_name)/js/tests" \
|
|
|
|
--exclude="../$(app_name)/js/test" \
|
|
|
|
--exclude="../$(app_name)/js/*.log" \
|
|
|
|
--exclude="../$(app_name)/js/package.json" \
|
|
|
|
--exclude="../$(app_name)/js/bower.json" \
|
|
|
|
--exclude="../$(app_name)/js/karma.*" \
|
|
|
|
--exclude="../$(app_name)/js/protractor.*" \
|
2023-12-23 18:31:00 +01:00
|
|
|
--exclude="../$(app_name)/package.json" \
|
2023-07-02 16:48:26 +02:00
|
|
|
--exclude="../$(app_name)/bower.json" \
|
|
|
|
--exclude="../$(app_name)/karma.*" \
|
|
|
|
--exclude="../$(app_name)/protractor\.*" \
|
|
|
|
--exclude="../$(app_name)/.*" \
|
|
|
|
--exclude="../$(app_name)/js/.*" \
|
2023-12-23 18:31:00 +01:00
|
|
|
--exclude="../$(app_name)/webpack.config.js" \
|
|
|
|
--exclude="../$(app_name)/stylelint.config.js" \
|
|
|
|
--exclude="../$(app_name)/CHANGELOG.md" \
|
|
|
|
--exclude="../$(app_name)/README.md" \
|
|
|
|
--exclude="../$(app_name)/package-lock.json" \
|
2024-01-11 09:39:43 +01:00
|
|
|
--exclude="../$(app_name)/LICENSE*" \
|
2023-08-28 20:33:17 +02:00
|
|
|
--exclude="../$(app_name)/src" \
|
|
|
|
--exclude="../$(app_name)/stubs" \
|
|
|
|
--exclude="../$(app_name)/vendor" \
|
2024-01-10 20:42:45 +01:00
|
|
|
--exclude="../$(app_name)/translationfiles" \
|
|
|
|
--exclude="../$(app_name)/babel.config.js" \
|
|
|
|
--exclude="../$(app_name)/Dockerfile" \
|
|
|
|
--exclude="../$(app_name)/psalm.xml" \
|
|
|
|
--exclude="../$(app_name)/renovate.json" \
|
2023-12-23 18:31:00 +01:00
|
|
|
../$(app_name)
|
2023-08-28 20:33:17 +02:00
|
|
|
|
|
|
|
# Start a nextcloud server on Docker to kickstart developement
|
2024-01-10 15:25:54 +01:00
|
|
|
.PHONY: dev
|
2023-08-28 20:33:17 +02:00
|
|
|
dev: build
|
2023-08-29 11:43:17 +02:00
|
|
|
docker stop repod || true
|
|
|
|
docker rm repod || true
|
2023-08-28 20:33:17 +02:00
|
|
|
docker build -t repod .
|
2024-01-10 20:21:49 +01:00
|
|
|
docker run -itd --rm --name repod -v $(CURDIR):/var/www/html/apps/repod -p 80:80 repod
|
2023-08-28 20:33:17 +02:00
|
|
|
npm run watch
|
2024-01-10 15:25:54 +01:00
|
|
|
|
|
|
|
# Generate translations
|
|
|
|
.PHONY: l10n
|
|
|
|
l10n:
|
2024-01-10 20:21:49 +01:00
|
|
|
docker run --rm \
|
2024-01-10 15:25:54 +01:00
|
|
|
-v $(CURDIR):/app \
|
|
|
|
--entrypoint php \
|
|
|
|
nextcloudci/translations \
|
|
|
|
/translationtool.phar create-pot-files
|
2024-01-10 20:21:49 +01:00
|
|
|
docker run --rm \
|
2024-01-10 15:25:54 +01:00
|
|
|
-v $(CURDIR):/app \
|
|
|
|
--entrypoint php \
|
|
|
|
nextcloudci/translations \
|
|
|
|
/translationtool.phar convert-po-files
|