-
Notifications
You must be signed in to change notification settings - Fork 0
/
pot-ext-meta.php
78 lines (69 loc) · 2 KB
/
pot-ext-meta.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
<?php
/**
* Console application, which adds metadata strings from
* a WordPress extension to a POT file
*
* @version $Id: pot-ext-meta.php 19937 2012-05-21 21:40:14Z nacin $
* @package wordpress-i18n
* @subpackage tools
*/
require_once dirname( __FILE__ ) . '/pomo/po.php';
require_once dirname( __FILE__ ) . '/makepot.php';
class PotExtMeta {
var $headers = array(
'Plugin Name',
'Theme Name',
'Plugin URI',
'Theme URI',
'Description',
'Author',
'Author URI',
'Tags',
);
function usage() {
fwrite(STDERR, "Usage: php pot-ext-meta.php EXT POT\n");
fwrite(STDERR, "Adds metadata from a WordPress theme or plugin file EXT to POT file\n");
exit(1);
}
function load_from_file( $ext_filename ) {
$makepot = new MakePOT;
$source = $makepot->get_first_lines($ext_filename);
$pot = '';
foreach( $this->headers as $header ) {
$string = $makepot->get_addon_header($header, $source);
if (!$string) continue;
$args = array(
'singular' => $string,
'extracted_comments' => $header.' of the plugin/theme',
);
$entry = new Translation_Entry($args);
$pot .= "\n".PO::export_entry($entry)."\n";
}
return $pot;
}
function append( $ext_filename, $pot_filename, $headers = null ) {
echo "pot_filename: $pot_filename" . PHP_EOL;
if ( $headers )
$this->headers = (array) $headers;
if ( is_dir( $ext_filename ) ) {
$pot = implode('', array_map(array(&$this, 'load_from_file'), glob("$ext_filename/*.php")));
} else {
$pot = $this->load_from_file($ext_filename);
}
$potf = '-' == $pot_filename? STDOUT : fopen($pot_filename, 'a');
if (!$potf) return false;
fwrite($potf, $pot);
if ('-' != $pot_filename) fclose($potf);
return true;
}
}
$included_files = get_included_files();
if ($included_files[0] == __FILE__) {
ini_set('display_errors', 1);
$potextmeta = new PotExtMeta;
if (!isset($argv[1])) {
$potextmeta->usage();
}
$potextmeta->append( $argv[1], isset( $argv[2] ) ? $argv[2] : '-', isset( $argv[3] ) ? $argv[3] : null );
}
?>