r94271 MediaWiki - Code Review archive

Repository:MediaWiki
Revision:r94270‎ | r94271 | r94272 >
Date:19:16, 11 August 2011
Author:neilk
Status:deferred
Tags:
Comment:
merges from trunk, r94187 through 94267
Modified paths:
  • /branches/extensions-realtime (modified) (history)
  • /branches/extensions-realtime/AddMediaWizard/MwEmbedModules/AddMedia/AddMedia.i18n.php (modified) (history)
  • /branches/extensions-realtime/AjaxLogin/AjaxLogin.php (modified) (history)
  • /branches/extensions-realtime/ArchiveLinks/ArchiveLinks.class.php (modified) (history)
  • /branches/extensions-realtime/ArticleFeedback/api/ApiArticleFeedback.php (modified) (history)
  • /branches/extensions-realtime/ArticleFeedback/api/ApiQueryArticleFeedback.php (modified) (history)
  • /branches/extensions-realtime/Babel/BabelAutoCreate.class.php (modified) (history)
  • /branches/extensions-realtime/CategoryTree/CategoryTreeFunctions.php (modified) (history)
  • /branches/extensions-realtime/CentralAuth/specials/SpecialWikiSets.php (modified) (history)
  • /branches/extensions-realtime/CentralNotice/CentralNoticeBannerLogPager.php (modified) (history)
  • /branches/extensions-realtime/CentralNotice/CentralNoticeLogPager.php (modified) (history)
  • /branches/extensions-realtime/CentralNotice/CentralNoticePager.php (modified) (history)
  • /branches/extensions-realtime/CodeReview (modified) (history)
  • /branches/extensions-realtime/ConditionalShowSection (modified) (history)
  • /branches/extensions-realtime/ContactPageFundraiser (modified) (history)
  • /branches/extensions-realtime/FlaggedRevs (modified) (history)
  • /branches/extensions-realtime/FundraiserPortal (modified) (history)
  • /branches/extensions-realtime/Gadgets/Gadgets_body.php (modified) (history)
  • /branches/extensions-realtime/HoneypotIntegration/HoneypotIntegration.class.php (modified) (history)
  • /branches/extensions-realtime/JSKit/JSKit.php (modified) (history)
  • /branches/extensions-realtime/LiquidThreads (modified) (history)
  • /branches/extensions-realtime/LiquidThreads/i18n/Lqt.i18n.php (modified) (history)
  • /branches/extensions-realtime/LocalisationUpdate (modified) (history)
  • /branches/extensions-realtime/LocalisationUpdate/LocalisationUpdate.class.php (modified) (history)
  • /branches/extensions-realtime/LocalisationUpdate/LocalisationUpdate.php (modified) (history)
  • /branches/extensions-realtime/MobileFrontend/MobileFrontend.php (modified) (history)
  • /branches/extensions-realtime/MwEmbedSupport/MwEmbedModules/MwEmbedSupport/MwEmbedSupport.php (modified) (history)
  • /branches/extensions-realtime/MwEmbedSupport/MwEmbedModules/MwEmbedSupport/mediawiki/mediawiki.Uri.js (deleted) (history)
  • /branches/extensions-realtime/PrefSwitch/PrefSwitch.hooks.php (modified) (history)
  • /branches/extensions-realtime/SVGZoom (modified) (history)
  • /branches/extensions-realtime/SelectCategory (modified) (history)
  • /branches/extensions-realtime/SemanticMediaWiki/RELEASE-NOTES (modified) (history)
  • /branches/extensions-realtime/SemanticMediaWiki/languages/SMW_Messages.php (modified) (history)
  • /branches/extensions-realtime/SemanticMediaWiki/skins/SMW_custom.css (modified) (history)
  • /branches/extensions-realtime/SemanticMediaWiki/specials/AskSpecial/SMW_SpecialAsk.php (modified) (history)
  • /branches/extensions-realtime/SemanticMediaWiki/specials/AskSpecial/SMW_SpecialQueryCreator.php (modified) (history)
  • /branches/extensions-realtime/SemanticResultFormats/RELEASE-NOTES (modified) (history)
  • /branches/extensions-realtime/SemanticResultFormats/jqPlot/SRF_jqPlotBar.php (modified) (history)
  • /branches/extensions-realtime/SemanticResultFormats/jqPlot/SRF_jqPlotPie.php (modified) (history)
  • /branches/extensions-realtime/SemanticSignup (added) (history)
  • /branches/extensions-realtime/SocialProfile/UserStatus/UserStatus.js (modified) (history)
  • /branches/extensions-realtime/StrategyWiki (modified) (history)
  • /branches/extensions-realtime/StrategyWiki/ActiveStrategy (modified) (history)
  • /branches/extensions-realtime/StringFunctionsEscaped (modified) (history)
  • /branches/extensions-realtime/TrustedXFF (modified) (history)
  • /branches/extensions-realtime/TrustedXFF/trusted-hosts.txt (modified) (history)
  • /branches/extensions-realtime/UploadWizard (modified) (history)
  • /branches/extensions-realtime/UploadWizard/UploadWizardHooks.php (modified) (history)
  • /branches/extensions-realtime/UploadWizard/resources/mw.Api.js (modified) (history)
  • /branches/extensions-realtime/UploadWizard/resources/mw.LanguageUpWiz.js (modified) (history)
  • /branches/extensions-realtime/UploadWizard/test/jasmine/SpecRunner.html (modified) (history)
  • /branches/extensions-realtime/UploadWizard/test/jasmine/spec/mw.Api.edit.spec.js (modified) (history)
  • /branches/extensions-realtime/Vector/modules/ext.vector.collapsibleTabs.js (modified) (history)
  • /branches/extensions-realtime/Vector/modules/ext.vector.simpleSearch.js (modified) (history)
  • /branches/extensions-realtime/WikiTweet (modified) (history)
  • /branches/extensions-realtime/WikimediaIncubator/IncubatorTest.php (modified) (history)

Diff [purge]

Property changes on: branches/extensions-realtime/AddMediaWizard/MwEmbedModules/AddMedia/AddMedia.i18n.php
___________________________________________________________________
Modified: svn:mergeinfo
11 Merged /trunk/extensions/AddMediaWizard/MwEmbedModules/AddMedia/AddMedia.i18n.php:r94187-94267
Property changes on: branches/extensions-realtime/TrustedXFF/trusted-hosts.txt
___________________________________________________________________
Modified: svn:mergeinfo
22 Merged /trunk/extensions/TrustedXFF/trusted-hosts.txt:r94187-94267
Property changes on: branches/extensions-realtime/TrustedXFF
___________________________________________________________________
Modified: svn:mergeinfo
33 Merged /trunk/extensions/TrustedXFF:r94187-94267
Index: branches/extensions-realtime/SemanticMediaWiki/specials/AskSpecial/SMW_SpecialQueryCreator.php
@@ -37,13 +37,17 @@
3838 $html_output = $this->makeResults( $p );
3939 if ( $this->uiCore->getQueryString() != "" ) {
4040 if ( $this->usesNavigationBar() ) {
41 - $html_output .= $this->getNavigationBar ( $this->uiCore->getLimit(), $this->uiCore->getOffset(), $this->uiCore->hasFurtherResults() ); // ? can we preload offset and limit?
 41+ $html_output .= Html::rawElement( 'div', array( 'class' => 'smwqcnavbar' ),
 42+ $this->getNavigationBar ( $this->uiCore->getLimit(), $this->uiCore->getOffset(), $this->uiCore->hasFurtherResults() )
 43+ ); // ? can we preload offset and limit?
4244 }
4345
44 - $html_output .= "<br/>" . $this->uiCore->getHTMLResult() . "<br>";
 46+ $html_output .= Html::rawElement( 'div', array( 'class' => 'smw-qc-result' ), $this->uiCore->getHTMLResult() );
4547
4648 if ( $this->usesNavigationBar() ) {
47 - $html_output .= $this->getNavigationBar ( $this->uiCore->getLimit(), $this->uiCore->getOffset(), $this->uiCore->hasFurtherResults() ); // ? can we preload offset and limit?
 49+ $html_output .= Html::rawElement( 'div', array( 'class' => 'smwqcnavbar' ),
 50+ $this->getNavigationBar ( $this->uiCore->getLimit(), $this->uiCore->getOffset(), $this->uiCore->hasFurtherResults() )
 51+ ); // ? can we preload offset and limit?
4852 }
4953 }
5054 $wgOut->addHTML( $html_output );
@@ -62,7 +66,7 @@
6367 * Overridden from parent to ignore GUI parameters 'format' 'limit' and 'offset'
6468 */
6569 protected function showFormatOptions( $format, array $paramValues, array $ignoredAttribs = array() ) {
66 - return parent::showFormatOptions( $format, $paramValues, array( 'format', 'limit', 'offset' ) );
 70+ return parent::showFormatOptions( $format, $paramValues, array( 'format', 'limit', 'offset', 'mainlabel' ) );
6771 }
6872 /**
6973 * Creates the input form
@@ -112,7 +116,7 @@
113117 $result .= '</div>'; // end of hidden additional options
114118 $result .= '<br /><input type="submit" value="' . wfMsg( 'smw_ask_submit' ) . '"/>' .
115119 '<input type="hidden" name="eq" value="no"/>' .
116 - "\n</form>";
 120+ "\n</form><br/>";
117121
118122 return $result;
119123
@@ -126,11 +130,12 @@
127131 * Overrides method from SMWQueryUI (modal window added)
128132 *
129133 * @global boolean $smwgQSortingSupport
 134+ * @global Language $wgContLang
130135 * @param WebRequest $wgRequest
131136 * @return string
132137 */
133138 protected function processPoSortFormBox( WebRequest $wgRequest ) {
134 - global $smwgQSortingSupport;
 139+ global $smwgQSortingSupport, $wgContLang;
135140 if ( !$smwgQSortingSupport ) return array();
136141
137142 $params = array();
@@ -138,13 +143,28 @@
139144 $property_values = $wgRequest->getArray( 'property' );
140145 $category_values = $wgRequest->getArray( 'category' );
141146 $category_label_values = $wgRequest->getArray( 'cat_label' );
 147+ $main_column_labels = $wgRequest->getArray( 'maincol_label' );
142148 $po = array();
 149+ $category_namespace = $wgContLang->getNsText( NS_CATEGORY );
 150+ if ( is_array( $main_column_labels ) ) {
 151+ $po['mainlabel'] = '-'; // disables mainlabel parameter so that the UI can control it from here
 152+ foreach ( $main_column_labels as $key => $label ) {
 153+ if ( $label == '' ) {
 154+ $po[$key] = "?";
 155+ } else {
 156+ $po[$key] = "? = $label";
 157+ }
 158+
 159+ }
 160+ } else {
 161+ $po['mainlabel'] = ''; // enables mainlabel parameter
 162+ }
143163 if ( is_array( $category_values ) ) {
144164 foreach ( $category_values as $key => $value ) {
145165 if ( trim( $value ) == '' ) {
146 - $po[$key] = '?Category'; // Todo: i18n
 166+ $po[$key] = "?$category_namespace" ;
147167 } else {
148 - $po[$key] = '?Category:' . $value; // Todo: i18n
 168+ $po[$key] = "?$category_namespace:$value";
149169 }
150170 }
151171 }
@@ -221,13 +241,19 @@
222242 $display_values = $wgRequest->getArray( 'display' );
223243 $category_values = $wgRequest->getArray( 'category' );
224244 $category_label_values = $wgRequest->getArray( 'cat_label' );
 245+ $main_column_labels = $wgRequest->getArray( 'maincol_label' );
225246
226 - if ( is_array( $property_values ) ) {
227 - // removing empty values
228 - foreach ( $property_values as $key => $property_value ) {
229 - $property_values[$key] = trim( $property_value );
230 - if ( $property_value == '' ) {
231 - unset( $property_values[$key] );
 247+ if ( is_array( $property_values ) or is_array( $category_values ) or is_array( $main_column_labels ) ) {
 248+ /*
 249+ * Printouts were set via this Ui
 250+ */
 251+ if ( is_array( $property_values ) ) {
 252+ // remove empty property values
 253+ foreach ( $property_values as $key => $property_value ) {
 254+ $property_values[$key] = trim( $property_value );
 255+ if ( $property_value == '' ) {
 256+ unset( $property_values[$key] );
 257+ }
232258 }
233259 }
234260 } else {
@@ -258,19 +284,18 @@
259285 $order_values = array(); // do not even show one sort input here
260286 $property_values = array();
261287 }
262 -
263 - foreach ( $po as $po_key => $po_value ) {
 288+ foreach ( $po as $po_value ) {
264289 if ( !in_array( $po_value, $property_values ) ) {
265290 $property_values[] = $po_value;
266291 }
267 - }
268 - $display_values = array();
269 - reset( $property_values );
270 - foreach ( $property_values as $property_key => $property_value ) {
271 - if ( in_array( $property_value, $po ) ) {
272 - $display_values[$property_key] = "yes";
273 - }
274 - }
 292+ }
 293+ $display_values = array();
 294+ reset( $property_values );
 295+ foreach ( $property_values as $property_key => $property_value ) {
 296+ if ( in_array( $property_value, $po ) ) {
 297+ $display_values[$property_key] = "yes";
 298+ }
 299+ }
275300 }
276301 $i = 0;
277302 $additional_POs = array();
@@ -278,13 +303,24 @@
279304 $additional_POs = array_merge( $additional_POs, $property_values );
280305 }
281306 if ( is_array( $category_values ) ) {// same as testing $category_label_values
282 - $additional_POs = array_merge( $additional_POs, $category_values );
 307+ $keys = array_keys( $category_values );
 308+ foreach ( $keys as $value ) {
 309+ $additional_POs[$value] = $category_values[$value]; // array_merge won't work because numeric keys need to be preserved
 310+ }
283311 }
 312+ if ( is_array( $main_column_labels ) ) {
 313+ $keys = array_keys( $main_column_labels );
 314+ foreach ( $keys as $value ) {
 315+ $additional_POs[$value] = $main_column_labels[$value]; // array_merge won't work because numeric keys need to be preserved
 316+ }
 317+ }
284318 ksort( $additional_POs );
285319 foreach ( $additional_POs as $key => $value ) {
286 - if ( array_key_exists( $key, $property_values ) ) {
287 - // make a element for additional properties
288 - $result .= Html::openElement( 'div', array( 'id' => "sort_div_$i", 'class' => 'smw-sort' ) );
 320+ if ( is_array( $property_values ) and array_key_exists( $key, $property_values ) ) {
 321+ /*
 322+ * Make an element for additional properties
 323+ */
 324+ $result .= Html::openElement( 'div', array( 'id' => "sort_div_$i", 'class' => 'smwsort' ) );
289325 $result .= '<span class="smw-remove"><a href="javascript:removePOInstance(\'sort_div_' . $i . '\')"><img src="' . $smwgScriptPath . '/skins/images/close-button.png" alt="' . wfMsg( 'smw_qui_delete' ) . '"></a></span>';
290326 $result .= wfMsg( 'smw_qui_property' );
291327 $result .= Html::input( 'property[' . $i . ']', $property_values[$key], 'text', array( 'size' => '35', 'id' => "property$i" ) ) . "\n";
@@ -309,22 +345,36 @@
310346 $i++;
311347 }
312348 if ( is_array( $category_values ) and array_key_exists( $key, $category_values ) ) {
313 - $result .= Html::openElement( 'div', array( 'id' => "sort_div_$i", 'class' => 'smw-sort' ) );
 349+ /*
 350+ * Make an element for additional categories
 351+ */
 352+ $result .= Html::openElement( 'div', array( 'id' => "sort_div_$i", 'class' => 'smwsort' ) );
314353 $result .= '<span class="smw-remove"><a href="javascript:removePOInstance(\'sort_div_' . $i . '\')"><img src="' . $smwgScriptPath . '/skins/images/close-button.png" alt="' . wfMsg( 'smw_qui_delete' ) . '"></a></span>' .
315354 'Category (optional)' . // todo: i18n
316 - Xml::input( "category[$i]", '20', $category_values[$key] ) . " " .
 355+ Xml::input( "category[$i]", '20', $category_values[$key], array( 'id' => "category$i" ) ) . " " .
317356 'Label' . // todo: i18n
318 - Xml::input( "cat_label[$i]", '20', array_key_exists( $key, $category_label_values ) ? $category_label_values[$key]:false ) . " " .
 357+ Xml::input( "cat_label[$i]", '20', array_key_exists( $key, $category_label_values ) ? $category_label_values[$key]:false, array( 'id' => "cat_label$i" ) ) . " " .
319358 ' <a id="more' . $i . '" "class="smwq-more" href="javascript:smw_makeCatDialog(\'' . $i . '\')"> options </a> ' . // TODO: i18n
320359 Xml::closeElement( 'div' );
321360 $i++;
322361 }
 362+ if ( is_array( $main_column_labels ) and array_key_exists( $key, $main_column_labels ) ) {
 363+ /*
 364+ * Make an element for main column
 365+ */
 366+ $result .= Html::openElement( 'div', array( 'id' => "sort_div_$i", 'class' => 'smwsort' ) ) .
 367+ '<span class="smw-remove"><a href="javascript:removePOInstance(\'sort_div_' . $i . '\')"><img src="' . $smwgScriptPath . '/skins/images/close-button.png" alt="' . wfMsg( 'smw_qui_delete' ) . '"></a></span>' .
 368+ wfMsg( 'smw_qui_rescol' ) .
 369+ Xml::input( "maincol_label[$i]", '20', $main_column_labels[$key], array ( 'id' => "maincol_label$i" ) ) . " " .
 370+ Xml::closeElement( 'div' );
 371+ $i++;
 372+ }
323373 }
324374 $num_sort_values = $i;
325375 // END: create form elements already submitted earlier via form
326376
327377 // create hidden form elements to be cloned later
328 - $hidden_property = Html::openElement( 'div', array( 'id' => 'property_starter', 'class' => 'smw-sort', 'style' => 'display:none' ) ) .
 378+ $hidden_property = Html::openElement( 'div', array( 'id' => 'property_starter', 'class' => 'smwsort', 'style' => 'display:none' ) ) .
329379 '<span class="smw-remove"><a><img src="' . $smwgScriptPath . '/skins/images/close-button.png" alt="' . wfMsg( 'smw_qui_delete' ) . '"></a></span>' .
330380 wfMsg( 'smw_qui_property' ) .
331381 Xml::input( "property_num", '35' ) . " " .
@@ -337,7 +387,7 @@
338388 Xml::closeElement( 'div' );
339389 $hidden_property = json_encode( $hidden_property );
340390
341 - $hidden_category = Html::openElement( 'div', array( 'id' => 'category_starter', 'class' => 'smw-sort', 'style' => 'display:none' ) ) .
 391+ $hidden_category = Html::openElement( 'div', array( 'id' => 'category_starter', 'class' => 'smwsort', 'style' => 'display:none' ) ) .
342392 '<span class="smw-remove"><a><img src="' . $smwgScriptPath . '/skins/images/close-button.png" alt="' . wfMsg( 'smw_qui_delete' ) . '"></a></span>' .
343393 'Category (optional)' . // todo: i18n
344394 Xml::input( "category_num", '20' ) . " " .
@@ -346,10 +396,17 @@
347397 Xml::closeElement( 'div' );
348398 $hidden_category = json_encode( $hidden_category );
349399
350 - $property_dialog_box = Xml::openElement( 'div', array( 'id' => 'prop-dialog', 'title' => 'Property Options', 'class' => 'smw-prop-dialog' ) ) . // todo i18n
 400+ $hidden_main_column = Html::openElement( 'div', array( 'id' => 'maincol_starter', 'class' => 'smwsort', 'style' => 'display:none' ) ) .
 401+ '<span class="smw-remove"><a><img src="' . $smwgScriptPath . '/skins/images/close-button.png" alt="' . wfMsg( 'smw_qui_delete' ) . '"></a></span>' .
 402+ wfMsg( 'smw_qui_rescol' ) .
 403+ Xml::input( "maincol_label_num", '20' ) . " " .
 404+ Xml::closeElement( 'div' );
 405+ $hidden_main_column = json_encode( $hidden_main_column );
 406+
 407+ $property_dialog_box = Xml::openElement( 'div', array( 'id' => 'prop-dialog', 'title' => 'Property Options', 'class' => 'smwpropdialog' ) ) . // todo i18n
351408 Xml::inputLabel( 'Property:', '', 'd-property', 'd-property' ) . '<br/>' . // todo i18n
352409 Xml::inputLabel( 'Label:', '', 'd-property-label', 'd-property-label' ) . '<br/>' . // todo i18n
353 - 'Format: ' . Html::openElement( 'select', array( 'name' => 'd-format', 'id' => 'd-format' ) ) . // todo i18n
 410+ '<label for="d-format">Format:</label> ' . Html::openElement( 'select', array( 'name' => 'd-format', 'id' => 'd-format' ) ) . // todo i18n
354411 Xml::option( 'None (default)', ' ' ) . // todo i18n
355412 Xml::option( 'Simple', '#-' ) . // todo i18n
356413 Xml::closeElement( 'select' ) .
@@ -357,7 +414,7 @@
358415 // Xml::inputLabel( 'Limit:', 'd-property-limit', 'd-property-limit' ) . '<br/>' . // todo i18n
359416 '<input type="hidden" name="d-property-code" id="d-property-code">' .
360417 Xml::closeElement( 'div' );
361 - $category_dialog_box = Xml::openElement( 'div', array( 'id' => 'cat-dialog', 'title' => 'Category Options', 'class' => 'smw-cat-dialog' ) ) . // todo i18n
 418+ $category_dialog_box = Xml::openElement( 'div', array( 'id' => 'cat-dialog', 'title' => 'Category Options', 'class' => 'smwcatdialog' ) ) . // todo i18n
362419 Xml::inputLabel( 'Category:', '', 'd-category', 'd-category' ) . '<br/>' . // todo i18n
363420 Xml::inputLabel( 'Label:', '', 'd-category-label', 'd-category-label' ) . '<br/>' . // todo i18n
364421 Xml::inputLabel( 'Yes:', '', 'd-category-yes', 'd-category-yes' ) . '<br/>' . // todo i18n
@@ -368,6 +425,7 @@
369426 $result .= '<div id="sorting_main"></div>' . "\n";
370427 $result .= '[<a href="javascript:smw_addPropertyInstance(\'property_starter\', \'sorting_main\')">' . wfMsg( 'smw_qui_addnprop' ) . '</a>]' .
371428 '[<a href="javascript:smw_addCategoryInstance(\'category_starter\', \'sorting_main\')">' . 'Add additional category' . '</a>]' . // todo i18n
 429+ '[<a href="javascript:smw_addMainColInstance(\'maincol_starter\', \'sorting_main\')">' . 'Add main column' . '</a>]' . // todo i18n
372430 "\n";
373431
374432 // Javascript code for handling adding and removing the "sort" inputs
@@ -397,6 +455,7 @@
398456 }
399457 });
400458 }
 459+
