]> scripts.mit.edu Git - autoinstalls/wordpress.git/blobdiff - wp-admin/post-new.php
WordPress 4.1.2-scripts
[autoinstalls/wordpress.git] / wp-admin / post-new.php
index 79896c3b789a738b52591ffbc4a45ca4ee21a1d6..d919d55ca111399c1df12e69aed15742620358ae 100644 (file)
@@ -28,8 +28,16 @@ if ( 'post' == $post_type ) {
        $submenu_file = "post-new.php?post_type=$post_type";
        if ( isset( $post_type_object ) && $post_type_object->show_in_menu && $post_type_object->show_in_menu !== true ) {
                $parent_file = $post_type_object->show_in_menu;
        $submenu_file = "post-new.php?post_type=$post_type";
        if ( isset( $post_type_object ) && $post_type_object->show_in_menu && $post_type_object->show_in_menu !== true ) {
                $parent_file = $post_type_object->show_in_menu;
-               if ( ! isset( $_registered_pages[ get_plugin_page_hookname( "post-new.php?post_type=$post_type", $post_type_object->show_in_menu ) ] ) )
-                       $submenu_file = $parent_file;
+               // What if there isn't a post-new.php item for this post type?
+               if ( ! isset( $_registered_pages[ get_plugin_page_hookname( "post-new.php?post_type=$post_type", $post_type_object->show_in_menu ) ] ) ) {
+                       if (    isset( $_registered_pages[ get_plugin_page_hookname( "edit.php?post_type=$post_type", $post_type_object->show_in_menu ) ] ) ) {
+                               // Fall back to edit.php for that post type, if it exists
+                               $submenu_file = "edit.php?post_type=$post_type";
+                       } else {
+                               // Otherwise, give up and highlight the parent
+                               $submenu_file = $parent_file;
+                       }
+               }
        } else {
                $parent_file = "edit.php?post_type=$post_type";
        }
        } else {
                $parent_file = "edit.php?post_type=$post_type";
        }
@@ -40,7 +48,7 @@ $title = $post_type_object->labels->add_new_item;
 $editing = true;
 
 if ( ! current_user_can( $post_type_object->cap->edit_posts ) || ! current_user_can( $post_type_object->cap->create_posts ) )
 $editing = true;
 
 if ( ! current_user_can( $post_type_object->cap->edit_posts ) || ! current_user_can( $post_type_object->cap->create_posts ) )
-       wp_die( __( 'Cheatin’ uh?' ) );
+       wp_die( __( 'Cheatin’ uh?' ), 403 );
 
 // Schedule auto-draft cleanup
 if ( ! wp_next_scheduled( 'wp_scheduled_auto_draft_delete' ) )
 
 // Schedule auto-draft cleanup
 if ( ! wp_next_scheduled( 'wp_scheduled_auto_draft_delete' ) )