Zum Inhalt springen

Benutzer:TMg/autoFormatter.js/Beta.js

aus Wikipedia, der freien Enzyklopädie
Dies ist eine alte Version dieser Seite, zuletzt bearbeitet am 7. August 2012 um 19:45 Uhr durch TMg (Diskussion | Beiträge) (Modularisierung des bestehenden Quelltextes; neue Funktionen: Permalinks umwandeln; Weblinks protokollrelativ machen; Zusammenfassungszeile säubern). Sie kann sich erheblich von der aktuellen Version unterscheiden.
(Unterschied) ← Nächstältere Version | Aktuelle Version (Unterschied) | Nächstjüngere Version → (Unterschied)

Hinweis: Leere nach dem Veröffentlichen den Browser-Cache, um die Änderungen sehen zu können.

  • Firefox/Safari: Umschalttaste drücken und gleichzeitig Aktualisieren anklicken oder entweder Strg+F5 oder Strg+R (⌘+R auf dem Mac) drücken
  • Google Chrome: Umschalttaste+Strg+R (⌘+Umschalttaste+R auf dem Mac) drücken
  • Edge: Strg+F5 drücken oder Strg drücken und gleichzeitig Aktualisieren anklicken
/**
 * Blendet eine „Auto-Format“-Funktion in der Werkzeugleiste ein, die viele typische Wikifizierungs-Fehler
 * automatisch korrigiert. Eine ausführliche Beschreibung ist auf der Diskussionsseite zu finden.
 */
