X-Git-Url: http://git.cyclocoop.org/?a=blobdiff_plain;f=maintenance%2FfetchText.php;h=3b43bcd503cb781d852f80a53f742779000e5e20;hb=0e18ea727d31f5f513e54f8e3d8bd45259c16378;hp=91b78be3fe052aeb604e137c6ffee2c5e77a245d;hpb=087a9f70c5c152b72dc6c539cf64e334a0f2d029;p=lhc%2Fweb%2Fwiklou.git diff --git a/maintenance/fetchText.php b/maintenance/fetchText.php index 91b78be3fe..3b43bcd503 100644 --- a/maintenance/fetchText.php +++ b/maintenance/fetchText.php @@ -1,39 +1,85 @@ mDescription = "Fetch the revision text from an old_id"; } - $textId = intval( $line ); - $text = doGetText( $db, $textId ); - echo strlen( $text ) . "\n"; - echo $text; -} -/** - * May throw a database error if, say, the server dies during query. - */ -function doGetText( $db, $id ) { - $id = intval( $id ); - $row = $db->selectRow( 'text', - array( 'old_text', 'old_flags' ), - array( 'old_id' => $id ), - 'TextPassDumper::getText' ); - $text = Revision::getRevisionText( $row ); - if( $text === false ) { - return false; + /** + * returns a string containing the following in order: + * textid + * \n + * length of text (-1 on error = failure to retrieve/unserialize/gunzip/etc) + * \n + * text (may be empty) + * + * note that that the text string itself is *not* followed by newline + */ + public function execute() { + $db = wfGetDB( DB_SLAVE ); + $stdin = $this->getStdin(); + while ( !feof( $stdin ) ) { + $line = fgets( $stdin ); + if ( $line === false ) { + // We appear to have lost contact... + break; + } + $textId = intval( $line ); + $text = $this->doGetText( $db, $textId ); + if ($text === false) { + # actual error, not zero-length text + $textLen = "-1"; + } + else { + $textLen = strlen($text); + } + $this->output( $textId . "\n" . $textLen . "\n" . $text ); + } + } + + /** + * May throw a database error if, say, the server dies during query. + * @param $db DatabaseBase object + * @param $id int The old_id + * @return String + */ + private function doGetText( $db, $id ) { + $id = intval( $id ); + $row = $db->selectRow( 'text', + array( 'old_text', 'old_flags' ), + array( 'old_id' => $id ), + __METHOD__ ); + $text = Revision::getRevisionText( $row ); + if ( $text === false ) { + return false; + } + return $text; } - return $text; } + +$maintClass = "FetchText"; +require_once( RUN_MAINTENANCE_IF_MAIN );