diff --git a/.github/workflows/bld.yml b/.github/workflows/bld.yml
new file mode 100644
index 0000000..cb04ac8
--- /dev/null
+++ b/.github/workflows/bld.yml
@@ -0,0 +1,35 @@
+name: bld-ci
+
+on: [ push, pull_request, workflow_dispatch ]
+
+jobs:
+ build-gradle-project:
+ runs-on: ubuntu-latest
+
+ strategy:
+ matrix:
+ java-version: [ 17, 19, 20 ]
+
+ steps:
+ - name: Checkout source repository
+ uses: actions/checkout@v3
+ with:
+ fetch-depth: 0
+
+ - name: Set up JDK ${{ matrix.java-version }}
+ uses: actions/setup-java@v3
+ with:
+ distribution: 'zulu'
+ java-version: ${{ matrix.java-version }}
+
+ - name: Grant execute permission for bld
+ run: chmod +x bld
+
+ - name: Download the dependencies
+ run: ./bld download
+
+ - name: Run tests with bld
+ run: >-
+ ./bld compile test
+ -DtestsBadgeUrl=https://rife2.com/tests-badge/update/com.uwyn.rife2/rife2-renderers
+ -DtestsBadgeApiKey=${{ secrets.TESTS_BADGE_API_KEY }}
\ No newline at end of file
diff --git a/.github/workflows/gradle.yml b/.github/workflows/gradle.yml
deleted file mode 100644
index a5f5b2b..0000000
--- a/.github/workflows/gradle.yml
+++ /dev/null
@@ -1,38 +0,0 @@
-name: gradle-ci
-
-on: [ push, pull_request, workflow_dispatch ]
-
-jobs:
- build-gradle-project:
- runs-on: ubuntu-latest
-
- env:
- GRADLE_OPTS: "-Dorg.gradle.jvmargs=-XX:MaxMetaspaceSize=512m"
-
- strategy:
- matrix:
- java-version: [ 17, 19 ]
-
- steps:
- - name: Checkout source repository
- uses: actions/checkout@v3
- with:
- fetch-depth: 0
-
- - name: Set up JDK ${{ matrix.java-version }}
- uses: actions/setup-java@v3
- with:
- distribution: 'temurin'
- java-version: ${{ matrix.java-version }}
-
- - name: Grant execute permission for gradlew
- run: chmod +x gradlew
-
- - name: Set up NO_CI env
- if: matrix.java-version != 17
- run: echo "NO_CI=true" >> $GITHUB_ENV
-
- - name: Test with Gradle
- uses: gradle/gradle-build-action@v2
- with:
- arguments: build check --stacktrace -PtestsBadgeApiKey=${{ secrets.TESTS_BADGE_API_KEY }}
diff --git a/.github/workflows/pages.yml b/.github/workflows/pages.yml
index 1a3f9fa..f6122cd 100644
--- a/.github/workflows/pages.yml
+++ b/.github/workflows/pages.yml
@@ -28,28 +28,20 @@ jobs:
runs-on: ubuntu-latest
- env:
- GRADLE_OPTS: "-Dorg.gradle.jvmargs=-XX:MaxMetaspaceSize=512m"
-
steps:
- name: Checkout source repository
uses: actions/checkout@v3
with:
fetch-depth: 0
- - name: Set up JDK 19
+ - name: Set up JDK 17
uses: actions/setup-java@v3
with:
- distribution: 'temurin'
- java-version: 19
-
- - name: Grant execute permission for gradlew
- run: chmod +x gradlew
+ distribution: 'zulu'
+ java-version: 17
- name: Build Javadocs
- uses: gradle/gradle-build-action@v2
- with:
- arguments: clean javadoc
+ run: ./bld download clean javadoc
- name: Setup Pages
uses: actions/configure-pages@v3
@@ -58,7 +50,7 @@ jobs:
uses: actions/upload-pages-artifact@v1
with:
# Upload generated Javadocs repository
- path: 'lib/build/docs/javadoc/'
+ path: 'build/javadoc/'
- name: Deploy to GitHub Pages
id: deployment
diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml
index d82f5e9..5d6d380 100644
--- a/.github/workflows/publish.yml
+++ b/.github/workflows/publish.yml
@@ -9,9 +9,6 @@ jobs:
build-gradle-project:
runs-on: ubuntu-latest
- env:
- GRADLE_OPTS: "-Dorg.gradle.jvmargs=-XX:MaxMetaspaceSize=512m"
-
steps:
- name: Checkout source repository
uses: actions/checkout@v3
@@ -24,17 +21,14 @@ jobs:
distribution: 'temurin'
java-version: 17
- - name: Grant execute permission for gradlew
- run: chmod +x gradlew
+ - name: Grant execute permission for bld
+ run: chmod +x bld
- - name: Publish with Gradle
- uses: gradle/gradle-build-action@v2
- env:
- NO_CI: true
- SONATYPE_USER: ${{ secrets.SONATYPE_USER}}
- SONATYPE_PASSWORD: ${{ secrets.SONATYPE_PASSWORD }}
- ORG_GRADLE_PROJECT_signingKey: ${{ secrets.ORG_GRADLE_PROJECT_signingKey }}
- ORG_GRADLE_PROJECT_signingPassword: ${{ secrets.ORG_GRADLE_PROJECT_signingPassword }}
- with:
- arguments: build check publish --stacktrace -PtestsBadgeApiKey=${{ secrets.TESTS_BADGE_API_KEY }}
+ - name: Download the dependencies
+ run: ./bld download
+ - name: Publish with bld
+ run: >-
+ ./bld compile test publish
+ -DtestsBadgeUrl=https://rife2.com/tests-badge/update/com.uwyn.rife2/rife2-renderers
+ -DtestsBadgeApiKey=${{ secrets.TESTS_BADGE_API_KEY }}
diff --git a/.gitignore b/.gitignore
index f7ada0c..a63b224 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,84 +1,55 @@
-!.vscode/extensions.json
-!.vscode/launch.json
-!.vscode/settings.json
-!.vscode/tasks.json
-*.class
-*.code-workspace
-*.ctxt
-*.iws
-*.log
-*.nar
-*.rar
-*.sublime-*
-*.tar.gz
-*.zip
-.DS_Store
-.classpath
.gradle
-.history
-.kobalt
-.mtj.tmp/
-.mvn/timing.properties
-.mvn/wrapper/maven-wrapper.jar
-.nb-gradle
-.project
-.scannerwork
-.settings
-.vscode/*
-/**/.idea/$CACHE_FILE$
-/**/.idea/$PRODUCT_WORKSPACE_FILE$
-/**/.idea/**/caches/build_file_checksums.ser
-/**/.idea/**/contentModel.xml
-/**/.idea/**/dataSources.ids
-/**/.idea/**/dataSources.local.xml
-/**/.idea/**/dataSources/
-/**/.idea/**/dbnavigator.xml
-/**/.idea/**/dictionaries
-/**/.idea/**/dynamic.xml
-/**/.idea/**/gradle.xml
-/**/.idea/**/httpRequests
-/**/.idea/**/libraries
-/**/.idea/**/mongoSettings.xml
-/**/.idea/**/replstate.xml
-/**/.idea/**/shelf/
-/**/.idea/**/sqlDataSources.xml
-/**/.idea/**/tasks.xml
-/**/.idea/**/uiDesigner.xml
-/**/.idea/**/usage.statistics.xml
-/**/.idea/**/workspace.xml
-/**/.idea/sonarlint*
-/**/.idea_modules/
-Thumbs.db
-__pycache__
+.DS_Store
+build
+lib/bld/**
+lib/compile/**
+lib/runtime/**
+lib/standalone/**
+lib/test/**
+!bld-wrapper.jar
+!bld-wrapper.properties
+
+# IDEA ignores
+
+# User-specific
+.idea/**/workspace.xml
+.idea/**/tasks.xml
+.idea/**/usage.statistics.xml
+.idea/**/dictionaries
+.idea/**/shelf
+
+# AWS User-specific
+.idea/**/aws.xml
+
+# Generated files
+.idea/**/contentModel.xml
+
+# Sensitive or high-churn files
+.idea/**/dataSources/
+.idea/**/dataSources.ids
+.idea/**/dataSources.local.xml
+.idea/**/sqlDataSources.xml
+.idea/**/dynamic.xml
+.idea/**/uiDesigner.xml
+.idea/**/dbnavigator.xml
+
+# Gradle
+.idea/**/gradle.xml
+
+# Mongo Explorer plugin
+.idea/**/mongoSettings.xml
+
+# mpeltonen/sbt-idea plugin
+.idea_modules/
+
+# JIRA plugin
atlassian-ide-plugin.xml
-bin/
-build/
-cmake-build-*/
-com_crashlytics_export_strings.xml
-crashlytics-build.properties
-crashlytics.properties
-dependency-reduced-pom.xml
-deploy/
-dist/
-ehthumbs.db
-fabric.properties
-gen/
-gradle.properties
-hs_err_pid*
-kobaltBuild
-kobaltw*-test
-lib/kotlin*
-libs/
-local.properties
-out/
-pom.xml.asc
-pom.xml.next
-pom.xml.releaseBackup
-pom.xml.tag
-pom.xml.versionsBackup
-proguard-project.txt
-project.properties
-release.properties
-target/
-test-output
-venv
+
+# Cursive Clojure plugin
+.idea/replstate.xml
+
+# SonarLint plugin
+.idea/sonarlint/
+
+# Editor-based Rest Client
+.idea/httpRequests
\ No newline at end of file
diff --git a/.idea/.gitignore b/.idea/.gitignore
deleted file mode 100644
index 26d3352..0000000
--- a/.idea/.gitignore
+++ /dev/null
@@ -1,3 +0,0 @@
-# Default ignored files
-/shelf/
-/workspace.xml
diff --git a/.idea/app.iml b/.idea/app.iml
new file mode 100644
index 0000000..9555946
--- /dev/null
+++ b/.idea/app.iml
@@ -0,0 +1,37 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/bld.iml b/.idea/bld.iml
new file mode 100644
index 0000000..e63e11e
--- /dev/null
+++ b/.idea/bld.iml
@@ -0,0 +1,14 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/compiler.xml b/.idea/compiler.xml
deleted file mode 100644
index b589d56..0000000
--- a/.idea/compiler.xml
+++ /dev/null
@@ -1,6 +0,0 @@
-
-
-
-
-
-
\ No newline at end of file
diff --git a/.idea/jarRepositories.xml b/.idea/jarRepositories.xml
deleted file mode 100644
index e15d88d..0000000
--- a/.idea/jarRepositories.xml
+++ /dev/null
@@ -1,30 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/.idea/libraries/bld.xml b/.idea/libraries/bld.xml
new file mode 100644
index 0000000..1bc7dda
--- /dev/null
+++ b/.idea/libraries/bld.xml
@@ -0,0 +1,17 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/libraries/compile.xml b/.idea/libraries/compile.xml
new file mode 100644
index 0000000..9bd86aa
--- /dev/null
+++ b/.idea/libraries/compile.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/libraries/runtime.xml b/.idea/libraries/runtime.xml
new file mode 100644
index 0000000..81feb0b
--- /dev/null
+++ b/.idea/libraries/runtime.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/libraries/test.xml b/.idea/libraries/test.xml
new file mode 100644
index 0000000..13b6513
--- /dev/null
+++ b/.idea/libraries/test.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/misc.xml b/.idea/misc.xml
index 690120f..542659b 100644
--- a/.idea/misc.xml
+++ b/.idea/misc.xml
@@ -1,57 +1,9 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
\ No newline at end of file
diff --git a/.idea/modules.xml b/.idea/modules.xml
new file mode 100644
index 0000000..55adcb9
--- /dev/null
+++ b/.idea/modules.xml
@@ -0,0 +1,9 @@
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/runConfigurations/Run Main.xml b/.idea/runConfigurations/Run Main.xml
new file mode 100644
index 0000000..271be19
--- /dev/null
+++ b/.idea/runConfigurations/Run Main.xml
@@ -0,0 +1,9 @@
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/runConfigurations/Run Tests.xml b/.idea/runConfigurations/Run Tests.xml
new file mode 100644
index 0000000..85ddbc6
--- /dev/null
+++ b/.idea/runConfigurations/Run Tests.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.vscode/launch.json b/.vscode/launch.json
new file mode 100644
index 0000000..ee72334
--- /dev/null
+++ b/.vscode/launch.json
@@ -0,0 +1,24 @@
+{
+ "version": "0.2.0",
+ "configurations": [
+ {
+ "type": "java",
+ "name": "Run Main",
+ "request": "launch",
+ "mainClass": "rife.render.TemplateRenderersMain"
+ },
+ {
+ "type": "java",
+ "name": "Run Tests",
+ "request": "launch",
+ "mainClass": "org.junit.platform.console.ConsoleLauncher",
+ "args": [
+ "--details=verbose",
+ "--scan-classpath",
+ "--disable-banner",
+ "--disable-ansi-colors",
+ "--exclude-engine=junit-platform-suite",
+ "--exclude-engine=junit-vintage"]
+ }
+ ]
+}
diff --git a/.vscode/settings.json b/.vscode/settings.json
new file mode 100644
index 0000000..e04f1cd
--- /dev/null
+++ b/.vscode/settings.json
@@ -0,0 +1,15 @@
+{
+ "java.project.sourcePaths": [
+ "src/main/java",
+ "src/main/resources",
+ "src/test/java",
+ "src/bld/java"
+ ],
+ "java.configuration.updateBuildConfiguration": "automatic",
+ "java.project.referencedLibraries": [
+ "${HOME}/.rife2/dist/rife2-1.5.18.jar",
+ "lib/compile/*.jar",
+ "lib/runtime/*.jar",
+ "lib/test/*.jar"
+ ]
+}
diff --git a/bld b/bld
new file mode 100755
index 0000000..7d67352
--- /dev/null
+++ b/bld
@@ -0,0 +1,2 @@
+#!/usr/bin/env sh
+java -jar "$(dirname "$0")/lib/bld/bld-wrapper.jar" "$0" --build rife.render.TemplateRenderersBuild "$@"
\ No newline at end of file
diff --git a/bld.bat b/bld.bat
new file mode 100644
index 0000000..60aaad2
--- /dev/null
+++ b/bld.bat
@@ -0,0 +1,4 @@
+@echo off
+set DIRNAME=%~dp0
+if "%DIRNAME%" == "" set DIRNAME=.
+java -jar "%DIRNAME%/lib/bld/bld-wrapper.jar" "%0" --build rife.render.TemplateRenderersBuild %*
\ No newline at end of file
diff --git a/lib/config/pmd.xml b/config/pmd.xml
similarity index 100%
rename from lib/config/pmd.xml
rename to config/pmd.xml
diff --git a/gradle/wrapper/gradle-wrapper.jar b/gradle/wrapper/gradle-wrapper.jar
deleted file mode 100644
index ccebba7..0000000
Binary files a/gradle/wrapper/gradle-wrapper.jar and /dev/null differ
diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties
deleted file mode 100644
index bdc9a83..0000000
--- a/gradle/wrapper/gradle-wrapper.properties
+++ /dev/null
@@ -1,6 +0,0 @@
-distributionBase=GRADLE_USER_HOME
-distributionPath=wrapper/dists
-distributionUrl=https\://services.gradle.org/distributions/gradle-8.0.2-bin.zip
-networkTimeout=10000
-zipStoreBase=GRADLE_USER_HOME
-zipStorePath=wrapper/dists
diff --git a/gradlew b/gradlew
deleted file mode 100755
index 79a61d4..0000000
--- a/gradlew
+++ /dev/null
@@ -1,244 +0,0 @@
-#!/bin/sh
-
-#
-# Copyright © 2015-2021 the original authors.
-#
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# https://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-#
-
-##############################################################################
-#
-# Gradle start up script for POSIX generated by Gradle.
-#
-# Important for running:
-#
-# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is
-# noncompliant, but you have some other compliant shell such as ksh or
-# bash, then to run this script, type that shell name before the whole
-# command line, like:
-#
-# ksh Gradle
-#
-# Busybox and similar reduced shells will NOT work, because this script
-# requires all of these POSIX shell features:
-# * functions;
-# * expansions «$var», «${var}», «${var:-default}», «${var+SET}»,
-# «${var#prefix}», «${var%suffix}», and «$( cmd )»;
-# * compound commands having a testable exit status, especially «case»;
-# * various built-in commands including «command», «set», and «ulimit».
-#
-# Important for patching:
-#
-# (2) This script targets any POSIX shell, so it avoids extensions provided
-# by Bash, Ksh, etc; in particular arrays are avoided.
-#
-# The "traditional" practice of packing multiple parameters into a
-# space-separated string is a well documented source of bugs and security
-# problems, so this is (mostly) avoided, by progressively accumulating
-# options in "$@", and eventually passing that to Java.
-#
-# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS,
-# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly;
-# see the in-line comments for details.
-#
-# There are tweaks for specific operating systems such as AIX, CygWin,
-# Darwin, MinGW, and NonStop.
-#
-# (3) This script is generated from the Groovy template
-# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
-# within the Gradle project.
-#
-# You can find Gradle at https://github.com/gradle/gradle/.
-#
-##############################################################################
-
-# Attempt to set APP_HOME
-
-# Resolve links: $0 may be a link
-app_path=$0
-
-# Need this for daisy-chained symlinks.
-while
- APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path
- [ -h "$app_path" ]
-do
- ls=$( ls -ld "$app_path" )
- link=${ls#*' -> '}
- case $link in #(
- /*) app_path=$link ;; #(
- *) app_path=$APP_HOME$link ;;
- esac
-done
-
-# This is normally unused
-# shellcheck disable=SC2034
-APP_BASE_NAME=${0##*/}
-APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
-
-# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
-DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
-
-# Use the maximum available, or set MAX_FD != -1 to use that value.
-MAX_FD=maximum
-
-warn () {
- echo "$*"
-} >&2
-
-die () {
- echo
- echo "$*"
- echo
- exit 1
-} >&2
-
-# OS specific support (must be 'true' or 'false').
-cygwin=false
-msys=false
-darwin=false
-nonstop=false
-case "$( uname )" in #(
- CYGWIN* ) cygwin=true ;; #(
- Darwin* ) darwin=true ;; #(
- MSYS* | MINGW* ) msys=true ;; #(
- NONSTOP* ) nonstop=true ;;
-esac
-
-CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
-
-
-# Determine the Java command to use to start the JVM.
-if [ -n "$JAVA_HOME" ] ; then
- if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
- # IBM's JDK on AIX uses strange locations for the executables
- JAVACMD=$JAVA_HOME/jre/sh/java
- else
- JAVACMD=$JAVA_HOME/bin/java
- fi
- if [ ! -x "$JAVACMD" ] ; then
- die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
-
-Please set the JAVA_HOME variable in your environment to match the
-location of your Java installation."
- fi
-else
- JAVACMD=java
- which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
-
-Please set the JAVA_HOME variable in your environment to match the
-location of your Java installation."
-fi
-
-# Increase the maximum file descriptors if we can.
-if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
- case $MAX_FD in #(
- max*)
- # In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
- # shellcheck disable=SC3045
- MAX_FD=$( ulimit -H -n ) ||
- warn "Could not query maximum file descriptor limit"
- esac
- case $MAX_FD in #(
- '' | soft) :;; #(
- *)
- # In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
- # shellcheck disable=SC3045
- ulimit -n "$MAX_FD" ||
- warn "Could not set maximum file descriptor limit to $MAX_FD"
- esac
-fi
-
-# Collect all arguments for the java command, stacking in reverse order:
-# * args from the command line
-# * the main class name
-# * -classpath
-# * -D...appname settings
-# * --module-path (only if needed)
-# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables.
-
-# For Cygwin or MSYS, switch paths to Windows format before running java
-if "$cygwin" || "$msys" ; then
- APP_HOME=$( cygpath --path --mixed "$APP_HOME" )
- CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" )
-
- JAVACMD=$( cygpath --unix "$JAVACMD" )
-
- # Now convert the arguments - kludge to limit ourselves to /bin/sh
- for arg do
- if
- case $arg in #(
- -*) false ;; # don't mess with options #(
- /?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath
- [ -e "$t" ] ;; #(
- *) false ;;
- esac
- then
- arg=$( cygpath --path --ignore --mixed "$arg" )
- fi
- # Roll the args list around exactly as many times as the number of
- # args, so each arg winds up back in the position where it started, but
- # possibly modified.
- #
- # NB: a `for` loop captures its iteration list before it begins, so
- # changing the positional parameters here affects neither the number of
- # iterations, nor the values presented in `arg`.
- shift # remove old arg
- set -- "$@" "$arg" # push replacement arg
- done
-fi
-
-# Collect all arguments for the java command;
-# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of
-# shell script including quotes and variable substitutions, so put them in
-# double quotes to make sure that they get re-expanded; and
-# * put everything else in single quotes, so that it's not re-expanded.
-
-set -- \
- "-Dorg.gradle.appname=$APP_BASE_NAME" \
- -classpath "$CLASSPATH" \
- org.gradle.wrapper.GradleWrapperMain \
- "$@"
-
-# Stop when "xargs" is not available.
-if ! command -v xargs >/dev/null 2>&1
-then
- die "xargs is not available"
-fi
-
-# Use "xargs" to parse quoted args.
-#
-# With -n1 it outputs one arg per line, with the quotes and backslashes removed.
-#
-# In Bash we could simply go:
-#
-# readarray ARGS < <( xargs -n1 <<<"$var" ) &&
-# set -- "${ARGS[@]}" "$@"
-#
-# but POSIX shell has neither arrays nor command substitution, so instead we
-# post-process each arg (as a line of input to sed) to backslash-escape any
-# character that might be a shell metacharacter, then use eval to reverse
-# that process (while maintaining the separation between arguments), and wrap
-# the whole thing up as a single "set" statement.
-#
-# This will of course break if any of these variables contains a newline or
-# an unmatched quote.
-#
-
-eval "set -- $(
- printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" |
- xargs -n1 |
- sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' |
- tr '\n' ' '
- )" '"$@"'
-
-exec "$JAVACMD" "$@"
diff --git a/gradlew.bat b/gradlew.bat
deleted file mode 100644
index 93e3f59..0000000
--- a/gradlew.bat
+++ /dev/null
@@ -1,92 +0,0 @@
-@rem
-@rem Copyright 2015 the original author or authors.
-@rem
-@rem Licensed under the Apache License, Version 2.0 (the "License");
-@rem you may not use this file except in compliance with the License.
-@rem You may obtain a copy of the License at
-@rem
-@rem https://www.apache.org/licenses/LICENSE-2.0
-@rem
-@rem Unless required by applicable law or agreed to in writing, software
-@rem distributed under the License is distributed on an "AS IS" BASIS,
-@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-@rem See the License for the specific language governing permissions and
-@rem limitations under the License.
-@rem
-
-@if "%DEBUG%"=="" @echo off
-@rem ##########################################################################
-@rem
-@rem Gradle startup script for Windows
-@rem
-@rem ##########################################################################
-
-@rem Set local scope for the variables with windows NT shell
-if "%OS%"=="Windows_NT" setlocal
-
-set DIRNAME=%~dp0
-if "%DIRNAME%"=="" set DIRNAME=.
-@rem This is normally unused
-set APP_BASE_NAME=%~n0
-set APP_HOME=%DIRNAME%
-
-@rem Resolve any "." and ".." in APP_HOME to make it shorter.
-for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
-
-@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
-set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
-
-@rem Find java.exe
-if defined JAVA_HOME goto findJavaFromJavaHome
-
-set JAVA_EXE=java.exe
-%JAVA_EXE% -version >NUL 2>&1
-if %ERRORLEVEL% equ 0 goto execute
-
-echo.
-echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
-echo.
-echo Please set the JAVA_HOME variable in your environment to match the
-echo location of your Java installation.
-
-goto fail
-
-:findJavaFromJavaHome
-set JAVA_HOME=%JAVA_HOME:"=%
-set JAVA_EXE=%JAVA_HOME%/bin/java.exe
-
-if exist "%JAVA_EXE%" goto execute
-
-echo.
-echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
-echo.
-echo Please set the JAVA_HOME variable in your environment to match the
-echo location of your Java installation.
-
-goto fail
-
-:execute
-@rem Setup the command line
-
-set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
-
-
-@rem Execute Gradle
-"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %*
-
-:end
-@rem End local scope for the variables with windows NT shell
-if %ERRORLEVEL% equ 0 goto mainEnd
-
-:fail
-rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
-rem the _cmd.exe /c_ return code!
-set EXIT_CODE=%ERRORLEVEL%
-if %EXIT_CODE% equ 0 set EXIT_CODE=1
-if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE%
-exit /b %EXIT_CODE%
-
-:mainEnd
-if "%OS%"=="Windows_NT" endlocal
-
-:omega
diff --git a/lib/bld/bld-wrapper.jar b/lib/bld/bld-wrapper.jar
new file mode 100644
index 0000000..a2bd323
Binary files /dev/null and b/lib/bld/bld-wrapper.jar differ
diff --git a/lib/bld/bld-wrapper.properties b/lib/bld/bld-wrapper.properties
new file mode 100644
index 0000000..a3374d3
--- /dev/null
+++ b/lib/bld/bld-wrapper.properties
@@ -0,0 +1,6 @@
+bld.downloadExtensionJavadoc=false
+bld.downloadExtensionSources=true
+bld.extension-tests=com.uwyn.rife2:bld-tests-badge:1.0.0
+bld.repositories=MAVEN_CENTRAL,RIFE2_RELEASES
+rife2.downloadLocation=
+rife2.version=1.5.18
\ No newline at end of file
diff --git a/lib/build.gradle.kts b/lib/build.gradle.kts
deleted file mode 100644
index b549fc0..0000000
--- a/lib/build.gradle.kts
+++ /dev/null
@@ -1,202 +0,0 @@
-import org.gradle.api.tasks.testing.logging.TestExceptionFormat
-import org.gradle.api.tasks.testing.logging.TestLogEvent
-import java.net.URI
-import java.net.http.HttpClient
-import java.net.http.HttpRequest
-import java.net.http.HttpResponse
-
-plugins {
- `java-library`
- `maven-publish`
- pmd
- signing
- id("com.github.ben-manes.versions") version "0.46.0"
-}
-
-val rifeVersion by rootProject.extra { "1.5.6" }
-
-group = "com.uwyn.rife2"
-version = "1.1.0"
-
-repositories {
- mavenLocal()
- mavenCentral()
- maven { url = uri("https://s01.oss.sonatype.org/content/repositories/snapshots") } // only needed for SNAPSHOT
-}
-
-dependencies {
- implementation("com.uwyn.rife2:rife2:${rifeVersion}") {
- this.isChanging = true
- }
- runtimeOnly("com.uwyn.rife2:rife2:${rifeVersion}:agent") {
- this.isChanging = true
- }
-
- testImplementation(platform("org.junit:junit-bom:5.9.2"))
- testImplementation("org.junit.jupiter:junit-jupiter")
- testImplementation("org.assertj:assertj-core:3.24.2")
-}
-
-configurations {
- all {
- resolutionStrategy.cacheChangingModulesFor(0, TimeUnit.SECONDS)
- }
-}
-
-java {
- withJavadocJar()
- withSourcesJar()
- toolchain {
- languageVersion.set(JavaLanguageVersion.of(17))
- }
-}
-
-pmd {
- isIgnoreFailures = true
- ruleSetFiles = files("${projectDir}/config/pmd.xml")
- isConsoleOutput = true
-}
-
-
-
-
-tasks {
- withType {
- options.encoding = "UTF-8"
- }
-
-
- test {
- val apiKey = project.properties["testsBadgeApiKey"]
- useJUnitPlatform {
- if (System.getenv("NO_CI") != null) {
- excludeTags("no-ci")
- println("Excluded test tags: $excludeTags")
- }
- }
-
- testLogging {
- exceptionFormat = TestExceptionFormat.FULL
- events = setOf(TestLogEvent.PASSED, TestLogEvent.SKIPPED, TestLogEvent.FAILED)
- showStandardStreams = true
- }
-
- addTestListener(object : TestListener {
- override fun beforeTest(p0: TestDescriptor?) = Unit
- override fun beforeSuite(p0: TestDescriptor?) = Unit
- override fun afterTest(desc: TestDescriptor, result: TestResult) = Unit
- override fun afterSuite(desc: TestDescriptor, result: TestResult) {
- if (desc.parent != null) {
- val output = result.run {
- "Results: $resultType (" +
- "$testCount tests, " +
- "$successfulTestCount successes, " +
- "$failedTestCount failures, " +
- "$skippedTestCount skipped" +
- ")"
- }
- val testResultLine = "| $output |"
- val repeatLength = testResultLine.length
- val separationLine = "-".repeat(repeatLength)
- println()
- println(separationLine)
- println(testResultLine)
- println(separationLine)
- }
-
- if (desc.parent == null) {
- val passed = result.successfulTestCount
- val failed = result.failedTestCount
- val skipped = result.skippedTestCount
-
- if (apiKey != null) {
- val response: HttpResponse = HttpClient.newHttpClient()
- .send(
- HttpRequest.newBuilder()
- .uri(
- URI(
- "https://rife2.com/tests-badge/update/com.uwyn.rife2/rife2-renderers?" +
- "apiKey=$apiKey&" +
- "passed=$passed&" +
- "failed=$failed&" +
- "skipped=$skipped"
- )
- )
- .POST(HttpRequest.BodyPublishers.noBody())
- .build(), HttpResponse.BodyHandlers.ofString()
- )
- println("RESPONSE: " + response.statusCode())
- println(response.body())
- }
- }
- }
- })
- }
-
- javadoc {
- title = "RIFE2 Template Renderers"
- options {
- this as StandardJavadocDocletOptions
- keyWords(true)
- splitIndex(true)
- links("https://rife2.github.io/rife2/")
- }
- }
-}
-
-publishing {
- publications {
- create("mavenJava") {
- artifactId = "rife2-renderers"
- from(components["java"])
- pom {
- name.set("RIFE2 Template Renderers")
- description.set("Template Renderers for the RIFE2 web framework")
- url.set("https://github.com/rife2/rife2-template-renderers")
- licenses {
- license {
- name.set("The Apache License, Version 2.0")
- url.set("http://www.apache.org/licenses/LICENSE-2.0.txt")
- }
- }
- developers {
- developer {
- id.set("ethauvin")
- name.set("Erik C. Thauvin")
- email.set("erik@thauvin.net")
- url.set("https://erik.thauvin.net/")
- }
- developer {
- id.set("gbevin")
- name.set("Geert Bevin")
- email.set("gbevin@uwyn.com")
- url.set("https://github.com/gbevin")
- }
- }
- scm {
- connection.set("scm:git:https://github.com/rife2/rife2-template-renderers.git")
- developerConnection.set("scm:git:git@github.com:rife2/rife2-template-renderers.git")
- url.set("https://github.com/rife2/rife2-template-renderers")
- }
- }
- repositories {
- maven {
- credentials {
- username = System.getenv("SONATYPE_USER")
- password = System.getenv("SONATYPE_PASSWORD")
- }
- val releasesRepoUrl = uri("https://s01.oss.sonatype.org/service/local/staging/deploy/maven2/")
- val snapshotsRepoUrl = uri("https://s01.oss.sonatype.org/content/repositories/snapshots/")
- url = if (version.toString().endsWith("SNAPSHOT")) snapshotsRepoUrl else releasesRepoUrl
- }
- }
- }
- }
-}
-
-signing {
- val signingKey: String? by project // ORG_GRADLE_PROJECT_signingKey
- val signingPassword: String? by project // ORG_GRADLE_PROJECT_signingPassword
- useInMemoryPgpKeys(signingKey, signingPassword)
- sign(publishing.publications["mavenJava"])
-}
diff --git a/settings.gradle.kts b/settings.gradle.kts
deleted file mode 100644
index fc4b198..0000000
--- a/settings.gradle.kts
+++ /dev/null
@@ -1,2 +0,0 @@
-rootProject.name = "rife2-template-renderers"
-include("lib")
diff --git a/src/bld/java/rife/render/TemplateRenderersBuild.java b/src/bld/java/rife/render/TemplateRenderersBuild.java
new file mode 100644
index 0000000..093a547
--- /dev/null
+++ b/src/bld/java/rife/render/TemplateRenderersBuild.java
@@ -0,0 +1,75 @@
+package rife.render;
+
+import rife.bld.Project;
+import rife.bld.extension.TestsBadgeOperation;
+import rife.bld.publish.PublishDeveloper;
+import rife.bld.publish.PublishInfo;
+import rife.bld.publish.PublishLicense;
+import rife.bld.publish.PublishScm;
+
+import java.util.List;
+
+import static rife.bld.dependencies.Repository.*;
+import static rife.bld.dependencies.Scope.*;
+import static rife.bld.operations.JavadocOptions.DocLinkOption.NO_MISSING;
+
+public class TemplateRenderersBuild extends Project {
+ private final TestsBadgeOperation testsBadgeOperation = new TestsBadgeOperation();
+
+ public TemplateRenderersBuild() {
+ pkg = "rife.render";
+ name = "rife2-template-renderers";
+ version = version(1, 1, 0);
+
+ javadocOperation().javadocOptions()
+ .docTitle("RIFE2 Template Renderers")
+ .docLint(NO_MISSING)
+ .link("https://rife2.github.io/rife2/");
+
+ publishOperation()
+// .repository(version.isSnapshot() ? repository("rife2-snapshots") : repository("rife2-releases"))
+ .repository(MAVEN_LOCAL)
+ .info(new PublishInfo()
+ .groupId("com.uwyn.rife2")
+ .artifactId("rife2-renderers")
+ .name("RIFE2 Template Renderers")
+ .description("Template Renderers for the RIFE2 web framework")
+ .url("https://github.com/rife2/rife2-template-renderers")
+ .developer(new PublishDeveloper().id("ethauvin").name("Erik C. Thauvin").email("erik@thauvin.net")
+ .url("https://erik.thauvin.net/"))
+ .developer(new PublishDeveloper().id("gbevin").name("Geert Bevin").email("gbevin@uwyn.com")
+ .url("https://github.com/gbevin"))
+ .license(new PublishLicense().name("The Apache License, Version 2.0")
+ .url("http://www.apache.org/licenses/LICENSE-2.0.txt"))
+ .scm(new PublishScm().connection("scm:git:https://github.com/rife2/rife2-template-renderers.git")
+ .developerConnection("scm:git:git@github.com:rife2/rife2-template-renderers.git")
+ .url("https://github.com/rife2/rife2-template-renderers"))
+ .signKey(property("sign.key"))
+ .signPassphrase(property("sign.passphrase")));
+
+ javaRelease = 17;
+ downloadSources = true;
+ autoDownloadPurge = true;
+ repositories = List.of(MAVEN_CENTRAL, RIFE2_RELEASES, RIFE2_SNAPSHOTS);
+
+ scope(compile)
+ .include(dependency("com.uwyn.rife2", "rife2", version(1, 5, 18)));
+ scope(runtime)
+ .include(dependency("com.uwyn.rife2", "rife2", version(1, 5, 17), "agent"));
+ scope(test)
+ .include(dependency("org.junit.jupiter", "junit-jupiter", version(5, 9, 2)))
+ .include(dependency("org.junit.platform", "junit-platform-console-standalone", version(1, 9, 2)))
+ .include(dependency("org.assertj:assertj-core:3.24.2"));
+ }
+
+ public static void main(String[] args) {
+ new TemplateRenderersBuild().start(args);
+ }
+
+ public void test() throws Exception {
+ testsBadgeOperation.executeOnce(() -> testsBadgeOperation
+ .url(property("testsBadgeUrl"))
+ .apiKey(property("testsBadgeApiKey"))
+ .fromProject(this));
+ }
+}
\ No newline at end of file
diff --git a/lib/src/main/java/rife/render/Abbreviate.java b/src/main/java/rife/render/Abbreviate.java
similarity index 100%
rename from lib/src/main/java/rife/render/Abbreviate.java
rename to src/main/java/rife/render/Abbreviate.java
diff --git a/lib/src/main/java/rife/render/BeatTime.java b/src/main/java/rife/render/BeatTime.java
similarity index 100%
rename from lib/src/main/java/rife/render/BeatTime.java
rename to src/main/java/rife/render/BeatTime.java
diff --git a/lib/src/main/java/rife/render/Capitalize.java b/src/main/java/rife/render/Capitalize.java
similarity index 100%
rename from lib/src/main/java/rife/render/Capitalize.java
rename to src/main/java/rife/render/Capitalize.java
diff --git a/lib/src/main/java/rife/render/DateIso.java b/src/main/java/rife/render/DateIso.java
similarity index 100%
rename from lib/src/main/java/rife/render/DateIso.java
rename to src/main/java/rife/render/DateIso.java
diff --git a/lib/src/main/java/rife/render/DateTimeIso.java b/src/main/java/rife/render/DateTimeIso.java
similarity index 100%
rename from lib/src/main/java/rife/render/DateTimeIso.java
rename to src/main/java/rife/render/DateTimeIso.java
diff --git a/lib/src/main/java/rife/render/DateTimeRfc2822.java b/src/main/java/rife/render/DateTimeRfc2822.java
similarity index 100%
rename from lib/src/main/java/rife/render/DateTimeRfc2822.java
rename to src/main/java/rife/render/DateTimeRfc2822.java
diff --git a/lib/src/main/java/rife/render/EncodeBase64.java b/src/main/java/rife/render/EncodeBase64.java
similarity index 100%
rename from lib/src/main/java/rife/render/EncodeBase64.java
rename to src/main/java/rife/render/EncodeBase64.java
diff --git a/lib/src/main/java/rife/render/EncodeHtml.java b/src/main/java/rife/render/EncodeHtml.java
similarity index 100%
rename from lib/src/main/java/rife/render/EncodeHtml.java
rename to src/main/java/rife/render/EncodeHtml.java
diff --git a/lib/src/main/java/rife/render/EncodeHtmlEntities.java b/src/main/java/rife/render/EncodeHtmlEntities.java
similarity index 100%
rename from lib/src/main/java/rife/render/EncodeHtmlEntities.java
rename to src/main/java/rife/render/EncodeHtmlEntities.java
diff --git a/lib/src/main/java/rife/render/EncodeJs.java b/src/main/java/rife/render/EncodeJs.java
similarity index 100%
rename from lib/src/main/java/rife/render/EncodeJs.java
rename to src/main/java/rife/render/EncodeJs.java
diff --git a/lib/src/main/java/rife/render/EncodeJson.java b/src/main/java/rife/render/EncodeJson.java
similarity index 100%
rename from lib/src/main/java/rife/render/EncodeJson.java
rename to src/main/java/rife/render/EncodeJson.java
diff --git a/lib/src/main/java/rife/render/EncodeUnicode.java b/src/main/java/rife/render/EncodeUnicode.java
similarity index 100%
rename from lib/src/main/java/rife/render/EncodeUnicode.java
rename to src/main/java/rife/render/EncodeUnicode.java
diff --git a/lib/src/main/java/rife/render/EncodeUrl.java b/src/main/java/rife/render/EncodeUrl.java
similarity index 100%
rename from lib/src/main/java/rife/render/EncodeUrl.java
rename to src/main/java/rife/render/EncodeUrl.java
diff --git a/lib/src/main/java/rife/render/EncodeXml.java b/src/main/java/rife/render/EncodeXml.java
similarity index 100%
rename from lib/src/main/java/rife/render/EncodeXml.java
rename to src/main/java/rife/render/EncodeXml.java
diff --git a/lib/src/main/java/rife/render/FormatCreditCard.java b/src/main/java/rife/render/FormatCreditCard.java
similarity index 100%
rename from lib/src/main/java/rife/render/FormatCreditCard.java
rename to src/main/java/rife/render/FormatCreditCard.java
diff --git a/lib/src/main/java/rife/render/Lowercase.java b/src/main/java/rife/render/Lowercase.java
similarity index 100%
rename from lib/src/main/java/rife/render/Lowercase.java
rename to src/main/java/rife/render/Lowercase.java
diff --git a/lib/src/main/java/rife/render/Mask.java b/src/main/java/rife/render/Mask.java
similarity index 100%
rename from lib/src/main/java/rife/render/Mask.java
rename to src/main/java/rife/render/Mask.java
diff --git a/lib/src/main/java/rife/render/Normalize.java b/src/main/java/rife/render/Normalize.java
similarity index 100%
rename from lib/src/main/java/rife/render/Normalize.java
rename to src/main/java/rife/render/Normalize.java
diff --git a/lib/src/main/java/rife/render/QrCode.java b/src/main/java/rife/render/QrCode.java
similarity index 100%
rename from lib/src/main/java/rife/render/QrCode.java
rename to src/main/java/rife/render/QrCode.java
diff --git a/lib/src/main/java/rife/render/RenderUtils.java b/src/main/java/rife/render/RenderUtils.java
similarity index 100%
rename from lib/src/main/java/rife/render/RenderUtils.java
rename to src/main/java/rife/render/RenderUtils.java
diff --git a/lib/src/main/java/rife/render/Rot13.java b/src/main/java/rife/render/Rot13.java
similarity index 100%
rename from lib/src/main/java/rife/render/Rot13.java
rename to src/main/java/rife/render/Rot13.java
diff --git a/lib/src/main/java/rife/render/ShortenUrl.java b/src/main/java/rife/render/ShortenUrl.java
similarity index 100%
rename from lib/src/main/java/rife/render/ShortenUrl.java
rename to src/main/java/rife/render/ShortenUrl.java
diff --git a/lib/src/main/java/rife/render/SwapCase.java b/src/main/java/rife/render/SwapCase.java
similarity index 100%
rename from lib/src/main/java/rife/render/SwapCase.java
rename to src/main/java/rife/render/SwapCase.java
diff --git a/lib/src/main/java/rife/render/TimeIso.java b/src/main/java/rife/render/TimeIso.java
similarity index 100%
rename from lib/src/main/java/rife/render/TimeIso.java
rename to src/main/java/rife/render/TimeIso.java
diff --git a/lib/src/main/java/rife/render/Trim.java b/src/main/java/rife/render/Trim.java
similarity index 100%
rename from lib/src/main/java/rife/render/Trim.java
rename to src/main/java/rife/render/Trim.java
diff --git a/lib/src/main/java/rife/render/Uncapitalize.java b/src/main/java/rife/render/Uncapitalize.java
similarity index 100%
rename from lib/src/main/java/rife/render/Uncapitalize.java
rename to src/main/java/rife/render/Uncapitalize.java
diff --git a/lib/src/main/java/rife/render/Uppercase.java b/src/main/java/rife/render/Uppercase.java
similarity index 100%
rename from lib/src/main/java/rife/render/Uppercase.java
rename to src/main/java/rife/render/Uppercase.java
diff --git a/lib/src/main/java/rife/render/Uptime.java b/src/main/java/rife/render/Uptime.java
similarity index 100%
rename from lib/src/main/java/rife/render/Uptime.java
rename to src/main/java/rife/render/Uptime.java
diff --git a/lib/src/main/java/rife/render/Year.java b/src/main/java/rife/render/Year.java
similarity index 100%
rename from lib/src/main/java/rife/render/Year.java
rename to src/main/java/rife/render/Year.java
diff --git a/src/test/java/rife/render/DisableOnCiCondition.java b/src/test/java/rife/render/DisableOnCiCondition.java
new file mode 100644
index 0000000..cd59296
--- /dev/null
+++ b/src/test/java/rife/render/DisableOnCiCondition.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2023 the original author or authors.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * https://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+package rife.render;
+
+import org.junit.jupiter.api.extension.ConditionEvaluationResult;
+import org.junit.jupiter.api.extension.ExecutionCondition;
+import org.junit.jupiter.api.extension.ExtensionContext;
+
+/**
+ * Disables tests on CI condition.
+ *
+ * @author Erik C. Thauvin
+ * @since 1.0
+ */
+public class DisableOnCiCondition implements ExecutionCondition {
+ @Override
+ public ConditionEvaluationResult evaluateExecutionCondition(ExtensionContext context) {
+ if (System.getenv("CI") != null) {
+ return ConditionEvaluationResult.disabled("Test disabled on CI");
+ } else {
+ return ConditionEvaluationResult.enabled("Test enabled");
+ }
+ }
+}
diff --git a/src/test/java/rife/render/DisabledOnCi.java b/src/test/java/rife/render/DisabledOnCi.java
new file mode 100644
index 0000000..b243ee7
--- /dev/null
+++ b/src/test/java/rife/render/DisabledOnCi.java
@@ -0,0 +1,37 @@
+/*
+ * Copyright 2023 the original author or authors.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * https://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+package rife.render;
+
+import org.junit.jupiter.api.extension.ExtendWith;
+
+import java.lang.annotation.ElementType;
+import java.lang.annotation.Retention;
+import java.lang.annotation.RetentionPolicy;
+import java.lang.annotation.Target;
+
+/**
+ * Disables tests on CI annotation.
+ *
+ * @author Erik C. Thauvin
+ * @since 1.0
+ */
+@Target({ ElementType.TYPE, ElementType.METHOD })
+@Retention(RetentionPolicy.RUNTIME)
+@ExtendWith(DisableOnCiCondition.class)
+public @interface DisabledOnCi {
+}
diff --git a/lib/src/test/java/rife/render/TestCase.java b/src/test/java/rife/render/TestCase.java
similarity index 100%
rename from lib/src/test/java/rife/render/TestCase.java
rename to src/test/java/rife/render/TestCase.java
diff --git a/lib/src/test/java/rife/render/TestDateTime.java b/src/test/java/rife/render/TestDateTime.java
similarity index 100%
rename from lib/src/test/java/rife/render/TestDateTime.java
rename to src/test/java/rife/render/TestDateTime.java
diff --git a/lib/src/test/java/rife/render/TestEncode.java b/src/test/java/rife/render/TestEncode.java
similarity index 100%
rename from lib/src/test/java/rife/render/TestEncode.java
rename to src/test/java/rife/render/TestEncode.java
diff --git a/lib/src/test/java/rife/render/TestFormat.java b/src/test/java/rife/render/TestFormat.java
similarity index 99%
rename from lib/src/test/java/rife/render/TestFormat.java
rename to src/test/java/rife/render/TestFormat.java
index d383198..706c648 100644
--- a/lib/src/test/java/rife/render/TestFormat.java
+++ b/src/test/java/rife/render/TestFormat.java
@@ -71,7 +71,7 @@ class TestFormat {
}
@Test
- @Tag("no-ci")
+ @DisabledOnCi
void testQrCode() {
var t = TemplateFactory.SVG.get("qrCode");
var foo = "https://example.com/";
@@ -80,7 +80,7 @@ class TestFormat {
}
@Test
- @Tag("no-ci")
+ @DisabledOnCi
void testShortenUrl() {
var t = TemplateFactory.HTML.get("shortenUrl");
var url = "https://example.com/";
diff --git a/lib/src/test/java/rife/render/TestRenderUtils.java b/src/test/java/rife/render/TestRenderUtils.java
similarity index 100%
rename from lib/src/test/java/rife/render/TestRenderUtils.java
rename to src/test/java/rife/render/TestRenderUtils.java
diff --git a/lib/src/test/java/rife/render/ValueBean.java b/src/test/java/rife/render/ValueBean.java
similarity index 100%
rename from lib/src/test/java/rife/render/ValueBean.java
rename to src/test/java/rife/render/ValueBean.java
diff --git a/lib/src/test/resources/templates/abbreviate.html b/src/test/resources/templates/abbreviate.html
similarity index 100%
rename from lib/src/test/resources/templates/abbreviate.html
rename to src/test/resources/templates/abbreviate.html
diff --git a/lib/src/test/resources/templates/abbreviate.txt b/src/test/resources/templates/abbreviate.txt
similarity index 100%
rename from lib/src/test/resources/templates/abbreviate.txt
rename to src/test/resources/templates/abbreviate.txt
diff --git a/lib/src/test/resources/templates/beatTime.html b/src/test/resources/templates/beatTime.html
similarity index 100%
rename from lib/src/test/resources/templates/beatTime.html
rename to src/test/resources/templates/beatTime.html
diff --git a/lib/src/test/resources/templates/capitalize.txt b/src/test/resources/templates/capitalize.txt
similarity index 100%
rename from lib/src/test/resources/templates/capitalize.txt
rename to src/test/resources/templates/capitalize.txt
diff --git a/lib/src/test/resources/templates/dateIso.html b/src/test/resources/templates/dateIso.html
similarity index 100%
rename from lib/src/test/resources/templates/dateIso.html
rename to src/test/resources/templates/dateIso.html
diff --git a/lib/src/test/resources/templates/dateTimeIso.html b/src/test/resources/templates/dateTimeIso.html
similarity index 100%
rename from lib/src/test/resources/templates/dateTimeIso.html
rename to src/test/resources/templates/dateTimeIso.html
diff --git a/lib/src/test/resources/templates/dateTimeRfc2822.html b/src/test/resources/templates/dateTimeRfc2822.html
similarity index 100%
rename from lib/src/test/resources/templates/dateTimeRfc2822.html
rename to src/test/resources/templates/dateTimeRfc2822.html
diff --git a/lib/src/test/resources/templates/dateTimeUtc.html b/src/test/resources/templates/dateTimeUtc.html
similarity index 100%
rename from lib/src/test/resources/templates/dateTimeUtc.html
rename to src/test/resources/templates/dateTimeUtc.html
diff --git a/lib/src/test/resources/templates/encodeBase64.html b/src/test/resources/templates/encodeBase64.html
similarity index 100%
rename from lib/src/test/resources/templates/encodeBase64.html
rename to src/test/resources/templates/encodeBase64.html
diff --git a/lib/src/test/resources/templates/encodeBase64.txt b/src/test/resources/templates/encodeBase64.txt
similarity index 100%
rename from lib/src/test/resources/templates/encodeBase64.txt
rename to src/test/resources/templates/encodeBase64.txt
diff --git a/lib/src/test/resources/templates/encodeHtml.html b/src/test/resources/templates/encodeHtml.html
similarity index 100%
rename from lib/src/test/resources/templates/encodeHtml.html
rename to src/test/resources/templates/encodeHtml.html
diff --git a/lib/src/test/resources/templates/encodeHtmlEntities.html b/src/test/resources/templates/encodeHtmlEntities.html
similarity index 100%
rename from lib/src/test/resources/templates/encodeHtmlEntities.html
rename to src/test/resources/templates/encodeHtmlEntities.html
diff --git a/lib/src/test/resources/templates/encodeJs.html b/src/test/resources/templates/encodeJs.html
similarity index 100%
rename from lib/src/test/resources/templates/encodeJs.html
rename to src/test/resources/templates/encodeJs.html
diff --git a/lib/src/test/resources/templates/encodeJs.txt b/src/test/resources/templates/encodeJs.txt
similarity index 100%
rename from lib/src/test/resources/templates/encodeJs.txt
rename to src/test/resources/templates/encodeJs.txt
diff --git a/lib/src/test/resources/templates/encodeJson.html b/src/test/resources/templates/encodeJson.html
similarity index 100%
rename from lib/src/test/resources/templates/encodeJson.html
rename to src/test/resources/templates/encodeJson.html
diff --git a/lib/src/test/resources/templates/encodeJson.json b/src/test/resources/templates/encodeJson.json
similarity index 100%
rename from lib/src/test/resources/templates/encodeJson.json
rename to src/test/resources/templates/encodeJson.json
diff --git a/lib/src/test/resources/templates/encodeUnicode.html b/src/test/resources/templates/encodeUnicode.html
similarity index 100%
rename from lib/src/test/resources/templates/encodeUnicode.html
rename to src/test/resources/templates/encodeUnicode.html
diff --git a/lib/src/test/resources/templates/encodeUnicode.txt b/src/test/resources/templates/encodeUnicode.txt
similarity index 100%
rename from lib/src/test/resources/templates/encodeUnicode.txt
rename to src/test/resources/templates/encodeUnicode.txt
diff --git a/lib/src/test/resources/templates/encodeUrl.html b/src/test/resources/templates/encodeUrl.html
similarity index 100%
rename from lib/src/test/resources/templates/encodeUrl.html
rename to src/test/resources/templates/encodeUrl.html
diff --git a/lib/src/test/resources/templates/encodeUrlwithUnicode.html b/src/test/resources/templates/encodeUrlwithUnicode.html
similarity index 100%
rename from lib/src/test/resources/templates/encodeUrlwithUnicode.html
rename to src/test/resources/templates/encodeUrlwithUnicode.html
diff --git a/lib/src/test/resources/templates/encodeXml.xml b/src/test/resources/templates/encodeXml.xml
similarity index 100%
rename from lib/src/test/resources/templates/encodeXml.xml
rename to src/test/resources/templates/encodeXml.xml
diff --git a/lib/src/test/resources/templates/formatCreditCard.txt b/src/test/resources/templates/formatCreditCard.txt
similarity index 100%
rename from lib/src/test/resources/templates/formatCreditCard.txt
rename to src/test/resources/templates/formatCreditCard.txt
diff --git a/lib/src/test/resources/templates/lowercase.txt b/src/test/resources/templates/lowercase.txt
similarity index 100%
rename from lib/src/test/resources/templates/lowercase.txt
rename to src/test/resources/templates/lowercase.txt
diff --git a/lib/src/test/resources/templates/mask.html b/src/test/resources/templates/mask.html
similarity index 100%
rename from lib/src/test/resources/templates/mask.html
rename to src/test/resources/templates/mask.html
diff --git a/lib/src/test/resources/templates/mask.txt b/src/test/resources/templates/mask.txt
similarity index 100%
rename from lib/src/test/resources/templates/mask.txt
rename to src/test/resources/templates/mask.txt
diff --git a/lib/src/test/resources/templates/normalize.html b/src/test/resources/templates/normalize.html
similarity index 100%
rename from lib/src/test/resources/templates/normalize.html
rename to src/test/resources/templates/normalize.html
diff --git a/lib/src/test/resources/templates/qrCode.svg b/src/test/resources/templates/qrCode.svg
similarity index 100%
rename from lib/src/test/resources/templates/qrCode.svg
rename to src/test/resources/templates/qrCode.svg
diff --git a/lib/src/test/resources/templates/rot13.txt b/src/test/resources/templates/rot13.txt
similarity index 100%
rename from lib/src/test/resources/templates/rot13.txt
rename to src/test/resources/templates/rot13.txt
diff --git a/lib/src/test/resources/templates/shortenUrl.html b/src/test/resources/templates/shortenUrl.html
similarity index 100%
rename from lib/src/test/resources/templates/shortenUrl.html
rename to src/test/resources/templates/shortenUrl.html
diff --git a/lib/src/test/resources/templates/swapCase.txt b/src/test/resources/templates/swapCase.txt
similarity index 100%
rename from lib/src/test/resources/templates/swapCase.txt
rename to src/test/resources/templates/swapCase.txt
diff --git a/lib/src/test/resources/templates/timeIso.html b/src/test/resources/templates/timeIso.html
similarity index 100%
rename from lib/src/test/resources/templates/timeIso.html
rename to src/test/resources/templates/timeIso.html
diff --git a/lib/src/test/resources/templates/trim.txt b/src/test/resources/templates/trim.txt
similarity index 100%
rename from lib/src/test/resources/templates/trim.txt
rename to src/test/resources/templates/trim.txt
diff --git a/lib/src/test/resources/templates/uncapitalize.txt b/src/test/resources/templates/uncapitalize.txt
similarity index 100%
rename from lib/src/test/resources/templates/uncapitalize.txt
rename to src/test/resources/templates/uncapitalize.txt
diff --git a/lib/src/test/resources/templates/uppercase.txt b/src/test/resources/templates/uppercase.txt
similarity index 100%
rename from lib/src/test/resources/templates/uppercase.txt
rename to src/test/resources/templates/uppercase.txt
diff --git a/lib/src/test/resources/templates/uptime.html b/src/test/resources/templates/uptime.html
similarity index 100%
rename from lib/src/test/resources/templates/uptime.html
rename to src/test/resources/templates/uptime.html
diff --git a/lib/src/test/resources/templates/uptime.json b/src/test/resources/templates/uptime.json
similarity index 100%
rename from lib/src/test/resources/templates/uptime.json
rename to src/test/resources/templates/uptime.json
diff --git a/lib/src/test/resources/templates/uptime.txt b/src/test/resources/templates/uptime.txt
similarity index 100%
rename from lib/src/test/resources/templates/uptime.txt
rename to src/test/resources/templates/uptime.txt
diff --git a/lib/src/test/resources/templates/uptime2.txt b/src/test/resources/templates/uptime2.txt
similarity index 100%
rename from lib/src/test/resources/templates/uptime2.txt
rename to src/test/resources/templates/uptime2.txt
diff --git a/lib/src/test/resources/templates/year.html b/src/test/resources/templates/year.html
similarity index 100%
rename from lib/src/test/resources/templates/year.html
rename to src/test/resources/templates/year.html