Edit File by line
/home/zeestwma/ceyloniy.../wp-admin/includes
File: misc.php
<?php
[0] Fix | Delete
/**
[1] Fix | Delete
* Misc WordPress Administration API.
[2] Fix | Delete
*
[3] Fix | Delete
* @package WordPress
[4] Fix | Delete
* @subpackage Administration
[5] Fix | Delete
*/
[6] Fix | Delete
[7] Fix | Delete
/**
[8] Fix | Delete
* Returns whether the server is running Apache with the mod_rewrite module loaded.
[9] Fix | Delete
*
[10] Fix | Delete
* @since 2.0.0
[11] Fix | Delete
*
[12] Fix | Delete
* @return bool Whether the server is running Apache with the mod_rewrite module loaded.
[13] Fix | Delete
*/
[14] Fix | Delete
function got_mod_rewrite() {
[15] Fix | Delete
$got_rewrite = apache_mod_loaded( 'mod_rewrite', true );
[16] Fix | Delete
[17] Fix | Delete
/**
[18] Fix | Delete
* Filters whether Apache and mod_rewrite are present.
[19] Fix | Delete
*
[20] Fix | Delete
* This filter was previously used to force URL rewriting for other servers,
[21] Fix | Delete
* like nginx. Use the {@see 'got_url_rewrite'} filter in got_url_rewrite() instead.
[22] Fix | Delete
*
[23] Fix | Delete
* @since 2.5.0
[24] Fix | Delete
*
[25] Fix | Delete
* @see got_url_rewrite()
[26] Fix | Delete
*
[27] Fix | Delete
* @param bool $got_rewrite Whether Apache and mod_rewrite are present.
[28] Fix | Delete
*/
[29] Fix | Delete
return apply_filters( 'got_rewrite', $got_rewrite );
[30] Fix | Delete
}
[31] Fix | Delete
[32] Fix | Delete
/**
[33] Fix | Delete
* Returns whether the server supports URL rewriting.
[34] Fix | Delete
*
[35] Fix | Delete
* Detects Apache's mod_rewrite, IIS 7.0+ permalink support, and nginx.
[36] Fix | Delete
*
[37] Fix | Delete
* @since 3.7.0
[38] Fix | Delete
*
[39] Fix | Delete
* @global bool $is_nginx
[40] Fix | Delete
* @global bool $is_caddy
[41] Fix | Delete
*
[42] Fix | Delete
* @return bool Whether the server supports URL rewriting.
[43] Fix | Delete
*/
[44] Fix | Delete
function got_url_rewrite() {
[45] Fix | Delete
$got_url_rewrite = ( got_mod_rewrite() || $GLOBALS['is_nginx'] || $GLOBALS['is_caddy'] || iis7_supports_permalinks() );
[46] Fix | Delete
[47] Fix | Delete
/**
[48] Fix | Delete
* Filters whether URL rewriting is available.
[49] Fix | Delete
*
[50] Fix | Delete
* @since 3.7.0
[51] Fix | Delete
*
[52] Fix | Delete
* @param bool $got_url_rewrite Whether URL rewriting is available.
[53] Fix | Delete
*/
[54] Fix | Delete
return apply_filters( 'got_url_rewrite', $got_url_rewrite );
[55] Fix | Delete
}
[56] Fix | Delete
[57] Fix | Delete
/**
[58] Fix | Delete
* Extracts strings from between the BEGIN and END markers in the .htaccess file.
[59] Fix | Delete
*
[60] Fix | Delete
* @since 1.5.0
[61] Fix | Delete
*
[62] Fix | Delete
* @param string $filename Filename to extract the strings from.
[63] Fix | Delete
* @param string $marker The marker to extract the strings from.
[64] Fix | Delete
* @return string[] An array of strings from a file (.htaccess) from between BEGIN and END markers.
[65] Fix | Delete
*/
[66] Fix | Delete
function extract_from_markers( $filename, $marker ) {
[67] Fix | Delete
$result = array();
[68] Fix | Delete
[69] Fix | Delete
if ( ! file_exists( $filename ) ) {
[70] Fix | Delete
return $result;
[71] Fix | Delete
}
[72] Fix | Delete
[73] Fix | Delete
$markerdata = explode( "\n", implode( '', file( $filename ) ) );
[74] Fix | Delete
[75] Fix | Delete
$state = false;
[76] Fix | Delete
[77] Fix | Delete
foreach ( $markerdata as $markerline ) {
[78] Fix | Delete
if ( str_contains( $markerline, '# END ' . $marker ) ) {
[79] Fix | Delete
$state = false;
[80] Fix | Delete
}
[81] Fix | Delete
[82] Fix | Delete
if ( $state ) {
[83] Fix | Delete
if ( str_starts_with( $markerline, '#' ) ) {
[84] Fix | Delete
continue;
[85] Fix | Delete
}
[86] Fix | Delete
[87] Fix | Delete
$result[] = $markerline;
[88] Fix | Delete
}
[89] Fix | Delete
[90] Fix | Delete
if ( str_contains( $markerline, '# BEGIN ' . $marker ) ) {
[91] Fix | Delete
$state = true;
[92] Fix | Delete
}
[93] Fix | Delete
}
[94] Fix | Delete
[95] Fix | Delete
return $result;
[96] Fix | Delete
}
[97] Fix | Delete
[98] Fix | Delete
/**
[99] Fix | Delete
* Inserts an array of strings into a file (.htaccess), placing it between
[100] Fix | Delete
* BEGIN and END markers.
[101] Fix | Delete
*
[102] Fix | Delete
* Replaces existing marked info. Retains surrounding
[103] Fix | Delete
* data. Creates file if none exists.
[104] Fix | Delete
*
[105] Fix | Delete
* @since 1.5.0
[106] Fix | Delete
*
[107] Fix | Delete
* @param string $filename Filename to alter.
[108] Fix | Delete
* @param string $marker The marker to alter.
[109] Fix | Delete
* @param array|string $insertion The new content to insert.
[110] Fix | Delete
* @return bool True on write success, false on failure.
[111] Fix | Delete
*/
[112] Fix | Delete
function insert_with_markers( $filename, $marker, $insertion ) {
[113] Fix | Delete
if ( ! file_exists( $filename ) ) {
[114] Fix | Delete
if ( ! is_writable( dirname( $filename ) ) ) {
[115] Fix | Delete
return false;
[116] Fix | Delete
}
[117] Fix | Delete
[118] Fix | Delete
if ( ! touch( $filename ) ) {
[119] Fix | Delete
return false;
[120] Fix | Delete
}
[121] Fix | Delete
[122] Fix | Delete
// Make sure the file is created with a minimum set of permissions.
[123] Fix | Delete
$perms = fileperms( $filename );
[124] Fix | Delete
[125] Fix | Delete
if ( $perms ) {
[126] Fix | Delete
chmod( $filename, $perms | 0644 );
[127] Fix | Delete
}
[128] Fix | Delete
} elseif ( ! is_writable( $filename ) ) {
[129] Fix | Delete
return false;
[130] Fix | Delete
}
[131] Fix | Delete
[132] Fix | Delete
if ( ! is_array( $insertion ) ) {
[133] Fix | Delete
$insertion = explode( "\n", $insertion );
[134] Fix | Delete
}
[135] Fix | Delete
[136] Fix | Delete
$switched_locale = switch_to_locale( get_locale() );
[137] Fix | Delete
[138] Fix | Delete
$instructions = sprintf(
[139] Fix | Delete
/* translators: 1: Marker. */
[140] Fix | Delete
__(
[141] Fix | Delete
'The directives (lines) between "BEGIN %1$s" and "END %1$s" are
[142] Fix | Delete
dynamically generated, and should only be modified via WordPress filters.
[143] Fix | Delete
Any changes to the directives between these markers will be overwritten.'
[144] Fix | Delete
),
[145] Fix | Delete
$marker
[146] Fix | Delete
);
[147] Fix | Delete
[148] Fix | Delete
$instructions = explode( "\n", $instructions );
[149] Fix | Delete
[150] Fix | Delete
foreach ( $instructions as $line => $text ) {
[151] Fix | Delete
$instructions[ $line ] = '# ' . $text;
[152] Fix | Delete
}
[153] Fix | Delete
[154] Fix | Delete
/**
[155] Fix | Delete
* Filters the inline instructions inserted before the dynamically generated content.
[156] Fix | Delete
*
[157] Fix | Delete
* @since 5.3.0
[158] Fix | Delete
*
[159] Fix | Delete
* @param string[] $instructions Array of lines with inline instructions.
[160] Fix | Delete
* @param string $marker The marker being inserted.
[161] Fix | Delete
*/
[162] Fix | Delete
$instructions = apply_filters( 'insert_with_markers_inline_instructions', $instructions, $marker );
[163] Fix | Delete
[164] Fix | Delete
if ( $switched_locale ) {
[165] Fix | Delete
restore_previous_locale();
[166] Fix | Delete
}
[167] Fix | Delete
[168] Fix | Delete
$insertion = array_merge( $instructions, $insertion );
[169] Fix | Delete
[170] Fix | Delete
$start_marker = "# BEGIN {$marker}";
[171] Fix | Delete
$end_marker = "# END {$marker}";
[172] Fix | Delete
[173] Fix | Delete
$fp = fopen( $filename, 'r+' );
[174] Fix | Delete
[175] Fix | Delete
if ( ! $fp ) {
[176] Fix | Delete
return false;
[177] Fix | Delete
}
[178] Fix | Delete
[179] Fix | Delete
// Attempt to get a lock. If the filesystem supports locking, this will block until the lock is acquired.
[180] Fix | Delete
flock( $fp, LOCK_EX );
[181] Fix | Delete
[182] Fix | Delete
$lines = array();
[183] Fix | Delete
[184] Fix | Delete
while ( ! feof( $fp ) ) {
[185] Fix | Delete
$lines[] = rtrim( fgets( $fp ), "\r\n" );
[186] Fix | Delete
}
[187] Fix | Delete
[188] Fix | Delete
// Split out the existing file into the preceding lines, and those that appear after the marker.
[189] Fix | Delete
$pre_lines = array();
[190] Fix | Delete
$post_lines = array();
[191] Fix | Delete
$existing_lines = array();
[192] Fix | Delete
$found_marker = false;
[193] Fix | Delete
$found_end_marker = false;
[194] Fix | Delete
[195] Fix | Delete
foreach ( $lines as $line ) {
[196] Fix | Delete
if ( ! $found_marker && str_contains( $line, $start_marker ) ) {
[197] Fix | Delete
$found_marker = true;
[198] Fix | Delete
continue;
[199] Fix | Delete
} elseif ( ! $found_end_marker && str_contains( $line, $end_marker ) ) {
[200] Fix | Delete
$found_end_marker = true;
[201] Fix | Delete
continue;
[202] Fix | Delete
}
[203] Fix | Delete
[204] Fix | Delete
if ( ! $found_marker ) {
[205] Fix | Delete
$pre_lines[] = $line;
[206] Fix | Delete
} elseif ( $found_end_marker ) {
[207] Fix | Delete
$post_lines[] = $line;
[208] Fix | Delete
} else {
[209] Fix | Delete
$existing_lines[] = $line;
[210] Fix | Delete
}
[211] Fix | Delete
}
[212] Fix | Delete
[213] Fix | Delete
// Check to see if there was a change.
[214] Fix | Delete
if ( $existing_lines === $insertion ) {
[215] Fix | Delete
flock( $fp, LOCK_UN );
[216] Fix | Delete
fclose( $fp );
[217] Fix | Delete
[218] Fix | Delete
return true;
[219] Fix | Delete
}
[220] Fix | Delete
[221] Fix | Delete
// Generate the new file data.
[222] Fix | Delete
$new_file_data = implode(
[223] Fix | Delete
"\n",
[224] Fix | Delete
array_merge(
[225] Fix | Delete
$pre_lines,
[226] Fix | Delete
array( $start_marker ),
[227] Fix | Delete
$insertion,
[228] Fix | Delete
array( $end_marker ),
[229] Fix | Delete
$post_lines
[230] Fix | Delete
)
[231] Fix | Delete
);
[232] Fix | Delete
[233] Fix | Delete
// Write to the start of the file, and truncate it to that length.
[234] Fix | Delete
fseek( $fp, 0 );
[235] Fix | Delete
$bytes = fwrite( $fp, $new_file_data );
[236] Fix | Delete
[237] Fix | Delete
if ( $bytes ) {
[238] Fix | Delete
ftruncate( $fp, ftell( $fp ) );
[239] Fix | Delete
}
[240] Fix | Delete
[241] Fix | Delete
fflush( $fp );
[242] Fix | Delete
flock( $fp, LOCK_UN );
[243] Fix | Delete
fclose( $fp );
[244] Fix | Delete
[245] Fix | Delete
return (bool) $bytes;
[246] Fix | Delete
}
[247] Fix | Delete
[248] Fix | Delete
/**
[249] Fix | Delete
* Updates the htaccess file with the current rules if it is writable.
[250] Fix | Delete
*
[251] Fix | Delete
* Always writes to the file if it exists and is writable to ensure that we
[252] Fix | Delete
* blank out old rules.
[253] Fix | Delete
*
[254] Fix | Delete
* @since 1.5.0
[255] Fix | Delete
*
[256] Fix | Delete
* @global WP_Rewrite $wp_rewrite WordPress rewrite component.
[257] Fix | Delete
*
[258] Fix | Delete
* @return bool|null True on write success, false on failure. Null in multisite.
[259] Fix | Delete
*/
[260] Fix | Delete
function save_mod_rewrite_rules() {
[261] Fix | Delete
global $wp_rewrite;
[262] Fix | Delete
[263] Fix | Delete
if ( is_multisite() ) {
[264] Fix | Delete
return null;
[265] Fix | Delete
}
[266] Fix | Delete
[267] Fix | Delete
// Ensure get_home_path() is declared.
[268] Fix | Delete
require_once ABSPATH . 'wp-admin/includes/file.php';
[269] Fix | Delete
[270] Fix | Delete
$home_path = get_home_path();
[271] Fix | Delete
$htaccess_file = $home_path . '.htaccess';
[272] Fix | Delete
[273] Fix | Delete
/*
[274] Fix | Delete
* If the file doesn't already exist check for write access to the directory
[275] Fix | Delete
* and whether we have some rules. Else check for write access to the file.
[276] Fix | Delete
*/
[277] Fix | Delete
if ( ! file_exists( $htaccess_file ) && is_writable( $home_path ) && $wp_rewrite->using_mod_rewrite_permalinks()
[278] Fix | Delete
|| is_writable( $htaccess_file )
[279] Fix | Delete
) {
[280] Fix | Delete
if ( got_mod_rewrite() ) {
[281] Fix | Delete
$rules = explode( "\n", $wp_rewrite->mod_rewrite_rules() );
[282] Fix | Delete
[283] Fix | Delete
return insert_with_markers( $htaccess_file, 'WordPress', $rules );
[284] Fix | Delete
}
[285] Fix | Delete
}
[286] Fix | Delete
[287] Fix | Delete
return false;
[288] Fix | Delete
}
[289] Fix | Delete
[290] Fix | Delete
/**
[291] Fix | Delete
* Updates the IIS web.config file with the current rules if it is writable.
[292] Fix | Delete
* If the permalinks do not require rewrite rules then the rules are deleted from the web.config file.
[293] Fix | Delete
*
[294] Fix | Delete
* @since 2.8.0
[295] Fix | Delete
*
[296] Fix | Delete
* @global WP_Rewrite $wp_rewrite WordPress rewrite component.
[297] Fix | Delete
*
[298] Fix | Delete
* @return bool|null True on write success, false on failure. Null in multisite.
[299] Fix | Delete
*/
[300] Fix | Delete
function iis7_save_url_rewrite_rules() {
[301] Fix | Delete
global $wp_rewrite;
[302] Fix | Delete
[303] Fix | Delete
if ( is_multisite() ) {
[304] Fix | Delete
return null;
[305] Fix | Delete
}
[306] Fix | Delete
[307] Fix | Delete
// Ensure get_home_path() is declared.
[308] Fix | Delete
require_once ABSPATH . 'wp-admin/includes/file.php';
[309] Fix | Delete
[310] Fix | Delete
$home_path = get_home_path();
[311] Fix | Delete
$web_config_file = $home_path . 'web.config';
[312] Fix | Delete
[313] Fix | Delete
// Using win_is_writable() instead of is_writable() because of a bug in Windows PHP.
[314] Fix | Delete
if ( iis7_supports_permalinks()
[315] Fix | Delete
&& ( ! file_exists( $web_config_file ) && win_is_writable( $home_path ) && $wp_rewrite->using_mod_rewrite_permalinks()
[316] Fix | Delete
|| win_is_writable( $web_config_file ) )
[317] Fix | Delete
) {
[318] Fix | Delete
$rule = $wp_rewrite->iis7_url_rewrite_rules( false );
[319] Fix | Delete
[320] Fix | Delete
if ( ! empty( $rule ) ) {
[321] Fix | Delete
return iis7_add_rewrite_rule( $web_config_file, $rule );
[322] Fix | Delete
} else {
[323] Fix | Delete
return iis7_delete_rewrite_rule( $web_config_file );
[324] Fix | Delete
}
[325] Fix | Delete
}
[326] Fix | Delete
[327] Fix | Delete
return false;
[328] Fix | Delete
}
[329] Fix | Delete
[330] Fix | Delete
/**
[331] Fix | Delete
* Updates the "recently-edited" file for the plugin or theme file editor.
[332] Fix | Delete
*
[333] Fix | Delete
* @since 1.5.0
[334] Fix | Delete
*
[335] Fix | Delete
* @param string $file
[336] Fix | Delete
*/
[337] Fix | Delete
function update_recently_edited( $file ) {
[338] Fix | Delete
$oldfiles = (array) get_option( 'recently_edited' );
[339] Fix | Delete
[340] Fix | Delete
if ( $oldfiles ) {
[341] Fix | Delete
$oldfiles = array_reverse( $oldfiles );
[342] Fix | Delete
$oldfiles[] = $file;
[343] Fix | Delete
$oldfiles = array_reverse( $oldfiles );
[344] Fix | Delete
$oldfiles = array_unique( $oldfiles );
[345] Fix | Delete
[346] Fix | Delete
if ( 5 < count( $oldfiles ) ) {
[347] Fix | Delete
array_pop( $oldfiles );
[348] Fix | Delete
}
[349] Fix | Delete
} else {
[350] Fix | Delete
$oldfiles[] = $file;
[351] Fix | Delete
}
[352] Fix | Delete
[353] Fix | Delete
update_option( 'recently_edited', $oldfiles );
[354] Fix | Delete
}
[355] Fix | Delete
[356] Fix | Delete
/**
[357] Fix | Delete
* Makes a tree structure for the theme file editor's file list.
[358] Fix | Delete
*
[359] Fix | Delete
* @since 4.9.0
[360] Fix | Delete
* @access private
[361] Fix | Delete
*
[362] Fix | Delete
* @param array $allowed_files List of theme file paths.
[363] Fix | Delete
* @return array Tree structure for listing theme files.
[364] Fix | Delete
*/
[365] Fix | Delete
function wp_make_theme_file_tree( $allowed_files ) {
[366] Fix | Delete
$tree_list = array();
[367] Fix | Delete
[368] Fix | Delete
foreach ( $allowed_files as $file_name => $absolute_filename ) {
[369] Fix | Delete
$list = explode( '/', $file_name );
[370] Fix | Delete
$last_dir = &$tree_list;
[371] Fix | Delete
[372] Fix | Delete
foreach ( $list as $dir ) {
[373] Fix | Delete
$last_dir =& $last_dir[ $dir ];
[374] Fix | Delete
}
[375] Fix | Delete
[376] Fix | Delete
$last_dir = $file_name;
[377] Fix | Delete
}
[378] Fix | Delete
[379] Fix | Delete
return $tree_list;
[380] Fix | Delete
}
[381] Fix | Delete
[382] Fix | Delete
/**
[383] Fix | Delete
* Outputs the formatted file list for the theme file editor.
[384] Fix | Delete
*
[385] Fix | Delete
* @since 4.9.0
[386] Fix | Delete
* @access private
[387] Fix | Delete
*
[388] Fix | Delete
* @global string $relative_file Name of the file being edited relative to the
[389] Fix | Delete
* theme directory.
[390] Fix | Delete
* @global string $stylesheet The stylesheet name of the theme being edited.
[391] Fix | Delete
*
[392] Fix | Delete
* @param array|string $tree List of file/folder paths, or filename.
[393] Fix | Delete
* @param int $level The aria-level for the current iteration.
[394] Fix | Delete
* @param int $size The aria-setsize for the current iteration.
[395] Fix | Delete
* @param int $index The aria-posinset for the current iteration.
[396] Fix | Delete
*/
[397] Fix | Delete
function wp_print_theme_file_tree( $tree, $level = 2, $size = 1, $index = 1 ) {
[398] Fix | Delete
global $relative_file, $stylesheet;
[399] Fix | Delete
[400] Fix | Delete
if ( is_array( $tree ) ) {
[401] Fix | Delete
$index = 0;
[402] Fix | Delete
$size = count( $tree );
[403] Fix | Delete
[404] Fix | Delete
foreach ( $tree as $label => $theme_file ) :
[405] Fix | Delete
++$index;
[406] Fix | Delete
[407] Fix | Delete
if ( ! is_array( $theme_file ) ) {
[408] Fix | Delete
wp_print_theme_file_tree( $theme_file, $level, $index, $size );
[409] Fix | Delete
continue;
[410] Fix | Delete
}
[411] Fix | Delete
?>
[412] Fix | Delete
<li role="treeitem" aria-expanded="true" tabindex="-1"
[413] Fix | Delete
aria-level="<?php echo esc_attr( $level ); ?>"
[414] Fix | Delete
aria-setsize="<?php echo esc_attr( $size ); ?>"
[415] Fix | Delete
aria-posinset="<?php echo esc_attr( $index ); ?>">
[416] Fix | Delete
<span class="folder-label"><?php echo esc_html( $label ); ?> <span class="screen-reader-text">
[417] Fix | Delete
<?php
[418] Fix | Delete
/* translators: Hidden accessibility text. */
[419] Fix | Delete
_e( 'folder' );
[420] Fix | Delete
?>
[421] Fix | Delete
</span><span aria-hidden="true" class="icon"></span></span>
[422] Fix | Delete
<ul role="group" class="tree-folder"><?php wp_print_theme_file_tree( $theme_file, $level + 1, $index, $size ); ?></ul>
[423] Fix | Delete
</li>
[424] Fix | Delete
<?php
[425] Fix | Delete
endforeach;
[426] Fix | Delete
} else {
[427] Fix | Delete
$filename = $tree;
[428] Fix | Delete
$url = add_query_arg(
[429] Fix | Delete
array(
[430] Fix | Delete
'file' => rawurlencode( $tree ),
[431] Fix | Delete
'theme' => rawurlencode( $stylesheet ),
[432] Fix | Delete
),
[433] Fix | Delete
self_admin_url( 'theme-editor.php' )
[434] Fix | Delete
);
[435] Fix | Delete
?>
[436] Fix | Delete
<li role="none" class="<?php echo esc_attr( $relative_file === $filename ? 'current-file' : '' ); ?>">
[437] Fix | Delete
<a role="treeitem" tabindex="<?php echo esc_attr( $relative_file === $filename ? '0' : '-1' ); ?>"
[438] Fix | Delete
href="<?php echo esc_url( $url ); ?>"
[439] Fix | Delete
aria-level="<?php echo esc_attr( $level ); ?>"
[440] Fix | Delete
aria-setsize="<?php echo esc_attr( $size ); ?>"
[441] Fix | Delete
aria-posinset="<?php echo esc_attr( $index ); ?>">
[442] Fix | Delete
<?php
[443] Fix | Delete
$file_description = esc_html( get_file_description( $filename ) );
[444] Fix | Delete
[445] Fix | Delete
if ( $file_description !== $filename && wp_basename( $filename ) !== $file_description ) {
[446] Fix | Delete
$file_description .= '<br /><span class="nonessential">(' . esc_html( $filename ) . ')</span>';
[447] Fix | Delete
}
[448] Fix | Delete
[449] Fix | Delete
if ( $relative_file === $filename ) {
[450] Fix | Delete
echo '<span class="notice notice-info">' . $file_description . '</span>';
[451] Fix | Delete
} else {
[452] Fix | Delete
echo $file_description;
[453] Fix | Delete
}
[454] Fix | Delete
?>
[455] Fix | Delete
</a>
[456] Fix | Delete
</li>
[457] Fix | Delete
<?php
[458] Fix | Delete
}
[459] Fix | Delete
}
[460] Fix | Delete
[461] Fix | Delete
/**
[462] Fix | Delete
* Makes a tree structure for the plugin file editor's file list.
[463] Fix | Delete
*
[464] Fix | Delete
* @since 4.9.0
[465] Fix | Delete
* @access private
[466] Fix | Delete
*
[467] Fix | Delete
* @param array $plugin_editable_files List of plugin file paths.
[468] Fix | Delete
* @return array Tree structure for listing plugin files.
[469] Fix | Delete
*/
[470] Fix | Delete
function wp_make_plugin_file_tree( $plugin_editable_files ) {
[471] Fix | Delete
$tree_list = array();
[472] Fix | Delete
[473] Fix | Delete
foreach ( $plugin_editable_files as $plugin_file ) {
[474] Fix | Delete
$list = explode( '/', preg_replace( '#^.+?/#', '', $plugin_file ) );
[475] Fix | Delete
$last_dir = &$tree_list;
[476] Fix | Delete
[477] Fix | Delete
foreach ( $list as $dir ) {
[478] Fix | Delete
$last_dir =& $last_dir[ $dir ];
[479] Fix | Delete
}
[480] Fix | Delete
[481] Fix | Delete
$last_dir = $plugin_file;
[482] Fix | Delete
}
[483] Fix | Delete
[484] Fix | Delete
return $tree_list;
[485] Fix | Delete
}
[486] Fix | Delete
[487] Fix | Delete
/**
[488] Fix | Delete
* Outputs the formatted file list for the plugin file editor.
[489] Fix | Delete
*
[490] Fix | Delete
* @since 4.9.0
[491] Fix | Delete
* @access private
[492] Fix | Delete
*
[493] Fix | Delete
* @param array|string $tree List of file/folder paths, or filename.
[494] Fix | Delete
* @param string $label Name of file or folder to print.
[495] Fix | Delete
* @param int $level The aria-level for the current iteration.
[496] Fix | Delete
* @param int $size The aria-setsize for the current iteration.
[497] Fix | Delete
* @param int $index The aria-posinset for the current iteration.
[498] Fix | Delete
*/
[499] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function