當前位置: 首頁>>代碼示例>>PHP>>正文


PHP DifferenceEngine::loadText方法代碼示例

本文整理匯總了PHP中DifferenceEngine::loadText方法的典型用法代碼示例。如果您正苦於以下問題:PHP DifferenceEngine::loadText方法的具體用法?PHP DifferenceEngine::loadText怎麽用?PHP DifferenceEngine::loadText使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在DifferenceEngine的用法示例。


在下文中一共展示了DifferenceEngine::loadText方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: execute


//.........這裏部分代碼省略.........
                                 $url = preg_replace("/" . $tld . "/i", "", $url, 1);
                                 break;
                             }
                         }
                         $url = preg_replace("@^http://([^/]*\\.)?([^./]+\\.[^./]+).*\$@", "\$2", $url);
                         $url = str_replace(".", "\\.", $url);
                         // escape the periods
                         $url .= $t;
                         break;
                     case 'subdomain':
                         $url = str_replace("http://", "", $url);
                         $url = str_replace(".", "\\.", $url);
                         // escape the periods
                         $url = preg_replace("/^([^\\/]*)\\/.*/", "\$1", $url);
                         // trim everything after the slash
                         break;
                     case 'dir':
                         $url = str_replace("http://", "", $url);
                         $url = preg_replace("@^([^/]*\\.)?([^./]+\\.[^./]+(/[^/?]*)?).*\$@", "\$1\$2", $url);
                         // trim everything after the slash
                         $url = preg_replace("/^(.*)\\/\$/", "\$1", $url);
                         // trim trailing / if one exists
                         $url = str_replace(".", "\\.", $url);
                         // escape the periods
                         $url = str_replace("/", "\\/", $url);
                         // escape the slashes
                         break;
                 }
                 if (!isset($urls[$url])) {
                     $text .= "{$url}\n";
                     $urls[$url] = true;
                 }
             }
         }
         if (trim($text) == '') {
             $wgOut->addHTML(wfMsg('spamdifftool_notext', $wgScript . "?" . urldecode($wgRequest->getVal('returnto'))));
             return;
         }
         $wgOut->addHTML("<form method=POST>\n\t\t\t\t\t<input type='hidden' name='confirm' value='true'>\n\t\t\t\t\t<input type='hidden' name='newurls' value=\"" . htmlspecialchars($text) . "\">\n\t\t\t\t\t<input type='hidden' name='returnto' value=\"" . htmlspecialchars($wgRequest->getVal('returnto')) . "\">\n\t\t\t\t");
         $wgOut->addHTML(wfMsg('spamdifftool_confirm') . "<pre style='padding: 10px'>{$text}</pre>");
         $wgOut->addHTML("</table><input type=submit value=\"" . htmlspecialchars(wfMsg('submit')) . "\"></form>");
         return;
     }
     if (!is_null($diff)) {
         require_once 'DifferenceEngine.php';
         // Get the last edit not by this guy
         $current = Revision::newFromTitle($title);
         $dbw = wfGetDB(DB_MASTER);
         $user = intval($current->getUser());
         $user_text = $dbw->addQuotes($current->getUserText());
         $s = $dbw->selectRow('revision', array('rev_id', 'rev_timestamp'), array('rev_page' => $current->getPage(), "rev_user <> {$user} OR rev_user_text <> {$user_text}"), $fname, array('USE INDEX' => 'page_timestamp', 'ORDER BY' => 'rev_timestamp DESC'));
         if ($s) {
             // set oldid
             $oldid = $s->rev_id;
         }
         if ($wgRequest->getVal('oldid2') < $oldid) {
             $oldid = $wgRequest->getVal('oldid2');
         }
         $de = new DifferenceEngine($title, $oldid, $diff, $rcid);
         $de->loadText();
         $otext = $de->mOldtext;
         $ntext = $de->mNewtext;
         $ota = explode("\n", $wgContLang->segmentForDiff($otext));
         $nta = explode("\n", $wgContLang->segmentForDiff($ntext));
         $diffs = new Diff($ota, $nta);
         foreach ($diffs->edits as $edit) {
             if ($edit->type != 'copy' && $edit->closing != "") {
                 $text .= implode("\n", $edit->closing) . "\n";
             }
         }
     } else {
         if ($title != "") {
             $a = new Article($title);
             $text = $a->getContent(true);
         }
     }
     $matches = array();
     $preg = "/http:\\/\\/[^] \n'\"\\>\\<]*/im";
     preg_match_all($preg, $text, $matches);
     if (sizeof($matches[0]) == 0) {
         $wgOut->addHTML(wfMsg('spamdifftool_no_urls_detected', $wgScript . "?" . urldecode($wgRequest->getVal('returnto'))));
         return;
     }
     $wgOut->addHTML("\n\t\t\t<form method='POST'>\n\t\t\t\t\t<input type='hidden' name='returnto' value=\"" . htmlspecialchars($wgRequest->getVal('returnto')) . "\">\n\t\t\t\t<style type='text/css'>\n\t\t\t\t\t\ttd.spam-url-row {\n\t\t\t\t\t\t\tborder: 1px solid #ccc;\n\t\t\t\t\t\t}\n\t\t\t\t</style> " . wfMsg('spamdifftool_urls_detected') . "\n\t\t\t<br/><br/><table cellpadding='5px' width='100%'>");
     $urls = array();
     foreach ($matches as $match) {
         foreach ($match as $url) {
             if (isset($urls[$url])) {
                 continue;
             }
             // avoid dupes
             $urls[$url] = true;
             $name = htmlspecialchars(str_replace(".", "%2E", $url));
             $wgOut->addHTML("<tr>\n\t\t\t\t\t<td class='spam-url-row'><b>{$url}</b><br/>\n\t\t\t\t\t" . wfMsg('spamdifftool_block') . " &nbsp;&nbsp;\n\t\t\t\t\t<INPUT type='radio' name=\"" . $name . "\"\tvalue='domain' checked> " . wfMsg('spamdifftool_option_domain') . "\n\t\t\t\t\t<INPUT type='radio' name=\"" . $name . "\"\tvalue='subdomain'> " . wfMsg('spamdifftool_option_subdomain') . "\n\t\t\t\t\t<INPUT type='radio' name=\"" . $name . "\"\tvalue='dir'>" . wfMsg('spamdifftool_option_directory') . "\n\t\t\t\t\t<INPUT type='radio' name=\"" . $name . "\"\tvalue='none'>" . wfMsg('spamdifftool_option_none') . "\n\t\t\t\t</td>\n\t\t\t\t</tr>\n\t\t\t\t");
         }
     }
     $wgOut->addHTML("</table><input type=submit value=\"" . htmlspecialchars(wfMsg('submit')) . "\"></form>");
     // DifferenceEngine directly fetched the revision:
     $RevIdFetched = $de->mNewid;
 }
