Retrieves the page permalink.
Description
Ignores page_on_front. Internal use only.
Parameters
$post
int|WP_Postoptional- Post ID or object. Default uses the global
$post
.Default:
false
$leavename
booloptional- Whether to keep the page name.
Default:
false
$sample
booloptional- Whether it should be treated as a sample permalink.
Default:
false
Source
function _get_page_link( $post = false, $leavename = false, $sample = false ) {
global $wp_rewrite;
$post = get_post( $post );
$force_plain_link = wp_force_plain_post_permalink( $post );
$link = $wp_rewrite->get_page_permastruct();
if ( ! empty( $link ) && ( ( isset( $post->post_status ) && ! $force_plain_link ) || $sample ) ) {
if ( ! $leavename ) {
$link = str_replace( '%pagename%', get_page_uri( $post ), $link );
}
$link = home_url( $link );
$link = user_trailingslashit( $link, 'page' );
} else {
$link = home_url( '?page_id=' . $post->ID );
}
/**
* Filters the permalink for a non-page_on_front page.
*
* @since 2.1.0
*
* @param string $link The page's permalink.
* @param int $post_id The ID of the page.
*/
return apply_filters( '_get_page_link', $link, $post->ID );
}
Hooks
- apply_filters( ‘_get_page_link’,
string $link ,int $post_id ) Filters the permalink for a non-page_on_front page.
Changelog
Version | Description |
---|---|
2.1.0 | Introduced. |
User Contributed Notes
You must log in before being able to contribute a note or feedback.