Make WordPress Core


Ignore:
Timestamp:
10/05/2019 12:53:39 AM (6 years ago)
Author:
SergeyBiryukov
Message:

Themes: In get_theme_mod(), only run the sprintf() replacement on the default value if there's a string format pattern found in the value.

This prevents standalone percent symbols from being stripped out, e.g. in a default value like 100%.

Props aristath, kuus, moonomo, westonruter, davetgreen, daviedR, katielgc, noisysocks, SergeyBiryukov.
Fixes #34290.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/wp-includes/theme.php

    r46394 r46395  
    935935
    936936    if ( is_string( $default ) ) {
    937         $default = sprintf( $default, get_template_directory_uri(), get_stylesheet_directory_uri() );
     937        // Only run the replacement if an sprintf() string format pattern was found.
     938        if ( preg_match( '#(?<!%)%(?:\d+\$?)?s#', $default ) ) {
     939            $default = sprintf( $default, get_template_directory_uri(), get_stylesheet_directory_uri() );
     940        }
    938941    }
    939942
Note: See TracChangeset for help on using the changeset viewer.