401460 function smw_category_autocomplete(){
402461 jQuery('[name*="category"]').autocomplete({
403462 minLength: 2,
@@ -417,47 +476,63 @@
418477 $javascript_text .= <<<EOT
419478 function smw_property_autocomplete(){
420479 }
 480+
421481 function smw_category_autocomplete(){
422482 }
 483+
423484 EOT;
424485 }
425486
426487 $javascript_text .= <<<EOT
427488 function smw_prop_code_update(){
428 - code = '?'+\$j('#d-property')[0].value;
429 - if(code!=''){
430 - if(\$j('#d-property-format-custom')[0].value !=''){
431 - code = code + \$j('#d-property-format-custom')[0].value;
432 - }
433 - if(\$j('#d-property-label')[0].value !=''){
434 - code = code + ' = '+ \$j('#d-property-label')[0].value;
435 - }
436 - \$j('#d-property-code')[0].value= code;
 489+ code = '?'+jQuery('#d-property')[0].value;
 490+ if(code!=''){
 491+ if(jQuery('#d-property-format-custom')[0].value !=''){
 492+ code = code + jQuery('#d-property-format-custom')[0].value;
437493 }
 494+ if(jQuery('#d-property-label')[0].value !=''){
 495+ code = code + ' = '+ jQuery('#d-property-label')[0].value;
 496+ }
 497+ jQuery('#d-property-code')[0].value= code;
 498+ }
438499 }
 500+
 501+function smw_cat_code_update(){
 502+
 503+}
 504+
 505+function smw_makeCatDialog(cat_id){
 506+ jQuery('#prop-cat input').attr('value','');
 507+ cat=jQuery('#category'+cat_id)[0].value;
 508+ jQuery('#d-category').attr('value',cat);
 509+ label=jQuery('#cat_label'+cat_id)[0].value;
 510+ jQuery('#d-category-label').attr('value',label);
 511+ //jQuery('#cat-dialog').dialog('open');
 512+}
 513+
439514 function smw_makePropDialog(prop_id){
440 - jQuery('#prop-dialog input').attr('value','');
441 - prop=val=\$j('#property'+prop_id)[0].value;
442 - if(val[0]='?') val=prop=prop.substr(1);
443 - if((i=val.indexOf('='))!=-1) prop=prop.substring(0, i);
444 - if((i=val.indexOf('#'))!=-1) prop=prop.substring(0, i);
445 - if(val.split('=')[1]){
446 - label=val.split('=')[1].trim();
447 - }else{
448 - label="";
449 - }
450 - format = val.split('=')[0];
451 - if(format.indexOf('#')!=-1){
452 - format=format.substr(format.indexOf('#'));
453 - }else{
454 - format="";
455 - }
 515+ jQuery('#prop-dialog input').attr('value','');
 516+ prop=val=jQuery('#property'+prop_id)[0].value;
 517+ if(val[0]='?') val=prop=prop.substr(1);
 518+ if((i=val.indexOf('='))!=-1) prop=prop.substring(0, i);
 519+ if((i=val.indexOf('#'))!=-1) prop=prop.substring(0, i);
 520+ if(val.split('=')[1]){
 521+ label=val.split('=')[1].trim();
 522+ }else{
 523+ label="";
 524+ }
 525+ format = val.split('=')[0];
 526+ if(format.indexOf('#')!=-1){
 527+ format=format.substr(format.indexOf('#'));
 528+ }else{
 529+ format="";
 530+ }
456531
457 - \$j('#d-property').attr('value', prop.trim());
458 - \$j('#d-property-label').attr('value', label);
459 - \$j('#d-property-format-custom').attr('value', format.trim());
460 - \$j('#prop-dialog').dialog.id=prop_id;
461 - \$j('#prop-dialog').dialog('open');
 532+ jQuery('#d-property').attr('value', prop.trim());
 533+ jQuery('#d-property-label').attr('value', label);
 534+ jQuery('#d-property-format-custom').attr('value', format.trim());
 535+ jQuery('#prop-dialog').dialog.id=prop_id;
 536+ jQuery('#prop-dialog').dialog('open');
462537 }
463538 // code for handling adding and removing the "sort" inputs
464539
@@ -533,6 +608,36 @@
534609 smw_category_autocomplete();
535610 }
536611
 612+function smw_addMainColInstance(starter_div_id, main_div_id) {
 613+ var starter_div = document.getElementById(starter_div_id);
 614+ var main_div = document.getElementById(main_div_id);
 615+
 616+ //Create the new instance
 617+ var new_div = starter_div.cloneNode(true);
 618+ var div_id = 'sort_div_' + num_elements;
 619+ new_div.id = div_id;
 620+ new_div.style.display = 'block';
 621+ jQuery(new_div.getElementsByTagName('label')).attr('for', 'display'+num_elements);
 622+ var children = new_div.getElementsByTagName('*');
 623+ var x;
 624+ for (x = 0; x < children.length; x++) {
 625+ if (children[x].for) children[x].for="display"+num_elements;
 626+ if (children[x].name){
 627+ children[x].id = children[x].name.replace(/_num/, ''+num_elements);
 628+ children[x].name = children[x].name.replace(/_num/, '[' + num_elements + ']');
 629+ }
 630+ }
 631+
 632+ //Add the new instance
 633+ main_div.appendChild(new_div);
 634+
 635+ // initialize delete button
 636+ st='sort_div_'+num_elements;
 637+ jQuery('#'+new_div.id).find(".smw-remove a")[0].href="javascript:removePOInstance('"+st+"')";
 638+ num_elements++;
 639+ smw_category_autocomplete();
 640+}
 641+
537642 function removePOInstance(div_id) {
538643 var olddiv = document.getElementById(div_id);
539644 var parent = olddiv.parentNode;
@@ -542,6 +647,7 @@
543648 jQuery(function(){
544649 jQuery('$hidden_property').appendTo(document.body);
545650 jQuery('$hidden_category').appendTo(document.body);
 651+ jQuery('$hidden_main_column').appendTo(document.body);
546652 jQuery('$property_dialog_box').appendTo(document.body);
547653 jQuery('$category_dialog_box').appendTo(document.body);
548654 jQuery('#cat-dialog').dialog({
@@ -550,7 +656,20 @@
551657 resizable: true,
552658 minHeight: 200,
553659 minWidth: 400,
 660+ buttons: {
 661+ "Ok": function(){ //todo i18
 662+ smw_cat_code_update();
 663+ // todo: move modal window data to main window form controls;
 664+ jQuery(this).dialog("close");
 665+ },
 666+ "Cancel": function(){ //todo:i18n
 667+ jQuery('#cat-dialog input').attr('value','');
 668+ jQuery(this).dialog("close");
 669+ }
 670+ }
554671 });
 672+ //todo: run smw_cat_code_update() when input values in category modal windows changes
 673+
555674 jQuery('#prop-dialog').dialog({
556675 autoOpen: false,
557676 modal: true,
@@ -560,7 +679,7 @@
561680 buttons: {
562681 "Ok": function(){ //todo: i18n
563682 smw_prop_code_update();
564 - \$j('#property'+\$j('#prop-dialog').dialog.id)[0].value=\$j('#d-property-code')[0].value;
 683+ jQuery('#property'+jQuery('#prop-dialog').dialog.id)[0].value=jQuery('#d-property-code')[0].value;
565684 jQuery(this).dialog("close");
566685 },
567686 "Cancel": function(){ //todo: i18n
@@ -577,10 +696,9 @@
578697 smw_prop_code_update();
579698 });
580699 });
581 -function smw_makeCatDialog(cat_id){
582 - //\$j('#cat-dialog').dialog('open');
583 -}
 700+
584701 jQuery(document).ready(smw_property_autocomplete);
 702+jQuery(document).ready(smw_category_autocomplete);
585703 </script>
586704
587705 EOT;
Index: branches/extensions-realtime/SemanticMediaWiki/specials/AskSpecial/SMW_SpecialAsk.php
@@ -147,18 +147,6 @@
148148 }
149149 }
150150
151 - // Find implicit ordering for RSS -- needed for downwards compatibility with SMW <=1.1
152 - /*
153 - if ( ($this->m_params['format'] == 'rss') && ($this->m_params['sort'] == '') && ($sortcount==0)) {
154 - foreach ($this->m_printouts as $printout) {
155 - if ((strtolower($printout->getLabel()) == "date") && ($printout->getTypeID() == "_dat")) {
156 - $this->m_params['sort'] = $printout->getTitle()->getText();
157 - $this->m_params['order'] = 'DESC';
158 - }
159 - }
160 - }
161 - */
162 -
163151 if ( !array_key_exists( 'offset', $this->m_params ) ) {
164152 $this->m_params['offset'] = $wgRequest->getVal( 'offset' );
165153 if ( $this->m_params['offset'] == '' ) $this->m_params['offset'] = 0;
@@ -361,7 +349,7 @@
362350 $result_mime = false; // output in MW Special page as usual
363351
364352 // build parameter strings for URLs, based on current settings
365 - $urltail = '&q=' . urlencode( $this->m_querystring );
 353+ $urlArgs['q'] = $this->m_querystring;
366354
367355 $tmp_parray = array();
368356 foreach ( $this->m_params as $key => $value ) {
@@ -370,16 +358,16 @@
371359 }
372360 }
373361
374 - $urltail .= '&p=' . urlencode( SMWInfolink::encodeParameters( $tmp_parray ) );
 362+ $urlArgs['p'] = SMWInfolink::encodeParameters( $tmp_parray );
375363 $printoutstring = '';
376364
377365 foreach ( $this->m_printouts as $printout ) {
378366 $printoutstring .= $printout->getSerialisation() . "\n";
379367 }
380368
381 - if ( $printoutstring != '' ) $urltail .= '&po=' . urlencode( $printoutstring );
382 - if ( array_key_exists( 'sort', $this->m_params ) ) $urltail .= '&sort=' . $this->m_params['sort'];
383 - if ( array_key_exists( 'order', $this->m_params ) ) $urltail .= '&order=' . $this->m_params['order'];
 369+ if ( $printoutstring != '' ) $urlArgs['po'] = $printoutstring;
 370+ if ( array_key_exists( 'sort', $this->m_params ) ) $urlArgs['sort'] = $this->m_params['sort'];
 371+ if ( array_key_exists( 'order', $this->m_params ) ) $urlArgs['order'] = $this->m_params['order'];
384372
385373 if ( $this->m_querystring != '' ) {
386374 $queryobj = SMWQueryProcessor::createQuery( $this->m_querystring, $this->m_params, SMWQueryProcessor::SPECIAL_PAGE , $this->m_params['format'], $this->m_printouts );
@@ -425,10 +413,14 @@
426414
427415 if ( $result_mime == false ) {
428416 if ( $res->getCount() > 0 ) {
429 - if ( $this->m_editquery ) $urltail .= '&eq=yes';
430 - if ( $hidequery ) $urltail .= '&eq=no';
 417+ if ( $this->m_editquery ) {
 418+ $urlArgs['eq'] = 'yes';
 419+ }
 420+ else if ( $hidequery ) {
 421+ $urlArgs['eq'] = 'no';
 422+ }
431423
432 - $navigation = $this->getNavigationBar( $res, $urltail );
 424+ $navigation = $this->getNavigationBar( $res, $urlArgs );
433425 $result .= '<div style="text-align: center;">' . "\n" . $navigation . "\n</div>\n";
434426 $query_result = $printer->getResult( $res, $this->m_params, SMW_OUTPUT_HTML );
435427
@@ -440,7 +432,7 @@
441433
442434 $result .= '<div style="text-align: center;">' . "\n" . $navigation . "\n</div>\n";
443435 } else {
444 - $result = '<div style="text-align: center;">' . wfMsg( 'smw_result_noresults' ) . '</div>';
 436+ $result = '<div style="text-align: center;">' . wfMsgHtml( 'smw_result_noresults' ) . '</div>';
445437 }
446438 } else { // make a stand-alone file
447439 $result = $printer->getResult( $res, $this->m_params, SMW_OUTPUT_FILE );
@@ -455,7 +447,13 @@
456448 $wgOut->setHTMLtitle( wfMsg( 'ask' ) );
457449 }
458450
459 - $result = $this->getInputForm( $printoutstring, 'offset=' . $this->m_params['offset'] . '&limit=' . $this->m_params['limit'] . $urltail ) . $result;
 451+ $result = $this->getInputForm(
 452+ $printoutstring,
 453+ 'offset=' . $this->m_params['offset']
 454+ . '&limit=' . $this->m_params['limit']
 455+ . wfArrayToCGI( $urlArgs )
 456+ ) . $result;
 457+
460458 $wgOut->addHTML( $result );
461459 } else {
462460 $wgOut->disable();
@@ -560,7 +558,7 @@
561559 $result .= '<fieldset><legend>' . wfMsg( 'smw_ask_otheroptions' ) . "</legend>\n";
562560 $result .= "<div id=\"other_options\">" . $this->showFormatOptions( $this->m_params['format'], $this->m_params ) . "</div>";
563561 $result .= "</fieldset>\n";
564 - $urltail = str_replace( '&eq=yes', '', $urltail ) . '&eq=no';
 562+ $urltail = str_replace( '&eq=yes', '', $urltail ) . '&eq=no'; // FIXME: doing it wrong, srysly
565563
566564 $result .= '<br /><input type="submit" value="' . wfMsg( 'smw_ask_submit' ) . '"/>' .
567565 '<input type="hidden" name="eq" value="yes"/>' .
@@ -629,11 +627,11 @@
630628 * Build the navigation for some given query result, reuse url-tail parameters.
631629 *
632630 * @param SMWQueryResult $res
633 - * @param string $urltail
 631+ * @param array $urlArgs
634632 *
635633 * @return string
636634 */
637 - protected function getNavigationBar( SMWQueryResult $res, $urltail ) {
 635+ protected function getNavigationBar( SMWQueryResult $res, array $urlArgs ) {
638636 global $smwgQMaxInlineLimit;
639637
640638 $offset = $this->m_params['offset'];
@@ -646,8 +644,8 @@
647645 array(
648646 'href' => SpecialPage::getSafeTitleFor( 'Ask' )->getLocalURL( array(
649647 'offset' => max( 0, $offset - $limit ),
650 - 'limit' => $limit . $urltail
651 - ) ),
 648+ 'limit' => $limit
 649+ ) + $urlArgs ),
652650 'rel' => 'nofollow'
653651 ),
654652 wfMsg( 'smw_result_prev' )
@@ -670,8 +668,8 @@
671669 array(
672670 'href' => SpecialPage::getSafeTitleFor( 'Ask' )->getLocalURL( array(
673671 'offset' => ( $offset + $limit ),
674 - 'limit' => $limit . $urltail
675 - ) ),
 672+ 'limit' => $limit
 673+ ) + $urlArgs ),
676674 'rel' => 'nofollow'
677675 ),
678676 wfMsg( 'smw_result_next' )
@@ -698,8 +696,8 @@
699697 array(
700698 'href' => SpecialPage::getSafeTitleFor( 'Ask' )->getLocalURL( array(
701699 'offset' => $offset,
702 - 'limit' => $l . $urltail
703 - ) ),
 700+ 'limit' => $l
 701+ ) + $urlArgs ),
704702 'rel' => 'nofollow'
705703 ),
706704 $l
@@ -802,21 +800,4 @@
803801 return $input->getHtml();
804802 }
805803
806 - /**
807 - * Compatibility method to get the skin; MW 1.18 introduces a getSkin method in SpecialPage.
808 - *
809 - * @since 1.6
810 - *
811 - * @return Skin
812 - */
813 - public function getSkin() {
814 - if ( method_exists( 'SpecialPage', 'getSkin' ) ) {
815 - return parent::getSkin();
816 - }
817 - else {
818 - global $wgUser;
819 - return $wgUser->getSkin();
820 - }
821 - }
822 -
823804 }
Index: branches/extensions-realtime/SemanticMediaWiki/RELEASE-NOTES
@@ -1,5 +1,11 @@
22 For a documentation of all features, see http://semantic-mediawiki.org
33
 4+
 5+== SMW 1.6.1 ==
 6+
 7+* Fixed continue and limit escaping issues on Special:Ask.
 8+* Internationalization improvements and layout tweaks to #smwdoc.
 9+
410 == SMW 1.6 ==
511
612 Released on July 30, 2011.
Index: branches/extensions-realtime/SemanticMediaWiki/languages/SMW_Messages.php
@@ -254,6 +254,7 @@
255255 'smw_qui_descorder' => 'Descending',
256256 'smw_qui_addnprop' => 'Add additional properties',
257257 'smw_qui_delete' => 'Remove',
 258+ 'smw_qui_rescol' => 'Result column label',