開發者ID:ErdemA,項目名稱:wikihow,代碼行數:101,代碼來源:SpamDiffTool.body.php

示例2: generateDiffBodyTxt

	/**
	 * Generates a diff txt
	 * @param Title $title
	 * @return string
	 */
	function generateDiffBodyTxt( $title ) {
		$revision = Revision::newFromTitle( $title, 0 );
		$diff = new DifferenceEngine( $title, $revision->getId(), 'prev' );
		// The getDiffBody() method generates html, so let's generate the txt diff manualy:
		global $wgContLang;
		$diff->loadText();
		$otext = str_replace( "\r\n", "\n", $diff->mOldtext );
		$ntext = str_replace( "\r\n", "\n", $diff->mNewtext );
		$ota = explode( "\n", $wgContLang->segmentForDiff( $otext ) );
		$nta = explode( "\n", $wgContLang->segmentForDiff( $ntext ) );
		// We use here the php diff engine included in MediaWiki
		$diffs = new Diff( $ota, $nta );
		// And we ask for a txt formatted diff
		$formatter = new UnifiedDiffFormatter();
		$diff_text = $wgContLang->unsegmentForDiff( $formatter->format( $diffs ) );
		return $diff_text;
	}
開發者ID:realsoc,項目名稱:mediawiki-extensions,代碼行數:22,代碼來源:SemanticTasks.classes.php

示例3: execute


