WordPress.org

Make WordPress Core

Ticket #23282: 23282.9.diff

File 23282.9.diff, 20.2 KB (added by wonderboymusic, 7 years ago)
  • wp-admin/includes/ajax-actions.php

    diff --git wp-admin/includes/ajax-actions.php wp-admin/includes/ajax-actions.php
    index 0fabe2a..cf6d80b 100644
    function wp_ajax_send_attachment_to_editor() { 
    20302030                $caption = isset( $attachment['post_excerpt'] ) ? $attachment['post_excerpt'] : '';
    20312031                $title = ''; // We no longer insert title tags into <img> tags, as they are redundant.
    20322032                $html = get_image_send_to_editor( $id, $caption, $title, $align, $url, (bool) $rel, $size, $alt );
     2033        } elseif ( 'video' === substr( $post->post_mime_type, 0, 5 ) || 'audio' === substr( $post->post_mime_type, 0, 5 )  ) {
     2034                $html = stripslashes_deep( $_POST['html'] );
    20332035        }
    20342036
    20352037        $html = apply_filters( 'media_send_to_editor', $html, $id, $attachment );
  • wp-includes/functions.php

    diff --git wp-includes/functions.php wp-includes/functions.php
    index cbd7925..5ac68c7 100644
    function wp_is_stream( $path ) { 
    38833883 */
    38843884function wp_checkdate( $month, $day, $year, $source_date ) {
    38853885        return apply_filters( 'wp_checkdate', checkdate( $month, $day, $year ), $source_date );
     3886}
     3887
     3888/**
     3889 * Return RegEx body to liberally match an opening HTML tag that:
     3890 * 1. Is self-closing or
     3891 * 2. Has no body but has a closing tag of the same name or
     3892 * 3. Contains a body and a closing tag of the same name
     3893 *
     3894 * Note: this RegEx does not balance inner tags and does not attempt to produce valid HTML
     3895 *
     3896 * @since 3.6.0
     3897 *
     3898 * @param string $tag An HTML tag name. Example: 'video'
     3899 * @return string
     3900 */
     3901function get_tag_regex( $tag ) {
     3902        if ( empty( $tag ) )
     3903                return;
     3904
     3905        return sprintf( '(<%1$s[^>]*(?:/?>$|>[\s\S]*?</%1$s>))', tag_escape( $tag ) );
    38863906}
     3907 No newline at end of file
  • wp-includes/js/media-editor.js

    diff --git wp-includes/js/media-editor.js wp-includes/js/media-editor.js
    index 15eff8d..1b5f844 100644
     
    6666                                        src:       size.url,
    6767                                        captionId: 'attachment_' + attachment.id
    6868                                });
    69 
     69                        } else if ( 'video' === attachment.type || 'audio' === attachment.type ) {
     70                                _.extend( props, _.pick( attachment, 'title', 'type', 'icon', 'mime' ) );
    7071                        // Format properties for non-images.
    7172                        } else {
    7273                                props.title = props.title || attachment.filename;
     
    9596                        return wp.html.string( options );
    9697                },
    9798
     99                audio: function( props, attachment ) {
     100                        var shortcode, html;
     101
     102                        props = wp.media.string.props( props, attachment );
     103
     104                        shortcode = {};
     105
     106                        if ( props.mime ) {
     107                                switch ( props.mime ) {
     108                                case 'audio/mpeg':
     109                                        shortcode.mp3 = props.linkUrl;
     110                                        break;
     111                                case 'audio/ogg':
     112                                        shortcode.ogg = props.linkUrl;
     113                                        break;
     114                                case 'audio/wma':
     115                                        shortcode.wma = props.linkUrl;
     116                                        break;
     117                                }
     118                        }
     119
     120                        html = wp.shortcode.string({
     121                                tag:     'audio',
     122                                attrs:   shortcode
     123                        });
     124
     125                        return html;
     126                },
     127
     128                video: function( props, attachment ) {
     129                        var shortcode, html;
     130
     131                        props = wp.media.string.props( props, attachment );
     132
     133                        shortcode = {};
     134
     135                        if ( props.mime ) {
     136                                switch ( props.mime ) {
     137                                case 'video/mp4':
     138                                        shortcode.mp4 = props.linkUrl;
     139                                        break;
     140                                case 'video/webm':
     141                                        shortcode.webm = props.linkUrl;
     142                                        break;
     143                                case 'video/ogg':
     144                                        shortcode.ogv = props.linkUrl;
     145                                        break;
     146                                case 'video/asf':
     147                                        shortcode.wmv = props.linkUrl;
     148                                        break;
     149                                case 'video/x-flv':
     150                                        shortcode.flv = props.linkUrl;
     151                                        break;
     152                                }
     153                        }
     154
     155                        html = wp.shortcode.string({
     156                                tag:     'video',
     157                                attrs:   shortcode
     158                        });
     159
     160                        return html;
     161                },
     162
    98163                image: function( props, attachment ) {
    99164                        var img = {},
    100165                                options, classes, shortcode, html;
     
    575640                                                if ( props[ prop ] )
    576641                                                        options[ option ] = props[ prop ];
    577642                                        });
    578 
     643                                } else if ( 'video' === attachment.type ) {
     644                                        html = wp.media.string.video( props );
     645                                } else if ( 'audio' === attachment.type ) {
     646                                        html = wp.media.string.audio( props );
    579647                                } else {
    580648                                        html = wp.media.string.link( props );
    581649                                        options.post_title = props.title;
  • wp-includes/media.php

    diff --git wp-includes/media.php wp-includes/media.php
    index f1f3737..87df77f 100644
    function gallery_shortcode($attr) { 
    803803}
    804804
    805805/**
     806 * Return a filtered list of WP-supported audio formats
     807 *
     808 * @since 3.6.0
     809 * @return array
     810 */
     811function wp_get_audio_extensions() {
     812        return apply_filters( 'wp_audio_extensions', array( 'mp3', 'ogg', 'wma' ) );
     813}
     814
     815/**
     816 * The Audio shortcode.
     817 *
     818 * This implements the functionality of the Audio Shortcode for displaying
     819 * WordPress mp3s in a post.
     820 *
     821 * @since 3.6.0
     822 *
     823 * @param array $attr Attributes of the shortcode.
     824 * @return string HTML content to display audio.
     825 */
     826function wp_audio_shortcode( $attr ) {
     827        $post_id = get_post() ? get_the_ID() : 0;
     828
     829        static $instances = 0;
     830        $instances++;
     831
     832        $audio = null;
     833
     834        $default_types = wp_get_audio_extensions();
     835        $defaults_atts = array( 'src' => '' );
     836        foreach ( $default_types as $type  )
     837                $defaults_atts[$type] = '';
     838
     839        extract( shortcode_atts( $defaults_atts, $attr ) );
     840
     841        $primary = false;
     842        if ( ! empty( $src ) ) {
     843                $type = wp_check_filetype( $src );
     844                if ( ! in_array( $type['ext'], $default_types ) ) {
     845                        printf( '<a class="wp-post-format-link-audio" href="%1$s">%1$s</a>', $src );
     846                        return;
     847                }
     848                $primary = true;
     849                array_unshift( $default_types, 'src' );
     850        } else {
     851                foreach ( $default_types as $ext ) {
     852                        if ( ! empty( $$ext ) ) {
     853                                $type = wp_check_filetype( $$ext );
     854                                if ( $type['ext'] === $ext )
     855                                        $primary = true;
     856                        }
     857                }
     858        }
     859
     860        if ( ! $primary ) {
     861                $audios = get_post_audio( $post_id );
     862                if ( empty( $audios ) )
     863                        return;
     864
     865                $audio = reset( $audios );
     866                $src = wp_get_attachment_url( $audio->ID );
     867                if ( empty( $src ) )
     868                        return;
     869
     870                array_unshift( $default_types, 'src' );
     871        }
     872
     873        wp_enqueue_style( 'wp-mediaelement' );
     874        wp_enqueue_script( 'wp-mediaelement' );
     875
     876        $atts = array(
     877                sprintf( 'class="%s"', apply_filters( 'wp_audio_shortcode_class', 'wp-audio-shortcode' ) ),
     878                sprintf( 'id="audio-%d-%d"', $post_id, $instances ),
     879        );
     880
     881        $html = sprintf( '<audio %s controls="controls" preload="none">', join( ' ', $atts ) );
     882
     883        $source = '<source type="%s" src="%s" />';
     884        foreach ( $default_types as $fallback ) {
     885                if ( ! empty( $$fallback ) ) {
     886                        $type = wp_check_filetype( $$fallback );
     887                        $html .= sprintf( $source, $type['type'], $$fallback );
     888                }
     889        }
     890
     891        $html .= '</audio>';
     892
     893        return apply_filters( 'wp_audio_shortcode', $html, $src, $audio, $post_id );
     894}
     895add_shortcode( 'audio', 'wp_audio_shortcode' );
     896
     897/**
     898 * Return a filtered list of WP-supported video formats
     899 *
     900 * @since 3.6.0
     901 * @return array
     902 */
     903function wp_get_video_extensions() {
     904        return apply_filters( 'wp_video_extensions', array( 'mp4', 'webm', 'ogv', 'wmv', 'flv' ) );
     905}
     906
     907/**
     908 * The Video shortcode.
     909 *
     910 * This implements the functionality of the Video Shortcode for displaying
     911 * WordPress mp4s in a post.
     912 *
     913 * @since 3.6.0
     914 *
     915 * @param array $attr Attributes of the shortcode.
     916 * @return string HTML content to display video.
     917 */
     918function wp_video_shortcode( $attr ) {
     919        global $content_width;
     920        $post_id = get_post() ? get_the_ID() : 0;
     921
     922        static $instances = 0;
     923        $instances++;
     924
     925        $video = null;
     926
     927        $default_types = wp_get_video_extensions();
     928        $defaults_atts = array(
     929                'src' => '',
     930                'poster' => '',
     931                'height' => 360,
     932                'width' => empty( $content_width ) ? 640 : $content_width,
     933        );
     934        foreach ( $default_types as $type  )
     935                $defaults_atts[$type] = '';
     936
     937        extract( shortcode_atts( $defaults_atts, $attr ) );
     938
     939        $primary = false;
     940        if ( ! empty( $src ) ) {
     941                $type = wp_check_filetype( $src );
     942                if ( ! in_array( $type['ext'], $default_types ) ) {
     943                        printf( '<a class="wp-post-format-link-video" href="%1$s">%1$s</a>', $src );
     944                        return;
     945                }
     946                $primary = true;
     947                array_unshift( $default_types, 'src' );
     948        } else {
     949                foreach ( $default_types as $ext ) {
     950                        if ( ! empty( $$ext ) ) {
     951                                $type = wp_check_filetype( $$ext );
     952                                if ( $type['ext'] === $ext )
     953                                        $primary = true;
     954                        }
     955                }
     956        }
     957
     958        if ( ! $primary ) {
     959                $videos = get_post_video( $post_id );
     960                if ( empty( $videos ) )
     961                        return;
     962
     963                $video = reset( $videos );
     964                $src = wp_get_attachment_url( $video->ID );
     965                if ( empty( $src ) )
     966                        return;
     967
     968                array_unshift( $default_types, 'src' );
     969        }
     970
     971        wp_enqueue_style( 'wp-mediaelement' );
     972        wp_enqueue_script( 'wp-mediaelement' );
     973
     974        $atts = array(
     975                sprintf( 'class="%s"', apply_filters( 'video_shortcode_class', 'wp-video-shortcode' ) ),
     976                sprintf( 'id="video-%d-%d"', $post_id, $instances ),
     977                sprintf( 'width="%d"', $width ),
     978                sprintf( 'height="%d"', $height ),
     979        );
     980
     981        if ( ! empty( $poster ) )
     982                $atts[] = sprintf( 'poster="%s"', esc_url( $poster ) );
     983
     984        $html = sprintf( '<video %s controls="controls" preload="none">', join( ' ', $atts ) );
     985
     986        $source = '<source type="%s" src="%s" />';
     987        foreach ( $default_types as $fallback ) {
     988                if ( ! empty( $$fallback ) ) {
     989                        $type = wp_check_filetype( $$fallback );
     990                        $html .= sprintf( $source, $type['type'], $$fallback );
     991                }
     992        }
     993
     994        $html .= '</video>';
     995
     996        return apply_filters( 'wp_video_shortcode', $html, $src, $video, $post_id );
     997}
     998add_shortcode( 'video', 'wp_video_shortcode' );
     999
     1000/**
    8061001 * Display previous image link that has the same post parent.
    8071002 *
    8081003 * @since 2.5.0
    function wp_enqueue_media( $args = array() ) { 
    15421737
    15431738        do_action( 'wp_enqueue_media' );
    15441739}
     1740
     1741/**
     1742 * Retrieve audio attached to the passed post
     1743 *
     1744 * @since 3.6.0
     1745 *
     1746 * @param int $post_id  Post ID
     1747 * @return array Found audio attachments
     1748 */
     1749function get_post_audio( $post_id = 0 ) {
     1750        $post = empty( $post_id ) ? get_post() : get_post( $post_id );
     1751        if ( empty( $post ) )
     1752                return;
     1753
     1754        $children = get_children( array(
     1755                'post_parent' => $post->ID,
     1756                'post_type' => 'attachment',
     1757                'post_mime_type' => 'audio',
     1758                'posts_per_page' => -1
     1759        ) );
     1760
     1761        if ( ! empty( $children ) )
     1762                return $children;
     1763}
     1764
     1765/**
     1766 * Check the content blob for an <audio>, <object>, <embed>, or <iframe>, in that order
     1767 * If no HTML tag is found, check the first line of the post for a URL
     1768 *
     1769 * @param string $content A string which might contain audio data.
     1770 * @param boolean $remove Whether to remove the found URL from the passed content.
     1771 * @return string The found data
     1772 */
     1773function get_content_audio( &$content, $remove = false ) {
     1774        $html = $matches = '';
     1775        foreach ( array( 'audio', 'object', 'embed', 'iframe' ) as $tag ) {
     1776                if ( preg_match( '#' . get_tag_regex( $tag ) . '#i', $content, $matches ) ) {
     1777                        $html = $matches[1];
     1778                        $count = 1;
     1779                        if ( $remove )
     1780                                $content = str_replace( $matches[0], '', $content, $count );
     1781
     1782                        return $html;
     1783                }
     1784        }
     1785
     1786        $lines = explode( "\n", trim( $content ) );
     1787        $line = trim( array_shift( $lines ) );
     1788
     1789        if ( 0 === stripos( $line, 'http' ) ) {
     1790                if ( $remove )
     1791                        $content = join( "\n", $lines );
     1792
     1793                return $line;
     1794        }
     1795}
     1796
     1797/**
     1798 * Return the found audio data for the passed post
     1799 *
     1800 * @since 3.6.0
     1801 *
     1802 * @param int $id Optional. Post ID
     1803 */
     1804function get_the_audio( $id = 0 ) {
     1805        $post = empty( $id ) ? get_post() : get_post( $id );
     1806        if ( empty( $post ) )
     1807                return array();
     1808
     1809        $data = get_content_audio( $post->post_content );
     1810        if ( ! empty( $data ) )
     1811                return $data;
     1812
     1813        $audios = get_post_audio( $post->ID );
     1814        if ( empty( $audios ) )
     1815                return array();
     1816
     1817        $audio = reset( $audios );
     1818        return wp_get_attachment_url( $audio->ID );
     1819}
     1820
     1821/**
     1822 * Output the found audio data for the current post
     1823 *
     1824 * @since 3.6.0
     1825 */
     1826function the_audio() {
     1827        echo apply_filters( 'the_audio', get_the_audio() );
     1828}
     1829
     1830/**
     1831 * Retrieve video attached to the passed post
     1832 *
     1833 * @since 3.6.0
     1834 *
     1835 * @param int $post_id  Post ID
     1836 * @return array Found video attachments
     1837 */
     1838function get_post_video( $post_id = 0 ) {
     1839        $post = empty( $post_id ) ? get_post() : get_post( $post_id );
     1840        if ( empty( $post ) )
     1841                return;
     1842
     1843        $children = get_children( array(
     1844                'post_parent' => $post->ID,
     1845                'post_type' => 'attachment',
     1846                'post_mime_type' => 'video',
     1847                'posts_per_page' => -1
     1848        ) );
     1849
     1850        if ( ! empty( $children ) )
     1851                return $children;
     1852}
     1853
     1854/**
     1855 * Check the content blob for a <video>, <object>, <embed>, or <iframe>, in that order
     1856 * If no HTML tag is found, check the first line of the post for a URL
     1857 *
     1858 * @param string $content A string which might contain video data.
     1859 * @param boolean $remove Whether to remove the found URL from the passed content.
     1860 * @return string The found data
     1861 */
     1862function get_content_video( &$content, $remove = false ) {
     1863        $html = $matches = '';
     1864        foreach ( array( 'video', 'object', 'embed', 'iframe' ) as $tag ) {
     1865                if ( preg_match( '#' . get_tag_regex( $tag ) . '#i', $content, $matches ) ) {
     1866                        $html = $matches[1];
     1867                        $count = 1;
     1868                        if ( $remove )
     1869                                $content = str_replace( $matches[0], '', $content, $count );
     1870
     1871                        return $html;
     1872                }
     1873        }
     1874
     1875        $lines = explode( "\n", trim( $content ) );
     1876        $line = trim( array_shift( $lines  ) );
     1877
     1878        if ( 0 === stripos( $line, 'http' ) ) {
     1879                if ( $remove )
     1880                        $content = join( "\n", $lines );
     1881
     1882                return $line;
     1883        }
     1884}
     1885
     1886/**
     1887 * Return the found video data for the passed post
     1888 *
     1889 * @since 3.6.0
     1890 *
     1891 * @param int $id Optional. Post ID
     1892 */
     1893function get_the_video( $id = 0 ) {
     1894        $post = empty( $id ) ? get_post() : get_post( $id );
     1895        if ( empty( $post ) )
     1896                return array();
     1897
     1898        $data = get_content_video( $post->post_content );
     1899        if ( ! empty( $data ) )
     1900                return $data;
     1901
     1902        $videos = get_post_video( $post->ID );
     1903        if ( empty( $videos ) )
     1904                return array();
     1905
     1906        $video = reset( $videos );
     1907        return wp_get_attachment_url( $video->ID );
     1908}
     1909
     1910/**
     1911 * Output the found video data for the current post
     1912 *
     1913 * @since 3.6.0
     1914 */
     1915function the_video() {
     1916        echo apply_filters( 'the_video', get_the_video() );
     1917}
     1918
     1919/**
     1920 * Audio embed handler callback.
     1921 *
     1922 * @param array $matches The regex matches from the provided regex when calling {@link wp_embed_register_handler()}.
     1923 * @param array $attr Embed attributes.
     1924 * @param string $url The original URL that was matched by the regex.
     1925 * @param array $rawattr The original unmodified attributes.
     1926 * @return string The embed HTML.
     1927 */
     1928function wp_audio_embed( $matches, $attr, $url, $rawattr ) {
     1929        $audio = do_shortcode( '[audio src="' . $url . '" /]' );
     1930        return apply_filters( 'wp_audio_embed', $audio, $attr, $url, $rawattr );
     1931}
     1932wp_embed_register_handler( 'wp_audio_embed', '#https?://.+?\.(' . join( '|', wp_get_audio_extensions() ) . ')#i', 'wp_audio_embed', 9999 );
     1933
     1934/**
     1935 * Video embed handler callback.
     1936 *
     1937 * @param array $matches The regex matches from the provided regex when calling {@link wp_embed_register_handler()}.
     1938 * @param array $attr Embed attributes.
     1939 * @param string $url The original URL that was matched by the regex.
     1940 * @param array $rawattr The original unmodified attributes.
     1941 * @return string The embed HTML.
     1942 */
     1943function wp_video_embed( $matches, $attr, $url, $rawattr ) {
     1944        $dimensions = '';
     1945        if ( ! empty( $rawattr['width'] ) && ! empty( $rawattr['height'] ) ) {
     1946                $dimensions .= sprintf( 'width="%d" ', (int) $rawattr['width'] );
     1947                $dimensions .= sprintf( 'height="%d" ', (int) $rawattr['height'] );
     1948        }
     1949        $video = do_shortcode( '[video ' . $dimensions . ' src="' . $url . '" /]' );
     1950        return apply_filters( 'wp_video_embed', $video, $attr, $url, $rawattr );
     1951}
     1952wp_embed_register_handler( 'wp_video_embed', '#https?://.+?\.(' . join( '|', wp_get_video_extensions() ) . ')#i', 'wp_video_embed', 9999 );
     1953 No newline at end of file
  • wp-includes/post-formats.php

    diff --git wp-includes/post-formats.php wp-includes/post-formats.php
    index 6d32aea..eddcd7f 100644
    function post_formats_compat( $content, $id = 0 ) { 
    301301                'link_class' => '',
    302302                'image_class' => '',
    303303                'gallery' => '[gallery]',
    304                 'audio' => '',
    305                 'video' => ''
     304                'audio' => '[audio]',
     305                'video' => '[video]'
    306306        );
    307307
    308308        $args = apply_filters( 'post_format_compat', array() );
    function post_formats_compat( $content, $id = 0 ) { 
    386386                case 'video':
    387387                case 'audio':
    388388                        $shortcode_regex = '/' . get_shortcode_regex() . '/s';
    389                         $matches = preg_match( $shortcode_regex, $content );
     389                        preg_match( $shortcode_regex, $content, $matches );
     390
    390391                        if ( ! $matches || $format !== $matches[2] ) {
    391392                                if ( empty( $meta['media'] ) && ! empty( $compat[$format] ) ) {
    392393                                        $format_output .= $compat[$format];
    function post_formats_compat( $content, $id = 0 ) { 
    398399                                                // attempt to embed the URL
    399400                                                $format_output .= sprintf( '[embed]%s[/embed]', $meta['media'] );
    400401                                        }
     402                                } elseif ( empty( $meta['media'] ) ) {
     403                                        $data = '';
     404                                        // attempt to grab an embed code or URL from the content
     405                                        if ( 'audio' === $format ) {
     406                                                $data = get_content_audio( $content, true );
     407                                        } elseif ( 'video' === $format ) {
     408                                                $data = get_content_video( $content, true );
     409                                        }
     410
     411                                        if ( ! empty( $data ) ) {
     412                                                // attempt to embed the URL
     413                                                if ( 0 === stripos( $data, 'http' ) )
     414                                                        $format_output .= sprintf( '[embed]%s[/embed]', $data );
     415                                                else // data is probably an embed code
     416                                                        $format_output .= $data;
     417                                        } elseif ( 'audio' === $format ) {
     418                                                // get attached audio URL
     419                                                $audios = get_post_audio( $post->ID );
     420                                                if ( ! empty( $audios ) ) {
     421                                                        $audio = reset( $audios );
     422                                                        $url = wp_get_attachment_url( $audio->ID );
     423                                                        // core or plugin support for [audio]
     424                                                        if ( shortcode_exists( 'audio' ) ) {
     425                                                                $format_output .= sprintf( '[audio src="%s"/]', $url );
     426                                                        } else {
     427                                                                // no support detected, just add URL
     428                                                                $format_output .= sprintf( '<a class="wp-post-format-link-audio" href="%1$s">%1$s</a>', $url );
     429                                                        }
     430                                                }
     431                                        } elseif ( 'video' === $format ) {
     432                                                // get attached video URL
     433                                                $videos = get_post_video( $post->ID );
     434                                                if ( ! empty( $videos ) ) {
     435                                                        $video = reset( $videos );
     436                                                        $url = wp_get_attachment_url( $video->ID );
     437                                                        // core or plugin support for [video]
     438                                                        if ( shortcode_exists( 'video' ) ) {
     439                                                                $format_output .= sprintf( '[video src="%s"/]', $url );
     440                                                        } else {
     441                                                                // no support detected, just add URL link
     442                                                                $format_output .= sprintf( '<a class="wp-post-format-link-video" href="%1$s">%1$s</a>', $url );
     443                                                        }
     444                                                }
     445                                        }
    401446                                }
    402447                        }
    403448                        break;
  • wp-includes/script-loader.php

    diff --git wp-includes/script-loader.php wp-includes/script-loader.php
    index d168c2c..dbe6cc4 100644
    function wp_default_scripts( &$scripts ) { 
    274274
    275275        $scripts->add( 'imgareaselect', "/wp-includes/js/imgareaselect/jquery.imgareaselect$suffix.js", array('jquery'), '0.9.8', 1 );
    276276
     277        $scripts->add( 'mediaelement', "/wp-includes/js/mediaelement/mediaelement-and-player$suffix.js", array('jquery'), '2.10.1', 1 );
     278        $scripts->add( 'wp-mediaelement', "/wp-includes/js/mediaelement/wp-mediaelement.js", array('mediaelement'), false, 1 );
     279
    277280        $scripts->add( 'password-strength-meter', "/wp-admin/js/password-strength-meter$suffix.js", array('jquery'), false, 1 );
    278281        did_action( 'init' ) && $scripts->localize( 'password-strength-meter', 'pwsL10n', array(
    279282                'empty' => __('Strength indicator'),
    function wp_default_styles( &$styles ) { 
    540543        $styles->add( 'media-views', "/wp-includes/css/media-views$suffix.css", array( 'buttons' ) );
    541544        $styles->add( 'buttons', "/wp-includes/css/buttons$suffix.css" );
    542545
     546        $styles->add( 'mediaelement', "/wp-includes/js/mediaelement/mediaelementplayer$suffix.css" );
     547        $styles->add( 'wp-mediaelement', "/wp-includes/js/mediaelement/wp-mediaelement.css", array( 'mediaelement' ) );
     548
    543549        foreach ( $rtl_styles as $rtl_style ) {
    544550                $styles->add_data( $rtl_style, 'rtl', true );
    545551                if ( $suffix && ! in_array( $rtl_style, $no_suffix ) )
  • wp-includes/shortcodes.php

    diff --git wp-includes/shortcodes.php wp-includes/shortcodes.php
    index 2dfc277..716dae4 100644
    function remove_all_shortcodes() { 
    128128}
    129129
    130130/**
     131 * Whether a registered shortcode exists named $tag
     132 *
     133 * @since 3.6.0
     134 *
     135 * @global array $shortcode_tags
     136 * @param string $tag
     137 * @return boolean
     138 */
     139function shortcode_exists( $tag ) {
     140        global $shortcode_tags;
     141        return array_key_exists( $tag, $shortcode_tags );
     142}
     143
     144/**
    131145 * Search content for shortcodes and filter shortcodes through their hooks.
    132146 *
    133147 * If there are no shortcode tags defined, then the content will be returned