258259
259260 // Messages for the search by property special
260261 'searchbyproperty' => 'Search by property',
Index: branches/extensions-realtime/SemanticMediaWiki/skins/SMW_custom.css
@@ -131,22 +131,35 @@
132132 }
133133
134134 /* ui buttons for QueryUI */
135 -.smw-sort input, .smw-sort a, .smw-sort select, .smw-sort checkbox{
 135+.smwsort input, .smwsort a, .smwsort select, .smwsort checkbox{
136136 margin-left: 5px;
137137 margin-bottom: 5px;
138138 }
 139+
139140 span.smw-remove a img{
140141 text-decoration: none;
141142 margin-right: 5px;
142143 vertical-align: -3px;
143144 }
144145
145 -.smw-prop-dialog input, .smw-prop-dialog select{
 146+.smwpropdialog input, .smwpropdialog select{
146147 margin-top: 10px;
147148 margin-right: 5px;
 149+ margin-left: 5px;
148150 }
149151
 152+.smwcatdialog input, .smwcatdialog select{
 153+ margin-top: 10px;
 154+ margin-right: 5px;
 155+ margin-left: 5px;
 156+}
150157
 158+/* Query Creator */
 159+div.smwqcnavbar{
 160+ padding-bottom: 5px;
 161+ padding-top: 5px;
 162+}
 163+
151164 /* search, browse, RDF icons */
152165
153166 span.smwsearchicon { /*FIXME: this was only used for Factbox docu, should be removed from code*/
Index: branches/extensions-realtime/Babel/BabelAutoCreate.class.php
@@ -37,7 +37,7 @@
3838 } else {
3939 $text = wfMsgForContent( 'babel-autocreate-text-levels', $level, $language );
4040 }
41 - $article = new Article( $title );
 41+ $article = new Article( $title, 0 );
4242
4343 $user = self::user();
4444 # Do not add a message if the username is invalid or if the account that adds it, is blocked
Index: branches/extensions-realtime/SocialProfile/UserStatus/UserStatus.js
@@ -36,6 +36,10 @@
3737 toEditMode: function() {
3838 jQuery( '#user-status-block' ).hide();
3939 jQuery( '#status-edit-controls' ).show();
 40+ // If the history div is (still) present, hide it
 41+ if ( jQuery( '#status-history-block' ) ) {
 42+ jQuery( '#status-history-block' ).hide();
 43+ }
4044 },
4145
4246 /**
Index: branches/extensions-realtime/LiquidThreads/i18n/Lqt.i18n.php
@@ -214,7 +214,7 @@
215215 'lqt-enotif-subject-reply' => '{{SITENAME}} discussion - Reply: $1',
216216 'lqt-enotif-subject-newthread' => '{{SITENAME}} discussion - New thread: $1',
217217 'lqt-enotif-newthread' => "Hi $1,
218 -
 218+
219219 this is a notification from {{SITENAME}} that a new thread on $5, '$2',
220220 was created on $3 at $4 by $8
221221
@@ -256,13 +256,10 @@
257257 'lqt-marked-as-read-placeholder' => 'The thread $1 was marked as read.',
258258 'lqt-change-subject' => 'Change subject',
259259 'lqt-save-subject' => 'Save',
260 - 'lqt-save-subject-failed' => 'The following error occurred while attempting to ' .
261 -'change the subject of this thread: $1',
262 - 'lqt-ajax-invalid-subject' => 'The subject you specified was invalid, probably ' .
263 -'because it was too long.',
 260+ 'lqt-save-subject-failed' => 'The following error occurred while attempting to change the subject of this thread: $1',
 261+ 'lqt-ajax-invalid-subject' => 'The subject you specified was invalid, probably because it was too long.',
264262 'lqt-ajax-no-subject' => 'You must specify a subject for the new thread.',
265 - 'lqt-save-subject-error-unknown' => 'An unknown error occurred when attempting ' .
266 -'to set the subject of this thread. Please try to do this by clicking "edit" on the top post.',
 263+ 'lqt-save-subject-error-unknown' => 'An unknown error occurred when attempting to set the subject of this thread. Please try to do this by clicking "edit" on the top post.',
267264 'lqt-cancel-subject-edit' => 'Cancel',
268265 'lqt-drag-activate' => 'Drag to new location',
269266 'lqt-drag-drop-zone' => 'Drop here',
@@ -2050,7 +2047,7 @@
20512048 'lqt-enotif-subject-newthread' => 'Абмеркаваньне {{GRAMMAR:родны|{{SITENAME}}}} — Новая галіна: $1',
20522049 'lqt-enotif-newthread' => "Вітаем $1,
20532050
2054 -Гэта паведамленьне з {{GRAMMAR:родны|{{SITENAME}}}} пра новую галіну $5, '$2',
 2051+Гэта паведамленьне з {{GRAMMAR:родны|{{SITENAME}}}} пра новую галіну $5, '$2',
20552052 створаную $3 $4 удзельнікам $8.
20562053
20572054 Вы можаце паглядзець яе на <$6>
@@ -2059,7 +2056,7 @@
20602057 $7",
20612058 'lqt-enotif-reply' => "Вітаем, $1!
20622059
2063 -Гэта паведамленьне з {{GRAMMAR:родны|{{SITENAME}}}} пра новы адказ '$2' на старонцы $5,
 2060+Гэта паведамленьне з {{GRAMMAR:родны|{{SITENAME}}}} пра новы адказ '$2' на старонцы $5,
20642061 створаны ў $4 $3 удзельнікам $8.
20652062
20662063 Вы можаце паглядзець яго на <$6>.
@@ -2312,7 +2309,7 @@
23132310 'lqt-thread-link-url' => 'URL на препратката:',
23142311 'lqt-thread-link-title' => 'Уикитекст на препратката:',
23152312 'lqt-thread-link-copy' => 'Копиране в системния буфер',
2316 - 'lqt-sign-not-necessary' => 'Не е нужно да подписвате коментара си с четири вълнички.
 2313+ 'lqt-sign-not-necessary' => 'Не е нужно да подписвате коментара си с четири вълнички.
23172314 Подписът ви ще се покаже автоматично.',
23182315 'lqt-marked-as-read-placeholder' => 'Тема $1 беше отбелязана като прочетена.',
23192316 'lqt-change-subject' => 'Смяна на темата',
@@ -2617,7 +2614,7 @@
26182615 'lqt_delete_show_checkbox' => "Diskouez ar c'haozeadennoù diverket",
26192616 'lqt_talkpage_autocreate_summary' => "Pajenn gaozeal krouet ent emgefre p'eo bet kaset an neudennad kaozioù kentañ",
26202617 'lqt_header_warning_big' => "Emaoc'h o kemmañ ur $1",
2621 - 'lqt_header_warning_after_big' => "Evit ar c'hemennoù hag ar rakgerioù eo an talbennoù.
 2618+ 'lqt_header_warning_after_big' => "Evit ar c'hemennoù hag ar rakgerioù eo an talbennoù.
26222619 Marteze e fell deoc'h $2 kentoc'h.",
26232620 'lqt_header_warning_bold' => 'Talbenn ur bajenn gaozeal',
26242621 'lqt_header_warning_new_discussion' => "boulc'hañ gant ur gaoz nevez",
@@ -3089,7 +3086,7 @@
30903087 'lqt_new_thread' => 'Comença una nova discussió',
30913088 'lqt_invalid_subject' => 'El tema que heu introduït no és vàlid.
30923089 Pot:
3093 -* ser massa llarg, o
 3090+* ser massa llarg, o
30943091 * entrar en conflicte amb prefixos interwiki o altres espai de noms.',
30953092 'lqt_empty_subject' => "Heu d'introduir un tema.",
30963093 'lqt_reply' => 'Respon',
@@ -3265,7 +3262,7 @@
32663263
32673264 El podeu veure a <$6>',
32683265 'lqt-enotif-reply' => 'Hola $1,
3269 -Açò és una notificació des del projecte {{SITENAME}} per a avisar-vos que ha aparegut una resposta al fil «$2» a $5,
 3266+Açò és una notificació des del projecte {{SITENAME}} per a avisar-vos que ha aparegut una resposta al fil «$2» a $5,
32703267 creada el dia $3 a les $4.
32713268
32723269 El podeu veure a <$6>
@@ -3723,8 +3720,8 @@
37243721 'lqt_toc_thread_modified' => 'Newidiwyd ddiwethaf',
37253722 'lqt_add_header' => 'Ychwanegu pennawd',
37263723 'lqt_new_thread' => 'Dechrau trafodaeth newydd',
3727 - 'lqt_invalid_subject' => "Mae'r pwnc a roddoch yn annilys.
3728 -Efallai:
 3724+ 'lqt_invalid_subject' => "Mae'r pwnc a roddoch yn annilys.
 3725+Efallai:
37293726 * ei fod yn rhy hir, neu
37303727 * bod gwrthdaro yn codi rhyngddo a rhagddodiaid rhyngwici neu ag enwau parthau'r wici.",
37313728 'lqt_empty_subject' => "Mae'n rhaid gosod pwnc.",
@@ -5515,7 +5512,7 @@
55165513 'lqt-preference-custom-signatures' => 'Mostrar firmas de usuario personalizadas',
55175514 'lqt-enotif-subject-reply' => '{{SITENAME}} discusión - Respuesta: $1',
55185515 'lqt-enotif-subject-newthread' => '{{SITENAME}} discusión - Nuevo hilo: $1',
5519 - 'lqt-enotif-newthread' => "Hola $1,
 5516+ 'lqt-enotif-newthread' => "Hola $1,
55205517
55215518 esta es una notificación de {{SITENAME}} de que un nuevo hilo en $5, '$2',
55225519 ha sido creado el $3 a las $4 por $8.
@@ -6177,7 +6174,7 @@
61786175 'lqt-marked-as-read-placeholder' => 'مبحث $1 به عنوان خوانده‌شده نشانه‌گذاری شده است.',
61796176 'lqt-change-subject' => 'تغییر عنوان',
61806177 'lqt-save-subject' => 'ذخیره',
6181 - 'lqt-save-subject-failed' => 'هنگامی که قصد تغییر عنوان این مبحث را داشتید خطای زیر رخ داد:
 6178+ 'lqt-save-subject-failed' => 'هنگامی که قصد تغییر عنوان این مبحث را داشتید خطای زیر رخ داد:
61826179 $1',
61836180 'lqt-ajax-invalid-subject' => 'عنوانی که مشخص کردید نامعتبر بود، احتمالاً به خاطر طولانی‌بودن بیش از حد.',
61846181 'lqt-ajax-no-subject' => 'شما باید یک عنوان مشخص کنید.',
@@ -6312,7 +6309,7 @@
63136310 'lqt_nosuchthread' => 'Määrittämääsi viestiketjua ei ole.',
63146311 'lqt_nosuchthread_title' => 'Ketjua ei löydy',
63156312 'lqt_threadrequired' => 'Sinun tulee antaa ketju URL-osoitteessa.',
6316 - 'lqt_move_movingthread' => 'Siirretään $1.
 6313+ 'lqt_move_movingthread' => 'Siirretään $1.
63176314 Tämä ketju on osa sivua $2.',
63186315 'lqt_move_torename' => 'Nimetäksesi uudelleen tämän ketjun – $1 ja muuta Aihe-kenttää.',
63196316 'lqt_move_torename_edit' => 'muokkaa sitä',
@@ -6335,7 +6332,7 @@
63366333 'lqt_delete_show_checkbox' => 'Näytä poistetut ketjut',
63376334 'lqt_talkpage_autocreate_summary' => 'Keskustelusivu luotiin automaattisesti kun ensimmäinen ketju lähettiin.',
63386335 'lqt_header_warning_big' => 'Muokkaat $1.',
6339 - 'lqt_header_warning_after_big' => 'Otsakkeet ovat ilmoituksille ja johdannoille.
 6336+ 'lqt_header_warning_after_big' => 'Otsakkeet ovat ilmoituksille ja johdannoille.
63406337 Saatat etsiä sivua $2 sen sijaan.',
63416338 'lqt_header_warning_bold' => 'keskustelusivun otsikkoa',
63426339 'lqt_header_warning_new_discussion' => 'aloita uusi keskustelu',
@@ -6423,7 +6420,7 @@
64246421 'lqt-enotif-subject-newthread' => '{{SITENAME}} – Uusi viestiketju: $1',
64256422 'lqt-enotif-newthread' => 'Hei $1,
64266423
6427 -Tämä on ilmoitus sivustolta {{SITENAME}}, että sivulle $5 on luotu uusi ketju, ”$2”,
 6424+Tämä on ilmoitus sivustolta {{SITENAME}}, että sivulle $5 on luotu uusi ketju, ”$2”,
64286425 $3 $4.
64296426
64306427 Näet sen osoitteessa <$6>.',
@@ -8192,9 +8189,9 @@
81938190 'lqt_toc_thread_modified' => 'Zadnje izmjenjeno',
81948191 'lqt_add_header' => 'Dodaj zaglavlje',
81958192 'lqt_new_thread' => 'Započnite novu raspravu',
8196 - 'lqt_invalid_subject' => 'Naziv teme koji ste unijeli nije ispravan.
8197 -Može biti:
8198 -* predug je, ili
 8193+ 'lqt_invalid_subject' => 'Naziv teme koji ste unijeli nije ispravan.
 8194+Može biti:
 8195+* predug je, ili
81998196 * naziv je isti kao međuwiki prefiks ili ime imenskog prostora.',
82008197 'lqt_empty_subject' => 'Morate upisati temu/sažetak.',
82018198 'lqt_reply' => 'Odgovori',
@@ -8246,11 +8243,11 @@
82478244 'lqt_protectedfromreply_link' => 'zaštićen',
82488245 'lqt_subject' => 'Tema:',
82498246 'lqt_noreason' => 'bez obrazloženja',
8250 - 'lqt_move_placeholder' => 'Tema $1 premještena je odavdje na $5.
 8247+ 'lqt_move_placeholder' => 'Tema $1 premještena je odavdje na $5.
82518248 Premještaj je napravio suradnik $2 dana $3 u $4.',
82528249 'lqt_thread_deleted_for_sysops' => "Tema je '''obrisana''' te je vidljiva samo administratorima.",
82538250 'lqt_thread_deleted' => 'Tema je obrisana.',
8254 - 'lqt_summary_notice' => 'Nije bilo uređivanja ove rasprave najmanje $2 {{PLURAL:$2|dan|dana|dana}}.
 8251+ 'lqt_summary_notice' => 'Nije bilo uređivanja ove rasprave najmanje $2 {{PLURAL:$2|dan|dana|dana}}.
82558252 Ukoliko je tema zaključena, možda želite urediti sažetak $1.',
82568253 'lqt_summary_notice_link' => 'napiši sažetak',
82578254 'lqt_summary_label' => 'Sažetak teme:',
@@ -8259,7 +8256,7 @@
82608257 'lqt_nosuchthread' => 'Tema koju ste naveli ne postoji.',
82618258 'lqt_nosuchthread_title' => 'Ne postoji tema s tim nazivom',
82628259 'lqt_threadrequired' => 'Morate navesti temu u URL-u.',
8263 - 'lqt_move_movingthread' => 'Premještam $1.
 8260+ 'lqt_move_movingthread' => 'Premještam $1.
82648261 Ova tema je dio $2.',
82658262 'lqt_move_torename' => "Za promjenu naslova ove teme, $1 i promijenite polje 'Subject'.",
82668263 'lqt_move_torename_edit' => 'uredi',
@@ -8282,7 +8279,7 @@
82838280 'lqt_delete_show_checkbox' => 'Pokaži obrisane teme',
82848281 'lqt_talkpage_autocreate_summary' => 'Stranica za razgovor automatski je stvorena kad je započeta prva tema',
82858282 'lqt_header_warning_big' => 'Uređujete $1.',
8286 - 'lqt_header_warning_after_big' => 'Zaglavlja služe za obavijesti i predgovore.
 8283+ 'lqt_header_warning_after_big' => 'Zaglavlja služe za obavijesti i predgovore.
82878284 Možda želite $2.',
82888285 'lqt_header_warning_bold' => 'zaglavlje stranice za razgovor',
82898286 'lqt_header_warning_new_discussion' => 'započnite novu temu',
@@ -8294,11 +8291,11 @@
82958292 'lqt-summary' => 'Sažetak',
82968293 'lqt-searching' => 'Pretražujem teme',
82978294 'lqt-read-message' => 'Označi kao pročitano',
8298 - 'lqt-read-message-tooltip' => 'Ukloni ovu temu iz novih poruka.
 8295+ 'lqt-read-message-tooltip' => 'Ukloni ovu temu iz novih poruka.
82998296 Ona će još uvijek biti vidljiva na njenoj stranici za razgovor.',
83008297 'lqt-read-all' => 'Označi sve pročitanim',
8301 - 'lqt-read-all-tooltip' => 'Uklonite sve teme iz novih poruke.
8302 -One će još uvijek biti vidljive na njihove izvornim stranicama za razgovor.
 8298+ 'lqt-read-all-tooltip' => 'Uklonite sve teme iz novih poruke.
 8299+One će još uvijek biti vidljive na njihove izvornim stranicama za razgovor.
83038300 Ovu operaciju je moguće povratiti.',
83048301 'lqt-marked-read' => "Tema '''$1''' označena je pročitanom.",
83058302 'lqt-count-marked-read' => '$1 {{PLURAL:$1|poruka označena je pročitanom|poruke označene su pročitanima|poruka označene su pročitanima}}.',
@@ -8330,8 +8327,8 @@
83318328 'lqt-split-submit' => 'Razdvoji',
83328329 'lqt_split_badsubject' => 'Tema koju ste unijeli nije ispravna.',
83338330 'lqt-no-threads' => 'Na ovoj stranici još uvijek ne postoji rasprava.',
8334 - 'lqt-delete-parent-warning' => 'Ovo je najviši-nivo teme s njenim odgovorima.
8335 -Odgovori će također biti automatski obrisani.
 8331+ 'lqt-delete-parent-warning' => 'Ovo je najviši-nivo teme s njenim odgovorima.
 8332+Odgovori će također biti automatski obrisani.
83368333 Kako bi to izbjegli, podijelite ih iz ove teme prije nego ju obrišete.',
83378334 'lqt-delete-parent-deleted' => 'Tema "roditelj" je obrisana ($1)',
83388335 'lqt-delete-replies-done' => 'Svi odgovori ove teme također su obrisani.',
@@ -8378,12 +8375,12 @@
83798376 $7",
83808377 'lqt-enotif-reply' => "Pozdrav $1,
83818378
8382 -ovo je obavijest s {{SITENAME}} o novom odgovoru na '$2' na $5,
 8379+ovo je obavijest s {{SITENAME}} o novom odgovoru na '$2' na $5,
83838380 dan $3 u $4 od strane $8
83848381
83858382 Odgovor možete vidjeti ovdje <$6>
83868383
8387 -Odgovor glasi:
 8384+Odgovor glasi:
83888385 $7",
83898386 'lqt-quote-intro' => '$2 u $3, [[User:$1|$1]] je napisao:',
83908387 'lqt-quote' => 'Citiraj',
@@ -10382,8 +10379,8 @@
1038310380 'lqt-read-message-tooltip' => 'წაშალეთ ეს ტოტი თქვენი კონტროლის სიიდან.
1038410381 იგი მაინც დარჩება განხილვის თავდაპირველ გვერდზე.',
1038510382 'lqt-read-all' => 'მონიშნეთ ყველა, როგორც წაკითხული',
10386 - 'lqt-read-all-tooltip' => 'წაშალეთ ყველა ტოტი ახალი შეტყობინებების სიიდან.
10387 -ისინი ისევ დარჩებიან შესაბამის გვერდებზე.
 10383+ 'lqt-read-all-tooltip' => 'წაშალეთ ყველა ტოტი ახალი შეტყობინებების სიიდან.
 10384+ისინი ისევ დარჩებიან შესაბამის გვერდებზე.
1038810385 ამ მოქმედების გაუქმება შეუძლებელია.',
1038910386 'lqt-marked-read' => "ტოტი '''$1''' მონიშნულია როგორც წაკითხული.",
1039010387 'lqt-count-marked-read' => '$1 {{PLURAL:$1|შეტყობინება მონიშნულია|შეტყობინებები მონიშნულია}} როგორც წაკითხული.',
@@ -12036,7 +12033,7 @@
1203712034 $7',
1203812035 'lqt-enotif-reply' => 'Здраво $1,
1203912036
12040 -ова е известување од {{SITENAME}} дека на страницата $5 на $3 во $4 ч.
 12037+ова е известување од {{SITENAME}} дека на страницата $5 на $3 во $4 ч.
1204112038 е објавен одговор на „$2“ од страна на корисникот $8
1204212039
1204312040 Можете да го погледате на <$6>
@@ -13511,7 +13508,7 @@
1351213509 'lqt_protectedfromreply_link' => 'låst',
1351313510 'lqt_subject' => 'Emne:',
1351413511 'lqt_noreason' => 'Ingen grunn gitt.',
13515 - 'lqt_move_placeholder' => 'Denne tråden eksisterer kun for å vise at tråden $1 ble flyttet fra denne siden til en annen diskusjonsside.
 13512+ 'lqt_move_placeholder' => 'Denne tråden eksisterer kun for å vise at tråden $1 ble flyttet fra denne siden til en annen diskusjonsside.
1351613513 Denne flyttingen ble foretatt av $2 $3 $4.
1351713514 Denne tråden ligger nå på $5',
1351813515 'lqt_thread_deleted_for_sysops' => "Denne tråden har blitt '''slettet''' og er kun synlig for administratorer.",
@@ -15897,7 +15894,7 @@
1589815895 'lqt-enotif-newthread' => 'Привет, $1.
1589915896
1590015897 Это уведомление с сайта {{SITENAME}} о том, что $3 $4 на странице $5
15901 -участником $8 была создана новая ветка «$2»
 15898+участником $8 была создана новая ветка «$2»
1590215899
1590315900 Вы можете увидеть её по адресу <$6>
1590415901
@@ -16243,7 +16240,7 @@
1624416241 'lqt_protectedfromreply_link' => 'көмүскэммит',
1624516242 'lqt_subject' => 'Аата:',
1624616243 'lqt_noreason' => 'Төрүөтэ ыйыллыбатах.',
16247 - 'lqt_move_placeholder' => 'Бу салаа бүөтэ $1 салаа бу сирэйтэн көһөрүллүбүтүн көрдөрөр.
 16244+ 'lqt_move_placeholder' => 'Бу салаа бүөтэ $1 салаа бу сирэйтэн көһөрүллүбүтүн көрдөрөр.
1624816245 Көһөрүүнү $3 $4 сирэйгэ $2 кыттааччы оҥорбут. Онон салаа маннык буолбут $5.',
1624916246 'lqt_thread_deleted_for_sysops' => "Бу салаа '''сотуллубут''', дьаһабылларга эрэ костөр кыахтаах.",
1625016247 'lqt_thread_deleted' => 'Бу салаа сотуллубут.',
@@ -16256,7 +16253,7 @@
1625716254 'lqt_nosuchthread' => 'Ыйбыт салааҥ суох эбит.',
1625816255 'lqt_nosuchthread_title' => 'Маннык салаа суох',
1625916256 'lqt_threadrequired' => 'URL-га салааны ыйыахтааххын.',
16260 - 'lqt_move_movingthread' => '$1 көһөрүү.
 16257+ 'lqt_move_movingthread' => '$1 көһөрүү.
1626116258 Бу салаа $2 сорҕото буолар.',
1626216259 'lqt_move_torename' => "Салааны аатын уларытыаххын баҕарар буоллаххына, $1 уонна 'Аата' диэн түннүгү уларыт.",
1626316260 'lqt_move_torename_edit' => 'маны көннөр',
@@ -16279,7 +16276,7 @@
1628016277 'lqt_delete_show_checkbox' => 'Сотуллубут салаалары көрдөр',
1628116278 'lqt_talkpage_autocreate_summary' => 'Саҥа ырытыы сирэйэ бастакы этии оҥоһуллубутун кэннэ апатмаатынан оҥоһулунна.',
1628216279 'lqt_header_warning_big' => 'Маны эрэдээксийэлиигин $1.',
16283 - 'lqt_header_warning_after_big' => 'Ааттар биллэрии уонна киирии быһыытынан туттуллаллар.
 16280+ 'lqt_header_warning_after_big' => 'Ааттар биллэрии уонна киирии быһыытынан туттуллаллар.
1628416281 Эн маны оҥоруоххун сөп $2.',
1628516282 'lqt_header_warning_bold' => 'ырытар сирэй аата',
1628616283 'lqt_header_warning_new_discussion' => 'саҥа ырытыыны саҕалааһын',
@@ -16365,11 +16362,11 @@
1636616363 'lqt-enotif-subject-reply' => '{{SITENAME}} ырытыы — Хоруй: $1',
1636716364 'lqt-enotif-subject-newthread' => '{{SITENAME}} ырытыы — Саҥа салаа: $1',
1636816365 'lqt-enotif-newthread' => 'Дорообо, $1.
16369 -Бу $3 $4 {{SITENAME}} саайка баар $5 сирэйгэ «$2» диэн саҥа салаа үөскээбитин туһунан биллэрии.
 16366+Бу $3 $4 {{SITENAME}} саайка баар $5 сирэйгэ «$2» диэн саҥа салаа үөскээбитин туһунан биллэрии.
1637016367
1637116368 Бу аадырыска <$6> көрүөххүн сөп.',
1637216369 'lqt-enotif-reply' => 'Дорообо, $1.
16373 -Бу $3 $4 {{SITENAME}} саайка баар $5 сирэй «$2» салаатыгар саҥа хоруй баар буолбутун туһунан биллэрии.
 16370+Бу $3 $4 {{SITENAME}} саайка баар $5 сирэй «$2» салаатыгар саҥа хоруй баар буолбутун туһунан биллэрии.
1637416371
1637516372 Бу аадырыска <$6> көрүөххүн сөп.
1637616373
@@ -18382,7 +18379,7 @@
1838318380 'lqt_subject' => 'Tema:',
1838418381 'lqt_noreason' => 'Sebäp görkezilmedik.',
1838518382 'lqt_move_placeholder' => 'Bu tred , $1 trediniň bu sahypadan başga bir ýere geçirilendigini görkezýän ýer-saklaýjydyr.
18386 -Tred $4 $3 senesinde $2 tarapyndan geçirilipdir.
 18383+Tred $4 $3 senesinde $2 tarapyndan geçirilipdir.
1838718384 Tred häzirki wagtda $5 adresinde ýerleşýär.',
1838818385 'lqt_thread_deleted_for_sysops' => "Bu tred '''öçürilipdir''' we ony diňe administratorlar görüp bilýär.",
1838918386 'lqt_thread_deleted' => 'Bu tred öçürilipdir.',
@@ -18505,7 +18502,7 @@
1850618503
1850718504 Ony <$6> adresinde görüp bilersiňiz.",
1850818505 'lqt-enotif-reply' => "Salam $1,
18509 -Bu {{SITENAME}} saýtynyň uwedomleniýasydyr: $5 sahypasynda $4 $3 senesinde '$2' tredine täze bir jogap döredildi.
 18506+Bu {{SITENAME}} saýtynyň uwedomleniýasydyr: $5 sahypasynda $4 $3 senesinde '$2' tredine täze bir jogap döredildi.
1851018507
1851118508 Ony <$6> adresinde görüp bilersiňiz.",
1851218509 'lqt-quote-intro' => '$2, $3 senesinde [[User:$1|$1]] ýazdy:',
@@ -18775,13 +18772,13 @@
1877618773 Ang teksto ay:
1877718774 $7",
1877818775 'lqt-enotif-reply' => "Kumusta ka $1,
18779 -
18780 -Isa itong pabatid mula sa {{SITENAME}} na may isang bagong tugon sa '$2' na nasa $5,
18781 -na nalikha ni $8 noong $3 sa ganap na ika-$4.
1878218776
18783 -Makikita mo ito sa <$6>
 18777+Isa itong pabatid mula sa {{SITENAME}} na may isang bagong tugon sa '$2' na nasa $5,
 18778+na nalikha ni $8 noong $3 sa ganap na ika-$4.
1878418779
18785 -Ang teksto ng tugon ay:
 18780+Makikita mo ito sa <$6>
 18781+
 18782+Ang teksto ng tugon ay:
1878618783 $7",
1878718784 'lqt-quote-intro' => 'Noong $2 noong $3, si [[User:$1|$1]] ang nagsulat ng:',
1878818785 'lqt-quote' => 'Sipi',
Property changes on: branches/extensions-realtime/LiquidThreads
___________________________________________________________________
Modified: svn:mergeinfo
1878918786 Merged /trunk/extensions/LiquidThreads:r94187-94267
Property changes on: branches/extensions-realtime/WikiTweet
___________________________________________________________________
Modified: svn:mergeinfo
1879018787 Merged /trunk/extensions/WikiTweet:r94187-94267
Property changes on: branches/extensions-realtime/ArticleFeedback/api/ApiArticleFeedback.php
___________________________________________________________________
Modified: svn:mergeinfo
1879118788 Merged /trunk/extensions/ArticleFeedback/api/ApiArticleFeedback.php:r94187-94267
Property changes on: branches/extensions-realtime/ArticleFeedback/api/ApiQueryArticleFeedback.php
___________________________________________________________________
Modified: svn:mergeinfo
1879218789 Merged /trunk/extensions/ArticleFeedback/api/ApiQueryArticleFeedback.php:r94187-94267
Index: branches/extensions-realtime/PrefSwitch/PrefSwitch.hooks.php
@@ -43,8 +43,8 @@
4444 */
4545 public static function personalUrls( &$personal_urls, &$title ) {
4646 global $wgUser, $wgRequest, $wgPrefSwitchShowLinks;
47 - if(!$wgPrefSwitchShowLinks) {
48 - return true;
 47+ if ( !$wgPrefSwitchShowLinks ) {
 48+ return true;
4949 }
5050
5151 // Figure out the orgin to include in the link
Property changes on: branches/extensions-realtime/Gadgets/Gadgets_body.php
___________________________________________________________________
Modified: svn:mergeinfo
5252 Merged /trunk/extensions/Gadgets/Gadgets_body.php:r94187-94267
Property changes on: branches/extensions-realtime/SelectCategory
___________________________________________________________________
Modified: svn:mergeinfo
5353 Merged /trunk/extensions/SelectCategory:r94187-94267
Index: branches/extensions-realtime/UploadWizard/test/jasmine/SpecRunner.html
@@ -12,9 +12,9 @@
1313
1414 <script type="text/javascript" src="../../../../resources/mediawiki/mediawiki.js"></script>
1515 <script type="text/javascript" src="../../../../resources/mediawiki.language/mediawiki.language.js"></script>
 16+ <script type="text/javascript" src="../../../../resources/mediawiki/mediawiki.Uri.js"></script>
1617 <script type="text/javascript" src="../../resources/mediawiki.language.parser.js"></script>
1718 <script type="text/javascript" src="../../resources/mw.Utilities.js"></script>
18 - <script type="text/javascript" src="../../resources/mw.Uri.js"></script>
1919 <script type="text/javascript" src="../../resources/mw.Api.js"></script>
2020 <script type="text/javascript" src="../../resources/mw.Api.edit.js"></script>
2121 <script type="text/javascript" src="../../resources/mw.Title.js"></script>
@@ -25,7 +25,6 @@
2626
2727
2828 <!-- include spec files here... -->
29 - <script type="text/javascript" src="spec/mw.Uri.spec.js"></script>
3029 <script type="text/javascript" src="spec/mw.Api.spec.js"></script>
3130 <script type="text/javascript" src="spec/mw.Api.edit.spec.js"></script>
3231
Index: branches/extensions-realtime/UploadWizard/test/jasmine/spec/mw.Api.edit.spec.js
@@ -17,9 +17,9 @@
1818 // TODO this only works for me (NeilK)
1919 var wgScriptPath = '/w';
2020
21 - var pageUri = new mw.uri( window.location );
 21+ var pageUri = new mw.Uri( window.location );
2222
23 - var apiUrl = new mw.uri( {
 23+ var apiUrl = new mw.Uri( {
2424 protocol: pageUri.protocol,
2525 host: pageUri.host,
2626 path: wgScriptPath + '/api.php'
Index: branches/extensions-realtime/UploadWizard/UploadWizardHooks.php
@@ -24,7 +24,7 @@
2525 'jquery.suggestions',
2626 'jquery.ui.widget',
2727 'mediawiki.language',
28 - 'mediawiki.uri',
 28+ 'mediawiki.Uri',
2929 'mediawiki.util',
3030 'mediawiki.libs.jpegmeta',
3131 'ext.uploadwizard.mediawiki.language.parser',
Index: branches/extensions-realtime/UploadWizard/resources/mw.Api.js
@@ -37,7 +37,7 @@
3838 },
3939
4040 ajax: {
41 - // force toString if we got a mw.uri object
 41+ // force toString if we got a mw.Uri object
4242 url: new String( this.url ),
4343
4444 /* default function for success and no API error */
Property changes on: branches/extensions-realtime/UploadWizard/resources/mw.LanguageUpWiz.js
___________________________________________________________________
Modified: svn:mergeinfo
4545 Merged /trunk/extensions/UploadWizard/resources/mw.LanguageUpWiz.js:r94187-94267
Property changes on: branches/extensions-realtime/UploadWizard
___________________________________________________________________
Modified: svn:mergeinfo
4646 Merged /trunk/extensions/UploadWizard:r94187-94267
Property changes on: branches/extensions-realtime/SVGZoom
___________________________________________________________________
Modified: svn:mergeinfo
4747 Merged /trunk/extensions/SVGZoom:r94187-94267
Property changes on: branches/extensions-realtime/CentralAuth/specials/SpecialWikiSets.php
___________________________________________________________________
Modified: svn:mergeinfo
4848 Merged /trunk/extensions/CentralAuth/specials/SpecialWikiSets.php:r94187-94267
Property changes on: branches/extensions-realtime/FlaggedRevs
___________________________________________________________________
Modified: svn:mergeinfo
4949 Merged /trunk/extensions/FlaggedRevs:r94187-94267
Property changes on: branches/extensions-realtime/FundraiserPortal
___________________________________________________________________
Modified: svn:mergeinfo
5050 Merged /trunk/extensions/FundraiserPortal:r94187-94267
Index: branches/extensions-realtime/ArchiveLinks/ArchiveLinks.class.php
@@ -42,8 +42,6 @@
4343 $old_id = $article->getTitle();
4444 $old_id = $old_id->getPreviousRevisionID( $page_id );
4545
46 - die('firing');
47 -
4846 $db_result['links_on_page'] = $db_master->select( 'el_archive_link_history', '*', array( 'hist_page_id' => $page_id ), __METHOD__ );
4947
5048 $old_external_links = array();
@@ -68,96 +66,56 @@
6967
7068 if ( count( $new_external_links ) <= $wgArchiveLinksConfig['link_insert_max'] ) {
7169 //insert the links into the queue now
72 - foreach( $new_external_links as $link ) {
73 - $this->feed_insert_links( $link );
74 -
75 - /*
 70+ foreach( $new_external_links as $link ) {
 71+ $db_result['queue'] = $db_slave->select( 'el_archive_queue', '*', array( 'url' => $link ), __METHOD__, array( 'LIMIT' => '1', ) );
 72+ $db_result['blacklist'] = $db_slave->select( 'el_archive_blacklist', '*', array( 'bl_url' => $link ), __METHOD__, array( 'LIMIT' => '1', ) );
7673
77 -
78 - /*
79 -
80 - } elseif ( $db_result['history-row']['hist_insertion_time'] >= $time - $wgArchiveLinksConfig['global_rearchive_time'] ) {
81 - $db_result['history_page'] = $db_slave->select( 'el_archive_link_history', '*', array( 'hist_url' => $link, 'page_id' => $page_id ), __METHOD__, array( 'LIMIT' => '1', 'ORDER BY' => 'hist_id DESC' ) );
 74+ $db_result['queue-numrows'] = $db_result['queue']->numRows();
 75+ $db_result['blacklist-numrows'] = $db_result['blacklist']->numRows();
8276
83 - $db_result['history_page-numrows'] = $db_result['history_page']->numRows();
84 - $db_result['history_page-row'] = $db_result['history_page']->fetchRow();
 77+ if ( $db_result['blacklist-numrows'] === 0 && $db_result['queue-numrows'] === 0 ) {
 78+ $db_master->insert( 'el_archive_queue', array(
 79+ 'page_id' => $page_id,
 80+ 'url' => $link,
 81+ 'delay_time' => '0',
 82+ 'insertion_time' => $time,
 83+ 'in_progress' => '0',
 84+ ));
8585
86 - if ( $db_result['history_page-numrows'] === 0 && $db_result['history-row']['hist_insertion_time'] >= $time - $wgArchiveLinksConfig['previous_archive_lockout_time'] ) {
87 - //this link is new to this particular page but has been archived on another page less than the rearchive delay
88 - //grab a new version of it in case the content has changed
89 - $db_master->insert( 'el_archive_queue', array(
90 - 'page_id' => $page_id,
91 - 'url' => $link,
92 - 'delay_time' => '0',
93 - 'insertion_time' => $time,
94 - 'in_progress' => '0',
95 - ));
96 -
97 - $db_master->insert( 'el_archive_link_history', array(
98 - 'page_id' => $page_id,
99 - 'url' => $link,
100 - 'delay_time' => '0',
101 - 'insertion_time' => $time,
102 - 'in_progress' => '0',
103 - ));
104 -
105 - }
106 -
107 - if ( $db_result['history_page-row']['insertion_time'] >= $time - $wgArchiveLinksConfig['page_rearchive_time']) {
108 -
109 - }
110 - }*/
 86+ $db_master->insert( 'el_archive_link_history', array(
 87+ 'hist_page_id' => $page_id,
 88+ 'hist_url' => $link,
 89+ 'hist_insertion_time' => $time,
 90+ ));
 91+ }
11192 }
11293 } else {
11394 //insert everything as a job and do the work later to avoid lagging page save
11495 }
11596
11697 } else {
117 -
11898 foreach ( $external_links as $link => $unused_value ) {
119 - $link = $db_slave->strencode( $link );
 99+ //$db_result['resource'] = $db_slave->select( 'el_archive_resource', '*', '`el_archive_resource`.`resource_url` = "' . $db_slave->strencode( $link ) . '"');
 100+ $db_result['blacklist'] = $db_slave->select( 'el_archive_blacklist', '*', array( 'bl_url' => $link ), __METHOD__ );
 101+ $db_result['queue'] = $db_slave->select( 'el_archive_queue', '*', array( 'url' => $link ), __METHOD__ );
120102
121 - if ( $wgArchiveLinksConfig['generate_feed'] === true ) {
122 -
123 -
124 -
125 - /*$diff_eng = new DifferenceEngine( null, $old_id, $page_id, null, false );
126 -
127 - $diff = $diff_eng->getDiffBody();
128 - die( var_dump($diff) );
129 - */
130 -
131 - //file_put_contents('stf.txt', var_export( $diff, TRUE ) );
132 -
133 - /*
134 - * Querying the db server with selects for every link on the page would potentially be a whole bunch of unnecessary load
135 - * Let's take the diff first then do it on a job instead...
136 - *
137 -*/
138 -
139 - } else {
140 - //$db_result['resource'] = $db_slave->select( 'el_archive_resource', '*', '`el_archive_resource`.`resource_url` = "' . $db_slave->strencode( $link ) . '"');
141 - $db_result['blacklist'] = $db_slave->select( 'el_archive_blacklist', '*', array( 'bl_url' => $link ), __METHOD__ );
142 - $db_result['queue'] = $db_slave->select( 'el_archive_queue', '*', array( 'url' => $link ), __METHOD__ );
143 -
144 - if ( $db_result['blacklist']->numRows() === 0 ) {
145 - if ( $db_result['queue']->numRows() === 0 ) {
146 - // this probably a first time job
147 - // but we should check the logs and resource table
148 - // to make sure
149 - $db_master->insert( 'el_archive_queue', array (
150 - 'page_id' => $page_id,
151 - 'url' => $link,
152 - 'delay_time' => '0',
153 - 'insertion_time' => $time,
154 - 'in_progress' => '0',
155 - ));
156 - } else {
157 - //this job is already in the queue, why?
158 - // * most likely reason is it has already been inserted by another page
159 - // * or we are checking it later because the site was down at last archival
160 - // in either case we don't really need to do anything right now, so skip...
161 - }
 103+ if ( $db_result['blacklist']->numRows() === 0 ) {
 104+ if ( $db_result['queue']->numRows() === 0 ) {
 105+ // this probably a first time job
 106+ // but we should check the logs and resource table
 107+ // to make sure
 108+ $db_master->insert( 'el_archive_queue', array (
 109+ 'page_id' => $page_id,
 110+ 'url' => $link,
 111+ 'delay_time' => '0',
 112+ 'insertion_time' => $time,
 113+ 'in_progress' => '0',
 114+ ));
 115+ } else {
 116+ //this job is already in the queue, why?
 117+ // * most likely reason is it has already been inserted by another page
 118+ // * or we are checking it later because the site was down at last archival
 119+ // in either case we don't really need to do anything right now, so skip...
162120 }
163121 }
164122 }
@@ -207,36 +165,6 @@
208166 }
209167 }
210168
211 - public function feed_insert_links ( $url, $escaped = false ) {
212 - if ( !$escaped ) {
213 - $url = $this->strencode( $url );
214 - }
215 -
216 - $db_result['queue'] = $db_slave->select( 'el_archive_queue', '*', array( 'url' => $link ), __METHOD__, array( 'LIMIT' => '1', ) );
217 - $db_result['blacklist'] = $db_slave->select( 'el_archive_blacklist', '*', array( 'bl_url' => $link ), __METHOD__, array( 'LIMIT' => '1', ) );
218 -
219 - $db_result['queue-numrows'] = $db_result['queue']->numRows();
220 - $db_result['blacklist-numrows'] = $db_result['blacklist']->numRows();
221 -
222 - if ( $db_result['blacklist-numrows'] === 0 && $db_result['queue-numrows'] === 0 ) {
223 - $db_master->insert( 'el_archive_queue', array(
224 - 'page_id' => $page_id,
225 - 'url' => $link,
226 - 'delay_time' => '0',
227 - 'insertion_time' => $time,
228 - 'in_progress' => '0',
229 - ));
230 -
231 - $db_master->insert( 'el_archive_link_history', array(
232 - 'page_id' => $page_id,
233 - 'url' => $link,
234 - 'delay_time' => '0',
235 - 'insertion_time' => $time,
236 - 'in_progress' => '0',
237 - ));
238 - }
239 - }
240 -
241169 public static function schemaUpdates ( $updater = null ) {
242170 $path = dirname( __FILE__ );
243171 $updater->addExtensionUpdate( array(
Index: branches/extensions-realtime/JSKit/JSKit.php
@@ -163,10 +163,10 @@
164164 }
165165
166166 # Appends the javascript
167 -function efJSKit(&$out, &$text) {
168 - global $wgJSKitNamespaces, $wgJSKitAlways, $wgTitle;
169 - $ns = $wgTitle->getNamespace();
170 - if( !$wgTitle->getArticleId() ) {
 167+function efJSKit( $out, &$text ) {
 168+ global $wgJSKitNamespaces, $wgJSKitAlways;
 169+ $ns = $out->getTitle()->getNamespace();
 170+ if( !$out->getTitle()->getArticleId() ) {
171171 // special page or wrong namespace, so don't do anything
172172 return true;
173173 }
Index: branches/extensions-realtime/WikimediaIncubator/IncubatorTest.php
@@ -631,6 +631,11 @@
632632 return true;
633633 }
634634
 635+ /**
 636+ * Make the page content language depend on the test wiki
 637+ * Only works for codes that are known to MediaWiki :(
 638+ * @return true
 639+ */
635640 static function onPageContentLanguage( $title, &$pageLang ) {
636641 global $wmincTestWikiNamespaces, $wgOut;
637642 $prefix = self::analyzePrefix( $title->getText(), /* onlyInfoPage*/ false );
Property changes on: branches/extensions-realtime/ConditionalShowSection
___________________________________________________________________
Modified: svn:mergeinfo
638643 Merged /trunk/extensions/ConditionalShowSection:r94187-94267
Index: branches/extensions-realtime/SemanticSignup/SemanticSignup.php
@@ -0,0 +1,74 @@
 2+<?php
 3+
 4+/**
 5+ * Initialization file for the Semantic Signup extension.
 6+ *
 7+ * Documentation: http://www.mediawiki.org/wiki/Extension:SemanticSignup
 8+ * Support http://www.mediawiki.org/wiki/Extension_talk:SemanticSignup
 9+ * Source code: http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/SemanticSignup
 10+ *
 11+ * @file SemanticSignup.php
 12+ * @ingroup SemanticSignup
 13+ *
 14+ * @licence GNU GPL v3+
 15+ * @author Jeroen De Dauw < jeroendedauw@gmail.com >
 16+ */
 17+
 18+/**
 19+ * This documenation group collects source code files belonging to SemanticSignup.
 20+ *
 21+ * @defgroup SemanticSignup SemanticSignup
 22+ */
 23+
 24+if ( !defined( 'MEDIAWIKI' ) ) {
 25+ die( 'Not an entry point.' );
 26+}
 27+
 28+if ( version_compare( $wgVersion, '1.16', '<' ) ) {
 29+ die( '<b>Error:</b> SemanticSignup requires MediaWiki 1.16 or above.' );
 30+}
 31+
 32+// Show a warning if Semantic MediaWiki is not loaded.
 33+if ( !defined( 'SMW_VERSION' ) ) {
 34+ die( '<b>Error:</b> You need to have <a href="http://semantic-mediawiki.org/wiki/Semantic_MediaWiki">Semantic MediaWiki</a> installed in order to use SemanticSignup.' );
 35+}
 36+
 37+if ( version_compare( SMW_VERSION, '1.6 alpha', '<' ) ) {
 38+ die( '<b>Error:</b> Semantic Signup requires Semantic MediaWiki 1.6 or above.' );
 39+}
 40+
 41+if ( !defined( 'SF_VERSION' ) ) {
 42+ die( '<b>Error:</b> You need to have <a href="http://semantic-mediawiki.org/wiki/Semantic_Forms">Semantic Forms</a> installed in order to use SemanticSignup.' );
 43+}
 44+
 45+define( 'SemanticSignup_VERSION', '0.3 alpha' );
 46+
 47+$wgExtensionCredits[defined( 'SEMANTIC_EXTENSION_TYPE' ) ? 'semantic' : 'specialpage'][] = array(
 48+ 'path' => __FILE__,
 49+ 'name' => 'SemanticSignup',
 50+ 'version' => SemanticSignup_VERSION,
 51+ 'author' => array(
 52+ 'Serg Kutny',
 53+ '[http://www.mediawiki.org/wiki/User:Jeroen_De_Dauw Jeroen De Dauw]',
 54+ ),
 55+ 'url' => 'http://www.mediawiki.org/wiki/Extension:Semantic_Watchlist',
 56+ 'descriptionmsg' => 'ses-desc'
 57+);
 58+
 59+$wgExtensionMessagesFiles['SemanticSignup'] = dirname( __FILE__ ) . '/SemanticSignup.i18n.php';
 60+$wgExtensionAliasesFiles['SemanticSignup'] = dirname( __FILE__ ) . '/SemanticSignup.i18n.aliases.php';
 61+
 62+$wgAutoloadClasses['SemanticSignupSettings'] = dirname( __FILE__ ) . '/SemanticSignup.settings.php';
 63+$wgAutoloadClasses['SemanticSignupHooks'] = dirname( __FILE__ ) . '/SemanticSignup.hooks.php';
 64+$wgAutoloadClasses['SemanticSignup'] = dirname( __FILE__ ) . '/includes/SES_Special.php';
 65+$wgAutoloadClasses['SES_UserAccountDataChecker'] = dirname( __FILE__ ) . '/includes/SES_Special.php';
 66+$wgAutoloadClasses['SES_DataChecker'] = dirname( __FILE__ ) . '/includes/SES_Utils.php';
 67+$wgAutoloadClasses['SES_SignupFields'] = dirname( __FILE__ ) . '/includes/SES_SignupFields.php';
 68+$wgAutoloadClasses['CreateUserFieldsTemplate'] = dirname( __FILE__ ) . '/includes/SES_SignupFields.php';
 69+
 70+$wgSpecialPages['SemanticSignup'] = 'SemanticSignup';
 71+
 72+$egSemanticSignupSettings = array();
 73+
 74+$wgHooks['UserCreateForm'][] = 'SemanticSignupHooks::onUserCreateForm';
 75+$wgHooks['ParserFirstCallInit'][] = 'SemanticSignupHooks::onParserFirstCallInit';
Property changes on: branches/extensions-realtime/SemanticSignup/SemanticSignup.php
___________________________________________________________________
Added: svn:eol-style
176 + native
Index: branches/extensions-realtime/SemanticSignup/SemanticSignup.hooks.php
@@ -0,0 +1,47 @@
 2+<?php
 3+
 4+/**
 5+ * Static class for hooks handled by the SemanticSignup extension.
 6+ *
 7+ * @since 0.3
 8+ *
 9+ * @file SemanticSignup.hooks.php
 10+ * @ingroup SemanticSignup
 11+ *
 12+ * @licence GNU GPL v3+
 13+ * @author Jeroen De Dauw < jeroendedauw@gmail.com >
 14+ */
 15+final class SemanticSignupHooks {
 16+
 17+ /**
 18+ * @since 0.3
 19+ *
 20+ * @param $template
 21+ *
 22+ * @return false
 23+ */
 24+ public static function onUserCreateForm( $template ) {
 25+ if ( is_null( Title::newFromText( SemanticSignupSettings::get( 'formName' ), SF_NS_FORM ) ) ) {
 26+ return true;
 27+ }
 28+
 29+ $semantic_signup_title = SemanticSignup::getTitleFor( 'SemanticSignup' );
 30+ $url = $semantic_signup_title->escapeFullURL();
 31+ global $wgOut;
 32+ $wgOut->redirect( $url );
 33+
 34+ return false;
 35+ }
 36+
 37+ /**
 38+ * @since 0.3
 39+ *
 40+ * @return true
 41+ */
 42+ public static function onParserFirstCallInit() {
 43+ global $wgParser;
 44+// $wgParser->setHook( 'signupfields', 'SES_SignupFields::render' );
 45+ return true;
 46+ }
 47+
 48+}
Property changes on: branches/extensions-realtime/SemanticSignup/SemanticSignup.hooks.php
___________________________________________________________________
Added: svn:eol-style
149 + native
Index: branches/extensions-realtime/SemanticSignup/INSTALL
@@ -0,0 +1,45 @@
 2+These is the install file for the SemanticSignup extension.
 3+
 4+Extension page on mediawiki.org: http://www.mediawiki.org/wiki/Extension:SemanticSignup
 5+Latest version of the install file: http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/SemanticSignup/INSTALL?view=co
 6+
 7+
 8+== Requirements ==
 9+
 10+SemanticSignup requires:
 11+
 12+* MediaWiki 1.16 or above
 13+* Semantic MediaWiki 1.6 or above
 14+* Semantic Forms 2.0 or above
 15+* PHP 5.2 or above
 16+
 17+== Download ==
 18+
 19+You can find the current version of SemanticSignup on the [https://code.google.com/p/semanticsignup/downloads/list Google Code download page],
 20+as well as a [https://code.google.com/p/semanticsignup/downloads/list?can=1 list of legacy downloads].
 21+
 22+You can also get the code directly from SVN. Tags can be obtained via
 23+
 24+ svn checkout <nowiki>http://svn.wikimedia.org/svnroot/mediawiki/tags/extensions/SemanticSignup/REL_version</nowiki>
 25+
 26+Where 'version' is the version number of the tag, such as 0_1 (see the [http://svn.wikimedia.org/svnroot/mediawiki/tags/extensions/SemanticSignup/ available tags]).
 27+The latest code can be obtained from trunk:
 28+
 29+ svn checkout <nowiki>http://svn.wikimedia.org/svnroot/mediawiki/trunk/extensions/SemanticSignup/</nowiki>
 30+
 31+== Installation ==
 32+
 33+Once you have downloaded the code, place the ''SemanticSignup'' directory within your MediaWiki
 34+'extensions' directory. Then add the following code to your [[Manual:LocalSettings.php|LocalSettings.php]] file:
 35+
 36+# SemanticSignup
 37+require_once( "$IP/extensions/SemanticSignup/SemanticSignup.php" );
 38+
 39+== Configuration ==
 40+
 41+Configuration of SemanticSignup is done by adding simple PHP statements to your
 42+[[Manual:LocalSettings.php|LocalSettings.php]] file. These statements need to be placed
 43+AFTER the inclusion of SemanticSignup. The options are listed below and their default
 44+is set in the [http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/SemanticSignup/SemanticSignup.settings.php?view=markup SemanticSignup settings file].
 45+You should NOT modify the settings file, but can have a look at it to get an idea of
 46+how to use the settings, in case the below descriptions do not suffice.
Index: branches/extensions-realtime/SemanticSignup/includes/SES_Special.php
@@ -0,0 +1,334 @@
 2+<?php
 3+
 4+/**
 5+ * Created on 7 Jan 2008 by Serhii Kutnii
 6+ */
 7+class SES_UserAccountDataChecker extends SES_DataChecker {
 8+
 9+ public $mUsername = '';
 10+ public $mPassword = '';
 11+ public $mEmail = '';
 12+ public $mRealname = '';
 13+ public $mDomain = '';
 14+ public $mLanguage = '';
 15+ public $mRemember = false;
 16+ public $mUser = null;
 17+
 18+ protected function populateData() {
 19+ $this->mUsername = $this->getUserDataValue( 'wpName', 'nousername' );
 20+ $name = trim( $this->mUsername );
 21+ $this->mUser = User::newFromName( $name, 'creatable' );
 22+ if ( !$this->mUser ) {
 23+ $this->error( wfMsg( 'noname' ) );
 24+ }
 25+
 26+ global $sesRealNameRequired;
 27+ $this->mRealname = $this->getUserDataValue('wpRealName', $sesRealNameRequired ? 'norealname' : null);
 28+
 29+ $this->mPassword = $this->getUserDataValue('wpPassword');
 30+ $retype = $this->getUserDataValue('wpRetype');
 31+ if (strcmp($this->mPassword, $retype))
 32+ $this->error(wfMsg('nopwdmatch'));
 33+
 34+ $this->mDomain = $this->getUserDataValue('wpDomain');
 35+
 36+ global $wgEmailConfirmToEdit;
 37+ $this->mEmail = $this->getUserDataValue('wpEmail', $wgEmailConfirmToEdit ? 'noemailtitle' : null );
 38+
 39+ $this->mLanguage = $this->getUserDataValue('uselang');
 40+
 41+ global $wgRequest;
 42+ $this->mRemember = $wgRequest->getCheck('wpRemember');
 43+ }
 44+
 45+ //Checks
 46+
 47+ public function checkDomainValidity()
 48+ {
 49+ global $wgAuth;
 50+
 51+ if( !$wgAuth->validDomain( $this->mDomain ) )
 52+ $this->error(wfMsg('wrongpassword'));
 53+ }
 54+
 55+ public function checkDomainUser()
 56+ {
 57+ global $wgAuth;
 58+
 59+ if( ('local' != $this->mDomain) && ('' != $this->mDomain)
 60+ && !$wgAuth->canCreateAccounts() && ( !$wgAuth->userExists($this->mName) || !$wgAuth->authenticate($this->mName, $this->mPassword) ) )
 61+ $this->error(wfMsg('wrongpassword'));
 62+ }
 63+
 64+ public function checkCreatePermissions()
 65+ {
 66+ global $wgUser;
 67+
 68+ if (!$wgUser->isAllowed( 'createaccount' ) || $wgUser->isBlockedFromCreateAccount() )
 69+ $this->error(wfMsg('createforbidden'));
 70+ }
 71+
 72+ public function checkSorbs()
 73+ {
 74+ global $wgProxyWhitelist;
 75+ global $wgEnableSorbs;
 76+ $ip = wfGetIP();
 77+ if ( $wgEnableSorbs && !in_array( $ip, $wgProxyWhitelist ) &&
 78+ $wgUser->inSorbsBlacklist( $ip ) )
 79+ $this->error(wfMsg('sorbs_create_account_reason'));
 80+ }
 81+
 82+ public function checkUserExists()
 83+ {
 84+ if ($this->mUser->idForName())
 85+ $this->error(wfMsg('userexists'));
 86+ }
 87+
 88+ public function checkPasswordLength()
 89+ {
 90+ if (!$this->mUser->isValidPassword($this->mPassword))
 91+ {
 92+ global $wgMinimalPasswordLength;
 93+ $this->error(wfMsgExt('passwordtooshort', array( 'parsemag' ), $wgMinimalPasswordLength));
 94+ }
 95+ }
 96+
 97+ public function checkEmailValidity()
 98+ {
 99+ global $wgEnableEmail;
 100+ if ($wgEnableEmail && !User::isValidEmailAddr($this->mEmail))
 101+ $this->error(wfMsg('invalidemailaddress'));
 102+ }
 103+
 104+ public function __construct()
 105+ {
 106+ $this->addCheck(array(&$this, 'checkDomainValidity'), array());
 107+ $this->addCheck(array(&$this, 'checkDomainUser'), array());
 108+ $this->addCheck(array(&$this, 'checkCreatePermissions'), array());
 109+ $this->addCheck(array(&$this, 'checkSorbs'), array());
 110+ $this->addCheck(array(&$this, 'checkUserExists'), array());
 111+ $this->addCheck(array(&$this, 'checkPasswordLength'), array());
 112+ $this->addCheck(array(&$this, 'checkEmailValidity'), array());
 113+ }
 114+ }
 115+
 116+ class SemanticSignup extends SpecialPage
 117+ {
 118+ private $mUserDataChecker = null;
 119+ private $mUserPageUrl = '';
 120+
 121+ public function __construct()
 122+ {
 123+ parent::__construct('SemanticSignup');
 124+ $this->mIncludable = false;
 125+
 126+ $this->mUserDataChecker = new SES_UserAccountDataChecker();
 127+ }
 128+
 129+ private function userSignup()
 130+ {
 131+ //Get user input and check the environment
 132+ $this->mUserDataChecker->run();
 133+
 134+ //Throw if data getting or environment checks have failed which indicates that account creation is impossible
 135+ $checker_error = $this->mUserDataChecker->getError();
 136+ if ($checker_error)
 137+ throw new Exception($checker_error);
 138+
 139+ $user = $this->mUserDataChecker->mUser;
 140+
 141+ $user->setEmail( $this->mUserDataChecker->mEmail );
 142+ $user->setRealName( $this->mUserDataChecker->mRealname );
 143+
 144+ $abortError = '';
 145+ if( !wfRunHooks( 'AbortNewAccount', array( $user, &$abortError ) ) )
 146+ {
 147+ // Hook point to add extra creation throttles and blocks
 148+ wfDebug( "LoginForm::addNewAccountInternal: a hook blocked creation\n" );
 149+ throw new Exception( $abortError );
 150+ }
 151+
 152+ global $wgAccountCreationThrottle;
 153+ global $wgUser;
 154+ if ( $wgAccountCreationThrottle && $wgUser->isPingLimitable() )
 155+ {
 156+ $key = wfMemcKey( 'acctcreate', 'ip', wfGetIP() );
 157+ $value = $wgMemc->incr( $key );
 158+
 159+ if ( !$value ) {
 160+ $wgMemc->set( $key, 1, 86400 );
 161+ }
 162+
 163+ if ( $value > $wgAccountCreationThrottle )
 164+ throw new Exception(wfMsg('throttlehit'));
 165+ }
 166+
 167+ global $wgAuth;
 168+
 169+ if( !$wgAuth->addUser( $user, $this->mUserDataChecker->mPassword,
 170+ $this->mUserDataChecker->mEmail, $this->mUserDataChecker->mRealname ) )
 171+ throw new Exception('externaldberror');
 172+
 173+ $user->addToDatabase();
 174+
 175+ if ( $wgAuth->allowPasswordChange() )
 176+ {
 177+ $user->setPassword($this->mUserDataChecker->mPassword);
 178+ }
 179+
 180+ $user->setToken();
 181+
 182+ $wgAuth->initUser( $user, false );
 183+
 184+ $user->setOption( 'rememberpassword', $this->mUserDataChecker->mRemember ? 1 : 0 );
 185+ $user->saveSettings();
 186+
 187+ # Update user count
 188+ $ssUpdate = new SiteStatsUpdate( 0, 0, 0, 0, 1 );
 189+ $ssUpdate->doUpdate();
 190+
 191+ global $wgLoginLanguageSelector;
 192+ $language = $this->mUserDataChecker->mLanguage;
 193+ if( $wgLoginLanguageSelector && $language )
 194+ $user->setOption( 'language', $language );
 195+
 196+ global $wgEmailAuthentication;
 197+ if( $wgEmailAuthentication && User::isValidEmailAddr( $user->getEmail() ) ){
 198+ $err = $user->sendConfirmationMail();
 199+ if (WikiError::isError($err))
 200+ throw new Exception(wfMsg('emailfailed'));
 201+ }
 202+
 203+ $user->saveSettings();
 204+ wfRunHooks('AddNewAccount', array($user));
 205+ }
 206+
 207+ private function createUserPage() {
 208+ $form_title = Title::newFromText( SemanticSignupSettings::get( 'formName' ), SF_NS_FORM );
 209+ $form = new Article($form_title);
 210+ $form_definition = $form->getContent();
 211+
 212+ $page_title = Title::newFromText($this->mUserDataChecker->mUser->getName(), NS_USER);
 213+ $this->mUserPageUrl = $page_title->escapeFullUrl();
 214+
 215+ global $sfgFormPrinter;
 216+ list ($form_text, $javascript_text, $data_text, $form_page_title, $generated_page_name) =
 217+ $sfgFormPrinter->formHTML($form_definition, true, false);
 218+
 219+ $user_page = new Article($page_title);
 220+
 221+ global $wgUser;
 222+ $wgUser = $this->mUserDataChecker->mUser;
 223+ $user_page->doEdit( $data_text, '', EDIT_FORCE_BOT );
 224+ }
 225+
 226+ private function printForm() {
 227+ global $sesSignupBotName;
 228+ global $wgUser;
 229+
 230+ /*
 231+ * SemanticForms disable the form automatically if current user hasn't got edit rights
 232+ * so we have to use a bot account for the form request. Current user is being saved in
 233+ * the $old_user variable to be restored afterwards
 234+ */
 235+ $old_user = null;
 236+ if ($wgUser->isAnon())
 237+ {
 238+ $old_user = $wgUser;
 239+ $wgUser = User::newFromName($sesSignupBotName);
 240+ }
 241+
 242+ $form_title = Title::newFromText( SemanticSignupSettings::get( 'formName' ), SF_NS_FORM );
 243+ $form = new Article($form_title);
 244+ $form_definition = $form->getContent();
 245+
 246+ global $sfgFormPrinter;
 247+ list ($form_text, $javascript_text, $data_text, $form_page_title, $generated_page_name) =
 248+ $sfgFormPrinter->formHTML($form_definition, false, false);
 249+
 250+ $text =<<<END
 251+ <form name="createbox" onsubmit="return validate_all()" action="" method="post" class="createbox">
 252+END;
 253+ $text .= $form_text.'</form>';
 254+
 255+ global $sfgScriptPath, $sfgYUIBase, $wgOut;
 256+ $mainCssUrl = $sfgScriptPath . '/skins/SF_main.css';
 257+ $wgOut->addLink( array(
 258+ 'rel' => 'stylesheet',
 259+ 'type' => 'text/css',
 260+ 'media' => "screen, projection",
 261+ 'href' => $mainCssUrl
 262+ ));
 263+ $wgOut->addLink( array(
 264+ 'rel' => 'stylesheet',
 265+ 'type' => 'text/css',
 266+ 'media' => "screen, projection",
 267+ 'href' => $sfgYUIBase . "autocomplete/assets/skins/sam/autocomplete.css"
 268+ ));
 269+ $wgOut->addLink( array(
 270+ 'rel' => 'stylesheet',
 271+ 'type' => 'text/css',
 272+ 'media' => "screen, projection",
 273+ 'href' => $sfgScriptPath . '/skins/SF_yui_autocompletion.css'
 274+ ));
 275+ $wgOut->addLink( array(
 276+ 'rel' => 'stylesheet',
 277+ 'type' => 'text/css',
 278+ 'media' => "screen, projection",
 279+ 'href' => $sfgScriptPath . '/skins/floatbox.css'
 280+ ));
 281+ $wgOut->addScript('<script type="text/javascript" src="' . $sfgYUIBase . 'yahoo/yahoo-min.js"></script>' . "\n");
 282+ $wgOut->addScript('<script type="text/javascript" src="' . $sfgYUIBase . 'dom/dom-min.js"></script>' . "\n");
 283+ $wgOut->addScript('<script type="text/javascript" src="' . $sfgYUIBase . 'event/event-min.js"></script>' . "\n");
 284+ $wgOut->addScript('<script type="text/javascript" src="' . $sfgYUIBase . 'get/get-min.js"></script>' . "\n");
 285+ $wgOut->addScript('<script type="text/javascript" src="' . $sfgYUIBase . 'connection/connection-min.js"></script>' . "\n");
 286+ $wgOut->addScript('<script type="text/javascript" src="' . $sfgYUIBase . 'json/json-min.js"></script>' . "\n");
 287+ $wgOut->addScript('<script type="text/javascript" src="' . $sfgYUIBase . 'datasource/datasource-min.js"></script>' . "\n");
 288+ $wgOut->addScript('<script type="text/javascript" src="' . $sfgYUIBase . 'autocomplete/autocomplete-min.js"></script>' . "\n");
 289+ $wgOut->addScript('<script type="text/javascript" src="' . $sfgScriptPath . '/libs/SF_yui_autocompletion.js"></script>' . "\n");
 290+ $wgOut->addScript('<script type="text/javascript" src="' . $sfgScriptPath . '/libs/floatbox.js"></script>' . "\n");
 291+
 292+ global $wgFCKEditorDir;
 293+ if ($wgFCKEditorDir)
 294+ $wgOut->addScript('<script type="text/javascript" src="' . "$wgScriptPath/$wgFCKEditorDir" . '/fckeditor.js"></script>' . "\n");
 295+ if (! empty($javascript_text))
 296+ $wgOut->addScript(' <script type="text/javascript">' . "\n" . $javascript_text . '</script>' . "\n");
 297+ $wgOut->addMeta('robots','noindex,nofollow');
 298+ $wgOut->addHTML($text);
 299+
 300+ //Restoring the current user
 301+ if ($old_user)
 302+ $wgUser = $old_user;
 303+ }
 304+
 305+ private function executeOnSubmit() {
 306+ global $wgOut;
 307+
 308+ try {
 309+ $this->userSignup();
 310+ $this->createUserPage();
 311+
 312+ $wgOut->redirect( $this->mUserPageUrl );
 313+ }
 314+ catch ( Exception $e ) {
 315+ $wgOut->addHTML( '<div class="error">' . $e->getMessage() . '</div>' );
 316+ $this->printForm();
 317+ }
 318+
 319+ return true;
 320+ }
 321+
 322+ public function execute( $par ) {
 323+ global $wgRequest, $wgOut;
 324+
 325+ $this->setHeaders();
 326+
 327+ if ( $wgRequest->getCheck( 'wpSave' ) ) {
 328+ return $this->executeOnSubmit();
 329+ } else {
 330+ $this->printForm();
 331+ return true;
 332+ }
 333+ }
 334+}
 335+
\ No newline at end of file
Property changes on: branches/extensions-realtime/SemanticSignup/includes/SES_Special.php
___________________________________________________________________
Added: svn:eol-style
1336 + native
Index: branches/extensions-realtime/SemanticSignup/includes/SES_Utils.php
@@ -0,0 +1,72 @@
 2+<?php
 3+/*
 4+ * Created on 13 Jan 2009 by Serhii Kutnii
 5+ */
 6+
 7+/*
 8+ * An abstract data getter and checker class.
 9+ * Its concrete subclasses should incapsulate all the necessary data getting
 10+ * and environment checks.
 11+ */
 12+abstract class SES_DataChecker
 13+{
 14+ private $mError = null;
 15+
 16+ public function getError()
 17+ {
 18+ return $this->mError;
 19+ }
 20+
 21+ /*
 22+ * Get a value from the request.
 23+ * $err_message_id specifies an error that should be thrown
 24+ * if the value is empty
 25+ */
 26+ protected function getUserDataValue($id, $err_message_id = null)
 27+ {
 28+ global $wgRequest;
 29+ $value = $wgRequest->getText($id);
 30+
 31+ if ($err_message_id && !$value)
 32+ $this->error(wfMsg($err_message_id));
 33+
 34+ return $value;
 35+ }
 36+
 37+ //Checks
 38+ private $mEnvCheckCalls = array();
 39+
 40+ protected function addCheck($method_callback, array $args)
 41+ {
 42+ $this->mEnvCheckCalls[] = array($method_callback, $args);
 43+ }
 44+
 45+ protected function runChecks()
 46+ {
 47+ foreach ($this->mEnvCheckCalls as $call_array)
 48+ {
 49+ call_user_func_array($call_array[0], $call_array[1]);
 50+ }
 51+ }
 52+
 53+ //Abstracting error calls in order to make this functionality changeable in subclasses
 54+ protected function error($message)
 55+ {
 56+ throw new Exception($message);
 57+ }
 58+
 59+ abstract protected function populateData();
 60+
 61+ public function run()
 62+ {
 63+ try
 64+ {
 65+ $this->populateData();
 66+ $this->runChecks();
 67+ }
 68+ catch (Exception $e)
 69+ {
 70+ $this->mError = $e->getMessage();
 71+ }
 72+ }
 73+}
Property changes on: branches/extensions-realtime/SemanticSignup/includes/SES_Utils.php
___________________________________________________________________
Added: svn:eol-style
174 + native
Index: branches/extensions-realtime/SemanticSignup/includes/SES_SignupFields.php
@@ -0,0 +1,187 @@
 2+<?php
 3+/*
 4+ * Created on 6 Jan 2009 by Serhii Kutnii
 5+ */
 6+
 7+/*
 8+ * Borrowed from standard UsercreateTemplate. Some minor changes have been made
 9+ */
 10+
 11+class CreateUserFieldsTemplate extends QuickTemplate
 12+{
 13+ function addInputItem( $name, $value, $type, $msg ) {
 14+ $this->data['extraInput'][] = array(
 15+ 'name' => $name,
 16+ 'value' => $value,
 17+ 'type' => $type,
 18+ 'msg' => $msg,
 19+ );
 20+ }
 21+
 22+ function execute() {
 23+
 24+ ?>
 25+<div id="userlogin">
 26+
 27+ <h2><?php $this->msg('createaccount') ?></h2>
 28+ <p id="userloginlink"><?php $this->html('link') ?></p>
 29+ <?php $this->html('header'); /* pre-table point for form plugins... */ ?>
 30+ <?php if( @$this->haveData( 'languages' ) ) { ?><div id="languagelinks"><p><?php $this->html( 'languages' ); ?></p></div><?php } ?>
 31+ <table>
 32+ <tr>
 33+ <td class="mw-label"><label for='wpName2'><?php $this->msg('yourname') ?></label></td>
 34+ <td class="mw-input">
 35+ <input type='text' class='loginText' name="wpName" id="wpName2"
 36+ tabindex="1"
 37+ size='20' />
 38+ </td>
 39+ </tr>
 40+ <tr>
 41+ <td class="mw-label"><label for='wpPassword2'><?php $this->msg('yourpassword') ?></label></td>
 42+ <td class="mw-input">
 43+ <input type='password' class='loginPassword' name="wpPassword" id="wpPassword2"
 44+ tabindex="2"
 45+ value="" size='20' />
 46+ </td>
 47+ </tr>
 48+ <?php if( $this->data['usedomain'] ) {
 49+ $doms = "";
 50+ foreach( $this->data['domainnames'] as $dom ) {
 51+ $doms .= "<option>" . htmlspecialchars( $dom ) . "</option>";
 52+ }
 53+ ?>
 54+ <tr>
 55+ <td class="mw-label"><?php $this->msg( 'yourdomainname' ) ?></td>
 56+ <td class="mw-input">
 57+ <select name="wpDomain" value="<?php $this->text( 'domain' ) ?>"
 58+ tabindex="3">
 59+ <?php echo $doms ?>
 60+ </select>
 61+ </td>
 62+ </tr>
 63+ <?php } ?>
 64+ <tr>
 65+ <td class="mw-label"><label for='wpRetype'><?php $this->msg('yourpasswordagain') ?></label></td>
 66+ <td class="mw-input">
 67+ <input type='password' class='loginPassword' name="wpRetype" id="wpRetype"
 68+ tabindex="4"
 69+ value=""
 70+ size='20' />
 71+ </td>
 72+ </tr>
 73+ <tr>
 74+ <?php if( $this->data['useemail'] ) { ?>
 75+ <td class="mw-label"><label for='wpEmail'><?php $this->msg('youremail') ?></label></td>
 76+ <td class="mw-input">
 77+ <input type='text' class='loginText' name="wpEmail" id="wpEmail"
 78+ tabindex="5"
 79+ value="<?php $this->text('email') ?>" size='20' />
 80+ <div class="prefsectiontip">
 81+ <?php if( $this->data['emailrequired'] ) {
 82+ $this->msgWiki('prefs-help-email-required');
 83+ } else {
 84+ $this->msgWiki('prefs-help-email');
 85+ } ?>
 86+ </div>
 87+ </td>
 88+ <?php } ?>
 89+ <?php if( $this->data['userealname'] ) { ?>
 90+ </tr>
 91+ <tr>
 92+ <td class="mw-label"><label for='wpRealName'><?php $this->msg('yourrealname') ?></label></td>
 93+ <td class="mw-input">
 94+ <input type='text' class='loginText' name="wpRealName" id="wpRealName"
 95+ tabindex="6"
 96+ size='20' />
 97+ </td>
 98+ <?php } ?>
 99+ </tr>
 100+ <tr>
 101+ <td></td>
 102+ </tr>
 103+<?php
 104+ $tabIndex = 8;
 105+ if ( isset( $this->data['extraInput'] ) && is_array( $this->data['extraInput'] ) ) {
 106+ foreach ( $this->data['extraInput'] as $inputItem ) { ?>
 107+ <tr>
 108+ <?php
 109+ if ( !empty( $inputItem['msg'] ) && $inputItem['type'] != 'checkbox' ) {
 110+ ?><td class="mw-label"><label for="<?php
 111+ echo htmlspecialchars( $inputItem['name'] ); ?>"><?php
 112+ $this->msgWiki( $inputItem['msg'] ) ?></label><?php
 113+ } else {
 114+ ?><td><?php
 115+ }
 116+ ?></td>
 117+ <td class="mw-input">
 118+ <input type="<?php echo htmlspecialchars( $inputItem['type'] ) ?>" name="<?php
 119+ echo htmlspecialchars( $inputItem['name'] ); ?>"
 120+ tabindex="<?php echo $tabIndex++; ?>"
 121+ value="<?php
 122+ if ( $inputItem['type'] != 'checkbox' ) {
 123+ echo htmlspecialchars( $inputItem['value'] );
 124+ } else {
 125+ echo '1';
 126+ }
 127+ ?>" id="<?php echo htmlspecialchars( $inputItem['name'] ); ?>"
 128+ <?php
 129+ if ( $inputItem['type'] == 'checkbox' && !empty( $inputItem['value'] ) )
 130+ echo 'checked="checked"';
 131+ ?> /> <?php
 132+ if ( $inputItem['type'] == 'checkbox' && !empty( $inputItem['msg'] ) ) {
 133+ ?>
 134+ <label for="<?php echo htmlspecialchars( $inputItem['name'] ); ?>"><?php
 135+ $this->msg( $inputItem['msg'] ) ?></label><?php
 136+ }
 137+ ?>
 138+ </td>
 139+ </tr>
 140+<?php
 141+
 142+ }
 143+ }
 144+?>
 145+ <tr>
 146+ <td></td>
 147+ </tr>
 148+ </table>
 149+<?php if( @$this->haveData( 'uselang' ) ) { ?><input type="hidden" name="uselang" value="<?php $this->text( 'uselang' ); ?>" /><?php } ?>
 150+</div>
 151+<div id="signupend"><?php $this->msgWiki( 'signupend' ); ?></div>
 152+<?php
 153+
 154+ }
 155+}
 156+
 157+class SES_SignupFields
 158+{
 159+ public static function render($input, $args, $parser)
 160+ {
 161+ $template = new CreateUserFieldsTemplate();
 162+
 163+ $template->set( 'header', '' );
 164+
 165+ global $wgEnableEmail, $wgAllowRealName, $wgEmailConfirmToEdit, $wgAuth, $wgUser;
 166+ $template->set( 'createemail', $wgEnableEmail && $wgUser->isLoggedIn() );
 167+ $template->set( 'userealname', $wgAllowRealName );
 168+ $template->set( 'useemail', $wgEnableEmail );
 169+ $template->set( 'emailrequired', $wgEmailConfirmToEdit );
 170+ $template->set( 'canreset', $wgAuth->allowPasswordChange() );
 171+ //$template->set( 'remember', $wgUser->getOption( 'rememberpassword' ) );
 172+
 173+ global $wgLoginLanguageSelector;
 174+ # Prepare language selection links as needed
 175+ if( $wgLoginLanguageSelector )
 176+ $template->set( 'languages', $this->makeLanguageSelector() );
 177+
 178+ // Give authentication and captcha plugins a chance to modify the form
 179+ $wgAuth->modifyUITemplate( $template );
 180+
 181+ ob_start();
 182+ $template->execute();
 183+ $text = ob_get_clean();
 184+
 185+ return $text;
 186+ }
 187+
 188+}
Property changes on: branches/extensions-realtime/SemanticSignup/includes/SES_SignupFields.php
___________________________________________________________________
Added: svn:eol-style
1189 + native
Index: branches/extensions-realtime/SemanticSignup/release-notes
@@ -0,0 +1,21 @@
 2+These are the release notes for the SemanticSignup extension.
 3+
 4+Extension page on mediawiki.org: http://www.mediawiki.org/wiki/Extension:SemanticSignup
 5+Latest version of the release notes: http://svn.wikimedia.org/viewvc/mediawiki/trunk/extensions/SemanticSignup/RELEASE-NOTES?view=co
 6+
 7+
 8+=== Version 0.3 ===
 9+2011-0x-xx
 10+
 11+* Added compatibility with MediaWiki 1.16 and above, removed compatibility with MediaWiki below 1.16.
 12+* Added compatibility with Semantic MediaWiki 1.6 and above.
 13+* Added INSTALL file.
 14+* Rewrote setting handling.
 15+* Moved entry point to SemanticSignup.php.
 16+* Moved code to standard i18n, hooks and settings files.
 17+* Stylized code.
 18+
 19+=== Version 0.2 ===
 20+
 21+* a new configuration setting $sesSignupBotName added;
 22+* README sections 3 and 4 updated.
Index: branches/extensions-realtime/SemanticSignup/COPYING
@@ -0,0 +1,674 @@
 2+ GNU GENERAL PUBLIC LICENSE
 3+ Version 3, 29 June 2007
 4+
 5+ Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
 6+ Everyone is permitted to copy and distribute verbatim copies
 7+ of this license document, but changing it is not allowed.
 8+
 9+ Preamble
 10+
 11+ The GNU General Public License is a free, copyleft license for
 12+software and other kinds of works.
 13+
 14+ The licenses for most software and other practical works are designed
 15+to take away your freedom to share and change the works. By contrast,
 16+the GNU General Public License is intended to guarantee your freedom to
 17+share and change all versions of a program--to make sure it remains free
 18+software for all its users. We, the Free Software Foundation, use the
 19+GNU General Public License for most of our software; it applies also to
 20+any other work released this way by its authors. You can apply it to
 21+your programs, too.
 22+
 23+ When we speak of free software, we are referring to freedom, not
 24+price. Our General Public Licenses are designed to make sure that you
 25+have the freedom to distribute copies of free software (and charge for
 26+them if you wish), that you receive source code or can get it if you
 27+want it, that you can change the software or use pieces of it in new
 28+free programs, and that you know you can do these things.
 29+
 30+ To protect your rights, we need to prevent others from denying you
 31+these rights or asking you to surrender the rights. Therefore, you have
 32+certain responsibilities if you distribute copies of the software, or if
 33+you modify it: responsibilities to respect the freedom of others.
 34+
 35+ For example, if you distribute copies of such a program, whether
 36+gratis or for a fee, you must pass on to the recipients the same
 37+freedoms that you received. You must make sure that they, too, receive
 38+or can get the source code. And you must show them these terms so they
 39+know their rights.
 40+
 41+ Developers that use the GNU GPL protect your rights with two steps:
 42+(1) assert copyright on the software, and (2) offer you this License
 43+giving you legal permission to copy, distribute and/or modify it.
 44+
 45+ For the developers' and authors' protection, the GPL clearly explains
 46+that there is no warranty for this free software. For both users' and
 47+authors' sake, the GPL requires that modified versions be marked as
 48+changed, so that their problems will not be attributed erroneously to
 49+authors of previous versions.
 50+
 51+ Some devices are designed to deny users access to install or run
 52+modified versions of the software inside them, although the manufacturer
 53+can do so. This is fundamentally incompatible with the aim of
 54+protecting users' freedom to change the software. The systematic
 55+pattern of such abuse occurs in the area of products for individuals to
 56+use, which is precisely where it is most unacceptable. Therefore, we
 57+have designed this version of the GPL to prohibit the practice for those
 58+products. If such problems arise substantially in other domains, we
 59+stand ready to extend this provision to those domains in future versions
 60+of the GPL, as needed to protect the freedom of users.
 61+
 62+ Finally, every program is threatened constantly by software patents.
 63+States should not allow patents to restrict development and use of
 64+software on general-purpose computers, but in those that do, we wish to
 65+avoid the special danger that patents applied to a free program could
 66+make it effectively proprietary. To prevent this, the GPL assures that
 67+patents cannot be used to render the program non-free.
 68+
 69+ The precise terms and conditions for copying, distribution and
 70+modification follow.
 71+
 72+ TERMS AND CONDITIONS
 73+
 74+ 0. Definitions.
 75+
 76+ "This License" refers to version 3 of the GNU General Public License.
 77+
 78+ "Copyright" also means copyright-like laws that apply to other kinds of
 79+works, such as semiconductor masks.
 80+
 81+ "The Program" refers to any copyrightable work licensed under this
 82+License. Each licensee is addressed as "you". "Licensees" and
 83+"recipients" may be individuals or organizations.
 84+
 85+ To "modify" a work means to copy from or adapt all or part of the work
 86+in a fashion requiring copyright permission, other than the making of an
 87+exact copy. The resulting work is called a "modified version" of the
 88+earlier work or a work "based on" the earlier work.
 89+
 90+ A "covered work" means either the unmodified Program or a work based
 91+on the Program.
 92+
 93+ To "propagate" a work means to do anything with it that, without
 94+permission, would make you directly or secondarily liable for
 95+infringement under applicable copyright law, except executing it on a
 96+computer or modifying a private copy. Propagation includes copying,
 97+distribution (with or without modification), making available to the
 98+public, and in some countries other activities as well.
 99+
 100+ To "convey" a work means any kind of propagation that enables other
 101+parties to make or receive copies. Mere interaction with a user through
 102+a computer network, with no transfer of a copy, is not conveying.
 103+
 104+ An interactive user interface displays "Appropriate Legal Notices"
 105+to the extent that it includes a convenient and prominently visible
 106+feature that (1) displays an appropriate copyright notice, and (2)
 107+tells the user that there is no warranty for the work (except to the
 108+extent that warranties are provided), that licensees may convey the
 109+work under this License, and how to view a copy of this License. If
 110+the interface presents a list of user commands or options, such as a
 111+menu, a prominent item in the list meets this criterion.
 112+
 113+ 1. Source Code.
 114+
 115+ The "source code" for a work means the preferred form of the work
 116+for making modifications to it. "Object code" means any non-source
 117+form of a work.
 118+
 119+ A "Standard Interface" means an interface that either is an official
 120+standard defined by a recognized standards body, or, in the case of
 121+interfaces specified for a particular programming language, one that
 122+is widely used among developers working in that language.
 123+
 124+ The "System Libraries" of an executable work include anything, other
 125+than the work as a whole, that (a) is included in the normal form of
 126+packaging a Major Component, but which is not part of that Major
 127+Component, and (b) serves only to enable use of the work with that
 128+Major Component, or to implement a Standard Interface for which an
 129+implementation is available to the public in source code form. A
 130+"Major Component", in this context, means a major essential component
 131+(kernel, window system, and so on) of the specific operating system
 132+(if any) on which the executable work runs, or a compiler used to
 133+produce the work, or an object code interpreter used to run it.
 134+
 135+ The "Corresponding Source" for a work in object code form means all
 136+the source code needed to generate, install, and (for an executable
 137+work) run the object code and to modify the work, including scripts to
 138+control those activities. However, it does not include the work's
 139+System Libraries, or general-purpose tools or generally available free
 140+programs which are used unmodified in performing those activities but
 141+which are not part of the work. For example, Corresponding Source
 142+includes interface definition files associated with source files for
 143+the work, and the source code for shared libraries and dynamically
 144+linked subprograms that the work is specifically designed to require,
 145+such as by intimate data communication or control flow between those
 146+subprograms and other parts of the work.
 147+
 148+ The Corresponding Source need not include anything that users
 149+can regenerate automatically from other parts of the Corresponding
 150+Source.
 151+
 152+ The Corresponding Source for a work in source code form is that
 153+same work.
 154+
 155+ 2. Basic Permissions.
 156+
 157+ All rights granted under this License are granted for the term of
 158+copyright on the Program, and are irrevocable provided the stated
 159+conditions are met. This License explicitly affirms your unlimited
 160+permission to run the unmodified Program. The output from running a
 161+covered work is covered by this License only if the output, given its
 162+content, constitutes a covered work. This License acknowledges your
 163+rights of fair use or other equivalent, as provided by copyright law.
 164+
 165+ You may make, run and propagate covered works that you do not
 166+convey, without conditions so long as your license otherwise remains
 167+in force. You may convey covered works to others for the sole purpose
 168+of having them make modifications exclusively for you, or provide you
 169+with facilities for running those works, provided that you comply with
 170+the terms of this License in conveying all material for which you do
 171+not control copyright. Those thus making or running the covered works
 172+for you must do so exclusively on your behalf, under your direction
 173+and control, on terms that prohibit them from making any copies of
 174+your copyrighted material outside their relationship with you.
 175+
 176+ Conveying under any other circumstances is permitted solely under
 177+the conditions stated below. Sublicensing is not allowed; section 10
 178+makes it unnecessary.
 179+
 180+ 3. Protecting Users' Legal Rights From Anti-Circumvention Law.
 181+
 182+ No covered work shall be deemed part of an effective technological
 183+measure under any applicable law fulfilling obligations under article
 184+11 of the WIPO copyright treaty adopted on 20 December 1996, or
 185+similar laws prohibiting or restricting circumvention of such
 186+measures.
 187+
 188+ When you convey a covered work, you waive any legal power to forbid
 189+circumvention of technological measures to the extent such circumvention
 190+is effected by exercising rights under this License with respect to
 191+the covered work, and you disclaim any intention to limit operation or
 192+modification of the work as a means of enforcing, against the work's
 193+users, your or third parties' legal rights to forbid circumvention of
 194+technological measures.
 195+
 196+ 4. Conveying Verbatim Copies.
 197+
 198+ You may convey verbatim copies of the Program's source code as you
 199+receive it, in any medium, provided that you conspicuously and
 200+appropriately publish on each copy an appropriate copyright notice;
 201+keep intact all notices stating that this License and any
 202+non-permissive terms added in accord with section 7 apply to the code;
 203+keep intact all notices of the absence of any warranty; and give all
 204+recipients a copy of this License along with the Program.
 205+
 206+ You may charge any price or no price for each copy that you convey,
 207+and you may offer support or warranty protection for a fee.
 208+
 209+ 5. Conveying Modified Source Versions.
 210+
 211+ You may convey a work based on the Program, or the modifications to
 212+produce it from the Program, in the form of source code under the
 213+terms of section 4, provided that you also meet all of these conditions:
 214+
 215+ a) The work must carry prominent notices stating that you modified
 216+ it, and giving a relevant date.
 217+
 218+ b) The work must carry prominent notices stating that it is
 219+ released under this License and any conditions added under section
 220+ 7. This requirement modifies the requirement in section 4 to
 221+ "keep intact all notices".
 222+
 223+ c) You must license the entire work, as a whole, under this
 224+ License to anyone who comes into possession of a copy. This
 225+ License will therefore apply, along with any applicable section 7
 226+ additional terms, to the whole of the work, and all its parts,
 227+ regardless of how they are packaged. This License gives no
 228+ permission to license the work in any other way, but it does not
 229+ invalidate such permission if you have separately received it.
 230+
 231+ d) If the work has interactive user interfaces, each must display
 232+ Appropriate Legal Notices; however, if the Program has interactive
 233+ interfaces that do not display Appropriate Legal Notices, your
 234+ work need not make them do so.
 235+
 236+ A compilation of a covered work with other separate and independent
 237+works, which are not by their nature extensions of the covered work,
 238+and which are not combined with it such as to form a larger program,
 239+in or on a volume of a storage or distribution medium, is called an
 240+"aggregate" if the compilation and its resulting copyright are not
 241+used to limit the access or legal rights of the compilation's users
 242+beyond what the individual works permit. Inclusion of a covered work
 243+in an aggregate does not cause this License to apply to the other
 244+parts of the aggregate.
 245+
 246+ 6. Conveying Non-Source Forms.
 247+
 248+ You may convey a covered work in object code form under the terms
 249+of sections 4 and 5, provided that you also convey the
 250+machine-readable Corresponding Source under the terms of this License,
 251+in one of these ways:
 252+
 253+ a) Convey the object code in, or embodied in, a physical product
 254+ (including a physical distribution medium), accompanied by the
 255+ Corresponding Source fixed on a durable physical medium
 256+ customarily used for software interchange.
 257+
 258+ b) Convey the object code in, or embodied in, a physical product
 259+ (including a physical distribution medium), accompanied by a
 260+ written offer, valid for at least three years and valid for as
 261+ long as you offer spare parts or customer support for that product
 262+ model, to give anyone who possesses the object code either (1) a
 263+ copy of the Corresponding Source for all the software in the
 264+ product that is covered by this License, on a durable physical
 265+ medium customarily used for software interchange, for a price no
 266+ more than your reasonable cost of physically performing this
 267+ conveying of source, or (2) access to copy the
 268+ Corresponding Source from a network server at no charge.
 269+
 270+ c) Convey individual copies of the object code with a copy of the
 271+ written offer to provide the Corresponding Source. This
 272+ alternative is allowed only occasionally and noncommercially, and
 273+ only if you received the object code with such an offer, in accord
 274+ with subsection 6b.
 275+
 276+ d) Convey the object code by offering access from a designated
 277+ place (gratis or for a charge), and offer equivalent access to the
 278+ Corresponding Source in the same way through the same place at no
 279+ further charge. You need not require recipients to copy the
 280+ Corresponding Source along with the object code. If the place to
 281+ copy the object code is a network server, the Corresponding Source
 282+ may be on a different server (operated by you or a third party)
 283+ that supports equivalent copying facilities, provided you maintain
 284+ clear directions next to the object code saying where to find the
 285+ Corresponding Source. Regardless of what server hosts the
 286+ Corresponding Source, you remain obligated to ensure that it is
 287+ available for as long as needed to satisfy these requirements.
 288+
 289+ e) Convey the object code using peer-to-peer transmission, provided
 290+ you inform other peers where the object code and Corresponding
 291+ Source of the work are being offered to the general public at no
 292+ charge under subsection 6d.
 293+
 294+ A separable portion of the object code, whose source code is excluded
 295+from the Corresponding Source as a System Library, need not be
 296+included in conveying the object code work.
 297+
 298+ A "User Product" is either (1) a "consumer product", which means any
 299+tangible personal property which is normally used for personal, family,
 300+or household purposes, or (2) anything designed or sold for incorporation
 301+into a dwelling. In determining whether a product is a consumer product,
 302+doubtful cases shall be resolved in favor of coverage. For a particular
 303+product received by a particular user, "normally used" refers to a
 304+typical or common use of that class of product, regardless of the status
 305+of the particular user or of the way in which the particular user
 306+actually uses, or expects or is expected to use, the product. A product
 307+is a consumer product regardless of whether the product has substantial
 308+commercial, industrial or non-consumer uses, unless such uses represent
 309+the only significant mode of use of the product.
 310+
 311+ "Installation Information" for a User Product means any methods,
 312+procedures, authorization keys, or other information required to install
 313+and execute modified versions of a covered work in that User Product from
 314+a modified version of its Corresponding Source. The information must
 315+suffice to ensure that the continued functioning of the modified object
 316+code is in no case prevented or interfered with solely because
 317+modification has been made.
 318+
 319+ If you convey an object code work under this section in, or with, or
 320+specifically for use in, a User Product, and the conveying occurs as
 321+part of a transaction in which the right of possession and use of the
 322+User Product is transferred to the recipient in perpetuity or for a
 323+fixed term (regardless of how the transaction is characterized), the
 324+Corresponding Source conveyed under this section must be accompanied
 325+by the Installation Information. But this requirement does not apply
 326+if neither you nor any third party retains the ability to install
 327+modified object code on the User Product (for example, the work has
 328+been installed in ROM).
 329+
 330+ The requirement to provide Installation Information does not include a
 331+requirement to continue to provide support service, warranty, or updates
 332+for a work that has been modified or installed by the recipient, or for
 333+the User Product in which it has been modified or installed. Access to a
 334+network may be denied when the modification itself materially and
 335+adversely affects the operation of the network or violates the rules and
 336+protocols for communication across the network.
 337+
 338+ Corresponding Source conveyed, and Installation Information provided,
 339+in accord with this section must be in a format that is publicly
 340+documented (and with an implementation available to the public in
 341+source code form), and must require no special password or key for
 342+unpacking, reading or copying.
 343+
 344+ 7. Additional Terms.
 345+
 346+ "Additional permissions" are terms that supplement the terms of this
 347+License by making exceptions from one or more of its conditions.
 348+Additional permissions that are applicable to the entire Program shall
 349+be treated as though they were included in this License, to the extent
 350+that they are valid under applicable law. If additional permissions
 351+apply only to part of the Program, that part may be used separately
 352+under those permissions, but the entire Program remains governed by
 353+this License without regard to the additional permissions.
 354+
 355+ When you convey a copy of a covered work, you may at your option
 356+remove any additional permissions from that copy, or from any part of
 357+it. (Additional permissions may be written to require their own
 358+removal in certain cases when you modify the work.) You may place
 359+additional permissions on material, added by you to a covered work,
 360+for which you have or can give appropriate copyright permission.
 361+
 362+ Notwithstanding any other provision of this License, for material you
 363+add to a covered work, you may (if authorized by the copyright holders of
 364+that material) supplement the terms of this License with terms:
 365+
 366+ a) Disclaiming warranty or limiting liability differently from the
 367+ terms of sections 15 and 16 of this License; or
 368+
 369+ b) Requiring preservation of specified reasonable legal notices or
 370+ author attributions in that material or in the Appropriate Legal
 371+ Notices displayed by works containing it; or
 372+
 373+ c) Prohibiting misrepresentation of the origin of that material, or
 374+ requiring that modified versions of such material be marked in
 375+ reasonable ways as different from the original version; or
 376+
 377+ d) Limiting the use for publicity purposes of names of licensors or
 378+ authors of the material; or
 379+
 380+ e) Declining to grant rights under trademark law for use of some
 381+ trade names, trademarks, or service marks; or
 382+
 383+ f) Requiring indemnification of licensors and authors of that
 384+ material by anyone who conveys the material (or modified versions of
 385+ it) with contractual assumptions of liability to the recipient, for
 386+ any liability that these contractual assumptions directly impose on
 387+ those licensors and authors.
 388+
 389+ All other non-permissive additional terms are considered "further
 390+restrictions" within the meaning of section 10. If the Program as you
 391+received it, or any part of it, contains a notice stating that it is
 392+governed by this License along with a term that is a further
 393+restriction, you may remove that term. If a license document contains
 394+a further restriction but permits relicensing or conveying under this
 395+License, you may add to a covered work material governed by the terms
 396+of that license document, provided that the further restriction does
 397+not survive such relicensing or conveying.
 398+
 399+ If you add terms to a covered work in accord with this section, you
 400+must place, in the relevant source files, a statement of the
 401+additional terms that apply to those files, or a notice indicating
 402+where to find the applicable terms.
 403+
 404+ Additional terms, permissive or non-permissive, may be stated in the
 405+form of a separately written license, or stated as exceptions;
 406+the above requirements apply either way.
 407+
 408+ 8. Termination.
 409+
 410+ You may not propagate or modify a covered work except as expressly
 411+provided under this License. Any attempt otherwise to propagate or
 412+modify it is void, and will automatically terminate your rights under
 413+this License (including any patent licenses granted under the third
 414+paragraph of section 11).
 415+
 416+ However, if you cease all violation of this License, then your
 417+license from a particular copyright holder is reinstated (a)
 418+provisionally, unless and until the copyright holder explicitly and
 419+finally terminates your license, and (b) permanently, if the copyright
 420+holder fails to notify you of the violation by some reasonable means
 421+prior to 60 days after the cessation.
 422+
 423+ Moreover, your license from a particular copyright holder is
 424+reinstated permanently if the copyright holder notifies you of the
 425+violation by some reasonable means, this is the first time you have
 426+received notice of violation of this License (for any work) from that
 427+copyright holder, and you cure the violation prior to 30 days after
 428+your receipt of the notice.
 429+
 430+ Termination of your rights under this section does not terminate the
 431+licenses of parties who have received copies or rights from you under
 432+this License. If your rights have been terminated and not permanently
 433+reinstated, you do not qualify to receive new licenses for the same
 434+material under section 10.
 435+
 436+ 9. Acceptance Not Required for Having Copies.
 437+
 438+ You are not required to accept this License in order to receive or
 439+run a copy of the Program. Ancillary propagation of a covered work
 440+occurring solely as a consequence of using peer-to-peer transmission
 441+to receive a copy likewise does not require acceptance. However,
 442+nothing other than this License grants you permission to propagate or
 443+modify any covered work. These actions infringe copyright if you do
 444+not accept this License. Therefore, by modifying or propagating a
 445+covered work, you indicate your acceptance of this License to do so.
 446+
 447+ 10. Automatic Licensing of Downstream Recipients.
 448+
 449+ Each time you convey a covered work, the recipient automatically
 450+receives a license from the original licensors, to run, modify and
 451+propagate that work, subject to this License. You are not responsible
 452+for enforcing compliance by third parties with this License.
 453+
 454+ An "entity transaction" is a transaction transferring control of an
 455+organization, or substantially all assets of one, or subdividing an
 456+organization, or merging organizations. If propagation of a covered
 457+work results from an entity transaction, each party to that
 458+transaction who receives a copy of the work also receives whatever
 459+licenses to the work the party's predecessor in interest had or could
 460+give under the previous paragraph, plus a right to possession of the
 461+Corresponding Source of the work from the predecessor in interest, if
 462+the predecessor has it or can get it with reasonable efforts.
 463+
 464+ You may not impose any further restrictions on the exercise of the
 465+rights granted or affirmed under this License. For example, you may
 466+not impose a license fee, royalty, or other charge for exercise of
 467+rights granted under this License, and you may not initiate litigation
 468+(including a cross-claim or counterclaim in a lawsuit) alleging that
 469+any patent claim is infringed by making, using, selling, offering for
 470+sale, or importing the Program or any portion of it.
 471+
 472+ 11. Patents.
 473+
 474+ A "contributor" is a copyright holder who authorizes use under this
 475+License of the Program or a work on which the Program is based. The
 476+work thus licensed is called the contributor's "contributor version".
 477+
 478+ A contributor's "essential patent claims" are all patent claims
 479+owned or controlled by the contributor, whether already acquired or
 480+hereafter acquired, that would be infringed by some manner, permitted
 481+by this License, of making, using, or selling its contributor version,
 482+but do not include claims that would be infringed only as a
 483+consequence of further modification of the contributor version. For
 484+purposes of this definition, "control" includes the right to grant
 485+patent sublicenses in a manner consistent with the requirements of
 486+this License.
 487+
 488+ Each contributor grants you a non-exclusive, worldwide, royalty-free
 489+patent license under the contributor's essential patent claims, to
 490+make, use, sell, offer for sale, import and otherwise run, modify and
 491+propagate the contents of its contributor version.
 492+
 493+ In the following three paragraphs, a "patent license" is any express
 494+agreement or commitment, however denominated, not to enforce a patent
 495+(such as an express permission to practice a patent or covenant not to
 496+sue for patent infringement). To "grant" such a patent license to a
 497+party means to make such an agreement or commitment not to enforce a
 498+patent against the party.
 499+
 500+ If you convey a covered work, knowingly relying on a patent license,
 501+and the Corresponding Source of the work is not available for anyone
 502+to copy, free of charge and under the terms of this License, through a
 503+publicly available network server or other readily accessible means,
 504+then you must either (1) cause the Corresponding Source to be so
 505+available, or (2) arrange to deprive yourself of the benefit of the
 506+patent license for this particular work, or (3) arrange, in a manner
 507+consistent with the requirements of this License, to extend the patent
 508+license to downstream recipients. "Knowingly relying" means you have
 509+actual knowledge that, but for the patent license, your conveying the
 510+covered work in a country, or your recipient's use of the covered work
 511+in a country, would infringe one or more identifiable patents in that
 512+country that you have reason to believe are valid.
 513+
 514+ If, pursuant to or in connection with a single transaction or
 515+arrangement, you convey, or propagate by procuring conveyance of, a
 516+covered work, and grant a patent license to some of the parties
 517+receiving the covered work authorizing them to use, propagate, modify
 518+or convey a specific copy of the covered work, then the patent license
 519+you grant is automatically extended to all recipients of the covered
 520+work and works based on it.
 521+
 522+ A patent license is "discriminatory" if it does not include within
 523+the scope of its coverage, prohibits the exercise of, or is
 524+conditioned on the non-exercise of one or more of the rights that are
 525+specifically granted under this License. You may not convey a covered
 526+work if you are a party to an arrangement with a third party that is
 527+in the business of distributing software, under which you make payment
 528+to the third party based on the extent of your activity of conveying
 529+the work, and under which the third party grants, to any of the
 530+parties who would receive the covered work from you, a discriminatory
 531+patent license (a) in connection with copies of the covered work
 532+conveyed by you (or copies made from those copies), or (b) primarily
 533+for and in connection with specific products or compilations that
 534+contain the covered work, unless you entered into that arrangement,
 535+or that patent license was granted, prior to 28 March 2007.
 536+
 537+ Nothing in this License shall be construed as excluding or limiting
 538+any implied license or other defenses to infringement that may
 539+otherwise be available to you under applicable patent law.
 540+
 541+ 12. No Surrender of Others' Freedom.
 542+
 543+ If conditions are imposed on you (whether by court order, agreement or
 544+otherwise) that contradict the conditions of this License, they do not
 545+excuse you from the conditions of this License. If you cannot convey a
 546+covered work so as to satisfy simultaneously your obligations under this
 547+License and any other pertinent obligations, then as a consequence you may
 548+not convey it at all. For example, if you agree to terms that obligate you
 549+to collect a royalty for further conveying from those to whom you convey
 550+the Program, the only way you could satisfy both those terms and this
 551+License would be to refrain entirely from conveying the Program.
 552+
 553+ 13. Use with the GNU Affero General Public License.
 554+
 555+ Notwithstanding any other provision of this License, you have
 556+permission to link or combine any covered work with a work licensed
 557+under version 3 of the GNU Affero General Public License into a single
 558+combined work, and to convey the resulting work. The terms of this
 559+License will continue to apply to the part which is the covered work,
 560+but the special requirements of the GNU Affero General Public License,
 561+section 13, concerning interaction through a network will apply to the
 562+combination as such.
 563+
 564+ 14. Revised Versions of this License.
 565+
 566+ The Free Software Foundation may publish revised and/or new versions of
 567+the GNU General Public License from time to time. Such new versions will
 568+be similar in spirit to the present version, but may differ in detail to
 569+address new problems or concerns.
 570+
 571+ Each version is given a distinguishing version number. If the
 572+Program specifies that a certain numbered version of the GNU General
 573+Public License "or any later version" applies to it, you have the
 574+option of following the terms and conditions either of that numbered
 575+version or of any later version published by the Free Software
 576+Foundation. If the Program does not specify a version number of the
 577+GNU General Public License, you may choose any version ever published
 578+by the Free Software Foundation.
 579+
 580+ If the Program specifies that a proxy can decide which future
 581+versions of the GNU General Public License can be used, that proxy's
 582+public statement of acceptance of a version permanently authorizes you
 583+to choose that version for the Program.
 584+
 585+ Later license versions may give you additional or different
 586+permissions. However, no additional obligations are imposed on any
 587+author or copyright holder as a result of your choosing to follow a
 588+later version.
 589+
 590+ 15. Disclaimer of Warranty.
 591+
 592+ THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
 593+APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
 594+HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
 595+OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
 596+THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 597+PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
 598+IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
 599+ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
 600+
 601+ 16. Limitation of Liability.
 602+
 603+ IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
 604+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
 605+THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
 606+GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
 607+USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
 608+DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
 609+PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
 610+EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
 611+SUCH DAMAGES.
 612+
 613+ 17. Interpretation of Sections 15 and 16.
 614+
 615+ If the disclaimer of warranty and limitation of liability provided
 616+above cannot be given local legal effect according to their terms,
 617+reviewing courts shall apply local law that most closely approximates
 618+an absolute waiver of all civil liability in connection with the
 619+Program, unless a warranty or assumption of liability accompanies a
 620+copy of the Program in return for a fee.
 621+
 622+ END OF TERMS AND CONDITIONS
 623+
 624+ How to Apply These Terms to Your New Programs
 625+
 626+ If you develop a new program, and you want it to be of the greatest
 627+possible use to the public, the best way to achieve this is to make it
 628+free software which everyone can redistribute and change under these terms.
 629+
 630+ To do so, attach the following notices to the program. It is safest
 631+to attach them to the start of each source file to most effectively
 632+state the exclusion of warranty; and each file should have at least
 633+the "copyright" line and a pointer to where the full notice is found.
 634+
 635+ <one line to give the program's name and a brief idea of what it does.>
 636+ Copyright (C) <year> <name of author>
 637+
 638+ This program is free software: you can redistribute it and/or modify
 639+ it under the terms of the GNU General Public License as published by
 640+ the Free Software Foundation, either version 3 of the License, or
 641+ (at your option) any later version.
 642+
 643+ This program is distributed in the hope that it will be useful,
 644+ but WITHOUT ANY WARRANTY; without even the implied warranty of
 645+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 646+ GNU General Public License for more details.
 647+
 648+ You should have received a copy of the GNU General Public License
 649+ along with this program. If not, see <http://www.gnu.org/licenses/>.
 650+
 651+Also add information on how to contact you by electronic and paper mail.
 652+
 653+ If the program does terminal interaction, make it output a short
 654+notice like this when it starts in an interactive mode:
 655+
 656+ <program> Copyright (C) <year> <name of author>
 657+ This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
 658+ This is free software, and you are welcome to redistribute it
 659+ under certain conditions; type `show c' for details.
 660+
 661+The hypothetical commands `show w' and `show c' should show the appropriate
 662+parts of the General Public License. Of course, your program's commands
 663+might be different; for a GUI interface, you would use an "about box".
 664+
 665+ You should also get your employer (if you work as a programmer) or school,
 666+if any, to sign a "copyright disclaimer" for the program, if necessary.
 667+For more information on this, and how to apply and follow the GNU GPL, see
 668+<http://www.gnu.org/licenses/>.
 669+
 670+ The GNU General Public License does not permit incorporating your program
 671+into proprietary programs. If your program is a subroutine library, you
 672+may consider it more useful to permit linking proprietary applications with
 673+the library. If this is what you want to do, use the GNU Lesser General
 674+Public License instead of this License. But first, please read
 675+<http://www.gnu.org/philosophy/why-not-lgpl.html>.
Index: branches/extensions-realtime/SemanticSignup/README
@@ -0,0 +1,56 @@
 2+1. INTRO
 3+
 4+This is SemanticSignup version 0.1.0
 5+
 6+This is a MediaWiki extension built on top of Semantic MediaWiki
 7+and SemanticForms extensions and intended to be used with them.
 8+
 9+It is recommended to read these extensions' manuals before this one.
 10+
 11+2. USAGE
 12+
 13+This extension tweaks user registration process in order to make
 14+users populate their user pages with semantic data at registration time.
 15+Whenever the user registration form is requested the user is redirected
 16+to the Semantic Signup special page where he has to enter the usual
 17+account data and some additional information into a semantic form.
 18+When the form is submitted, the usual account information is used
 19+to register the new user account and a new User:<Username> page is
 20+populated with the additional data.
 21+
 22+3. INSTALLATION
 23+
 24+1. Create a semantic form for user pages (see the SemanticForms manual
 25+for details). Use the <signupfields /> tag to insert the user account
 26+input fields (e. g. username password and all that stuff) into this form -
 27+this is required for the form to be suitable for account registration.
 28+
 29+2. Insert the following lines into your LocalSettings.php:
 30+
 31+require_once('extensions/SemanticSignup/includes/SES_Main.php');
 32+$sesSignupFormName = 'MyFormName';
 33+$sesSignupBotName ='SignupBotName';
 34+
 35+where "MyFormName" should be replaced with whatever the form
 36+created at step 1 is called (the namespace title - i.e. "Form:" - should not be included)
 37+and "SignupBotName" is a name of a bot user account that will be used by SemanticSignup (you might need to create one).
 38+
 39+4. CONFIGURATION
 40+
 41+$sesSignupFormName controls the form which is displayed by the Semantic Signup
 42+special page.
 43+
 44+$sesRealNameRequired controls whether real name is required to register an account.
 45+
 46+$sesSignupBotName controls the name of a bot account used by SemanticSignup.
 47+Currently the extension makes use of it when getting the signup form only
 48+in order to avoid it being disabled if an anonymous user hasn't got "edit" permissions.
 49+
 50+5. SUPPORT & DONATIONS
 51+
 52+This extension was created by Serhii Kutnii mnkutster@gmail.com.
 53+
 54+The project home page is http://semanticsignup.sourceforge.net/.
 55+
 56+The bug and feature request tracker is available at
 57+https://sourceforge.net/tracker/?atid=1126589&group_id=250562&func=browse
\ No newline at end of file
Index: branches/extensions-realtime/SemanticSignup/SemanticSignup.i18n.aliases.php
@@ -0,0 +1,11 @@
 2+<?php
 3+
 4+/**
 5+ * Created on 7 Jan 2008 by Serhii Kutnii
 6+ */
 7+
 8+$aliases = array();
 9+
 10+$aliases['en'] = array(
 11+ 'SemanticSignup' => array( 'SemanticSignup', 'Semantic Signup' )
 12+);
Property changes on: branches/extensions-realtime/SemanticSignup/SemanticSignup.i18n.aliases.php
___________________________________________________________________
Added: svn:eol-style
113 + native
Index: branches/extensions-realtime/SemanticSignup/SemanticSignup.i18n.php
@@ -0,0 +1,21 @@
 2+<?php
 3+
 4+/**
 5+ * Created on 7 Jan 2008 by Serhii Kutnii
 6+ */
 7+
 8+$messages = array();
 9+
 10+$messages['en'] = array(
 11+ 'semanticsignup' => 'Semantic Signup',
 12+ 'ses-desc' => 'A MediaWiki extension built on top of Semantic Forms allowing to populate a user page with semantic data at signup time',
 13+ 'nousername' => 'Username has not been specified',
 14+ 'nopwdmatch' => 'Password and password confirmation don\'t match',
 15+ 'norealname' => 'Real name is required but has not been specified',
 16+ 'userexists' => 'User already exists',
 17+ 'invaliduname' => 'Username specified is not allowed',
 18+ 'emailfailed' => 'Confirmation email sending failed',
 19+ 'createforbidden' => 'Current user is not allowed to create accounts',
 20+ 'throttlehit' => 'New user accounts number maximum per day has been exceeded for this IP',
 21+ 'ses_userexists' => 'User already exists'
 22+);
Property changes on: branches/extensions-realtime/SemanticSignup/SemanticSignup.i18n.php
___________________________________________________________________
Added: svn:eol-style
123 + native
Index: branches/extensions-realtime/SemanticSignup/SemanticSignup.settings.php
@@ -0,0 +1,46 @@
 2+<?php
 3+
 4+/**
 5+ * File defining the settings for the SemanticSignup extension.
 6+ * More info can be found at http://www.mediawiki.org/wiki/Extension:SemanticSignup#Settings
 7+ *
 8+ * NOTICE:
 9+ * Changing one of these settings can be done by copying or cutting it,
 10+ * and placing it in LocalSettings.php, AFTER the inclusion of this extension.
 11+ *
 12+ * @file SemanticSignup.settings.php
 13+ * @ingroup SemanticSignup
 14+ *
 15+ * @licence GNU GPL v3+
 16+ * @author Jeroen De Dauw < jeroendedauw@gmail.com >
 17+ */
 18+
 19+class SemanticSignupSettings {
 20+
 21+ protected static function getDefaultSettings() {
 22+ return array(
 23+ 'requireName' => false,
 24+ 'formName' => '',
 25+ 'botName' => '',
 26+ );
 27+ }
 28+
 29+ public static function getSettings() {
 30+ static $settings = false;
 31+
 32+ if ( $settings === false ) {
 33+ $settings = array_merge(
 34+ self::getDefaultSettings(),
 35+ $GLOBALS['egSemanticSignupSettings']
 36+ );
 37+ }
 38+
 39+ return $settings;
 40+ }
 41+
 42+ public static function get( $settingName ) {
 43+ $settings = self::getSettings();
 44+ return array_key_exists( $settingName, $settings ) ? $settings[$settingName] : null;
 45+ }
 46+
 47+}
Property changes on: branches/extensions-realtime/SemanticSignup/SemanticSignup.settings.php
___________________________________________________________________
Added: svn:eol-style
148 + native
Property changes on: branches/extensions-realtime/CodeReview
___________________________________________________________________
Modified: svn:mergeinfo
249 Merged /trunk/extensions/CodeReview:r94187-94267
Index: branches/extensions-realtime/MwEmbedSupport/MwEmbedModules/MwEmbedSupport/MwEmbedSupport.php
@@ -36,8 +36,9 @@
3737 ),
3838 'mediawiki.UtilitiesTime' => array( 'scripts' => 'mediawiki/mediawiki.UtilitiesTime.js' ),
3939 'mediawiki.client' => array( 'scripts' => 'mediawiki/mediawiki.client.js' ),
40 - 'mediawiki.Uri' => array( 'scripts' => 'mediawiki/mediawiki.Uri.js' ),
41 - 'mediawiki.absoluteUrl' => array( 'scripts' => 'mediawiki/mediawiki.absoluteUrl.js' ),
 40+ 'mediawiki.absoluteUrl' => array( 'scripts' => 'mediawiki/mediawiki.absoluteUrl.js',
 41+ 'dependancies' => array( 'mediawiki.Uri' ),
 42+ ),
