Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93

Warning: Undefined array key "page_file_edit_line" in /home/sportsfever/public_html/filemanger/edit_text_line.php on line 32
/home/sportsfe.../httpdocs/clone/wp-inclu...
File: post.php
}
[3000] Fix | Delete
}
[3001] Fix | Delete
[3002] Fix | Delete
// Restore the type for integer fields after esc_attr().
[3003] Fix | Delete
if ( in_array( $field, $int_fields, true ) ) {
[3004] Fix | Delete
$value = (int) $value;
[3005] Fix | Delete
}
[3006] Fix | Delete
[3007] Fix | Delete
return $value;
[3008] Fix | Delete
}
[3009] Fix | Delete
[3010] Fix | Delete
/**
[3011] Fix | Delete
* Makes a post sticky.
[3012] Fix | Delete
*
[3013] Fix | Delete
* Sticky posts should be displayed at the top of the front page.
[3014] Fix | Delete
*
[3015] Fix | Delete
* @since 2.7.0
[3016] Fix | Delete
*
[3017] Fix | Delete
* @param int $post_id Post ID.
[3018] Fix | Delete
*/
[3019] Fix | Delete
function stick_post( $post_id ) {
[3020] Fix | Delete
$post_id = (int) $post_id;
[3021] Fix | Delete
$stickies = get_option( 'sticky_posts' );
[3022] Fix | Delete
$updated = false;
[3023] Fix | Delete
[3024] Fix | Delete
if ( ! is_array( $stickies ) ) {
[3025] Fix | Delete
$stickies = array();
[3026] Fix | Delete
} else {
[3027] Fix | Delete
$stickies = array_unique( array_map( 'intval', $stickies ) );
[3028] Fix | Delete
}
[3029] Fix | Delete
[3030] Fix | Delete
if ( ! in_array( $post_id, $stickies, true ) ) {
[3031] Fix | Delete
$stickies[] = $post_id;
[3032] Fix | Delete
$updated = update_option( 'sticky_posts', array_values( $stickies ) );
[3033] Fix | Delete
}
[3034] Fix | Delete
[3035] Fix | Delete
if ( $updated ) {
[3036] Fix | Delete
/**
[3037] Fix | Delete
* Fires once a post has been added to the sticky list.
[3038] Fix | Delete
*
[3039] Fix | Delete
* @since 4.6.0
[3040] Fix | Delete
*
[3041] Fix | Delete
* @param int $post_id ID of the post that was stuck.
[3042] Fix | Delete
*/
[3043] Fix | Delete
do_action( 'post_stuck', $post_id );
[3044] Fix | Delete
}
[3045] Fix | Delete
}
[3046] Fix | Delete
[3047] Fix | Delete
/**
[3048] Fix | Delete
* Un-sticks a post.
[3049] Fix | Delete
*
[3050] Fix | Delete
* Sticky posts should be displayed at the top of the front page.
[3051] Fix | Delete
*
[3052] Fix | Delete
* @since 2.7.0
[3053] Fix | Delete
*
[3054] Fix | Delete
* @param int $post_id Post ID.
[3055] Fix | Delete
*/
[3056] Fix | Delete
function unstick_post( $post_id ) {
[3057] Fix | Delete
$post_id = (int) $post_id;
[3058] Fix | Delete
$stickies = get_option( 'sticky_posts' );
[3059] Fix | Delete
[3060] Fix | Delete
if ( ! is_array( $stickies ) ) {
[3061] Fix | Delete
return;
[3062] Fix | Delete
}
[3063] Fix | Delete
[3064] Fix | Delete
$stickies = array_values( array_unique( array_map( 'intval', $stickies ) ) );
[3065] Fix | Delete
[3066] Fix | Delete
if ( ! in_array( $post_id, $stickies, true ) ) {
[3067] Fix | Delete
return;
[3068] Fix | Delete
}
[3069] Fix | Delete
[3070] Fix | Delete
$offset = array_search( $post_id, $stickies, true );
[3071] Fix | Delete
if ( false === $offset ) {
[3072] Fix | Delete
return;
[3073] Fix | Delete
}
[3074] Fix | Delete
[3075] Fix | Delete
array_splice( $stickies, $offset, 1 );
[3076] Fix | Delete
[3077] Fix | Delete
$updated = update_option( 'sticky_posts', $stickies );
[3078] Fix | Delete
[3079] Fix | Delete
if ( $updated ) {
[3080] Fix | Delete
/**
[3081] Fix | Delete
* Fires once a post has been removed from the sticky list.
[3082] Fix | Delete
*
[3083] Fix | Delete
* @since 4.6.0
[3084] Fix | Delete
*
[3085] Fix | Delete
* @param int $post_id ID of the post that was unstuck.
[3086] Fix | Delete
*/
[3087] Fix | Delete
do_action( 'post_unstuck', $post_id );
[3088] Fix | Delete
}
[3089] Fix | Delete
}
[3090] Fix | Delete
[3091] Fix | Delete
/**
[3092] Fix | Delete
* Returns the cache key for wp_count_posts() based on the passed arguments.
[3093] Fix | Delete
*
[3094] Fix | Delete
* @since 3.9.0
[3095] Fix | Delete
* @access private
[3096] Fix | Delete
*
[3097] Fix | Delete
* @param string $type Optional. Post type to retrieve count Default 'post'.
[3098] Fix | Delete
* @param string $perm Optional. 'readable' or empty. Default empty.
[3099] Fix | Delete
* @return string The cache key.
[3100] Fix | Delete
*/
[3101] Fix | Delete
function _count_posts_cache_key( $type = 'post', $perm = '' ) {
[3102] Fix | Delete
$cache_key = 'posts-' . $type;
[3103] Fix | Delete
[3104] Fix | Delete
if ( 'readable' === $perm && is_user_logged_in() ) {
[3105] Fix | Delete
$post_type_object = get_post_type_object( $type );
[3106] Fix | Delete
[3107] Fix | Delete
if ( $post_type_object && ! current_user_can( $post_type_object->cap->read_private_posts ) ) {
[3108] Fix | Delete
$cache_key .= '_' . $perm . '_' . get_current_user_id();
[3109] Fix | Delete
}
[3110] Fix | Delete
}
[3111] Fix | Delete
[3112] Fix | Delete
return $cache_key;
[3113] Fix | Delete
}
[3114] Fix | Delete
[3115] Fix | Delete
/**
[3116] Fix | Delete
* Counts number of posts of a post type and if user has permissions to view.
[3117] Fix | Delete
*
[3118] Fix | Delete
* This function provides an efficient method of finding the amount of post's
[3119] Fix | Delete
* type a blog has. Another method is to count the amount of items in
[3120] Fix | Delete
* get_posts(), but that method has a lot of overhead with doing so. Therefore,
[3121] Fix | Delete
* when developing for 2.5+, use this function instead.
[3122] Fix | Delete
*
[3123] Fix | Delete
* The $perm parameter checks for 'readable' value and if the user can read
[3124] Fix | Delete
* private posts, it will display that for the user that is signed in.
[3125] Fix | Delete
*
[3126] Fix | Delete
* @since 2.5.0
[3127] Fix | Delete
*
[3128] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[3129] Fix | Delete
*
[3130] Fix | Delete
* @param string $type Optional. Post type to retrieve count. Default 'post'.
[3131] Fix | Delete
* @param string $perm Optional. 'readable' or empty. Default empty.
[3132] Fix | Delete
* @return stdClass An object containing the number of posts for each status,
[3133] Fix | Delete
* or an empty object if the post type does not exist.
[3134] Fix | Delete
*/
[3135] Fix | Delete
function wp_count_posts( $type = 'post', $perm = '' ) {
[3136] Fix | Delete
global $wpdb;
[3137] Fix | Delete
[3138] Fix | Delete
if ( ! post_type_exists( $type ) ) {
[3139] Fix | Delete
return new stdClass();
[3140] Fix | Delete
}
[3141] Fix | Delete
[3142] Fix | Delete
$cache_key = _count_posts_cache_key( $type, $perm );
[3143] Fix | Delete
[3144] Fix | Delete
$counts = wp_cache_get( $cache_key, 'counts' );
[3145] Fix | Delete
if ( false !== $counts ) {
[3146] Fix | Delete
// We may have cached this before every status was registered.
[3147] Fix | Delete
foreach ( get_post_stati() as $status ) {
[3148] Fix | Delete
if ( ! isset( $counts->{$status} ) ) {
[3149] Fix | Delete
$counts->{$status} = 0;
[3150] Fix | Delete
}
[3151] Fix | Delete
}
[3152] Fix | Delete
[3153] Fix | Delete
/** This filter is documented in wp-includes/post.php */
[3154] Fix | Delete
return apply_filters( 'wp_count_posts', $counts, $type, $perm );
[3155] Fix | Delete
}
[3156] Fix | Delete
[3157] Fix | Delete
$query = "SELECT post_status, COUNT( * ) AS num_posts FROM {$wpdb->posts} WHERE post_type = %s";
[3158] Fix | Delete
[3159] Fix | Delete
if ( 'readable' === $perm && is_user_logged_in() ) {
[3160] Fix | Delete
$post_type_object = get_post_type_object( $type );
[3161] Fix | Delete
if ( ! current_user_can( $post_type_object->cap->read_private_posts ) ) {
[3162] Fix | Delete
$query .= $wpdb->prepare(
[3163] Fix | Delete
" AND (post_status != 'private' OR ( post_author = %d AND post_status = 'private' ))",
[3164] Fix | Delete
get_current_user_id()
[3165] Fix | Delete
);
[3166] Fix | Delete
}
[3167] Fix | Delete
}
[3168] Fix | Delete
[3169] Fix | Delete
$query .= ' GROUP BY post_status';
[3170] Fix | Delete
[3171] Fix | Delete
$results = (array) $wpdb->get_results( $wpdb->prepare( $query, $type ), ARRAY_A );
[3172] Fix | Delete
$counts = array_fill_keys( get_post_stati(), 0 );
[3173] Fix | Delete
[3174] Fix | Delete
foreach ( $results as $row ) {
[3175] Fix | Delete
$counts[ $row['post_status'] ] = $row['num_posts'];
[3176] Fix | Delete
}
[3177] Fix | Delete
[3178] Fix | Delete
$counts = (object) $counts;
[3179] Fix | Delete
wp_cache_set( $cache_key, $counts, 'counts' );
[3180] Fix | Delete
[3181] Fix | Delete
/**
[3182] Fix | Delete
* Filters the post counts by status for the current post type.
[3183] Fix | Delete
*
[3184] Fix | Delete
* @since 3.7.0
[3185] Fix | Delete
*
[3186] Fix | Delete
* @param stdClass $counts An object containing the current post_type's post
[3187] Fix | Delete
* counts by status.
[3188] Fix | Delete
* @param string $type Post type.
[3189] Fix | Delete
* @param string $perm The permission to determine if the posts are 'readable'
[3190] Fix | Delete
* by the current user.
[3191] Fix | Delete
*/
[3192] Fix | Delete
return apply_filters( 'wp_count_posts', $counts, $type, $perm );
[3193] Fix | Delete
}
[3194] Fix | Delete
[3195] Fix | Delete
/**
[3196] Fix | Delete
* Counts number of attachments for the mime type(s).
[3197] Fix | Delete
*
[3198] Fix | Delete
* If you set the optional mime_type parameter, then an array will still be
[3199] Fix | Delete
* returned, but will only have the item you are looking for. It does not give
[3200] Fix | Delete
* you the number of attachments that are children of a post. You can get that
[3201] Fix | Delete
* by counting the number of children that post has.
[3202] Fix | Delete
*
[3203] Fix | Delete
* @since 2.5.0
[3204] Fix | Delete
*
[3205] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[3206] Fix | Delete
*
[3207] Fix | Delete
* @param string|string[] $mime_type Optional. Array or comma-separated list of
[3208] Fix | Delete
* MIME patterns. Default empty.
[3209] Fix | Delete
* @return stdClass An object containing the attachment counts by mime type.
[3210] Fix | Delete
*/
[3211] Fix | Delete
function wp_count_attachments( $mime_type = '' ) {
[3212] Fix | Delete
global $wpdb;
[3213] Fix | Delete
[3214] Fix | Delete
$cache_key = sprintf(
[3215] Fix | Delete
'attachments%s',
[3216] Fix | Delete
! empty( $mime_type ) ? ':' . str_replace( '/', '_', implode( '-', (array) $mime_type ) ) : ''
[3217] Fix | Delete
);
[3218] Fix | Delete
[3219] Fix | Delete
$counts = wp_cache_get( $cache_key, 'counts' );
[3220] Fix | Delete
if ( false == $counts ) {
[3221] Fix | Delete
$and = wp_post_mime_type_where( $mime_type );
[3222] Fix | Delete
$count = $wpdb->get_results( "SELECT post_mime_type, COUNT( * ) AS num_posts FROM $wpdb->posts WHERE post_type = 'attachment' AND post_status != 'trash' $and GROUP BY post_mime_type", ARRAY_A );
[3223] Fix | Delete
[3224] Fix | Delete
$counts = array();
[3225] Fix | Delete
foreach ( (array) $count as $row ) {
[3226] Fix | Delete
$counts[ $row['post_mime_type'] ] = $row['num_posts'];
[3227] Fix | Delete
}
[3228] Fix | Delete
$counts['trash'] = $wpdb->get_var( "SELECT COUNT( * ) FROM $wpdb->posts WHERE post_type = 'attachment' AND post_status = 'trash' $and" );
[3229] Fix | Delete
[3230] Fix | Delete
wp_cache_set( $cache_key, (object) $counts, 'counts' );
[3231] Fix | Delete
}
[3232] Fix | Delete
[3233] Fix | Delete
/**
[3234] Fix | Delete
* Filters the attachment counts by mime type.
[3235] Fix | Delete
*
[3236] Fix | Delete
* @since 3.7.0
[3237] Fix | Delete
*
[3238] Fix | Delete
* @param stdClass $counts An object containing the attachment counts by
[3239] Fix | Delete
* mime type.
[3240] Fix | Delete
* @param string|string[] $mime_type Array or comma-separated list of MIME patterns.
[3241] Fix | Delete
*/
[3242] Fix | Delete
return apply_filters( 'wp_count_attachments', (object) $counts, $mime_type );
[3243] Fix | Delete
}
[3244] Fix | Delete
[3245] Fix | Delete
/**
[3246] Fix | Delete
* Gets default post mime types.
[3247] Fix | Delete
*
[3248] Fix | Delete
* @since 2.9.0
[3249] Fix | Delete
* @since 5.3.0 Added the 'Documents', 'Spreadsheets', and 'Archives' mime type groups.
[3250] Fix | Delete
*
[3251] Fix | Delete
* @return array List of post mime types.
[3252] Fix | Delete
*/
[3253] Fix | Delete
function get_post_mime_types() {
[3254] Fix | Delete
$post_mime_types = array( // array( adj, noun )
[3255] Fix | Delete
'image' => array(
[3256] Fix | Delete
__( 'Images' ),
[3257] Fix | Delete
__( 'Manage Images' ),
[3258] Fix | Delete
/* translators: %s: Number of images. */
[3259] Fix | Delete
_n_noop(
[3260] Fix | Delete
'Image <span class="count">(%s)</span>',
[3261] Fix | Delete
'Images <span class="count">(%s)</span>'
[3262] Fix | Delete
),
[3263] Fix | Delete
),
[3264] Fix | Delete
'audio' => array(
[3265] Fix | Delete
_x( 'Audio', 'file type group' ),
[3266] Fix | Delete
__( 'Manage Audio' ),
[3267] Fix | Delete
/* translators: %s: Number of audio files. */
[3268] Fix | Delete
_n_noop(
[3269] Fix | Delete
'Audio <span class="count">(%s)</span>',
[3270] Fix | Delete
'Audio <span class="count">(%s)</span>'
[3271] Fix | Delete
),
[3272] Fix | Delete
),
[3273] Fix | Delete
'video' => array(
[3274] Fix | Delete
_x( 'Video', 'file type group' ),
[3275] Fix | Delete
__( 'Manage Video' ),
[3276] Fix | Delete
/* translators: %s: Number of video files. */
[3277] Fix | Delete
_n_noop(
[3278] Fix | Delete
'Video <span class="count">(%s)</span>',
[3279] Fix | Delete
'Video <span class="count">(%s)</span>'
[3280] Fix | Delete
),
[3281] Fix | Delete
),
[3282] Fix | Delete
'document' => array(
[3283] Fix | Delete
__( 'Documents' ),
[3284] Fix | Delete
__( 'Manage Documents' ),
[3285] Fix | Delete
/* translators: %s: Number of documents. */
[3286] Fix | Delete
_n_noop(
[3287] Fix | Delete
'Document <span class="count">(%s)</span>',
[3288] Fix | Delete
'Documents <span class="count">(%s)</span>'
[3289] Fix | Delete
),
[3290] Fix | Delete
),
[3291] Fix | Delete
'spreadsheet' => array(
[3292] Fix | Delete
__( 'Spreadsheets' ),
[3293] Fix | Delete
__( 'Manage Spreadsheets' ),
[3294] Fix | Delete
/* translators: %s: Number of spreadsheets. */
[3295] Fix | Delete
_n_noop(
[3296] Fix | Delete
'Spreadsheet <span class="count">(%s)</span>',
[3297] Fix | Delete
'Spreadsheets <span class="count">(%s)</span>'
[3298] Fix | Delete
),
[3299] Fix | Delete
),
[3300] Fix | Delete
'archive' => array(
[3301] Fix | Delete
_x( 'Archives', 'file type group' ),
[3302] Fix | Delete
__( 'Manage Archives' ),
[3303] Fix | Delete
/* translators: %s: Number of archives. */
[3304] Fix | Delete
_n_noop(
[3305] Fix | Delete
'Archive <span class="count">(%s)</span>',
[3306] Fix | Delete
'Archives <span class="count">(%s)</span>'
[3307] Fix | Delete
),
[3308] Fix | Delete
),
[3309] Fix | Delete
);
[3310] Fix | Delete
[3311] Fix | Delete
$ext_types = wp_get_ext_types();
[3312] Fix | Delete
$mime_types = wp_get_mime_types();
[3313] Fix | Delete
[3314] Fix | Delete
foreach ( $post_mime_types as $group => $labels ) {
[3315] Fix | Delete
if ( in_array( $group, array( 'image', 'audio', 'video' ), true ) ) {
[3316] Fix | Delete
continue;
[3317] Fix | Delete
}
[3318] Fix | Delete
[3319] Fix | Delete
if ( ! isset( $ext_types[ $group ] ) ) {
[3320] Fix | Delete
unset( $post_mime_types[ $group ] );
[3321] Fix | Delete
continue;
[3322] Fix | Delete
}
[3323] Fix | Delete
[3324] Fix | Delete
$group_mime_types = array();
[3325] Fix | Delete
foreach ( $ext_types[ $group ] as $extension ) {
[3326] Fix | Delete
foreach ( $mime_types as $exts => $mime ) {
[3327] Fix | Delete
if ( preg_match( '!^(' . $exts . ')$!i', $extension ) ) {
[3328] Fix | Delete
$group_mime_types[] = $mime;
[3329] Fix | Delete
break;
[3330] Fix | Delete
}
[3331] Fix | Delete
}
[3332] Fix | Delete
}
[3333] Fix | Delete
$group_mime_types = implode( ',', array_unique( $group_mime_types ) );
[3334] Fix | Delete
[3335] Fix | Delete
$post_mime_types[ $group_mime_types ] = $labels;
[3336] Fix | Delete
unset( $post_mime_types[ $group ] );
[3337] Fix | Delete
}
[3338] Fix | Delete
[3339] Fix | Delete
/**
[3340] Fix | Delete
* Filters the default list of post mime types.
[3341] Fix | Delete
*
[3342] Fix | Delete
* @since 2.5.0
[3343] Fix | Delete
*
[3344] Fix | Delete
* @param array $post_mime_types Default list of post mime types.
[3345] Fix | Delete
*/
[3346] Fix | Delete
return apply_filters( 'post_mime_types', $post_mime_types );
[3347] Fix | Delete
}
[3348] Fix | Delete
[3349] Fix | Delete
/**
[3350] Fix | Delete
* Checks a MIME-Type against a list.
[3351] Fix | Delete
*
[3352] Fix | Delete
* If the `$wildcard_mime_types` parameter is a string, it must be comma separated
[3353] Fix | Delete
* list. If the `$real_mime_types` is a string, it is also comma separated to
[3354] Fix | Delete
* create the list.
[3355] Fix | Delete
*
[3356] Fix | Delete
* @since 2.5.0
[3357] Fix | Delete
*
[3358] Fix | Delete
* @param string|string[] $wildcard_mime_types Mime types, e.g. `audio/mpeg`, `image` (same as `image/*`),
[3359] Fix | Delete
* or `flash` (same as `*flash*`).
[3360] Fix | Delete
* @param string|string[] $real_mime_types Real post mime type values.
[3361] Fix | Delete
* @return array array(wildcard=>array(real types)).
[3362] Fix | Delete
*/
[3363] Fix | Delete
function wp_match_mime_types( $wildcard_mime_types, $real_mime_types ) {
[3364] Fix | Delete
$matches = array();
[3365] Fix | Delete
if ( is_string( $wildcard_mime_types ) ) {
[3366] Fix | Delete
$wildcard_mime_types = array_map( 'trim', explode( ',', $wildcard_mime_types ) );
[3367] Fix | Delete
}
[3368] Fix | Delete
if ( is_string( $real_mime_types ) ) {
[3369] Fix | Delete
$real_mime_types = array_map( 'trim', explode( ',', $real_mime_types ) );
[3370] Fix | Delete
}
[3371] Fix | Delete
[3372] Fix | Delete
$patternses = array();
[3373] Fix | Delete
$wild = '[-._a-z0-9]*';
[3374] Fix | Delete
[3375] Fix | Delete
foreach ( (array) $wildcard_mime_types as $type ) {
[3376] Fix | Delete
$mimes = array_map( 'trim', explode( ',', $type ) );
[3377] Fix | Delete
foreach ( $mimes as $mime ) {
[3378] Fix | Delete
$regex = str_replace( '__wildcard__', $wild, preg_quote( str_replace( '*', '__wildcard__', $mime ) ) );
[3379] Fix | Delete
[3380] Fix | Delete
$patternses[][ $type ] = "^$regex$";
[3381] Fix | Delete
[3382] Fix | Delete
if ( ! str_contains( $mime, '/' ) ) {
[3383] Fix | Delete
$patternses[][ $type ] = "^$regex/";
[3384] Fix | Delete
$patternses[][ $type ] = $regex;
[3385] Fix | Delete
}
[3386] Fix | Delete
}
[3387] Fix | Delete
}
[3388] Fix | Delete
asort( $patternses );
[3389] Fix | Delete
[3390] Fix | Delete
foreach ( $patternses as $patterns ) {
[3391] Fix | Delete
foreach ( $patterns as $type => $pattern ) {
[3392] Fix | Delete
foreach ( (array) $real_mime_types as $real ) {
[3393] Fix | Delete
if ( preg_match( "#$pattern#", $real )
[3394] Fix | Delete
&& ( empty( $matches[ $type ] ) || false === array_search( $real, $matches[ $type ], true ) )
[3395] Fix | Delete
) {
[3396] Fix | Delete
$matches[ $type ][] = $real;
[3397] Fix | Delete
}
[3398] Fix | Delete
}
[3399] Fix | Delete
}
[3400] Fix | Delete
}
[3401] Fix | Delete
[3402] Fix | Delete
return $matches;
[3403] Fix | Delete
}
[3404] Fix | Delete
[3405] Fix | Delete
/**
[3406] Fix | Delete
* Converts MIME types into SQL.
[3407] Fix | Delete
*
[3408] Fix | Delete
* @since 2.5.0
[3409] Fix | Delete
*
[3410] Fix | Delete
* @param string|string[] $post_mime_types List of mime types or comma separated string
[3411] Fix | Delete
* of mime types.
[3412] Fix | Delete
* @param string $table_alias Optional. Specify a table alias, if needed.
[3413] Fix | Delete
* Default empty.
[3414] Fix | Delete
* @return string The SQL AND clause for mime searching.
[3415] Fix | Delete
*/
[3416] Fix | Delete
function wp_post_mime_type_where( $post_mime_types, $table_alias = '' ) {
[3417] Fix | Delete
$where = '';
[3418] Fix | Delete
$wildcards = array( '', '%', '%/%' );
[3419] Fix | Delete
if ( is_string( $post_mime_types ) ) {
[3420] Fix | Delete
$post_mime_types = array_map( 'trim', explode( ',', $post_mime_types ) );
[3421] Fix | Delete
}
[3422] Fix | Delete
[3423] Fix | Delete
$where_clauses = array();
[3424] Fix | Delete
[3425] Fix | Delete
foreach ( (array) $post_mime_types as $mime_type ) {
[3426] Fix | Delete
$mime_type = preg_replace( '/\s/', '', $mime_type );
[3427] Fix | Delete
$slashpos = strpos( $mime_type, '/' );
[3428] Fix | Delete
if ( false !== $slashpos ) {
[3429] Fix | Delete
$mime_group = preg_replace( '/[^-*.a-zA-Z0-9]/', '', substr( $mime_type, 0, $slashpos ) );
[3430] Fix | Delete
$mime_subgroup = preg_replace( '/[^-*.+a-zA-Z0-9]/', '', substr( $mime_type, $slashpos + 1 ) );
[3431] Fix | Delete
if ( empty( $mime_subgroup ) ) {
[3432] Fix | Delete
$mime_subgroup = '*';
[3433] Fix | Delete
} else {
[3434] Fix | Delete
$mime_subgroup = str_replace( '/', '', $mime_subgroup );
[3435] Fix | Delete
}
[3436] Fix | Delete
$mime_pattern = "$mime_group/$mime_subgroup";
[3437] Fix | Delete
} else {
[3438] Fix | Delete
$mime_pattern = preg_replace( '/[^-*.a-zA-Z0-9]/', '', $mime_type );
[3439] Fix | Delete
if ( ! str_contains( $mime_pattern, '*' ) ) {
[3440] Fix | Delete
$mime_pattern .= '/*';
[3441] Fix | Delete
}
[3442] Fix | Delete
}
[3443] Fix | Delete
[3444] Fix | Delete
$mime_pattern = preg_replace( '/\*+/', '%', $mime_pattern );
[3445] Fix | Delete
[3446] Fix | Delete
if ( in_array( $mime_type, $wildcards, true ) ) {
[3447] Fix | Delete
return '';
[3448] Fix | Delete
}
[3449] Fix | Delete
[3450] Fix | Delete
if ( str_contains( $mime_pattern, '%' ) ) {
[3451] Fix | Delete
$where_clauses[] = empty( $table_alias ) ? "post_mime_type LIKE '$mime_pattern'" : "$table_alias.post_mime_type LIKE '$mime_pattern'";
[3452] Fix | Delete
} else {
[3453] Fix | Delete
$where_clauses[] = empty( $table_alias ) ? "post_mime_type = '$mime_pattern'" : "$table_alias.post_mime_type = '$mime_pattern'";
[3454] Fix | Delete
}
[3455] Fix | Delete
}
[3456] Fix | Delete
[3457] Fix | Delete
if ( ! empty( $where_clauses ) ) {
[3458] Fix | Delete
$where = ' AND (' . implode( ' OR ', $where_clauses ) . ') ';
[3459] Fix | Delete
}
[3460] Fix | Delete
[3461] Fix | Delete
return $where;
[3462] Fix | Delete
}
[3463] Fix | Delete
[3464] Fix | Delete
/**
[3465] Fix | Delete
* Trashes or deletes a post or page.
[3466] Fix | Delete
*
[3467] Fix | Delete
* When the post and page is permanently deleted, everything that is tied to
[3468] Fix | Delete
* it is deleted also. This includes comments, post meta fields, and terms
[3469] Fix | Delete
* associated with the post.
[3470] Fix | Delete
*
[3471] Fix | Delete
* The post or page is moved to Trash instead of permanently deleted unless
[3472] Fix | Delete
* Trash is disabled, item is already in the Trash, or $force_delete is true.
[3473] Fix | Delete
*
[3474] Fix | Delete
* @since 1.0.0
[3475] Fix | Delete
*
[3476] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[3477] Fix | Delete
* @see wp_delete_attachment()
[3478] Fix | Delete
* @see wp_trash_post()
[3479] Fix | Delete
*
[3480] Fix | Delete
* @param int $post_id Optional. Post ID. Default 0.
[3481] Fix | Delete
* @param bool $force_delete Optional. Whether to bypass Trash and force deletion.
[3482] Fix | Delete
* Default false.
[3483] Fix | Delete
* @return WP_Post|false|null Post data on success, false or null on failure.
[3484] Fix | Delete
*/
[3485] Fix | Delete
function wp_delete_post( $post_id = 0, $force_delete = false ) {
[3486] Fix | Delete
global $wpdb;
[3487] Fix | Delete
[3488] Fix | Delete
$post = $wpdb->get_row( $wpdb->prepare( "SELECT * FROM $wpdb->posts WHERE ID = %d", $post_id ) );
[3489] Fix | Delete
[3490] Fix | Delete
if ( ! $post ) {
[3491] Fix | Delete
return $post;
[3492] Fix | Delete
}
[3493] Fix | Delete
[3494] Fix | Delete
$post = get_post( $post );
[3495] Fix | Delete
[3496] Fix | Delete
if ( ! $force_delete
[3497] Fix | Delete
&& ( 'post' === $post->post_type || 'page' === $post->post_type )
[3498] Fix | Delete
&& 'trash' !== get_post_status( $post_id ) && EMPTY_TRASH_DAYS
[3499] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function