/users/patterns/www2_Hacked_x/blog/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
<?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
     */
    
class Translation_Entry {

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

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

        
/**
         * @param array $args associative array, support following keys:
         *  - singular (string) -- the string to translate, if omitted and empty entry will be created
         *  - plural (string) -- the plural form of the string, setting this will set {@link $is_plural} to true
         *  - translations (array) -- translations of the string and possibly -- its plural forms
         *  - context (string) -- a string differentiating two equal strings used in different contexts
         *  - translator_comments (string) -- comments left by translators
         *  - extracted_comments (string) -- comments left by developers
         *  - references (array) -- places in the code this strings is used, in relative_to_root_path/file.php:linenum form
         *  - flags (array) -- flags like php-format
         */
        
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.
         */
        
public function Translation_Entry$args = array() ) {
            
self::__construct$args );
        }

        
/**
         * Generates a unique key for this entry
         *
         * @return string|bool the key or false if the entry is empty
         */
        
function key() {
            if ( 
null === $this->singular || '' === $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;
        }

        
/**
         * @param object $other
         */
        
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;