Correctly handle post_parent during import. Props tellyworth. fixes #5456
git-svn-id: https://develop.svn.wordpress.org/trunk@6374 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
7003316321
commit
267ecd4981
@ -2,9 +2,8 @@
|
||||
|
||||
class WP_Import {
|
||||
|
||||
var $posts = array ();
|
||||
var $post_ids_processed = array ();
|
||||
// Array of arrays. [[0] => XML fragment, [1] => New post ID]
|
||||
var $orphans = array ();
|
||||
var $file;
|
||||
var $id;
|
||||
var $mtnames = array ();
|
||||
@ -88,13 +87,6 @@ class WP_Import {
|
||||
function get_entries($process_post_func=NULL) {
|
||||
set_magic_quotes_runtime(0);
|
||||
|
||||
# $this->posts = array();
|
||||
# $this->categories = array();
|
||||
# $this->tags = array();
|
||||
# $num = 0;
|
||||
|
||||
for ($i=0; $i<2; $i++) {
|
||||
$this->another_pass = false;
|
||||
$doing_entry = false;
|
||||
|
||||
$fp = fopen($this->file, 'r');
|
||||
@ -132,10 +124,6 @@ class WP_Import {
|
||||
fclose($fp);
|
||||
}
|
||||
|
||||
// skip the second loop iteration unless it's needed
|
||||
if ( !$this->another_pass )
|
||||
break;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@ -270,7 +258,6 @@ class WP_Import {
|
||||
}
|
||||
|
||||
function process_posts() {
|
||||
return; //FIXME
|
||||
$i = -1;
|
||||
echo '<ol>';
|
||||
|
||||
@ -335,13 +322,13 @@ class WP_Import {
|
||||
// If it has parent, process parent first.
|
||||
$post_parent = (int) $post_parent;
|
||||
if ($post_parent) {
|
||||
// if we already know the parent, map it to the local ID
|
||||
if ( $parent = $this->post_ids_processed[$post_parent] ) {
|
||||
$post_parent = $parent; // new ID of the parent
|
||||
}
|
||||
else {
|
||||
// wait until the parent has been processed
|
||||
$this->another_pass = true;
|
||||
return;
|
||||
// record the parent for later
|
||||
$this->orphans[intval($post_ID)] = $post_parent;
|
||||
}
|
||||
}
|
||||
|
||||
@ -435,15 +422,35 @@ class WP_Import {
|
||||
} }
|
||||
}
|
||||
|
||||
// update the post_parent of orphans now that we know the local id's of all parents
|
||||
function backfill_parents() {
|
||||
global $wpdb;
|
||||
|
||||
foreach ($this->orphans as $child_id => $parent_id) {
|
||||
$local_child_id = $this->post_ids_processed[$child_id];
|
||||
$local_parent_id = $this->post_ids_processed[$parent_id];
|
||||
if ($local_child_id and $local_parent_id) {
|
||||
$wpdb->query( $wpdb->prepare("UPDATE {$wpdb->posts} SET post_parent = %d WHERE ID = %d", $local_parent_id, $local_child_id));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function import($id) {
|
||||
$this->id = (int) $id;
|
||||
|
||||
$this->file = get_attached_file($this->id);
|
||||
$file = get_attached_file($this->id);
|
||||
$this->import_file($file);
|
||||
}
|
||||
|
||||
function import_file($file) {
|
||||
$this->file = $file;
|
||||
|
||||
$this->get_authors_from_post();
|
||||
$this->get_entries(array(&$this, 'process_post'));
|
||||
$this->get_entries();
|
||||
$this->process_categories();
|
||||
$this->process_tags();
|
||||
$result = $this->process_posts();
|
||||
$this->backfill_parents();
|
||||
if ( is_wp_error( $result ) )
|
||||
return $result;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user