4243
4344 'mediawiki.language.parser' => array(
4445 'scripts'=> 'mediawiki/mediawiki.language.parser.js',
Index: branches/extensions-realtime/MwEmbedSupport/MwEmbedModules/MwEmbedSupport/mediawiki/mediawiki.Uri.js
@@ -1,250 +0,0 @@
2 -/**
3 - * Library for simple URI parsing and manipulation. Requires jQuery.
4 - *
5 - * Do not expect full RFC 3986 compliance. Intended to be minimal, but featureful.
6 - * The use cases we have in mind are constructing 'next page' or 'previous page' URLs,
7 - * detecting whether we need to use cross-domain proxies for an API, constructing simple
8 - * URL-based API calls, etc.
9 - *
10 - * Intended to compress very well if you use a JS-parsing minifier.
11 - *
12 - * Dependencies: mw, mw.Utilities, jQuery
13 - *
14 - * Example:
15 - *
16 - * var uri = new mw.Uri( 'http://foo.com/mysite/mypage.php?quux=2' );
17 - *
18 - * if ( uri.host == 'foo.com' ) {
19 - * uri.host = 'www.foo.com';
20 - * uri.extend( { bar: 1 } );
21 - *
22 - * $( 'a#id1' ).setAttr( 'href', uri );
23 - * // anchor with id 'id1' now links to http://www.foo.com/mysite/mypage.php?bar=1&quux=2
24 - *
25 - * $( 'a#id2' ).setAttr( 'href', uri.clone().extend( { bar: 3, pif: 'paf' } ) );
26 - * // anchor with id 'id2' now links to http://www.foo.com/mysite/mypage.php?bar=3&quux=2&pif=paf
27 - * }
28 - *
29 - * Parsing here is regex based, so may not work on all URIs, but is good enough for most.
30 - *
31 - * Given a URI like
32 - * 'http://usr:pwd@www.test.com:81/dir/dir.2/index.htm?q1=0&&test1&test2=value+%28escaped%29#top':
33 - * The returned object will have the following properties:
34 - *
35 - * protocol 'http'
36 - * user 'usr'
37 - * password 'pwd'
38 - * host 'www.test.com'
39 - * port '81'
40 - * path '/dir/dir.2/index.htm'
41 - * query { q1: 0, test1: '', test2: 'value (escaped)' }
42 - * fragment 'top'
43 - *
44 - * n.b. 'password' is not technically allowed for HTTP URIs, but it is possible with other sorts of URIs.
45 - *
46 - * You can modify the properties directly. Then use the toString() method to extract the full URI string again.
47 - *
48 - * parsing based on parseUri 1.2.2 (c) Steven Levithan <stevenlevithan.com> MIT License
49 - * http://stevenlevithan.com/demo/parseuri/js/
50 - *
51 - */
52 -
53 -( function( mw, $ ) {
54 - /**
55 - * Constructs URI object. Throws error if arguments are illegal/impossible, or otherwise don't parse.
56 - * @constructor
57 - * @param {!Object|String} URI string, or an Object with appropriate properties (especially another URI object to clone). Object must have non-blank 'protocol', 'host', and 'path' properties.
58 - * @param {Boolean} strict mode (when parsing a string)
59 - */
60 - mw.Uri = function( uri, strictMode ) {
61 - strictMode = !!strictMode;
62 - if ( mw.isFull( uri ) ) {
63 - if ( typeof uri === 'string' ) {
64 - this._parse( uri, strictMode );
65 - } else if ( typeof uri === 'object' ) {
66 - var _this = this;
67 - $.each( this._properties, function( i, property ) {
68 - _this[property] = uri[property];
69 - } );
70 - if ( ! mw.isDefined( this.query ) ) {
71 - this.query = {};
72 - }
73 - }
74 - }
75 - //if ( !( this.protocol && this.host && this.path ) ) {
76 - // throw new Error( "bad constructor arguments for " + uri);
77 - //}
78 - };
79 -
80 - mw.Uri.prototype = {
81 -
82 - /**
83 - * Standard encodeURIComponent, with extra stuff to make all browsers work similarly and more compliant with RFC 3986
84 - * @param {String} string
85 - * @return {String} encoded for URI
86 - */
87 - encode: function( component ) {
88 - return encodeURIComponent( component )
89 - .replace( /!/g, '%21')
90 - .replace( /'/g, '%27')
91 - .replace( /\(/g, '%28')
92 - .replace( /\)/g, '%29')
93 - .replace( /\*/g, '%2A')
94 - .replace( /%20/g, '+' );
95 - },
96 -
97 - /**
98 - * Standard decodeURIComponent, with '+' to space
99 - * @param {String} string encoded for URI
100 - * @return {String} decoded string
101 - */
102 - decode: function( component ) {
103 - return decodeURIComponent( component ).replace( /\+/g, ' ' );
104 - },
105 -
106 - // regular expressions to parse many common URIs.
107 - // @private
108 - _parser: {
109 - strict: /^(?:([^:\/?#]+):)?(?:\/\/(?:(?:([^:@]*)(?::([^:@]*))?)?@)?([^:\/?#]*)(?::(\d*))?)?((?:[^?#\/]*\/)*[^?#]*)(?:\?([^#]*))?(?:#(.*))?/,
110 - loose: /^(?:(?![^:@]+:[^:@\/]*@)([^:\/?#.]+):)?(?:\/\/)?(?:(?:([^:@]*)(?::([^:@]*))?)?@)?([^:\/?#]*)(?::(\d*))?((?:\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?[^?#\/]*)(?:\?([^#]*))?(?:#(.*))?/
111 - },
112 -
113 - /* the order here matches the order of captured matches in the above parser regexes */
114 - // @private
115 - _properties: [
116 - "protocol", // http
117 - "user", // usr
118 - "password", // pwd
119 - "host", // www.test.com
120 - "port", // 81
121 - "path", // /dir/dir.2/index.htm
122 - "query", // q1=0&&test1&test2=value (will become { q1: 0, test1: '', test2: 'value' } )
123 - "fragment" // top
124 - ],
125 -
126 - /**
127 - * Parse a string and set our properties accordingly.
128 - * @param {String} URI
129 - * @param {Boolean} strictness
130 - * @return {Boolean} success
131 - */
132 - _parse: function( str, strictMode ) {
133 - var matches = this._parser[ strictMode ? "strict" : "loose" ].exec( str );
134 - var uri = this;
135 - $.each( uri._properties, function( i, property ) {
136 - uri[ property ] = matches[ i+1 ];
137 - } );
138 -
139 - // uri.query starts out as the query string; we will parse it into key-val pairs then make
140 - // that object the "query" property.
141 - // we overwrite query in uri way to make cloning easier, it can use the same list of properties.
142 - var query = {};
143 - // using replace to iterate over a string
144 - // JS 1.3 - function as parameter to replace
145 - // Note: uri does not work with repeated parameter names (e.g. foo=1&foo=2 )
146 - if ( uri.query ) {
147 - uri.query.replace( /(?:^|&)([^&=]*)=?([^&]*)/g, function ($0, $1, $2) {
148 - if ( $1 ) {
149 - query[ uri.decode( $1 ) ] = uri.decode( $2 );
150 - }
151 - } );
152 - }
153 - this.query = query;
154 - },
155 -
156 - /**
157 - * Returns user and password portion of a URI.
158 - * @return {String}
159 - */
160 - getUserInfo: function() {
161 - var userInfo = '';
162 - if ( mw.isFull( this.user ) ) {
163 - userInfo += this.encode( this.user );
164 - if ( mw.isFull( this.password ) ) {
165 - userInfo += ':' + this.encode( this.password );
166 - }
167 - }
168 - return userInfo;
169 - },
170 -
171 - /**
172 - * Gets host and port portion of a URI.
173 - * @return {String}
174 - */
175 - getHostPort: function() {
176 - return this.host
177 - + ( mw.isFull( this.port ) ? ':' + this.port
178 - : ''
179 - );
180 - },
181 -
182 - /**
183 - * Returns the userInfo and host and port portion of the URI.
184 - * In most real-world URLs, this is simply the hostname, but it is more general.
185 - * @return {String}
186 - */
187 - getAuthority: function() {
188 - var userInfo = this.getUserInfo();
189 - return ( mw.isFull( userInfo ) ? userInfo + '@'
190 - : ''
191 - )
192 - + this.getHostPort();
193 - },
194 -
195 - /**
196 - * Returns the query arguments of the URL, encoded into a string
197 - * Does not preserve the order of arguments passed into the URI. Does handle escaping.
198 - * @return {String}
199 - */
200 - getQueryString: function() {
201 - var pairs = [];
202 - var _this = this;
203 - $.each( this.query, function( key, value ) {
204 - pairs.push( _this.encode( key ) + '=' + _this.encode( value ) );
205 - } );
206 - return pairs.join( '&' );
207 - },
208 -
209 - /**
210 - * Returns everything after the authority section of the URI
211 - * @return {String}
212 - */
213 - getRelativePath: function() {
214 - var queryString = this.getQueryString();
215 - return this.path
216 - + ( mw.isFull( queryString ) ? '?' + queryString
217 - : ''
218 - )
219 - + ( mw.isFull( this.fragment ) ? '#' + this.encode( this.fragment )
220 - : ''
221 - );
222 - },
223 -
224 - /**
225 - * Gets the entire URI string. May not be precisely the same as input due to order of query arguments.
226 - * @return {String} the URI string
227 - */
228 - toString: function() {
229 - return this.protocol + '://' + this.getAuthority() + this.getRelativePath();
230 - },
231 -
232 - /**
233 - * Clone this URI
234 - * @return {Object} new URI object with same properties
235 - */
236 - clone: function() {
237 - return new mw.Uri( this );
238 - },
239 -
240 - /**
241 - * Extend the query -- supply query parameters to override or add to ours
242 - * @param {Object} query parameters in key-val form to override or add
243 - * @return {Object} this URI object
244 - */
245 - extend: function( parameters ) {
246 - $.extend( this.query, parameters );
247 - return this;
248 - }
249 - };
250 -
251 -} )( window.mediaWiki, jQuery );
Index: branches/extensions-realtime/SemanticResultFormats/RELEASE-NOTES
@@ -5,6 +5,7 @@
66 == SRF 1.6.1 ==
77
88 * Fixed rendering bug in the tagcloud format occuring for inline queries.
 9+* Fixed jqPlotBar and jqPlotPie rendering on Special:Ask and other special pages.
910
1011 == SRF 1.6 ==
1112
Index: branches/extensions-realtime/SemanticResultFormats/jqPlot/SRF_jqPlotPie.php
@@ -6,10 +6,6 @@
77 * @author Yaron Koren
88 */
99
10 -if ( !defined( 'MEDIAWIKI' ) ) {
11 - die( 'Not an entry point.' );
12 -}
13 -
1410 class SRFjqPlotPie extends SMWResultPrinter {
1511 protected $m_width = 400;
1612 protected $m_height = 400;
@@ -105,9 +101,7 @@
106102 }
107103
108104 protected function getResultText( SMWQueryResult $res, $outputmode ) {
109 - global $wgOut, $wgParser;
110 -
111 - $wgParser->disableCache();
 105+ global $wgOut;
112106
113107 $this->addJavascriptAndCSS();
114108
Index: branches/extensions-realtime/SemanticResultFormats/jqPlot/SRF_jqPlotBar.php
@@ -132,10 +132,8 @@
133133 }
134134
135135 protected function getResultText( SMWQueryResult $res, $outputmode ) {
136 - global $wgOut, $wgParser;
 136+ global $wgOut;
137137
138 - $wgParser->disableCache();
139 -
140138 self::addJavascriptAndCSS();
141139
142140 $this->isHTML = true;
Property changes on: branches/extensions-realtime/Vector/modules/ext.vector.simpleSearch.js
___________________________________________________________________
Modified: svn:mergeinfo
143141 Merged /trunk/extensions/Vector/modules/ext.vector.simpleSearch.js:r94187-94267
Property changes on: branches/extensions-realtime/Vector/modules/ext.vector.collapsibleTabs.js
___________________________________________________________________
Modified: svn:mergeinfo
144142 Merged /trunk/extensions/Vector/modules/ext.vector.collapsibleTabs.js:r94187-94267
Property changes on: branches/extensions-realtime/CentralNotice/CentralNoticeBannerLogPager.php
___________________________________________________________________
Added: svn:eol-style
145143 + native
Property changes on: branches/extensions-realtime/CentralNotice/CentralNoticePager.php
___________________________________________________________________
Added: svn:eol-style
146144 + native
Property changes on: branches/extensions-realtime/CentralNotice/CentralNoticeLogPager.php
___________________________________________________________________
Added: svn:eol-style
147145 + native
Property changes on: branches/extensions-realtime/HoneypotIntegration/HoneypotIntegration.class.php
___________________________________________________________________
Modified: svn:mergeinfo
148146 Merged /trunk/extensions/HoneypotIntegration/HoneypotIntegration.class.php:r94187-94267
Property changes on: branches/extensions-realtime/ContactPageFundraiser
___________________________________________________________________
Modified: svn:mergeinfo
149147 Merged /trunk/extensions/ContactPageFundraiser:r94187-94267
Index: branches/extensions-realtime/LocalisationUpdate/LocalisationUpdate.php
@@ -11,7 +11,7 @@
1212 /**
1313 * Directory to store serialized cache files in. Defaults to $wgCacheDirectory.
1414 * It's OK to share this directory among wikis as long as the wiki you run
15 - * update.php on has all extensions the other wikis using the same directory
 15+ * update.php on has all extensions the other wikis using the same directory
1616 * have.
1717 * NOTE: If this variable and $wgCacheDirectory are both false, this extension
1818 * WILL NOT WORK.
@@ -33,7 +33,6 @@
3434
3535 $wgLocalisationUpdateRetryAttempts = 5;
3636
37 -
3837 // Info about me!
3938 $wgExtensionCredits['other'][] = array(
4039 'path' => __FILE__,
Index: branches/extensions-realtime/LocalisationUpdate/LocalisationUpdate.class.php
@@ -2,21 +2,21 @@
33
44 /**
55 * Class for localization updates.
6 - *
 6+ *
77 * TODO: refactor code to remove duplication
88 */
99 class LocalisationUpdate {
10 -
 10+
1111 private static $newHashes = null;
1212 private static $filecache = array();
13 -
 13+
1414 /**
1515 * LocalisationCacheRecache hook handler.
16 - *
 16+ *
1717 * @param $lc LocalisationCache
1818 * @param $langcode String
1919 * @param $cache Array
20 - *
 20+ *
2121 * @return true
2222 */
2323 public static function onRecache( LocalisationCache $lc, $langcode, array &$cache ) {
@@ -24,50 +24,50 @@
2525 $cache['messages'],
2626 self::readFile( $langcode )
2727 );
28 -
 28+
2929 $cache['deps'][] = new FileDependency(
3030 self::filename( $langcode )
3131 );
32 -
 32+
3333 return true;
3434 }
3535
3636 /**
3737 * Called from the cronjob to fetch new messages from SVN.
38 - *
 38+ *
3939 * @param $options Array
40 - *
 40+ *
4141 * @return true
4242 */
4343 public static function updateMessages( array $options ) {
4444 global $wgLocalisationUpdateDirectory;
45 -
 45+
4646 $verbose = !isset( $options['quiet'] );
4747 $all = isset( $options['all'] );
4848 $skipCore = isset( $options['skip-core'] );
4949 $skipExtensions = isset( $options['skip-extensions'] );
50 -
 50+
5151 if( isset( $options['outdir'] ) ) {
5252 $wgLocalisationUpdateDirectory = $options['outdir'];
5353 }
54 -
 54+
5555 $result = 0;
56 -
 56+
5757 // Update all MW core messages.
5858 if( !$skipCore ) {
5959 $result = self::updateMediawikiMessages( $verbose );
6060 }
61 -
 61+
6262 // Update all Extension messages.
6363 if( !$skipExtensions ) {
6464 if( $all ) {
6565 global $IP;
6666 $extFiles = array();
67 -
 67+
6868 // Look in extensions/ for all available items...
6969 // TODO: add support for $wgExtensionAssetsPath
7070 $dirs = new RecursiveDirectoryIterator( "$IP/extensions/" );
71 -
 71+
7272 // I ain't kidding... RecursiveIteratorIterator.
7373 foreach( new RecursiveIteratorIterator( $dirs ) as $pathname => $item ) {
7474 $filename = basename( $pathname );
@@ -85,30 +85,30 @@
8686 $result += self::updateExtensionMessages( $locFile, $extension, $verbose );
8787 }
8888 }
89 -
 89+
9090 self::writeHashes();
9191
9292 // And output the result!
9393 self::myLog( "Updated {$result} messages in total" );
9494 self::myLog( "Done" );
95 -
 95+
9696 return true;
9797 }
9898
9999 /**
100100 * Update Extension Messages.
101 - *
 101+ *
102102 * @param $file String
103103 * @param $extension String
104104 * @param $verbose Boolean
105 - *
 105+ *
106106 * @return Integer: the amount of updated messages
107107 */
108108 public static function updateExtensionMessages( $file, $extension, $verbose ) {
109109 global $IP, $wgLocalisationUpdateSVNURL;
110 -
 110+
111111 $relfile = wfRelativePath( $file, "$IP/extensions" );
112 -
 112+
113113 // Create a full path.
114114 // TODO: add support for $wgExtensionAssetsPath
115115 $localfile = "$IP/extensions/$relfile";
@@ -119,15 +119,15 @@
120120
121121 // Compare the 2 files.
122122 $result = self::compareExtensionFiles( $extension, $svnfile, $file, $verbose, false, true );
123 -
 123+
124124 return $result;
125125 }
126126
127127 /**
128128 * Update the Mediawiki Core Messages.
129 - *
 129+ *
130130 * @param $verbose Boolean
131 - *
 131+ *
132132 * @return Integer: the amount of updated messages
133133 */
134134 public static function updateMediawikiMessages( $verbose ) {
@@ -173,22 +173,22 @@
174174
175175 // Compare the files.
176176 $result = self::compareFiles( $svnfile, $localfile, $verbose, $changedEnglishStrings, false, true );
177 -
 177+
178178 // And update the change counter.
179179 $changedCount += count( $result );
180180 }
181181
182182 // Log some nice info.
183183 self::myLog( "{$changedCount} Mediawiki messages are updated" );
184 -
 184+
185185 return $changedCount;
186186 }
187187
188188 /**
189189 * Removes all unneeded content from a file and returns it.
190 - *
 190+ *
191191 * @param $contents String
192 - *
 192+ *
193193 * @return String
194194 */
195195 public static function cleanupFile( $contents ) {
@@ -199,9 +199,9 @@
200200 '?' . '>' => ''
201201 )
202202 );
203 -
 203+
204204 $results = array();
205 -
 205+
206206 // And we only want the messages array.
207207 preg_match( "/\\\$messages(.*\s)*?\);/", $contents, $results );
208208
@@ -218,26 +218,26 @@
219219 // Return the cleaned up file.
220220 return $contents;
221221 }
222 -
 222+
223223 /**
224224 * Removes all unneeded content from a file and returns it.
225 - *
226 - * FIXME: duplicated cleanupFile code
227 - *
 225+ *
 226+ * FIXME: duplicated cleanupFile code
 227+ *
228228 * @param $contents String
229 - *
 229+ *
230230 * @return string
231231 */
232232 public static function cleanupExtensionFile( $contents ) {
233233 // We don't want PHP tags.
234234 $contents = preg_replace( "/<\?php/", "", $contents );
235235 $contents = preg_replace( "/\?" . ">/", "", $contents );
236 -
 236+
237237 $results = array();
238 -
 238+
239239 // And we only want message arrays.
240240 preg_match_all( "/\\\$messages(.*\s)*?\);/", $contents, $results );
241 -
 241+
242242 // But we want them all in one string.
243243 if( !empty( $results[0] ) && is_array( $results[0] ) ) {
244244 $contents = implode( "\n\n", $results[0] );
@@ -247,23 +247,23 @@
248248
249249 // And we hate the windows vs linux linebreaks.
250250 $contents = preg_replace( "/\\\r\\\n?/", "\n", $contents );
251 -
 251+
252252 return $contents;
253 - }
 253+ }
254254
255255 /**
256256 * Returns the contents of a file or false on failiure.
257 - *
 257+ *
258258 * @param $basefile String
259 - *
 259+ *
260260 * @return string or false
261261 */
262262 public static function getFileContents( $basefile ) {
263263 global $wgLocalisationUpdateRetryAttempts;
264 -
 264+
265265 $attempts = 0;
266266 $basefilecontents = '';
267 -
 267+
268268 // Use cURL to get the SVN contents.
269269 if ( preg_match( "/^http/", $basefile ) ) {
270270 while( !$basefilecontents && $attempts <= $wgLocalisationUpdateRetryAttempts ) {
@@ -272,7 +272,7 @@
273273 self::myLog( 'Failed to download ' . $basefile . "; retrying in ${delay}s..." );
274274 sleep( $delay );
275275 }
276 -
 276+
277277 $basefilecontents = Http::get( $basefile );
278278 $attempts++;
279279 }
@@ -286,20 +286,20 @@
287287 return false;
288288 }
289289 }
290 -
 290+
291291 return $basefilecontents;
292292 }
293293
294294 /**
295295 * Returns an array containing the differences between the files.
296 - *
 296+ *
297297 * @param $basefile String
298298 * @param $comparefile String
299299 * @param $verbose Boolean
300300 * @param $forbiddenKeys Array
301301 * @param $alwaysGetResult Boolean
302302 * @param $saveResults Boolean
303 - *
 303+ *
304304 * @return array
305305 */
306306 public static function compareFiles( $basefile, $comparefile, $verbose, array $forbiddenKeys = array(), $alwaysGetResult = true, $saveResults = false ) {
@@ -307,7 +307,7 @@
308308 $langcode = Language::getCodeFromFileName( $basefile, 'Messages' );
309309
310310 $basefilecontents = self::getFileContents( $basefile );
311 -
 311+
312312 if ( $basefilecontents === false || $basefilecontents === '' ) {
313313 return array(); // Failed
314314 }
@@ -318,7 +318,7 @@
319319 // Change the variable name.
320320 $basefilecontents = preg_replace( "/\\\$messages/", "\$base_messages", $basefilecontents );
321321 $basehash = md5( $basefilecontents );
322 -
 322+
323323 // Check if the file has changed since our last update.
324324 if ( !$alwaysGetResult ) {
325325 if ( !self::checkHash( $basefile, $basehash ) ) {
@@ -331,7 +331,7 @@
332332 $base_messages = self::parsePHP( $basefilecontents, 'base_messages' );
333333
334334 $comparefilecontents = self::getFileContents( $comparefile );
335 -
 335+
336336 if ( $comparefilecontents === false || $comparefilecontents === '' ) {
337337 return array(); // Failed
338338 }
@@ -342,7 +342,7 @@
343343 // Rename the array.
344344 $comparefilecontents = preg_replace( "/\\\$messages/", "\$compare_messages", $comparefilecontents );
345345 $comparehash = md5( $comparefilecontents );
346 -
 346+
347347 // If this is the remote file check if the file has changed since our last update.
348348 if ( preg_match( "/^http/", $comparefile ) && !$alwaysGetResult ) {
349349 if ( !self::checkHash( $comparefile, $comparehash ) ) {
@@ -350,7 +350,7 @@
351351 return array();
352352 }
353353 }
354 -
 354+
355355 // Get the array.
356356 $compare_messages = self::parsePHP( $comparefilecontents, 'compare_messages' );
357357
@@ -378,69 +378,69 @@
379379 } elseif ( $saveResults ) {
380380 self::myLog( "--{$langcode} hasn't changed--", $verbose );
381381 }
382 -
 382+
383383 self::saveHash( $basefile, $basehash );
384 -
 384+
385385 self::saveHash( $comparefile, $comparehash );
386 -
 386+
387387 return $changedStrings;
388388 }
389389
390390 /**
391391 * Checks whether a messages file has a certain hash.
392 - *
 392+ *
393393 * TODO: Swap return values, this is insane
394 - *
 394+ *
395395 * @param $file string Filename
396396 * @param $hash string Hash
397 - *
 397+ *
398398 * @return bool True if $file does NOT have hash $hash, false if it does
399399 */
400400 public static function checkHash( $file, $hash ) {
401401 $hashes = self::readFile( 'hashes' );
402402 return @$hashes[$file] !== $hash;
403403 }
404 -
 404+
405405 public static function saveHash( $file, $hash ) {
406406 if ( is_null( self::$newHashes ) ) {
407407 self::$newHashes = self::readFile( 'hashes' );
408408 }
409 -
 409+
410410 self::$newHashes[$file] = $hash;
411411 }
412 -
 412+
413413 public static function writeHashes() {
414414 self::writeFile( 'hashes', self::$newHashes );
415415 }
416416
417417 /**
418 - *
419 - *
 418+ *
 419+ *
420420 * @param $changedStrings Array
421421 * @param $forbiddenKeys Array
422422 * @param $compare_messages Array
423423 * @param $base_messages Array
424424 * @param $langcode String
425425 * @param $verbose Boolean
426 - *
 426+ *
427427 * @return Integer: the amount of updated messages
428428 */
429429 public static function saveChanges( $changedStrings, array $forbiddenKeys, array $compare_messages, array $base_messages, $langcode, $verbose ) {
430430 // Count the updates.
431431 $updates = 0;
432 -
 432+
433433 if( !is_array( $changedStrings ) ) {
434434 self::myLog("CRITICAL ERROR: \$changedStrings is not an array in file " . (__FILE__) . ' at line ' .( __LINE__ ) );
435435 return 0;
436436 }
437437
438438 $new_messages = self::readFile( $langcode );
439 -
 439+
440440 foreach ( $changedStrings as $key => $value ) {
441441 // If this message wasn't changed in English.
442442 if ( !isset( $forbiddenKeys[$key] ) ) {
443443 $new_messages[$key] = $base_messages[$key];
444 -
 444+
445445 // Output extra logmessages when needed.
446446 if ( $verbose ) {
447447 $oldmsg = isset( $compare_messages[$key] ) ? "'{$compare_messages[$key]}'" : 'not set';
@@ -452,26 +452,26 @@
453453 }
454454 }
455455 self::writeFile( $langcode, $new_messages );
456 -
 456+
457457 return $updates;
458458 }
459459
460460 /**
461 - *
 461+ *
462462 * @param $extension String
463463 * @param $basefile String
464464 * @param $comparefile String
465465 * @param $verbose Boolean
466466 * @param $alwaysGetResult Boolean
467467 * @param $saveResults Boolean
468 - *
 468+ *
469469 * @return Integer: the amount of updated messages
470470 */
471471 public static function compareExtensionFiles( $extension, $basefile, $comparefile, $verbose, $alwaysGetResult = true, $saveResults = false ) {
472472 // FIXME: Factor out duplicated code?
473473
474474 $basefilecontents = self::getFileContents( $basefile );
475 -
 475+
476476 if ( $basefilecontents === false || $basefilecontents === '' ) {
477477 return 0; // Failed
478478 }
@@ -482,7 +482,7 @@
483483 // Rename the arrays.
484484 $basefilecontents = preg_replace( "/\\\$messages/", "\$base_messages", $basefilecontents );
485485 $basehash = md5( $basefilecontents );
486 -
 486+
487487 // If this is the remote file
488488 if ( preg_match( "/^http/", $basefile ) && !$alwaysGetResult ) {
489489 // Check if the hash has changed
@@ -578,21 +578,21 @@
579579 } elseif($saveResults === true) {
580580 self::myLog( "--{$language} hasn't changed--", $verbose );
581581 }
582 - }
 582+ }
583583
584584 // And log some stuff.
585585 self::myLog( "Updated " . $updates . " messages for the '{$extension}' extension", $verbose );
586586
587587 self::saveHash( $basefile, $basehash );
588 -
 588+
589589 self::saveHash( $comparefile, $comparehash );
590 -
 590+
591591 return $updates;
592592 }
593 -
 593+
594594 /**
595595 * Logs a message.
596 - *
 596+ *
597597 * @param $log String
598598 */
599599 public static function myLog( $log, $verbose = true ) {
@@ -605,7 +605,7 @@
606606 print( $log . "\n" );
607607 }
608608 }
609 -
 609+
610610 public static function parsePHP( $php, $varname ) {
611611 try {
612612 $reader = new QuickArrayReader("<?php $php");
@@ -615,32 +615,32 @@
616616 return false;
617617 }
618618 }
619 -
 619+
620620 public static function filename( $lang ) {
621621 global $wgLocalisationUpdateDirectory, $wgCacheDirectory;
622 -
 622+
623623 $dir = $wgLocalisationUpdateDirectory ?
624624 $wgLocalisationUpdateDirectory :
625625 $wgCacheDirectory;
626 -
 626+
627627 if ( !$dir ) {
628628 throw new MWException( 'No cache directory configured' );
629629 }
630 -
 630+
631631 return "$dir/l10nupdate-$lang.cache";
632632 }
633 -
 633+
634634 public static function readFile( $lang ) {
635635 if ( !isset( self::$filecache[$lang] ) ) {
636636 $file = self::filename( $lang );
637637 $contents = @file_get_contents( $file );
638 -
 638+
639639 if ( $contents === false ) {
640640 wfDebug( "Failed to read file '$file'\n" );
641641 $retval = array();
642642 } else {
643643 $retval = unserialize( $contents );
644 -
 644+
645645 if ( $retval === false ) {
646646 wfDebug( "Corrupted data in file '$file'\n" );
647647 $retval = array();
@@ -648,18 +648,18 @@
649649 }
650650 self::$filecache[$lang] = $retval;
651651 }
652 -
 652+
653653 return self::$filecache[$lang];
654654 }
655 -
 655+
656656 public static function writeFile( $lang, $var ) {
657657 $file = self::filename( $lang );
658 -
 658+
659659 if ( !@file_put_contents( $file, serialize( $var ) ) ) {
660660 throw new MWException( "Failed to write to file '$file'" );
661661 }
662 -
 662+
663663 self::$filecache[$lang] = $var;
664664 }
665 -
666 -}
\ No newline at end of file
 665+
 666+}
Property changes on: branches/extensions-realtime/LocalisationUpdate
___________________________________________________________________
Modified: svn:mergeinfo
667667 Merged /trunk/extensions/LocalisationUpdate:r94187-94267
Property changes on: branches/extensions-realtime/StringFunctionsEscaped
___________________________________________________________________
Modified: svn:mergeinfo
668668 Merged /trunk/extensions/StringFunctionsEscaped:r94187-94267
Index: branches/extensions-realtime/MobileFrontend/MobileFrontend.php
@@ -49,7 +49,7 @@
5050 $wgHooks['SkinTemplateOutputPageBeforeExec'][] = array( &$wgExtMobileFrontend, 'addMobileFooter' );
5151
5252 class ExtMobileFrontend {
53 - const VERSION = '0.5.14';
 53+ const VERSION = '0.5.18';
5454
5555 /**
5656 * @var DOMDocument
@@ -173,34 +173,6 @@
174174 self::$title = $out->getTitle();
175175 self::$htmlTitle = $out->getHTMLTitle();
176176
177 - // Need to get copyright footer from skin. The footer changes depending
178 - // on whether we're using the WikimediaMessages extension or not.
179 - //$skin = $wgUser->getSkin();
180 - //$copyright = $skin->getCopyright();
181 -
182 - // Need to stash the results of the "wfMsg" call before the Output Buffering handler
183 - // because at this point the database connection is shut down, etc.
184 - //self::$messages['mobile-frontend-show'] = wfMsg( 'mobile-frontend-show-button' );
185 - //self::$messages['mobile-frontend-hide'] = wfMsg( 'mobile-frontend-hide-button' );
186 - //self::$messages['mobile-frontend-back-to-top'] = wfMsg( 'mobile-frontend-back-to-top-of-section' );
187 - //self::$messages['mobile-frontend-regular-site'] = wfMsg( 'mobile-frontend-regular-site' );
188 - //self::$messages['mobile-frontend-perm-stop-redirect'] = wfMsg( 'mobile-frontend-perm-stop-redirect' );
189 - //self::$messages['mobile-frontend-copyright'] = $copyright;
190 - //self::$messages['mobile-frontend-home-button'] = wfMsg( 'mobile-frontend-home-button' );
191 - //self::$messages['mobile-frontend-random-button'] = wfMsg( 'mobile-frontend-random-button' );
192 - //self::$messages['mobile-frontend-are-you-sure'] = wfMsg( 'mobile-frontend-are-you-sure' );
193 - //self::$messages['mobile-frontend-explain-disable'] = wfMsg( 'mobile-frontend-explain-disable' );
194 - //self::$messages['mobile-frontend-disable-button'] = wfMsg( 'mobile-frontend-disable-button' );
195 - //self::$messages['mobile-frontend-back-button'] = wfMsg( 'mobile-frontend-back-button' );
196 -
197 - //self::$dir = $wgContLang->getDir();
198 - //self::$code = $wgContLang->getCode();
199 -
200 - self::$disableImages = $wgRequest->getText( 'disableImages', 0 );
201 -
202 - //self::$mainPageUrl = Title::newMainPage()->getLocalUrl();
203 - //self::$randomPageUrl = SpecialPage::getTitleFor( 'Randompage' )->getLocalUrl();
204 -
205177 $userAgent = $_SERVER['HTTP_USER_AGENT'];
206178 $uAmd5 = md5($userAgent);
207179
@@ -234,6 +206,8 @@
235207 // This is stated to be intended behavior, as per the following: [http://bugs.php.net/bug.php?id=40104]
236208
237209 $mAction = $wgRequest->getText( 'mAction' );
 210+ $action = $wgRequest->getText( 'action' );
 211+ self::$disableImages = $wgRequest->getText( 'disableImages', 0 );
238212 self::$useFormat = $wgRequest->getText( 'useFormat' );
239213 self::$format = $wgRequest->getText( 'format' );
240214 self::$requestedSegment = $wgRequest->getText( 'seg', 0 );
@@ -277,11 +251,11 @@
278252 }
279253
280254 if ( $mAction == 'opt_in_cookie' ) {
281 - $wgRequest->response()->setcookie( 'optin', '1' );
 255+ $this->setOptInOutCookie( '1' );
282256 }
283257
284258 if ( $mAction == 'opt_out_cookie' ) {
285 - $wgRequest->response()->setcookie( 'optin', '' );
 259+ $this->setOptInOutCookie( '' );
286260 }
287261
288262 // Note: Temporarily disabling this section for trial deployment
@@ -320,18 +294,40 @@
321295
322296 // Determine
323297
324 - $xDevice = $_SERVER['HTTP_X_DEVICE'];
 298+ $xDevice = isset( $_SERVER['HTTP_X_DEVICE'] ) ? $_SERVER['HTTP_X_DEVICE'] : '';
325299
326300 if (self::$useFormat === 'mobile' ||
327301 self::$useFormat === 'mobile-wap' ||
328 - isset( $xDevice ) ) {
329 - $this->getMsg();
330 - $this->disableCaching();
331 - ob_start( array( $this, 'DOMParse' ) );
 302+ !empty( $xDevice ) ) {
 303+ if ( $action !== 'edit' ) {
 304+ $this->getMsg();
 305+ $this->disableCaching();
 306+ ob_start( array( $this, 'DOMParse' ) );
 307+ }
332308 }
333309
334310 return true;
335311 }
 312+
 313+ private function setOptInOutCookie( $value ) {
 314+ global $wgCookieDomain, $wgRequest;
 315+ $tempWgCookieDomain = $wgCookieDomain;
 316+ $wgCookieDomain = $this->getBaseDomain();
 317+ $wgRequest->response()->setcookie( 'optin', $value );
 318+ $wgCookieDomain = $tempWgCookieDomain;
 319+ }
 320+
 321+ private function getBaseDomain() {
 322+ //Validates value as IP address
 323+ if( !filter_var( $_SERVER['HTTP_HOST'], FILTER_VALIDATE_IP ) ) {
 324+ $domainParts = explode( '.', $_SERVER['HTTP_HOST'] );
 325+ $domainParts = array_reverse( $domainParts );
 326+ //Although some browsers will accept cookies without the initial ., » RFC 2109 requires it to be included.
 327+ return '.' . $domainParts[1] . '.' . $domainParts[0];
 328+ } else {
 329+ return $_SERVER['HTTP_HOST'];
 330+ }
 331+ }
336332
337333 private function disableCaching() {
338334 if ( isset( $_SERVER['HTTP_VIA'] ) &&
Property changes on: branches/extensions-realtime/CategoryTree/CategoryTreeFunctions.php
___________________________________________________________________
Modified: svn:mergeinfo
339335 Merged /trunk/extensions/CategoryTree/CategoryTreeFunctions.php:r94187-94267
Index: branches/extensions-realtime/AjaxLogin/AjaxLogin.php
@@ -43,7 +43,7 @@
4444 // Hook things up
4545 $wgHooks['BeforePageDisplay'][] = 'AjaxLoginJS';
4646 $wgHooks['SkinAfterContent'][] = 'GetAjaxLoginForm';
47 -$wgHooks['ResourceLoaderConfigVars'][] = 'efAddAjaxLoginVariables';
 47+$wgHooks['ResourceLoaderGetConfigVars'][] = 'efAddAjaxLoginVariables';
4848
4949 /**
5050 * Adds required JavaScript & CSS files to the HTML output of a page if AjaxLogin is enabled
Property changes on: branches/extensions-realtime/StrategyWiki/ActiveStrategy
___________________________________________________________________
Modified: svn:mergeinfo
5151 Merged /trunk/extensions/StrategyWiki/ActiveStrategy:r94187-94267
Property changes on: branches/extensions-realtime/StrategyWiki
___________________________________________________________________
Modified: svn:mergeinfo
5252 Merged /trunk/extensions/StrategyWiki:r94187-94267
Property changes on: branches/extensions-realtime
___________________________________________________________________
Added: svn:mergeinfo
5353 Merged /trunk/extensions:r94187-94267

Past revisions this follows-up on

RevisionCommit summaryAuthorDate
r94187svn:eol-style nativeialex19:18, 10 August 2011

Status & tagging log