(function($, mw)
{
	var autoFormatter = {
		click: function(a)
		{
			var elements = document.forms['editform'].elements;
			var textbox = elements['wpTextbox1'], summary = elements['wpSummary'];
			this.isDisambiguation = /\{\{\s*[Bb]egriffsklärung\s*\}\}/.test(textbox.value);

			var t = textbox.value;
			/* Überflüssige Leerräume entfernen, aber das allein rechtfertigt keinen Edit */
			t = t.replace(/\s+$/, '');
			t = t.replace(/[ \t\r]+\n/g, '\n');
			textbox.value = t;

			t = this.cleanText(t);
			var changed = t !== textbox.value.replace(/\r+\n/g, '\n');
			if (changed) textbox.value = t.replace(/\s+$/, '');
			summary.value = this.cleanInternalLinks(summary.value);

			if ((!a || !a.nodeType || a.nodeName === 'IMG') && $) /* Vector/Monobook */
			{
				var e = $(a && a.nodeType ? a : 'img[rel=autoFormatter]');
				e.css('backgroundColor', changed ? '#DEF740' : '');
				e.css('borderRadius', changed ? '3px' : '');
				e.css('opacity', changed ? '' : '.4');
			}
			else if (a) a.style.color = changed ? 'green' : 'silver';
			return false;
		},
		cleanText: function(t)
		{
			/* Steuerzeichen, undefinierte Unicode-Nummern, LRM, ZERO WIDTH SPACE, BOM entfernen */
			t = t.replace(/[\x00-\x08\x0C\x0E-\x1F\x7F-\x9F\u200B\u200E\uFEFF]+/g, '');
			/* Mehrfache Leerzeilen auf einzelne reduzieren */
			if (!this.isDisambiguation) t = t.replace(/([ \t\r]*\n){3,}/g, '\n\n');
			/* Geschützte Leerzeichen einheitlich als " ", vereinfacht viele folgende Suchmuster */
			t = t.replace(/&#(x0*A|0*16)0 *;/gi, ' ');
			/* Die verschiedensten Formen der Zeilenumbrüche durch korrekte ersetzen */
			t = t.replace(/<[\s\/]*br\s*(\s\w[^>]*?)?[\s\/]*>/gi, '<br$1 />');

			t = this.backupFilenames(t);

			/* == Überschriften == immer mit Leerzeichen, repariert auch kaputte Überschriften */
			t = t.replace(/^(=+) *(.*[^ =]) *\1$/gm, '$1 $2 $1');

			/* Weblinks immer als Weblinks */
			t = t.replace(/^== *(External|Externer?)? *(Links?|Weblinks?|Webseiten?|Websites?) *==/gim,
				'== Weblinks ==');

			/* Einheitliche Schreibweisen für Schlüsselwörter incl. Leerzeichenausgleich */
			t = t.replace(/\[\[\s*(Category|Kategorie)\s*:\s*/gi, '[[Kategorie:');
			t = t.replace(/(\[\[Datei:[^\]]*?)\s*\|+\s*((rechts|right)\s*\|+\s*)?(miniatur|thumb)\s*\|+\s*((rechts|right)\s*\|+\s*)?/gi, '$1|miniatur|');
			t = t.replace(/(\[\[Datei:[^\]]*?)\s*\|+\s*(rechts|right)\s*\|+\s*/gi, '$1|rechts|');
			t = t.replace(/(\[\[Datei:[^\]]*?)\s*\|+\s*(links|left)\s*\|+\s*/gi, '$1|links|');
			t = t.replace(/(\[\[Datei:[^\]]*?)\s*\|+\s*(hochkant|upright)\s*((=)\s*([\d.]*))?\s*\|+\s*/gi, '$1|hochkant$4$5|');
			t = t.replace(/\{\{\s*(Template|Vorlage)\s*:\s*/gi, '{{');
			t = t.replace(/\{\{\s*Commons(cat\s*\|(\s*(Category|Kategorie)\s*:)?|\s*\|\s*(Category|Kategorie)\s*:)\s*/gi, '{{Commonscat|');
			t = t.replace(/\{\{\s*Commons\s*\|\s*/gi, '{{Commons|');
			t = t.replace(/\{\{\s*Wikisource\s*\|\s*/gi, '{{Wikisource|');
			t = t.replace(/\{\{\s*Wiktionary\s*\|\s*/gi, '{{Wiktionary|');
			t = t.replace(/\s*#(REDIRECT|WEITERLEITUNG)\s*\[\[/gi, '#WEITERLEITUNG [[');
			t = t.replace(/\s*<\s*\/\s*ref\s*>/gi, '</ref>');
			t = t.replace(/<\s*references\s*\/\s*>/gi, '<references />');
			t = t.replace(/class\s*=\s*("(\s*[^\s"]+\s)*)?\s*\bprettytable\b/g, 'class=$1wikitable');

			t = this.cleanDefaultSort(t);
			t = this.cleanInternalLinks(t);

			/* Jede Kategorie in einer eigenen Zeile */
			t = t.replace(/(\[\[Kategorie:[^\[\]\n]*\]\]) *(?!\n|$)/gi, '$1\n');
			t = t.replace(/([^\n])(\[\[Kategorie:[^\[\]\n]*\]\])/gi, '$1\n$2');
			t = t.replace(/(\[\[Kategorie:[^\[\]\n]*\]\]\n)(?!\[\[Kategorie:|\n|$)/gi, '$1\n');

			/* Versehentliche Links um ISO-Daten entfernen */
			t = t.replace(/\[+([12]\d{3}-[01]\d-[0-3]\d)\]+/g, '$1');
			t = this.cleanDuplicateLinks(t);

			/* Unnötige Leerzeichen bei HTML-Attributen, wichtig vor den Anführungszeichen */
			while (/[<|][^|>]*\b *= +"/im.test(t))
				t = t.replace(/([<|][^|>]*)\b *= +"/gim, '$1="');
			/* Anführungszeichen */
			t = t.replace(/([^\w={])["“]([^\n"“”]+)["”]([^\w|])/gm, '$1„$2“$3');
			/* Bis-Striche bei Jahreszahlen */
			t = t.replace(/([\s(|][12]\d{3}) *[–-] *([12]\d{3}[^\d–-])/g, '$1–$2');
			/* ISSNs aber ohne Bis-Striche */
			t = t.replace(/(IS\wN\W*\d+)–(\d)/g, '$1-$2');

			t = this.cleanISBNs(t);
			t = this.cleanDates(t);

			/* Gedankenstriche in <math> vermeiden */
			t = t.replace(/([a-z\]\xC0-\xFF]) +- +([a-z\[\xC0-\xFF])/gi, '$1 – $2');

			/* Maßeinheiten immer mit Leerzeichen */
			t = t.replace(/\b(\d+) ?([mck]?m|kg|[KMG]iB|[kMG](B|Hz)|KB)\b(?![\xC0-\xFF])/g, '$1&nbsp;$2');
			/* Prozentwerte erhalten seit Mitte 2007 automatisch ein geschütztes Leerzeichen */
			t = t.replace(/\b(\d+)(&nbsp;)?(%[^\w"%;])/gi, '$1 $3');
			/* Paragraf, Abs. und Satz mit geschützten Leerzeichen */
			t = t.replace(/§( |&nbsp;)+(\d+\w* +Abs\.)( |&nbsp;)+(\d+ +Satz) +(\d+)/gi,
				'§&nbsp;$2&nbsp;$4&nbsp;$5');
			t = t.replace(/§( |&nbsp;)+(\d+\w* +Abs\.) +(\d+)/gi,
				'§&nbsp;$2&nbsp;$3');
			t = t.replace(/§ +(\d+)/gi,
				'§&nbsp;$1');

			t = this.executeUserReplacements(t);

			/* Keine geschützten Leerzeichen in Überschriften */
			while (/^=.*&nbsp;.*=$/m.test(t))
				t = t.replace(/^(=.*)&nbsp;(.*=)$/gm, '$1 $2');

			t = this.cleanRedundantTemplateParameters(t);
			t = this.cleanInfoboxVerwaltungseinheitInDeutschland(t);
			t = this.restoreFilenames(t);
			return t;
		},
		cleanInternalLinks: function(t)
		{
			var lang = mw.config.get('wgPageContentLanguage');
			var ns = mw.config.get('wgFormattedNamespaces')[-1];

			/* Permanente Weblinks in Spezialseiten-Syntax umwandeln */
			var permaLinkReplace = function($0, $1, $2, $3)
			{
				return '[[:' + $1 + ':' +
					($1 === lang ? ns : 'Special') + ':' +
					($1 === 'de' ? 'Permanenter Link' : 'PermanentLink') + '/' + $2 +
					(typeof $3 === 'string' ? '|' + $3 : '') + ']]';
			}
			/* Weblinks auf Sprachversionen (auch auf die eigene) in Wikilinks umwandeln */
			var interWikiReplace = function($0, $1, $2, $3)
			{
				return '[[:' + $1 + ':' + $2.replace(/_/g, ' ') +
					(typeof $3 === 'string' ? '|' + $3 : '') + ']]';
			}
			/* Schreibweise [[Weblink#Anker mit Leerzeichen|Beschriftung]] reparieren */
			t = t.replace(/\[+ *(?:https?:)?\/\/([a-z-]+)\.wikipedia\.org\/w\/[^|\[\]\s]*\boldid=([^?|\[\]\n]+?) *\|+ *([^|\[\]\n]+?) *\]+/gi, permaLinkReplace);
			t = t.replace(/\[+ *(?:https?:)?\/\/([a-z-]+)\.wikipedia\.org\/wiki\/([^?|\[\]\n]*?) *\|+ *([^|\[\]\n]+?) *\]+/gi, interWikiReplace);
			/* Schreibweise [Weblink#Anker Beschriftung] umwandeln */
			t = t.replace(/\[+ *(?:https?:)?\/\/([a-z-]+)\.wikipedia\.org\/w\/[^|\[\]\s]*\boldid=([^?|\[\]\s]+) +([^|\[\]\n]+?) *\]+/gi, permaLinkReplace);
			t = t.replace(/\[+ *(?:https?:)?\/\/([a-z-]+)\.wikipedia\.org\/wiki\/([^?|\[\]\s]*) +([^|\[\]\n]+?) *\]+/gi, interWikiReplace);
			/* Schreibweise [Weblink#Anker] umwandeln */
			t = t.replace(/\[+ *(?:https?:)?\/\/([a-z-]+)\.wikipedia\.org\/w\/[^|\[\]\s]*\boldid=([^?|\[\]\s]+) *\]+/gi, permaLinkReplace);
			t = t.replace(/\[+ *(?:https?:)?\/\/([a-z-]+)\.wikipedia\.org\/wiki\/([^?|\[\]\s]*) *\]+/gi, interWikiReplace);
			/* Verbliebene projektinterne Weblinks ohne eckige Klammern ebenfalls umwandeln */
			t = t.replace(/(?:https?:)?\/\/([a-z-]+)\.wikipedia\.org\/w\/[^|\[\]\s]*\boldid=([^?|\[\]\s]*[^?|\[\]\s!"),.:;<>?\\])/gi, permaLinkReplace);
			t = t.replace(/(?:https?:)?\/\/([a-z-]+)\.wikipedia\.org\/wiki\/([^?|\[\]\s]*[^?|\[\]\s!"),.:;<>?\\])/gi, interWikiReplace);

			/* Wikilinks mit unnötigem Präfix "w:de:" oder ":de:" vereinfachen */
			t = t.replace(new RegExp('\\[\\[ *w? *: *' + lang + ' *: *([^\\[\\]\\n]*?) *\\]\\]', 'gi'), '[[$1]]');
			/* Sonstige Weblinks mit senkrechtem Strich reparieren */
			t = t.replace(/\[+ *(https?:\/\/[^|\[\]\s]*?) *\| *([^|\[\]\n]+?) *\]+/gi, '[$1 $2]');
			/* Doppelte eckige Klammern um Weblinks vereinfachen */
			t = t.replace(/\[+ *(https?:\/\/[^\[\]\n]*?) *\]+/gi, '[$1]');
			/* Verbliebene projektinterne Weblinks wenigstens protokollrelativ machen */
			t = t.replace(/\[ *https?:\/+([a-z-]+\.wikipedia\.org\b)/gi, '[//$1');

			/* Anker in internen Links dekodieren */
			t = t.replace(/(\[\[[^#|\[\]\n]*#)([^|\[\]\n]+)(\|?[^|\[\]\n]*\]\])/gi, function($0, $1, $2, $3)
			{
				try
				{
					$2 = decodeURIComponent($2.replace(/\.([289A-E][\dA-F]|[357][B-F]|40|60)/g, '%$1')).
						replace(/[%\[\]{|}]/g, function($0)
						{
							return '%' + $0.charCodeAt(0).toString(16).toUpperCase();
						});
				}
				catch (ex) { /* keine Veränderung im Fehlerfall */ }
				return ($1 + $2).replace(/_/g, ' ') + $3;
			});

			/* [[Link|Die]]s wird zu [[Link|Dies]] weil besser lesbar */
			t = t.replace(/(\[\[[^|\[\]\n]+\|[^|\[\]\n]+)\]\]([a-zäöüß]+)/gi, '$1$2]]');
			/* [[Link|Link]]s werden zu [[Link]]s weil kürzer und besser lesbar */
			t = t.replace(/\[\[([^|\[\]\n]+)\|\1([^|\[\]\n]*)\]\]/g, '[[$1]]$2');
			return t;
		},
		cleanDuplicateLinks: function(t)
		{
			/* Doppelte Jahreszahlen entlinken */
			var m = t.match(/\[\[[12]\d{3}\]\]/g);
			if (m && m.length > 1)
			{
				var p, pMax = t.lastIndexOf('{{Personendaten');
				for (var i = m.length; i--; )
				{
					p = t.lastIndexOf(m[i], pMax > 0 ? pMax : t.length);
					/* Je ein Duplikat entfernen, wenn vorhanden */
					if (p > t.indexOf(m[i]))
						t = t.slice(0, p) + m[i].slice(2, 6) + t.slice(p + m[i].length);
				}
			}
			return t;
		},
		cleanDates: function(t)
		{
			var months = ['Januar', 'Februar', 'März', 'April', 'Mai', 'Juni',
				'Juli', 'August', 'September', 'Oktober', 'November', 'Dezember'];
			/* Missverständliches deutsches Datumsformat durch Langform ersetzen */
			t = t.replace(/([\s(|])(3[01]|[12]\d|0?[1-9])\. *(1[012]|0?[1-9])\. *([12]\d{3}[^\d.–-])/g,
				function($0, $1, $2, $3, $4)
				{
					return $1 + 1 * $2 + '. ' + months[$3 - 1] + ' ' + $4;
				});
			/* In "1850–14. Januar" immer "bis" einsetzen */
			t = t.replace(/(\s[12]\d{3}) *[–-] *(3[01]|[12]\d|0?[1-9])\. *([A-Z][a-zä]+)/g,
				function($0, $1, $2, $3)
				{
					for (var i = months.length; i--; )
						if ($3 === months[i]) return $1 + ' bis ' + $2 + '. ' + $3;
					return $0;
				});
			/* 1980–90 immer als 1980–1990 */
			t = t.replace(/([\s(|][12]\d{3}) *- *((1[3-9]|[2-9]\d)[^\d.=–-])/g, '$1–$2'); /* Bindestrich gefunden */
			t = t.replace(/\b(([12]\d)\d{2}) *– *(\d{2})\b/g, '$1–$2$3'); /* Bis-Strich gefunden */
			return t;
		},
		cleanISBNs: function(t)
		{
			/* ISBNs mit Bindestrichen gliedern */
			/* Gruppennummern 0 und 1 für englischsprachige Bücher */
			t = t.replace(/\bISBN(?:-?1[03])?:?\s*((?:9-?7-?[89]-?)?0)([\d-]{8,}[\dX]\b)/gi, function($0, $1, $2) {
				return 'ISBN ' + $1.replace(/^9\D*7\D*([89])\D*0/, '97$1-0') + '-' + $2.replace(/[^\dX]/gi, '').
					replace(/^([01]\d)(\d{6})/, '$1-$2-').
					replace(/^([2-6]\d\d)(\d{5})/, '$1-$2-').
					replace(/^(7\d{3}|8[0-4]\d\d)(\d{4})/, '$1-$2-').
					replace(/^(8[5-9]\d{3})(\d{3})/, '$1-$2-').
					replace(/^(9[0-4]\d{4})(\d\d)/, '$1-$2-').
					replace(/^(9[5-9]\d{5})(\d)/, '$1-$2-');
			});
			t = t.replace(/\bISBN(?:-?1[03])?:?\s*((?:9-?7-?[89]-?)?1)([\d-]{8,}[\dX]\b)/gi, function($0, $1, $2) {
				return 'ISBN ' + $1.replace(/^9\D*7\D*([89])\D*1/, '97$1-1') + '-' + $2.replace(/[^\dX]/gi, '').
					replace(/^(0\d)(\d{6})/, '$1-$2-').
					replace(/^([1-3]\d\d)(\d{5})/, '$1-$2-').
					replace(/^(4\d{3}|5[0-4]\d\d)(\d{4})/, '$1-$2-').
					replace(/^(5[5-9]\d{3}|[67]\d{4}|8[0-5]\d{3}|86[0-8]\d\d|869[0-7]\d)(\d{3})/, '$1-$2-').
					replace(/^(869[89]\d\d|8[7-9]\d{4}|9[0-8]\d{4}|99[0-8]\d{3})(\d\d)/, '$1-$2-').
					replace(/^(999\d{4})(\d)/, '$1-$2-');
			});
			/* Gruppennummer 3 für deutschsprachige Bücher */
			t = t.replace(/\bISBN(?:-?1[03])?:?\s*((?:9-?7-?[89]-?)?3)([\d-]{8,}[\dX]\b)/gi, function($0, $1, $2) {
				return 'ISBN ' + $1.replace(/^9\D*7\D*([89])\D*3/, '97$1-3') + '-' + $2.replace(/[^\dX]/gi, '').
					replace(/^(0[0-24-9]|1\d)(\d{6})/, '$1-$2-').
					replace(/^(03[0-3]|[2-6]\d\d)(\d{5})/, '$1-$2-').
					replace(/^(03[4-6]\d|7\d{3}|8[0-4]\d\d)(\d{4})/, '$1-$2-').
					replace(/^(03[7-9]\d\d|8[5-9]\d{3}|95[4-9]\d\d|9[69]\d{3})(\d{3})/, '$1-$2-').
					replace(/^(9[0-4]\d{4})(\d\d)/, '$1-$2-').
					replace(/^(95[0-3]\d{4}|9[78]\d{5})(\d)/, '$1-$2-');
			});
			return t;
		},
		cleanDefaultSort: function(t)
		{
			t = t.replace(/\{\{\s*(DEFAULTSORT|SORTIERUNG)\s*:\s*/gi, '{{SORTIERUNG:');

			/* Sortierung soll nie Umlaute enthalten */
			t = t.replace(/(\{\{SORTIERUNG:[^}]*?)ß/, '$1ss');
			var sortSrc = '¢£¥©ª®²³¹ºÀÁÂÃÄÅÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝàáâãäåçèéêëìíîïðñòóôõöøùúûüýÿ';
			var sortDst = 'cLYCaR231oAAAAAACEEEEIIIIDNOOOOOOUUUUYaaaaaaceeeeiiiidnoooooouuuuyy';
			var regex = new RegExp('(\\{\\{SORTIERUNG:[^}]*?)([' + sortSrc + '])', 'g');
			while (regex.test(t)) t = t.replace(regex, function($0, $1, $2) { return $1 + sortDst.charAt(sortSrc.indexOf($2)); });

			/* Sortierung soll einheitliche Groß/Kleinschreibung haben */
			regex = /(\{\{SORTIERUNG:[^}]*?)(\b[a-z])/g;
			while (regex.test(t)) t = t.replace(regex, function($0, $1, $2) { return $1 + $2.toUpperCase(); });
			regex = /(\{\{SORTIERUNG:[^}]*?)(\B[A-Z]+)/g;
			while (regex.test(t)) t = t.replace(regex, function($0, $1, $2) { return $1 + $2.toLowerCase(); });
			return t;
		},
		cleanRedundantTemplateParameters: function(t)
		{
			var redundantTemplateParameters = window.redundantTemplateParameters || [
				'Infobox Arcade|Titel',
				'Infobox Band|Name',
				'Infobox Berg|NAME',
				'Infobox Burg|Name',
				'Infobox Chemikalie|Name',
				'Infobox Computer- und Videospiel|Titel',
				'Infobox Eishockeyspieler|Name',
				'Infobox Flughafen|Name',
				'Infobox Flugzeug|Name',
				'Infobox Fluss|NAME',
				'Infobox Fußballspieler|kurzname',
				'Infobox Gemeinde in Österreich|Name',
				'Infobox Gemeinde in Deutschland|Name',
				'Infobox Gemeinde in Italien|nomeComune',
				'Infobox Gemeindeverband in Deutschland|Name',
				'Infobox Insel|NAME',
				'Infobox Landkreis|Name',
				'Infobox Musikalbum|Titel',
				'Infobox Ort in den Vereinigten Staaten|Name',
				'Infobox Ort in der Schweiz|NAME_ORT',
				'Infobox Ort in Polen|Ort',
				'Infobox Ort in Tschechien|Ort',
				'Infobox Ortsteil einer Gemeinde|Ortsteil',
				'Infobox Ortsteil einer Gemeinde in Deutschland|Ortsteil',
				'Infobox PKW-Modell|Modell',
				'Infobox Publikation|titel',
				'Infobox Schiff|Name',
				'Infobox See|NAME',
				'Infobox Software|Name',
				'Infobox Stadion|Name',
				'Infobox Unternehmen|Name'];
			var title = '\\s*=\\s*(' +
				mw.config.get('wgTitle').replace(/([.\\+*?\[\](){}|])/g, '\\$1').replace(/\s+/g, '\\s+') +
				'|\\{+\\w*\\}+)?\\s*([}|])';
			for (var i = redundantTemplateParameters.length; i--; )
			{
				t = t.replace(new RegExp('(\\{\\{\\s*' +
					redundantTemplateParameters[i].replace(/[\s_]+/g, '[\\s_]+').replace('|', '\\s*(?:\\|[^|}]*)*)\\|\\s*') +
					title, 'g'), '$1$3');
			}
			return t;
		},
		cleanInfoboxVerwaltungseinheitInDeutschland: function(t)
		{
			if (/Infobox[ _](?:Gemeinde|Ort)[ _]in[ _]Deutschland/i.test(t))
			{
				t = t.replace(/Infobox[ _](?:Gemeinde|Ort)[ _]in[ _]Deutschland([^}]*}})[\s\r\n]*/i, 'Infobox Gemeinde in Deutschland$1\n\n');
				t = t.replace(/\|\s*lat_deg\s*=\s*(\S*)(?:\s*\|\s*lat_min\s*=\s*(\S*)(?:\s*\|\s*lat_sec\s*=\s*(\S*))?)?/ig,
					'|Breitengrad       = $1/$2/$3');
				t = t.replace(/\|\s*lon_deg\s*=\s*(\S*)(?:\s*\|\s*lon_min\s*=\s*(\S*)(?:\s*\|\s*lon_sec\s*=\s*(\S*))?)?/ig,
					'|Längengrad        = $1/$2/$3');
				t = t.replace(/(?:\/0*)+[\r\n]+/g, '\n');
				t = t.replace(/(\[http:\/\/[^\/\s\]]*)\s+/ig, '$1/ ');
				if (/Art\s*=\s*(?:Amt|(?:Samt|Verbands)gemeinde|Verwaltungsgemeinschaft|(?:Gemeinde)?verwaltungsverband)/i.test(t))
				{
					t = t.replace(/[ _]Gemeinde[ _]in[ _]Deutschland/i, ' Gemeindeverband in Deutschland');
					t = t.replace(/\|\s*(?:PLZ(?:-alt)?|Vorwahl|Kfz)\s*=.*[\r\n]+/ig, '');
					t = t.replace(/\|\s*Bürgermeister( {0,5}|titel)?\s*=\s*/ig, '|Organwalter$1  = ');
					if (!/\|\s*Gliederung\s*=/.test(t))
						t = t.replace(/(\|\s*Adresse\s*=)/i, '|Gliederung        = \n$1');
					t = t.replace(/\|\s*Gliederung\s*=\s*(\d*).*/i, '|Gliederung        = $1');
				}
				if (!/\|\s*Partei\s*=/.test(t))
					t = t.replace(/((?:\|\s*(?:Bürgermeister|Organwalter)[^|}]*)+)/i, '$1|Partei            =\n');
				t = t.replace(/[\r\n]+\s*\|\s*(.{17})\s*=/ig, '\n|$1 =');
			}
			return t;
		},
		executeUserReplacements: function(t)
		{
			var from, autoFormatReplacements = window.autoFormatReplacements || {};
			for (from in autoFormatReplacements)
			{
				var to = autoFormatReplacements[from];
				from = from.replace(/([.+*?(){}<>|])/g, '\\$1'); //Regex-Zeichen maskieren
				from = from.replace(/^(\w)/, '\\b$1').replace(/(\w)$/, '$1\\b'); //Wortgrenzen beachten
				for (var i = 1; /\.\\d/.test(from); i++)
				{
					from = from.replace(/\.\\d/, '.(\\d+)'); //Platzhalter für Zahlen
					to = to.replace(/\\d/, '$' + i);
				}
				from = from.replace(/\.([\w\xC0-\xFF(])/g, '.(?: |&nbsp;)*$1'); //Leerzeichen nach Punkt
				t = t.replace(new RegExp(from, 'g'), to);
			}
			return t;
		},
		backupFilenames: function(t)
		{
			/* Dateinamen retten incl. Vereinheitlichung als "Datei:" */
			this.files = [];
			var match, regex = /(^|\[\[)\s*(Bild|Datei|File|Image)\s*:\s*([^|\]\n]*?)\s*([|\]\n])/gim;
			while (match = regex.exec(t)) this.files[this.files.length] = match;
			for (var i = this.files.length; i--; )
			{
				if (!this.files[i][1]) this.files[i][0] = (this.files[i][1] = '\n') + this.files[i][0];
				/* Keine geschützten Leerzeichen/Unterstriche in Dateinamen */
				this.files[i][3] = this.files[i][3].replace(/(_|%20|&nbsp;)/gi, ' ');
				/* Einheitliche Schreibweise und Leerzeichenausgleich */
				t = t.replace(this.files[i][0], this.files[i][1] + 'Datei:' + i + this.files[i][4]);
			}
			return t;
		},
		restoreFilenames: function(t)
		{
			/* Gerettete Dateinamen wieder einsetzen */
			for (var i = this.files.length; i--; )
			{
				t = t.replace(this.files[i][1] + 'Datei:' + i + this.files[i][4],
					this.files[i][1] + 'Datei:' + this.files[i][3] + this.files[i][4]);
			}
			delete this.files;
			return t;
		}
	};

	if (typeof $ === 'function' && typeof mw === 'object' && mw.user.options.get('usebetatoolbar')) /* Vector */
	{
		mw.loader.using('ext.wikiEditor.toolbar', function()
		{
			$('#wpTextbox1').wikiEditor('addToToolbar', {
				'section': 'main', /* oder 'advanced' */
				'group': 'format',
				'tools': {
					'autoFormatter': {
						'label': 'Auto-Format',
						'type': 'button',
						'icon': '/media/wikipedia/commons/thumb/2/2c/Broom_icon.svg/22px-Broom_icon.svg.png',
						'action': {
							'type': 'callback',
							'execute': function() { return autoFormatter.click(this); }
						}
					}
				}
			});
		});
	}
	else if (typeof $ === 'function' && typeof mw === 'object' && mw.user.options.get('showtoolbar')) /* Monobook */
	{
		mw.loader.using('mediawiki.action.edit', function()
		{
			mw.toolbar.addButton('/media/wikipedia/commons/2/2e/Button_broom.png',
				'Auto-Format', '', '', '', 'mw-customeditbutton-autoFormatter');
			$(function()
			{
				$('#mw-customeditbutton-autoFormatter').click(function() { return autoFormatter.click(this); });
			});
		});
	}
	else if (typeof hookEvent === 'function')
	{
		hookEvent('load', function()
		{
			/* Notfalls als Link unter dem Bearbeitungsfenster */
			var e = document.getElementById('editform');
			if (!e) return;
			var e = e.getElementsByTagName('SPAN');
			for (var i = e.length; i--; )
				if (e[i].className === 'editHelp')
				{
					var a = document.createElement('A');
					a.href = '#';
					a.onclick = function() { return autoFormatter.click(this); }
					a.appendChild(document.createTextNode('Auto-Format'));
					e[i].appendChild(document.createTextNode(' | '));
					e[i].appendChild(a);
					break;
				}
		});
	}
}(jQuery, mediaWiki));