-
Notifications
You must be signed in to change notification settings - Fork 36
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #663 from nextcloud/bugfix/noid/better-vue-matching
fix(translationtool): Improve regex for vue translation matching
- Loading branch information
Showing
12 changed files
with
349 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
# This workflow is provided via the organization template repository | ||
# | ||
# https://github.com/nextcloud/.github | ||
# https://docs.github.com/en/actions/learn-github-actions/sharing-workflows-with-your-organization | ||
# | ||
# SPDX-FileCopyrightText: 2021-2024 Nextcloud GmbH and Nextcloud contributors | ||
# SPDX-License-Identifier: MIT | ||
|
||
name: Test translationtool | ||
|
||
on: pull_request | ||
|
||
permissions: | ||
contents: read | ||
|
||
concurrency: | ||
group: test-translationtool-${{ github.head_ref || github.run_id }} | ||
cancel-in-progress: true | ||
|
||
jobs: | ||
test: | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | ||
|
||
- name: Install gettext | ||
run: | | ||
sudo apt-get update | ||
sudo apt-get -y install gettext | ||
- name: Set up php8.1 | ||
uses: shivammathur/setup-php@c541c155eee45413f5b09a52248675b1a2575231 # v2.31.1 | ||
with: | ||
php-version: 8.1 | ||
extensions: bz2, ctype, curl, dom, fileinfo, gd, iconv, intl, json, libxml, mbstring, openssl, pcntl, posix, session, simplexml, xmlreader, xmlwriter, zip, zlib, sqlite, pdo_sqlite | ||
coverage: none | ||
ini-file: development | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
- name: Install dependencies of translationtool/ directory | ||
working-directory: translations/translationtool/ | ||
run: composer i | ||
|
||
- name: Install dependencies of translationtool.php | ||
working-directory: translations/translationtool/src | ||
run: composer i | ||
|
||
- name: Create POT files | ||
working-directory: translations/translationtool/ | ||
run: composer run test |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,3 +2,4 @@ vendor | |
composer.phar | ||
.vscode | ||
.php-cs-fixer.cache | ||
/tests/translationfiles/templates/tests.pot |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,168 @@ | ||
# SOME DESCRIPTIVE TITLE. | ||
# Copyright (C) YEAR THE PACKAGE'S COPYRIGHT HOLDER | ||
# This file is distributed under the same license as the Nextcloud package. | ||
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR. | ||
# | ||
#, fuzzy | ||
msgid "" | ||
msgstr "" | ||
|
||
#. TRANSLATORS PHP string with plain text | ||
#: lib/php.php:12 | ||
msgid "PHP String" | ||
msgstr "" | ||
|
||
#. TRANSLATORS PHP string with parameters | ||
#: lib/php.php:14 | ||
#, php-format | ||
msgid "PHP String with %s" | ||
msgstr "" | ||
|
||
#. TRANSLATORS PHP string with positional parameters | ||
#: lib/php.php:16 | ||
#, php-format | ||
msgid "PHP String with positional %1$s" | ||
msgstr "" | ||
|
||
#. TRANSLATORS PHP plural with plain text | ||
#: lib/php.php:21 | ||
msgid "PHP %n Plural" | ||
msgid_plural "PHP %n Plurals" | ||
msgstr[0] "" | ||
msgstr[1] "" | ||
|
||
#. TRANSLATORS PHP plural with parameters | ||
#: lib/php.php:23 | ||
msgid "PHP %n Plural with %s" | ||
msgid_plural "PHP %n Plurals with %s" | ||
msgstr[0] "" | ||
msgstr[1] "" | ||
|
||
#. TRANSLATORS PHP plural with positional parameters | ||
#: lib/php.php:27 | ||
msgid "PHP %n Plural with positional %1$s" | ||
msgid_plural "PHP %n Plurals with positional %1$s" | ||
msgstr[0] "" | ||
msgstr[1] "" | ||
|
||
#. TRANSLATORS VUE string with plain text (src/vue.vue:8) | ||
#: specialVueFakeDummyForL10nScript.js:2 | ||
msgid "VUE String" | ||
msgstr "" | ||
|
||
#. TRANSLATORS VUE string with parameters (src/vue.vue:10) | ||
#: specialVueFakeDummyForL10nScript.js:4 | ||
msgid "VUE String with inline {parameter}" | ||
msgstr "" | ||
|
||
#. TRANSLATORS VUE string with wrapped parameters (src/vue.vue:12) | ||
#: specialVueFakeDummyForL10nScript.js:6 | ||
msgid "VUE String with wrapped {parameter}" | ||
msgstr "" | ||
|
||
#. TRANSLATORS VUE Fix for https://github.com/nextcloud/docker-ci/pull/663 - Part 1 (src/vue.vue:26) | ||
#: specialVueFakeDummyForL10nScript.js:8 | ||
msgid "VUE String testing" | ||
msgstr "" | ||
|
||
#: specialVueFakeDummyForL10nScript.js:8 | ||
msgid "VUE String not" | ||
msgstr "" | ||
|
||
#. TRANSLATORS VUE Fix for https://github.com/nextcloud/docker-ci/pull/663 - Part 2 (src/vue.vue:29) | ||
#: specialVueFakeDummyForL10nScript.js:10 | ||
msgid "VUE String with followup double quotes" | ||
msgstr "" | ||
|
||
#. TRANSLATORS VUE plural with plain text (src/vue.vue:17) | ||
#: specialVueFakeDummyForL10nScript.js:12 | ||
msgid "VUE %n Plural" | ||
msgid_plural "VUE %n Plurals" | ||
msgstr[0] "" | ||
msgstr[1] "" | ||
|
||
#. TRANSLATORS VUE plural with wrapped parameters (src/vue.vue:21) | ||
#: specialVueFakeDummyForL10nScript.js:16 | ||
msgid "VUE %n Plural with wrapped %s" | ||
msgid_plural "VUE %n Plurals with wrapped %s" | ||
msgstr[0] "" | ||
msgstr[1] "" | ||
|
||
#. TRANSLATORS VUE plural with parameters (src/vue.vue:19) | ||
#: specialVueFakeDummyForL10nScript.js:14 | ||
msgid "VUE %n Plural with %s" | ||
msgid_plural "VUE %n Plurals with %s" | ||
msgstr[0] "" | ||
msgstr[1] "" | ||
|
||
#. TRANSLATORS JS string with plain text | ||
#: src/js.js:7 | ||
msgid "JS String" | ||
msgstr "" | ||
|
||
#. TRANSLATORS JS string with parameters | ||
#: src/js.js:9 | ||
msgid "JS String with inline {parameter}" | ||
msgstr "" | ||
|
||
#. TRANSLATORS JS string with wrapped parameters | ||
#: src/js.js:11 | ||
msgid "JS String with wrapped {parameter}" | ||
msgstr "" | ||
|
||
#. TRANSLATORS JS plural with plain text | ||
#: src/js.js:16 | ||
msgid "JS %n Plural" | ||
msgid_plural "JS %n Plurals" | ||
msgstr[0] "" | ||
msgstr[1] "" | ||
|
||
#. TRANSLATORS JS plural with parameters | ||
#: src/js.js:18 | ||
msgid "JS %n Plural with %s" | ||
msgid_plural "JS %n Plurals with %s" | ||
msgstr[0] "" | ||
msgstr[1] "" | ||
|
||
#. TRANSLATORS JS plural with wrapped parameters | ||
#: src/js.js:20 | ||
msgid "JS %n Plural with wrapped %s" | ||
msgid_plural "JS %n Plurals with wrapped %s" | ||
msgstr[0] "" | ||
msgstr[1] "" | ||
|
||
#. TRANSLATORS TS string with plain text | ||
#: src/ts.ts:7 | ||
msgid "TS String" | ||
msgstr "" | ||
|
||
#. TRANSLATORS TS string with parameters | ||
#: src/ts.ts:9 | ||
msgid "TS String with inline {parameter}" | ||
msgstr "" | ||
|
||
#. TRANSLATORS TS string with wrapped parameters | ||
#: src/ts.ts:11 | ||
msgid "TS String with wrapped {parameter}" | ||
msgstr "" | ||
|
||
#. TRANSLATORS TS plural with plain text | ||
#: src/ts.ts:16 | ||
msgid "TS %n Plural" | ||
msgid_plural "TS %n Plurals" | ||
msgstr[0] "" | ||
msgstr[1] "" | ||
|
||
#. TRANSLATORS TS plural with parameters | ||
#: src/ts.ts:18 | ||
msgid "TS %n Plural with %s" | ||
msgid_plural "TS %n Plurals with %s" | ||
msgstr[0] "" | ||
msgstr[1] "" | ||
|
||
#. TRANSLATORS TS plural with wrapped parameters | ||
#: src/ts.ts:20 | ||
msgid "TS %n Plural with wrapped %s" | ||
msgid_plural "TS %n Plurals with wrapped %s" | ||
msgstr[0] "" | ||
msgstr[1] "" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
# SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors | ||
# SPDX-License-Identifier: CC0-1.0 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
<?php | ||
|
||
declare(strict_types=1); | ||
/** | ||
* SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors | ||
* SPDX-License-Identifier: AGPL-3.0-or-later | ||
*/ | ||
|
||
$l = \OCP\Server::get(\OCP\IL10N::class); | ||
|
||
// TRANSLATORS PHP string with plain text | ||
$l->t('PHP String'); | ||
// TRANSLATORS PHP string with parameters | ||
$l->t('PHP String with %s', 'Parameter'); | ||
// TRANSLATORS PHP string with positional parameters | ||
$l->t('PHP String with positional %1$s', [ | ||
'Parameter', | ||
]); | ||
|
||
// TRANSLATORS PHP plural with plain text | ||
$l->n('PHP %n Plural', 'PHP %n Plurals', 6); | ||
// TRANSLATORS PHP plural with parameters | ||
$l->n('PHP %n Plural with %s', 'PHP %n Plurals with %s', 6, [ | ||
'Parameter', | ||
]); | ||
// TRANSLATORS PHP plural with positional parameters | ||
$l->n('PHP %n Plural with positional %1$s', 'PHP %n Plurals with positional %1$s', 6, [ | ||
'Parameter', | ||
]); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
/** | ||
* SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors | ||
* SPDX-License-Identifier: AGPL-3.0-or-later | ||
*/ | ||
|
||
// TRANSLATORS JS string with plain text | ||
t('test', 'JS String'); | ||
// TRANSLATORS JS string with parameters | ||
t('test', 'JS String with inline {parameter}', { parameter: 'Parameter' }); | ||
// TRANSLATORS JS string with wrapped parameters | ||
t('test', 'JS String with wrapped {parameter}', { | ||
parameter: 'Parameter', | ||
}); | ||
|
||
// TRANSLATORS JS plural with plain text | ||
n('test', 'JS %n Plural', 'JS %n Plurals', 6); | ||
// TRANSLATORS JS plural with parameters | ||
n('test', 'JS %n Plural with %s', 'JS %n Plurals with %s', 6, { parameter: 'Parameter' }); | ||
// TRANSLATORS JS plural with wrapped parameters | ||
n('test', 'JS %n Plural with wrapped %s', 'JS %n Plurals with wrapped %s', 6, { | ||
parameter: 'Parameter', | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
/** | ||
* SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors | ||
* SPDX-License-Identifier: AGPL-3.0-or-later | ||
*/ | ||
|
||
// TRANSLATORS TS string with plain text | ||
t('test', 'TS String') | ||
// TRANSLATORS TS string with parameters | ||
t('test', 'TS String with inline {parameter}', { parameter: 'Parameter' }); | ||
// TRANSLATORS TS string with wrapped parameters | ||
t('test', 'TS String with wrapped {parameter}', { | ||
parameter: 'Parameter', | ||
}); | ||
|
||
// TRANSLATORS TS plural with plain text | ||
n('test', 'TS %n Plural', 'TS %n Plurals', 6) | ||
// TRANSLATORS TS plural with parameters | ||
n('test', 'TS %n Plural with %s', 'TS %n Plurals with %s', 6, { parameter: 'Parameter' }); | ||
// TRANSLATORS TS plural with wrapped parameters | ||
n('test', 'TS %n Plural with wrapped %s', 'TS %n Plurals with wrapped %s', 6, { | ||
parameter: 'Parameter', | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
<!-- | ||
- SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors | ||
- SPDX-License-Identifier: AGPL-3.0-or-later | ||
--> | ||
|
||
<template> | ||
<!-- TRANSLATORS VUE string with plain text --> | ||
{{ t('test', 'VUE String') }} | ||
<!-- TRANSLATORS VUE string with parameters --> | ||
{{ t('test', 'VUE String with inline {parameter}', { parameter: 'Parameter' }) }} | ||
<!-- TRANSLATORS VUE string with wrapped parameters --> | ||
{{ t('test', 'VUE String with wrapped {parameter}', { | ||
parameter: 'Parameter', | ||
}) }} | ||
|
||
<!-- TRANSLATORS VUE plural with plain text --> | ||
{{ n('test', 'VUE %n Plural', 'VUE %n Plurals', 6) }} | ||
<!-- TRANSLATORS VUE plural with parameters --> | ||
{{ n('test', 'VUE %n Plural with %s', 'VUE %n Plurals with %s', 6, { parameter: 'Parameter' }) }} | ||
<!-- TRANSLATORS VUE plural with wrapped parameters --> | ||
{{ n('test', 'VUE %n Plural with wrapped %s', 'VUE %n Plurals with wrapped %s', 6, { | ||
parameter: 'Parameter', | ||
}) }} | ||
|
||
<!-- TRANSLATORS VUE Fix for https://github.com/nextcloud/docker-ci/pull/663 - Part 1 --> | ||
{{ test ? t('test', 'VUE String testing') : t('test', 'VUE String not') }} | ||
|
||
<!-- TRANSLATORS VUE Fix for https://github.com/nextcloud/docker-ci/pull/663 - Part 2 --> | ||
{{ t("test", "VUE String with followup double quotes") }}: {{ data["random property"] }} | ||
</template> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
#!/bin/bash | ||
php ../src/translationtool.php create-pot-files | ||
|
||
# Remove unstable data like "POT-Creation-Date: 2024-09-10 14:25+0200\n" | ||
# And remove the development path | ||
cat translationfiles/templates/tests.pot | grep -v '^"' | sed -e "s/${PWD//\//\\/}\\///" > expected.pot | ||
|
||
CHANGED_LINES=$(git diff expected.pot | wc -l) | ||
|
||
if ! [[ "$CHANGED_LINES" = "0" ]]; then | ||
echo 'POT file changed' | ||
git diff expected.pot | ||
exit 1 | ||
fi |
Binary file not shown.