diff --git a/wordpress.org/public_html/wp-content/plugins/wporg-gp-custom-errors/wporg-gp-custom-errors.php b/wordpress.org/public_html/wp-content/plugins/wporg-gp-custom-errors/wporg-gp-custom-errors.php
index f5ae6bf63a..9d79d8fec8 100644
--- a/wordpress.org/public_html/wp-content/plugins/wporg-gp-custom-errors/wporg-gp-custom-errors.php
+++ b/wordpress.org/public_html/wp-content/plugins/wporg-gp-custom-errors/wporg-gp-custom-errors.php
@@ -15,6 +15,20 @@ class WPorg_GP_Custom_Translation_Errors {
*/
const WORPRESS_CORE_PROJECT_ID = 1;
+ /**
+ * The parent WordPress core project ID.
+ *
+ * @var int
+ */
+ const CONTEXT_ENUM_CHECK_LIST = [
+ 'text direction' => [ 'ltr', 'rtl' ],
+ 'Open Sans font: on or off' => [ 'on', 'off' ],
+ 'Open Sans font: add new subset (greek, cyrillic, vietnamese)' => [ 'no-subset', 'greek', 'cyrillic', 'vietnamese' ],
+ 'Word count type. Do not translate!' => [ 'characters_excluding_spaces', 'characters_including_spaces', 'words' ],
+ 'decline months names: on or off' => [ 'on', 'off' ],
+ 'Comment number declension: on or off' => [ 'on', 'off' ],
+ ];
+
/**
* Registers all methods starting with error_ with GlotPress.
*/
@@ -39,8 +53,11 @@ function ( $key ) {
*/
public function is_core_project( GP_Original $gp_original ): bool {
$project = GP::$project->get( $gp_original->project_id );
- $project = GP::$project->get( $project->parent_project_id );
+ if ( self::WORPRESS_CORE_PROJECT_ID == $project->parent_project_id ) {
+ return true;
+ }
+ $project = GP::$project->get( $project->parent_project_id );
if ( self::WORPRESS_CORE_PROJECT_ID == $project->parent_project_id ) {
return true;
} else {
@@ -169,10 +186,10 @@ public function error_timezone_date_format( $original, $translation, $gp_origina
if ( ! $this->is_core_project( $gp_original ) ) {
return true;
}
- if ( is_null( $gp_original->context ) ) {
+ if ( is_null( $gp_original->comment ) ) {
return true;
}
- if ( ! str_contains( $gp_original->context, 'timezone date format' ) ) {
+ if ( strpos( $gp_original->comment, 'https://www.php.net/manual/datetime.format.php' ) === false ) {
return true;
}
@@ -186,7 +203,81 @@ public function error_timezone_date_format( $original, $translation, $gp_origina
return esc_html__( 'The translation has empty spaces, new lines or another similar elements.', 'glotpress' );
}
- return esc_html__( 'Must be a valid timezone date format.', 'glotpress' );
+ return esc_html__( 'Must be a valid date format.', 'glotpress' );
+ }
+
+ /**
+ * Adds an error for text direction.
+ *
+ * @param string $original The original string.
+ * @param string $translation The translated string.
+ * @param GP_Original $gp_original The GP_original object.
+ * @param GP_Locale $locale The locale.
+ * @return string|true The error message or true if no error.
+ */
+ public function error_check_enum_list( $original, $translation, $gp_original, $locale ) {
+ if ( ! $this->is_core_project( $gp_original ) ) {
+ return true;
+ }
+ if ( is_null( $gp_original->context ) ) {
+ return true;
+ }
+ if ( !isset(self::CONTEXT_ENUM_CHECK_LIST[$gp_original->context])) {
+ return true;
+ }
+ if ( in_array( $translation, self::CONTEXT_ENUM_CHECK_LIST[$gp_original->context]) ) {
+ return true;
+ }
+
+ return esc_html__(
+ 'Must be ' . $this->array_to_string( self::CONTEXT_ENUM_CHECK_LIST[$gp_original->context] ),
+ 'glotpress'
+ );
+ }
+
+ /**
+ * Adds an error for text direction.
+ *
+ * @param string $original The original string.
+ * @param string $translation The translated string.
+ * @param GP_Original $gp_original The GP_original object.
+ * @param GP_Locale $locale The locale.
+ * @return string|true The error message or true if no error.
+ */
+ public function error_check_integer( $original, $translation, $gp_original, $locale ) {
+ if ( ! $this->is_core_project( $gp_original ) ) {
+ return true;
+ }
+ if ( is_null( $gp_original->context ) ) {
+ return true;
+ }
+ if (
+ ! in_array($gp_original->context, [
+ 'draft_length',
+ 'minimum input length for searching post links',
+ 'comment_excerpt_length',
+ 'excerpt_length',
+ ])
+ ) {
+ return true;
+ }
+
+ if ( absint( $translation ) == $translation ) {
+ return true;
+ }
+
+ return esc_html__( 'The translation has to be a number.', 'glotpress' );
+ }
+
+ private function array_to_string( $array ) {
+ $str = implode('’, ’', $array);
+ $lastCommaPos = strrpos($str, ',');
+
+ if ($lastCommaPos !== false) {
+ $str = substr_replace($str, ' or', $lastCommaPos, 1);
+ }
+
+ return '’' . $str . '’';
}
}
@@ -196,7 +287,7 @@ public function error_timezone_date_format( $original, $translation, $gp_origina
* @return WPorg_GP_Custom_Translation_Errors
*/
function wporg_gp_custom_translation_errors() {
- global $wporg_gp_custom_translation_errors;
+ global $wporg_gp_custom_translation_errors;
if ( ! isset( $wporg_gp_custom_translation_errors ) ) {
$wporg_gp_custom_translation_errors = new WPorg_GP_Custom_Translation_Errors();