post_title) . '-' . $id; echo ''; break; case 'id': default: echo ''; break; } } function permalink_single_rss($file = '') { echo get_permalink(); } function get_permalink($id = false) { global $post, $wpdb; $rewritecode = array( '%year%', '%monthnum%', '%day%', '%hour%', '%minute%', '%second%', '%postname%', '%post_id%', '%category%', '%author%', '%pagename%' ); if ($id) { $idpost = $wpdb->get_row("SELECT ID, post_date, post_name, post_status, post_author FROM $wpdb->posts WHERE ID = $id"); } else { $idpost = $post; } $permalink = get_settings('permalink_structure'); if ('' != $permalink) { if ($idpost->post_status == 'static') $permalink = page_permastruct(); $unixtime = strtotime($idpost->post_date); $cats = get_the_category($idpost->ID); $category = $cats[0]->category_nicename; $authordata = get_userdata($idpost->post_author); $author = $authordata->user_nicename; $rewritereplace = array( date('Y', $unixtime), date('m', $unixtime), date('d', $unixtime), date('H', $unixtime), date('i', $unixtime), date('s', $unixtime), $idpost->post_name, $idpost->ID, $category, $author, $idpost->post_name, ); return get_settings('home') . str_replace($rewritecode, $rewritereplace, $permalink); } else { // if they're not using the fancy permalink option $permalink = get_settings('home') . '/' . get_settings('blogfilename') . '?p=' . $idpost->ID; if ($idpost->post_status == 'static') $permalink .= '&static=1'; return $permalink; } } function get_month_link($year, $month) { global $querystring_start, $querystring_equal; if (!$year) $year = gmdate('Y', time()+(get_settings('gmt_offset') * 3600)); if (!$month) $month = gmdate('m', time()+(get_settings('gmt_offset') * 3600)); if ('' != get_settings('permalink_structure')) { $permalink = get_settings('permalink_structure'); // If the permalink structure does not contain year and month, make // one that does. if (! (strstr($permalink, '%year%') && strstr($permalink, '%monthnum%')) || preg_match('/%category%.*(%year%|%monthnum%|%day%)/', $permalink)) { $front = substr($permalink, 0, strpos($permalink, '%')); $permalink = $front . '%year%/%monthnum%/'; } $off = strpos($permalink, '%monthnum%'); $offset = $off + 11; $monthlink = substr($permalink, 0, $offset); if ('/' != substr($monthlink, -1)) $monthlink = substr($monthlink, 0, -1); $monthlink = str_replace('%year%', $year, $monthlink); $monthlink = str_replace('%monthnum%', zeroise(intval($month), 2), $monthlink); $monthlink = str_replace('%post_id%', '', $monthlink); $monthlink = str_replace('%category%', '', $monthlink); return get_settings('home') . $monthlink; } else { return get_settings('home') .'/'. get_settings('blogfilename') .$querystring_start.'m'.$querystring_equal.$year.zeroise($month, 2); } } function get_day_link($year, $month, $day) { global $querystring_start, $querystring_equal; if (!$year) $year = gmdate('Y', time()+(get_settings('gmt_offset') * 3600)); if (!$month) $month = gmdate('m', time()+(get_settings('gmt_offset') * 3600)); if (!$day) $day = gmdate('j', time()+(get_settings('gmt_offset') * 3600)); if ('' != get_settings('permalink_structure')) { $permalink = get_settings('permalink_structure'); // If the permalink structure does not contain year, month, and day, // make one that does. if (! (strstr($permalink, '%year%') && strstr($permalink, '%monthnum%')&& strstr($permalink, '%day%')) || preg_match('/%category%.*(%year%|%monthnum%|%day%)/', $permalink)) { $front = substr($permalink, 0, strpos($permalink, '%')); $permalink = $front . '%year%/%monthnum%/%day%/'; } $off = strpos($permalink, '%day%'); $offset = $off + 6; $daylink = substr($permalink, 0, $offset); if ('/' != substr($daylink, -1)) $daylink = substr($daylink, 0, -1); $daylink = str_replace('%year%', $year, $daylink); $daylink = str_replace('%monthnum%', zeroise(intval($month), 2), $daylink); $daylink = str_replace('%day%', zeroise(intval($day), 2), $daylink); $daylink = str_replace('%post_id%', '', $daylink); $daylink = str_replace('%category%', '', $daylink); return get_settings('home') . $daylink; } else { return get_settings('home') .'/'. get_settings('blogfilename') .$querystring_start.'m'.$querystring_equal.$year.zeroise($month, 2).zeroise($day, 2); } } function get_feed_link($feed='rss2') { $do_perma = 0; $feed_url = get_settings('siteurl'); $comment_feed_url = $feed_url; $permalink = get_settings('permalink_structure'); if ('' != $permalink) { $do_perma = 1; $feed_url = get_settings('home'); $index = 'index.php'; $prefix = ''; if (using_index_permalinks()) { $feed_url .= '/' . $index; } $comment_feed_url = $feed_url; $feed_url .= '/feed'; $comment_feed_url .= '/comments/feed'; } switch($feed) { case 'rdf': $output = $feed_url .'/wp-rdf.php'; if ($do_perma) { $output = $feed_url . '/rdf/'; } break; case 'rss': $output = $feed_url . '/wp-rss.php'; if ($do_perma) { $output = $feed_url . '/rss/'; } break; case 'atom': $output = $feed_url .'/wp-atom.php'; if ($do_perma) { $output = $feed_url . '/atom/'; } break; case 'comments_rss2': $output = $feed_url .'/wp-commentsrss2.php'; if ($do_perma) { $output = $comment_feed_url . '/rss2/'; } break; case 'rss2': default: $output = $feed_url .'/wp-rss2.php'; if ($do_perma) { $output = $feed_url . '/rss2/'; } break; } return $output; } function edit_post_link($link = 'Edit This', $before = '', $after = '') { global $user_level, $post; get_currentuserinfo(); if ($user_level > 0) { $authordata = get_userdata($post->post_author); if ($user_level < $authordata->user_level) { return; } } else { return; } $location = get_settings('siteurl') . "/wp-admin/post.php?action=edit&post=$post->ID"; echo "$before $link $after"; } function edit_comment_link($link = 'Edit This', $before = '', $after = '') { global $user_level, $post, $comment; get_currentuserinfo(); if ($user_level > 0) { $authordata = get_userdata($post->post_author); if ($user_level < $authordata->user_level) { return; } } else { return; } $location = get_settings('siteurl') . "/wp-admin/post.php?action=editcomment&comment=$comment->comment_ID"; echo "$before $link $after"; } // Navigation links function get_previous_post($in_same_cat = false, $excluded_categories = '') { global $post, $wpdb; if(! is_single()) { return null; } $current_post_date = $post->post_date; $current_category = $post->post_category; $sqlcat = ''; if ($in_same_cat) { $sqlcat = " AND post_category = '$current_category' "; } $sql_exclude_cats = ''; if (!empty($excluded_categories)) { $blah = explode('and', $excluded_categories); foreach($blah as $category) { $category = intval($category); $sql_exclude_cats .= " AND post_category != $category"; } } return @$wpdb->get_row("SELECT ID, post_title FROM $wpdb->posts WHERE post_date < '$current_post_date' AND post_status = 'publish' $sqlcat $sql_exclude_cats ORDER BY post_date DESC LIMIT 1"); } function get_next_post($in_same_cat = false, $excluded_categories = '') { global $post, $wpdb; if(! is_single()) { return null; } $current_post_date = $post->post_date; $current_category = $post->post_category; $sqlcat = ''; if ($in_same_cat) { $sqlcat = " AND post_category = '$current_category' "; } $sql_exclude_cats = ''; if (!empty($excluded_categories)) { $blah = explode('and', $excluded_categories); foreach($blah as $category) { $category = intval($category); $sql_exclude_cats .= " AND post_category != $category"; } } $now = current_time('mysql'); return @$wpdb->get_row("SELECT ID,post_title FROM $wpdb->posts WHERE post_date > '$current_post_date' AND post_date < '$now' AND post_status = 'publish' $sqlcat $sql_exclude_cats AND ID != $post->ID ORDER BY post_date ASC LIMIT 1"); } function previous_post_link($format='« %link', $link='%title', $in_same_cat = false, $excluded_categories = '') { $post = get_previous_post($in_same_cat, $excluded_categories); if(! $post) { return; } $title = apply_filters('the_title', $post->post_title); $string = ''; $link = str_replace('%title', $title, $link); $link = $string . $link . ''; $format = str_replace('%link', $link, $format); echo $format; } function next_post_link($format='%link »', $link='%title', $in_same_cat = false, $excluded_categories = '') { $post = get_next_post($in_same_cat, $excluded_categories); if(! $post) { return; } $title = apply_filters('the_title', $post->post_title); $string = ''; $link = str_replace('%title', $title, $link); $link = $string . $link . ''; $format = str_replace('%link', $link, $format); echo $format; } function previous_post($format='%', $previous='previous post: ', $title='yes', $in_same_cat='no', $limitprev=1, $excluded_categories='') { global $id, $post, $wpdb; global $posts, $posts_per_page, $s; global $querystring_start, $querystring_equal, $querystring_separator; if(($posts_per_page == 1) || is_single()) { $current_post_date = $post->post_date; $current_category = $post->post_category; $sqlcat = ''; if ($in_same_cat != 'no') { $sqlcat = " AND post_category = '$current_category' "; } $sql_exclude_cats = ''; if (!empty($excluded_categories)) { $blah = explode('and', $excluded_categories); foreach($blah as $category) { $category = intval($category); $sql_exclude_cats .= " AND post_category != $category"; } } $limitprev--; $lastpost = @$wpdb->get_row("SELECT ID, post_title FROM $wpdb->posts WHERE post_date < '$current_post_date' AND post_status = 'publish' $sqlcat $sql_exclude_cats ORDER BY post_date DESC LIMIT $limitprev, 1"); if ($lastpost) { $string = ''.$previous; if ($title == 'yes') { $string .= wptexturize($lastpost->post_title); } $string .= ''; $format = str_replace('%', $string, $format); echo $format; } } } function next_post($format='%', $next='next post: ', $title='yes', $in_same_cat='no', $limitnext=1, $excluded_categories='') { global $posts_per_page, $post, $wpdb; if(1 == $posts_per_page || is_single()) { $current_post_date = $post->post_date; $current_category = $post->post_category; $sqlcat = ''; if ($in_same_cat != 'no') { $sqlcat = " AND post_category='$current_category' "; } $sql_exclude_cats = ''; if (!empty($excluded_categories)) { $blah = explode('and', $excluded_categories); foreach($blah as $category) { $category = intval($category); $sql_exclude_cats .= " AND post_category != $category"; } } $now = current_time('mysql'); $limitnext--; $nextpost = @$wpdb->get_row("SELECT ID,post_title FROM $wpdb->posts WHERE post_date > '$current_post_date' AND post_date < '$now' AND post_status = 'publish' $sqlcat $sql_exclude_cats AND ID != $post->ID ORDER BY post_date ASC LIMIT $limitnext,1"); if ($nextpost) { $string = ''.$next; if ($title=='yes') { $string .= wptexturize($nextpost->post_title); } $string .= ''; $format = str_replace('%', $string, $format); echo $format; } } } function get_pagenum_link($pagenum = 1){ $qstr = $_SERVER['REQUEST_URI']; $page_querystring = "paged"; $page_modstring = "page/"; $page_modregex = "page/?"; $permalink = 0; $index = 'index.php'; $home_root = parse_url(get_settings('home')); $home_root = $home_root['path']; $home_root = trailingslashit($home_root); $qstr = preg_replace('|^'. $home_root . '|', '', $qstr); $qstr = preg_replace('|^/+|', '', $qstr); // if we already have a QUERY style page string if( stristr( $qstr, $page_querystring ) ) { $replacement = "$page_querystring=$pagenum"; $qstr = preg_replace("/".$page_querystring."[^\d]+\d+/", $replacement, $qstr); // if we already have a mod_rewrite style page string } elseif ( preg_match( '|'.$page_modregex.'\d+|', $qstr ) ){ $permalink = 1; $qstr = preg_replace('|'.$page_modregex.'\d+|',"$page_modstring$pagenum",$qstr); // if we don't have a page string at all ... // lets see what sort of URL we have... } else { // we need to know the way queries are being written global $querystring_start, $querystring_equal, $querystring_separator; // if there's a querystring_start (a "?" usually), it's deffinitely not mod_rewritten if ( stristr( $qstr, $querystring_start ) ){ // so append the query string (using &, since we already have ?) $qstr .= $querystring_separator.$page_querystring.$querystring_equal.$pagenum; // otherwise, it could be rewritten, OR just the default index ... } elseif( '' != get_settings('permalink_structure')) { $permalink = 1; // If it's not a path info permalink structure, trim the index. if (! using_index_permalinks()) { $qstr = preg_replace("#/*" . $index . "/*#", '/', $qstr); } else { // If using path info style permalinks, make sure the index is in // the URI. if (strpos($qstr, $index) === false) { $qstr = '/' . $index . $qstr; } } $qstr = trailingslashit($qstr) . $page_modstring . $pagenum; } else { $qstr = $index . $querystring_start.$page_querystring.$querystring_equal.$pagenum; } } $qstr = preg_replace('|^/+|', '', $qstr); if ($permalink) $qstr = trailingslashit($qstr); return preg_replace('/&([^#])(?![a-z]{1,8};)/', '&$1', trailingslashit( get_settings('home') ) . $qstr ); } function next_posts($max_page = 0) { // original by cfactor at cooltux.org global $paged, $pagenow; global $querystring_start, $querystring_equal, $querystring_separator; if (! is_single()) { if (!$paged) $paged = 1; $nextpage = intval($paged) + 1; if (!$max_page || $max_page >= $nextpage) { echo get_pagenum_link($nextpage); } } } function next_posts_link($label='Next Page »', $max_page=0) { global $paged, $result, $request, $posts_per_page, $wpdb; if (!$max_page) { $nxt_request = $request; //if the query includes a limit clause, call it again without that //limit clause! if ($pos = strpos(strtoupper($request), 'LIMIT')) { $nxt_request = substr($request, 0, $pos); } $nxt_result = $wpdb->query($nxt_request); $numposts = $wpdb->num_rows; $max_page = ceil($numposts / $posts_per_page); } if (!$paged) $paged = 1; $nextpage = intval($paged) + 1; if ((! is_single()) && (empty($paged) || $nextpage <= $max_page)) { echo ''. preg_replace('/&([^#])(?![a-z]{1,8};)/', '&$1', $label) .''; } } function previous_posts() { // original by cfactor at cooltux.org global $_SERVER, $paged, $pagenow; global $querystring_start, $querystring_equal, $querystring_separator; if (! is_single()) { $nextpage = intval($paged) - 1; if ($nextpage < 1) $nextpage = 1; echo get_pagenum_link($nextpage); } } function previous_posts_link($label='« Previous Page') { global $paged; if ((! is_single()) && ($paged > 1) ) { echo ''. preg_replace('/&([^#])(?![a-z]{1,8};)/', '&$1', $label) .''; } } function posts_nav_link($sep=' — ', $prelabel='« Previous Page', $nxtlabel='Next Page »') { global $request, $posts_per_page, $wpdb; if (! is_single()) { $show_what = get_query_var('what_to_show'); if (get_query_var('what_to_show') == 'posts') { $nxt_request = $request; if ($pos = strpos(strtoupper($request), 'LIMIT')) { $nxt_request = substr($request, 0, $pos); } $nxt_result = $wpdb->query($nxt_request); $numposts = $wpdb->num_rows; $max_page = ceil($numposts / $posts_per_page); } else { $max_page = 999999; } if ($max_page > 1) { previous_posts_link($prelabel); echo preg_replace('/&([^#])(?![a-z]{1,8};)/', '&$1', $sep); next_posts_link($nxtlabel, $max_page); } } } ?>