diff --git wp-includes/functions.php wp-includes/functions.php
index 0afa50b..c10709c 100644
|
|
function wp_auth_check( $response, $data ) { |
3985 | 3985 | function get_tag_regex( $tag ) { |
3986 | 3986 | if ( empty( $tag ) ) |
3987 | 3987 | return; |
3988 | | |
3989 | | return sprintf( '(<%1$s[^>]*(?:/?>$|>[\s\S]*?</%1$s>))', tag_escape( $tag ) ); |
| 3988 | return sprintf( '<%1$s[^<]*(?:>[\s\S]*<\/%1$s>|\s*\/>)', tag_escape( $tag ) ); |
3990 | 3989 | } |
diff --git wp-includes/media.php wp-includes/media.php
index bd52867..51a466d 100644
|
|
function get_embedded_media( $type, &$content, $remove = false, $limit = 0 ) { |
1966 | 1966 | |
1967 | 1967 | foreach ( array( $type, 'object', 'embed', 'iframe' ) as $tag ) { |
1968 | 1968 | if ( preg_match( '#' . get_tag_regex( $tag ) . '#', $content, $matches ) ) { |
1969 | | $html[] = $matches[1]; |
| 1969 | $html[] = $matches[0]; |
1970 | 1970 | if ( $remove ) |
1971 | 1971 | $content = str_replace( $matches[0], '', $content ); |
1972 | 1972 | |
… |
… |
function get_content_images( &$content, $html = true, $remove = false, $limit = |
2209 | 2209 | $tags = array(); |
2210 | 2210 | $captions = array(); |
2211 | 2211 | |
2212 | | if ( $remove && preg_match_all( '/' . get_shortcode_regex() . '/s', $content, $matches, PREG_SET_ORDER ) && ! empty( $matches ) ) { |
| 2212 | if ( preg_match_all( '/' . get_shortcode_regex() . '/s', $content, $matches, PREG_SET_ORDER ) && ! empty( $matches ) ) { |
2213 | 2213 | foreach ( $matches as $shortcode ) { |
2214 | | if ( 'caption' === $shortcode[2] ) |
| 2214 | if ( 'caption' === $shortcode[2] ) { |
2215 | 2215 | $captions[] = $shortcode[0]; |
| 2216 | if ( $html ) |
| 2217 | $tags[] = do_shortcode( $shortcode[0] ); |
| 2218 | } |
| 2219 | |
| 2220 | if ( $limit > 0 && count( $tags ) >= $limit ) |
| 2221 | break; |
2216 | 2222 | } |
2217 | 2223 | } |
2218 | 2224 | |
2219 | | if ( preg_match_all( '#<img[^>]+/?>#i', $content, $matches, PREG_SET_ORDER ) && ! empty( $matches ) ) { |
2220 | | foreach ( $matches as $tag ) { |
2221 | | $count = 1; |
2222 | | if ( $remove ) { |
| 2225 | foreach ( array( 'a', 'img' ) as $tag ) { |
| 2226 | if ( preg_match_all( '#' . get_tag_regex( $tag ) . '#i', $content, $matches, PREG_SET_ORDER ) && ! empty( $matches ) ) { |
| 2227 | foreach ( $matches as $node ) { |
| 2228 | if ( ! strstr( $node[0], '<img ' ) ) |
| 2229 | continue; |
| 2230 | |
| 2231 | $count = 1; |
| 2232 | $found = false; |
| 2233 | |
2223 | 2234 | foreach ( $captions as $caption ) { |
2224 | | if ( strstr( $caption, $tag[0] ) ) { |
2225 | | $content = str_replace( $caption, '', $content, $count ); |
| 2235 | if ( strstr( $caption, $node[0] ) ) { |
| 2236 | $found = true; |
| 2237 | if ( $remove ) |
| 2238 | $content = str_replace( $caption, '', $content, $count ); |
2226 | 2239 | } |
2227 | 2240 | } |
2228 | 2241 | |
2229 | | $content = str_replace( $tag[0], '', $content, $count ); |
2230 | | } |
| 2242 | if ( $remove ) |
| 2243 | $content = str_replace( $node[0], '', $content, $count ); |
2231 | 2244 | |
2232 | | $tags[] = $tag[0]; |
| 2245 | if ( ! $found ) |
| 2246 | $tags[] = $node[0]; |
2233 | 2247 | |
2234 | | if ( $limit > 0 && count( $tags ) >= $limit ) |
2235 | | break; |
| 2248 | if ( $limit > 0 && count( $tags ) >= $limit ) |
| 2249 | break 2; |
| 2250 | } |
2236 | 2251 | } |
2237 | 2252 | } |
2238 | 2253 | |
… |
… |
function get_the_post_format_image( $attached_size = 'full', &$post = null ) { |
2400 | 2415 | if ( isset( $post->format_content ) ) |
2401 | 2416 | return $post->format_content; |
2402 | 2417 | |
| 2418 | $matched = false; |
2403 | 2419 | $meta = get_post_format_meta( $post->ID ); |
2404 | 2420 | |
2405 | 2421 | $link_fmt = '%s'; |
… |
… |
function get_the_post_format_image( $attached_size = 'full', &$post = null ) { |
2426 | 2442 | $sizes = get_intermediate_image_sizes(); |
2427 | 2443 | $sizes[] = 'full'; // Add original image source. |
2428 | 2444 | |
2429 | | $urls = array(); |
| 2445 | $urls = array( get_attachment_link( $media->ID ) ); |
2430 | 2446 | foreach ( $sizes as $size ) { |
2431 | 2447 | $image = wp_get_attachment_image_src( $media->ID, $size ); |
2432 | 2448 | if ( $image ) |
… |
… |
function get_the_post_format_image( $attached_size = 'full', &$post = null ) { |
2444 | 2460 | foreach ( $matches as $shortcode ) { |
2445 | 2461 | if ( 'caption' === $shortcode[2] ) { |
2446 | 2462 | foreach ( $urls as $url ) { |
2447 | | if ( strstr( $shortcode[0], $url ) ) |
| 2463 | if ( strstr( $shortcode[0], $url ) ) { |
| 2464 | if ( ! $matched ) |
| 2465 | $matched = do_shortcode( $shortcode[0] ); |
2448 | 2466 | $content = str_replace( $shortcode[0], '', $content, $count ); |
| 2467 | } |
2449 | 2468 | } |
2450 | 2469 | } |
2451 | 2470 | } |
… |
… |
function get_the_post_format_image( $attached_size = 'full', &$post = null ) { |
2455 | 2474 | if ( preg_match_all( '#' . get_tag_regex( $tag ) . '#', $content, $matches, PREG_SET_ORDER ) && ! empty( $matches ) ) { |
2456 | 2475 | foreach ( $matches as $match ) { |
2457 | 2476 | foreach ( $urls as $url ) { |
2458 | | if ( strstr( $match[0], $url ) ) |
| 2477 | if ( strstr( $match[0], $url ) ) { |
| 2478 | if ( ! $matched ) |
| 2479 | $matched = $match[0]; |
2459 | 2480 | $content = str_replace( $match[0], '', $content, $count ); |
| 2481 | } |
2460 | 2482 | } |
2461 | 2483 | } |
2462 | 2484 | } |
2463 | 2485 | } |
2464 | 2486 | |
2465 | 2487 | $post->split_content = $content; |
2466 | | $image = wp_get_attachment_image( $media->ID, $attached_size ); |
2467 | | $post->format_content = sprintf( $link_fmt, $image ); |
| 2488 | if ( ! $matched ) { |
| 2489 | $image = wp_get_attachment_image( $media->ID, $attached_size ); |
| 2490 | $post->format_content = sprintf( $link_fmt, $image ); |
| 2491 | } else { |
| 2492 | $post->format_content = $matched; |
| 2493 | if ( ! empty( $meta['url'] ) && false === stripos( $matched, '<a ' ) ) |
| 2494 | $post->format_content = sprintf( $link_fmt, $matched ); |
| 2495 | } |
2468 | 2496 | return $post->format_content; |
2469 | 2497 | } |
2470 | 2498 | |
diff --git wp-includes/post-formats.php wp-includes/post-formats.php
index 127d1ef..4301bed 100644
|
|
function post_formats_compat( $content, $id = 0 ) { |
380 | 380 | $image = is_numeric( $meta['image'] ) ? wp_get_attachment_url( $meta['image'] ) : $meta['image']; |
381 | 381 | |
382 | 382 | if ( ! empty( $image ) && ! stristr( $content, $image ) ) { |
383 | | $image_html = sprintf( |
384 | | '<img %ssrc="%s" alt="" />', |
385 | | empty( $compat['image_class'] ) ? '' : sprintf( 'class="%s" ', esc_attr( $compat['image_class'] ) ), |
386 | | $image |
387 | | ); |
388 | | if ( empty( $meta['url'] ) ) { |
| 383 | if ( false === strpos( $image, '<a ' ) ) { |
| 384 | $image_html = sprintf( |
| 385 | '<img %ssrc="%s" alt="" />', |
| 386 | empty( $compat['image_class'] ) ? '' : sprintf( 'class="%s" ', esc_attr( $compat['image_class'] ) ), |
| 387 | $image |
| 388 | ); |
| 389 | } else { |
| 390 | $image_html = $image; |
| 391 | } |
| 392 | |
| 393 | if ( empty( $meta['url'] ) || false !== strpos( $image, '<a ' ) ) { |
389 | 394 | $format_output .= $image_html; |
390 | 395 | } else { |
391 | 396 | $format_output .= sprintf( |