_get_page_link() – Retrieves the page permalink.

You appear to be a bot. Output may be restricted

Description

Retrieves the page permalink.

Ignores page_on_front. Internal use only.

Usage

$string = _get_page_link( $post, $leavename, $sample );

Parameters

$post
( int|WP_Post ) optional – Optional. Post ID or object. Default uses the global `$post`.
$leavename
( bool ) optional – Optional. Whether to keep the page name. Default false.
$sample
( bool ) optional – Optional. Whether it should be treated as a sample permalink. Default false.

Returns

string The page permalink.

Source

File name: wordpress/wp-includes/link-template.php
Lines:

1 to 30 of 30
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 );
}
 

 View on GitHub View on Trac