//.........這裏部分代碼省略.........
		}

		if ( !$title ) {
			$wgOut->addWikiMsg( 'spamdifftool-no-title' );
			return;
		}

		if ( !is_null( $diff ) ) {
			# Get the last edit not by this guy
			$current = Revision::newFromTitle( $title );
			$dbw = wfGetDB( DB_MASTER );
			$user = intval( $current->getUser() );
			$user_text = $dbw->addQuotes( $current->getUserText() );
			$s = $dbw->selectRow( 'revision',
				//array( 'min(rev_id)', 'rev_timestamp' ),
				array( 'min(rev_id) as rev_id' ),
				array(
					'rev_page' => $current->getPage(),
					"rev_user <> {$user} OR rev_user_text <> {$user_text}",
					$diff != "" ? "rev_id <  $diff" : '1 = 1', // sure - why not!
				), __METHOD__,
				array(
					'USE INDEX' => 'page_timestamp',
					'ORDER BY'  => 'rev_timestamp DESC' )
				);
			if ( $s ) {
				// set oldid
				$oldid = $s->rev_id;
			}

			// new diff object to extract the revision texts
			if ( $rcid != '' ) {
				$de = new DifferenceEngine( $title, $oldid, $diff, $rcid );
			} else {
				$de = new DifferenceEngine( $title, $oldid, $diff);
			}

			$de->loadText();
			$otext = $de->mOldtext;
			$ntext = $de->mNewtext;
			$ota = explode( "\n", $wgContLang->segmentForDiff( $otext ) );
			$nta = explode( "\n", $wgContLang->segmentForDiff( $ntext ) );
			$diffs = new Diff( $ota, $nta );

			// iterate over the edits and get all of the changed text
			$text = '';
			foreach ( $diffs->edits as $edit ) {
				if ( $edit->type != 'copy' ) {
					$text .= implode( "\n", $edit->closing ) . "\n";
				}
			}
		} else {
			$a = new Article( $title );
			$text = $a->getContent( true );
		}

		$matches = array();
		$preg = "/http:\/\/[^] \n'\"]*/";
		preg_match_all( $preg, $text, $matches );

		if ( !count( $matches[0] ) ) {
			$wgOut->addHTML( wfMsg( 'spamdifftool_no_urls_detected', $wgScript . "?" . urldecode( $wgRequest->getVal( 'returnto' ) ) ) );
			return;
		}

		$wgOut->addWikiMsg( 'spamdifftool_urls_detected' );
		$wgOut->addInlineStyle( 'td.spam-url-row { border: 1px solid #ccc; }' );

		$wgOut->addHTML(
			Xml::openElement( 'form', array( 'method' => 'post' ) ) . "\n" .
			Html::Hidden( 'returnto', $wgRequest->getVal( 'returnto' ) ) . "\n" .
			Xml::openElement( 'table', array( 'cellpadding' => 5, 'width' => '100%' ) ) . "\n"
		);

		$urls = array();
		foreach ( $matches as $match ) {
			foreach ( $match as $url ) {
				if ( isset( $urls[$url] ) ) continue; // avoid dupes
				$urls[$url] = true;
				$name = htmlspecialchars( str_replace( ".", "%2E", $url ) );
				$wgOut->addHTML(
					Xml::tags( 'tr', array(),
						Xml::tags( 'td', array( 'class' => 'spam-url-row' ),
							"<b>$url</b><br />" . wfMsgHtml( 'spamdifftool_block' ) . "&#160;&#160;" .
							Xml::radioLabel( wfMsg( 'spamdifftool_option_domain'), $name, 'domain', '{$name}-domain', true ) . "\n" .
							Xml::radioLabel( wfMsg( 'spamdifftool_option_subdomain' ), $name, 'subdomain', '{$name}-subdomain' ) . "\n" .
							Xml::radioLabel( wfMsg( 'spamdifftool_option_directory' ), $name, 'dir', '{$name}-dir' ) . "\n" .
							Xml::radioLabel( wfMsg( 'spamdifftool_option_none' ), $name, 'none', '{$name}-none' ) . "\n"
						)
					)
				);
			}
		}

		$wgOut->addHTML(
			Xml::closeElement( 'table' ) . "\n" .
			Xml::submitButton( wfMsg( 'spamdifftool_submit_buttom' ) ) . "\n" .
			Xml::closeElement( 'form' )
		);
	}
開發者ID:realsoc,項目名稱:mediawiki-extensions,代碼行數:101,代碼來源:SpamDiffTool_body.php


注:本文中的DifferenceEngine::loadText方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。