/var/www/html_uk/wp-includes/pomo/entry.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
<?php
/**
 * Contains Translation_Entry class
 *
 * @version $Id: entry.php 1157 2015-11-20 04:30:11Z dd32 $
 * @package pomo
 * @subpackage entry
 */

if ( ! class_exists'Translation_Entry'false ) ) :
    
/**
     * Translation_Entry class encapsulates a translatable string.
     *
     * @since 2.8.0
     */
    
#[AllowDynamicProperties]
    class 
Translation_Entry {

        
/**
         * Whether the entry contains a string and its plural form, default is false.
         *
         * @var bool
         */
        
public $is_plural false;

        public 
$context             null;
        public 
$singular            null;
        public 
$plural              null;
        public 
$translations        = array();
        public 
$translator_comments '';
        public 
$extracted_comments  '';
        public 
$references          = array();
        public 
$flags               = array();

        
/**
         * @param array $args {
         *     Arguments array, supports the following keys:
         *
         *     @type string $singular            The string to translate, if omitted an
         *                                       empty entry will be created.
         *     @type string $plural              The plural form of the string, setting
         *                                       this will set `$is_plural` to true.
         *     @type array  $translations        Translations of the string and possibly
         *                                       its plural forms.
         *     @type string $context             A string differentiating two equal strings
         *                                       used in different contexts.
         *     @type string $translator_comments Comments left by translators.
         *     @type string $extracted_comments  Comments left by developers.
         *     @type array  $references          Places in the code this string is used, in
         *                                       relative_to_root_path/file.php:linenum form.
         *     @type array  $flags               Flags like php-format.
         * }
         */
        
public function __construct$args = array() ) {
            
// If no singular -- empty object.
            
if ( ! isset( $args['singular'] ) ) {
                return;
            }
            
// Get member variable values from args hash.
            
foreach ( $args as $varname => $value ) {
                
$this->$varname $value;
            }
            if ( isset( 
$args['plural'] ) && $args['plural'] ) {
                
$this->is_plural true;
            }
            if ( ! 
is_array$this->translations ) ) {
                
$this->translations = array();
            }
            if ( ! 
is_array$this->references ) ) {
                
$this->references = array();
            }
            if ( ! 
is_array$this->flags ) ) {
                
$this->flags = array();
            }
        }

        
/**
         * PHP4 constructor.
         *
         * @since 2.8.0
         * @deprecated 5.4.0 Use __construct() instead.
         *
         * @see Translation_Entry::__construct()
         */
        
public function Translation_Entry$args = array() ) {
            
_deprecated_constructorself::class, '5.4.0', static::class );
            
self::__construct$args );
        }

        
/**
         * Generates a unique key for this entry.
         *
         * @since 2.8.0
         *
         * @return string|false The key or false if the entry is null.
         */
        
public function key() {
            if ( 
null === $this->singular ) {
                return 
false;
            }

            
// Prepend context and EOT, like in MO files.
            
$key = ! $this->context $this->singular $this->context "\4" $this->singular;
            
// Standardize on \n line endings.
            
$key str_replace( array( "\r\n""\r" ), "\n"$key );

            return 
$key;
        }

        
/**
         * Merges another translation entry with the current one.
         *
         * @since 2.8.0
         *
         * @param Translation_Entry $other Other translation entry.
         */
        
public function merge_with( &$other ) {
            
$this->flags      array_uniquearray_merge$this->flags$other->flags ) );
            
$this->references array_uniquearray_merge$this->references$other->references ) );
            if ( 
$this->extracted_comments !== $other->extracted_comments ) {
                
$this->extracted_comments .= $other->extracted_comments;
            }
        }
    }
endif;