Commit graph

4738 commits

Author SHA1 Message Date
Marius Hoch 847a09be11 Refactor Cite extension JavaScript and make it pass Jshint
Moved the scripts and the CSS into the modules folder directly
(like almost all other extensions do), added a .jshintrc to not have
jenkins shout at this change and minor stuff.

After this change Cite will no longer work with anything older than
PHP 5.3!

Change-Id: I1c87af794f2a9894fb0d82a5bd97bd2182f028e1
2013-08-25 22:23:15 +02:00
Translation updater bot 0011f4c3c8 Localisation updates from http://translatewiki.net.
Change-Id: I3c5af33be47c71b2a8167c68290ac037cd1a054f
2013-08-25 20:01:19 +00:00
Translation updater bot a2a96152e9 Localisation updates from http://translatewiki.net.
Change-Id: I5ea7712ebcf0833b953b62f958cae159451ddc8d
2013-08-24 18:45:05 +00:00
Translation updater bot 345cbf789e Localisation updates from http://translatewiki.net.
Change-Id: I907ff9cc249aa328cdb6f5c05a867a036b989049
2013-08-23 19:43:57 +00:00
Translation updater bot eca979a06e Localisation updates from http://translatewiki.net.
Change-Id: I1053a76434e59fb03283250d4bf64a9e9d1a57c7
2013-08-22 19:44:53 +00:00
Translation updater bot be0a36e17b Localisation updates from http://translatewiki.net.
Change-Id: I65d5645dcee2c87f44ab6ea748bf89183522caac
2013-08-20 19:32:32 +00:00
Translation updater bot 1dfcb64e81 Localisation updates from http://translatewiki.net.
Change-Id: I0500a4530d1cdee88ad982f7fc0c04111792f16c
2013-08-19 19:30:32 +00:00
Translation updater bot b4ced4d430 Localisation updates from http://translatewiki.net.
Change-Id: Id94b089d0221b51b6255439be12b1bcfdbcf1041
2013-08-18 19:31:52 +00:00
Translation updater bot 2585365239 Localisation updates from http://translatewiki.net.
Change-Id: Iefb80e3b1bed89390c8165aaa6ad266040ee1916
2013-08-17 19:20:39 +00:00
Nemo bis cce95414f6 Mention potentially missing </ref> tag in Cite error message
Bug: 45415
Change-Id: I5293f814eff4c0fad3dce412f3adf049c70ee73e
2013-08-17 10:25:54 +00:00
MatmaRex b104717624 Fix parser tests for master MediaWiki core
Caused by I33462a8b in core.

Bug: 52961
Change-Id: I7efa50f4ac86ee732d9ce34fdaa3d8c28179d062
2013-08-17 10:24:29 +00:00
Translation updater bot 6fb67cf760 Localisation updates from http://translatewiki.net.
Change-Id: Id54d42a80fcf50d1a67ae9ec733d5ff3a7fa4a2f
2013-08-14 19:24:07 +00:00
Translation updater bot c5a1abc2c2 Localisation updates from http://translatewiki.net.
Change-Id: I4e8d821a2301eb945fded85c86334980620d6d0f
2013-08-11 19:28:25 +00:00
Translation updater bot 96a9950a9b Localisation updates from http://translatewiki.net.
Change-Id: I37d30e3737c254f83e8aee732bbbe75a6901e4d1
2013-08-10 19:24:57 +00:00
Translation updater bot ce9534cc66 Localisation updates from http://translatewiki.net.
Change-Id: I5376754ce4d4f59cdf16835b1618493970182557
2013-08-05 19:34:42 +00:00
Translation updater bot 91f0d33022 Localisation updates from http://translatewiki.net.
Change-Id: I1a44fcc1973f095d5ae00128d4fc06fe5186732d
2013-07-29 19:32:16 +00:00
Subramanya Sastry d6fb0fabb6 Fixed incorrect initialization of nested-ref-collection-map
* The initialization of nestedRefCollectionMap[references-id]
  in handleReferences was the wrong place to initialize it since
  on pages with multiple <references /> tags, the map can get
  reset after a references tag is processed.  So, for later
  references tags, the entry for those will get cleared which
  led to crashes.

  Ex: es:Abderramán_I and couple others found in RT testing.

* This patch fixes the crasher.

* Added a new parser test with multiple references tags that
  captures this scenario. Regenerated selser changes file.

Change-Id: I64402e77996486b099acda114f2e250258b0048e
2013-07-27 17:57:32 -05:00
Subramanya Sastry 46ddbf3f7b Make <ref>s nested in <references> editable.
* Track <ref>s birthed in <references> tags and capture their
  HTML and set <references>.data-mw.body.html to the concatenated
  HTML for all those child <ref> tags.

* No change in parser-tests because our test normalization code
  strips data-mw before comparing results.  Since this patch
  only changes data-mw output for "References: 5. ..." test,
  there is no change.  In any case, this patch updates the
  data-mw output for the test in question so that if we do
  modify our normalization routines, the test will still pass.

Change-Id: Iaea752dec03e5e7f0d36baf3b7a9973f1b85e8a5
2013-07-27 11:32:50 -05:00
Translation updater bot 5e1213548b Localisation updates from http://translatewiki.net.
Change-Id: I5cbe64600e07b508cfac40e3b31c5904770aa0b9
2013-07-25 19:27:21 +00:00
Translation updater bot 7df82a6419 Localisation updates from http://translatewiki.net.
Change-Id: I9a66c78a9f7f340a4e7296513ca88b65c0d5997e
2013-07-22 20:11:27 +00:00
Subramanya Sastry 23b9c314e1 Take #2: (Bug 49555): Support all nested ref scenarios
* This patch now supports any template that generates nested refs
  where the top-level token is just a single-ref.

  Ex: {{efn|New timetable{{sfn|Vallance|1991|p=31}}}}

* The solution in this patch removes the hack from the previous
  version (53bbcbb3). As documented in the bug report, this
  solution essentially "trusts" template authors and lets
  nested refs through when they come from templates.

  But, top-level nested refs are still not allowed.
  <ref>foo<ref>bar</ref>baz</ref> in the toplevel page
  will still generate a single reference with content
  "foo<ref>bar</ref>baz"

* Updated the nested ref test output
  - Regenerated selser changes because of the changed output.
  - Regenerated blacklist because of the changed selser changes.

* This now handles:
  - https://en.wikipedia.org/wiki/User:Edgepedia/VE/GNoSR
  - https://en.wikipedia.org/wiki/Phellinus ellipsoideus

Change-Id: I627955f0be1c5e2bafc49647c94c2be68ce711a8
2013-07-18 15:35:21 -05:00
Ed Sanders 4f3f9068b0 Add more specific class to cite errors
Problem:

* VisualEditor needs to be able to more reliably target Cite errors.

Solution:

* Add a more specific class to cite errors

Grumble:

* Ideally all extensions would use mw-ext-{extension name} as a prefix to
  their CSS classes (or something similar).

Bug: 51337
Change-Id: If4f5360cc1c7b765ad896b14901a9b024782cc93
2013-07-15 01:46:53 +00:00
Translation updater bot da5a49ba48 Localisation updates from http://translatewiki.net.
Change-Id: I3c4669aecb4a655573b4d2e4ce8d386f642e81d4
2013-07-08 18:59:20 +00:00
Translation updater bot 95e718b91a Localisation updates from http://translatewiki.net.
Change-Id: I0a6154e9be354671761a60d673790f0de7435bbc
2013-07-07 19:40:27 +00:00
Translation updater bot 695ac67ad9 Localisation updates from http://translatewiki.net.
Change-Id: Ic02486d5ae8311c559d1a028285c6b10da280780
2013-07-05 21:36:48 +00:00
Translation updater bot 141604a051 Localisation updates from http://translatewiki.net.
Change-Id: I50c2b89e86602118640f61bdc25f72b13fca09f5
2013-07-04 20:07:17 +00:00
Translation updater bot d130231b84 Localisation updates from http://translatewiki.net.
Change-Id: I5e8594c509c76a5198021f44d9735a135d198aa8
2013-07-02 19:20:52 +00:00
Gabriel Wicke a9ac140990 Bug 50474: Remove children of references node
Make sure we don't keep old references content around on re-render.

Change-Id: I79ad1e5d69ebb506078fa5903d1ff78b6ff82433
2013-07-01 14:21:48 -07:00
Translation updater bot 0bb2dae1d1 Localisation updates from http://translatewiki.net.
Change-Id: I0e551ce2c1cbf000aeac66488c9dcf4b249e542d
2013-07-01 19:54:09 +00:00
Subramanya Sastry cafe2f8799 (Bug 50394) Fixed bad regexp
* There is another unrelated issue on that page ==> It has
  a couple instances of <ref>text<ref> which slurps the entire
  rest of the page into a 10K string (on which the regexp failed).

Change-Id: Ia4c498b28042de5bfe9b0945c0efaa8c6cb81ea0
2013-06-28 15:54:15 -05:00
Translation updater bot ac0ed4a334 Localisation updates from http://translatewiki.net.
Change-Id: Ieced19ad44f6a25e3d414603735c56ea733e6733
2013-06-28 13:55:42 +00:00
Gabriel Wicke 65eca748e7 Better fallback value in case src is missing
Change-Id: Ia9eb5492c871fce97665de718e56d93dd1db433d
2013-06-26 18:13:32 -07:00
Subramanya Sastry 093188931a References handling: Fix bugs introduced by 213f9682
* source and group attributes were being added as HTML attrs.
  on the ol-node which is invalid.  Plus, after refererences
  generation, source attr was being deleted which causes crashers
  in production if references output is reused from cache.

* Moved both attributes to data.parsoid

* Removed group="" from parserTests that I erroneously added
  in that previous commit.

* Minor cleanup in DOMPostProcessor.

Change-Id: I85f4ad0a311d653d7ba3e010c7a5db028b643e9f
2013-06-26 18:08:17 -07:00
Subramanya Sastry 213f968282 (Bug 50218) Generated DOMFragment wrapping <ol> for references tag
* So far, references wikitext was being replaced with a meta marker
  token that participated as an inline token in p-wrapping.  As a
  result, in some cases, a p-tag was wrapping the references ol-node
  which is buggy HTML.  When VE loaded this DOM, the p-node was split
  around the ol-node and duplicated DSR which led to duplicated
  output when selser ran on this.

* One way of fixing this would have been to add a special case in
  the paragraph wrapper to treat the mw:Extensions/References/Marker
  meta tag as a block token.

* A better solution with an eye towards the longer-term is to emit
  mw:DOMFragment wrapper for the references tag with the content
  being an ol-node. The dom-fragment unpacking code then takes care
  of p-wrapping issues for the ol-node. This fixes the bug in this
  case.

* Also fixed parser tests output where group attribute was missing
  on some tests (which indicated that the older code was not emitting
  the group attribute on references tag).

* No change in parser tests.

Change-Id: I073b2e68667d577c75cad07d19cea2b19d0e89fe
2013-06-26 12:47:51 -05:00
Translation updater bot e3128e12d1 Localisation updates from http://translatewiki.net.
Change-Id: I4962dcd85b128bc492d76584fcf4b71cc3e1c3bb
2013-06-25 19:55:23 +00:00
Translation updater bot 1e542ef08a Localisation updates from http://translatewiki.net.
Change-Id: I7d15b651fa61d5250305aff579a204ac691656e2
2013-06-23 20:23:38 +00:00
Translation updater bot ad119f2581 Localisation updates from http://translatewiki.net.
Change-Id: Ic56f31da9eb542fd5df71b1f42a7c49893399cf8
2013-06-20 18:57:40 +00:00
Subramanya Sastry 53bbcbb37e (Bug 49555) Support nested refs
* After trying various hacks, came up with a relatively simple
  fix/hack to support nested refs.

  The fix looks for {{#tag:ref..}} and short-circuits full
  pipeline expansion and converts that to an extension tag
  in place.

* Tested with the following wikitext which parses and RTs correctly

A <ref name='foo' />
B {{#tag:ref|nested ref <ref>bar</ref> |name=foo}}
<references />

* Also tested on en:Fomitiporia_ellipsoidea from the bug report
  and verified correct parse and round tripping.

* Verified that the nested ref in <ref> foo <ref>bar</ref> </ref>
  continues to be parsed as plain text.

* No change in parser test results -- have to make another
  round of updates to parser tests.

Change-Id: I43bb8b710bd10a9ddbea27818ff8aaf97ddb3fdc
2013-06-18 14:55:00 -05:00
Subramanya Sastry 7d93200a91 Roundtrip {{#tag:ref|..}} properly in editMode
* See example below that clarifies the problem before this patch
-------------------
$ echo "{{#tag:ref|foo}} {{echo|<references />}}" | node parse --extensions ref,references --wt2wt --editMode true
<ref>foo</ref> <references />
-------------------

* The problem is that references are generated after dom fragments
  are unpacked in the DOM which lost the mw:Transclusion typeof and
  data-mw that had been set on the ref and references tags.

* This is a quick fix to prevent some dirty diffs with #tag:ref being
  reported on en-wp. Longer term, we do have a plan to use DOMFragment
  encapsulation for refs and references as well and splitting up
  references processing differently than is being done currently.

Change-Id: I4186cae93b9882d367c7d4efecc092607fe17c61
2013-06-17 13:11:48 -05:00
Subramanya Sastry 84795339cb About attribute values should have "#" prefixed everywhere
* While debugging reports of dirty diffs on some pages (en:Bleak House
  specifically), it took me a while to notice that some mw:Transclusion
  had about="mwt5" style ids (introduced during template expansion reuse)
  whereas all other about ids had about="#mwt5" (note the # char) style ids.

  While this by itself shouldn't cause dirty diffs since DOM-diff ignores
  about ids, this could potentially introduce introduce other bugs elsewhere
  if we start using/comparing about ids.

  Fixed all uses of "#" + env.newObjectId() with env.newAboutId and let
  env prefix the "#" key.

Change-Id: I74d50ae155f5d24af95c07da15b14eb990cf2891
2013-06-17 10:26:00 -05:00
Subramanya Sastry 5de43f24fb Start aligning Parsoid cite with PHP cite behavior some more
* Nested ref tags are not supported anymore.

* Turned off pre and p-wrap handlers on ref content since the native
  cite extension seems to not do any of this on ref content.

* No change in parser test results (because there are no tests yet).

Other cleanup:

* Removed the 'inBlockToken' hack from Cite since this is not
  necessary anymore.

  TODO: The use of this flag in TemplateHandler may not be needed
  either. Verify and get rid of it.

* Leading whitespace in ref-content is still removed but this may
  not be strictly necessary.

Change-Id: I3406236032abe36099a1e420f443277a95fe597b
2013-06-13 16:48:16 -05:00
Subramanya Sastry acf1c28898 (Bug 49314) Add space before ref-content
Change-Id: Ie67ba1c332451b60107f6fb946efeafc15485b50
2013-06-12 16:07:01 -05:00
Subramanya Sastry c7073d1f3e Fix shoddy work I did in fdf5fa4b when I broke references
* I will work on adding testing for refs and references next.

Change-Id: Ib9be770d70587cd36ecad4df8067e646eac6d750
2013-06-12 16:05:15 -05:00
Subramanya Sastry fdf5fa4bd0 (Bug 49490) Prefix ref name/group before using as property key
* The page in question "es:Estadio_Deportivo_Cali" had a ref
  with name "constructor", and this name was used as an object
  property key and this clashed with the predefined property
  constructor.

* The reliable solution here is to prefix ref-name and ref-group
  with a string and use it to prevent clashes.

Change-Id: Ib5cf7cce6fa4acd88e3d49ca9d4390a61bfddd7e
2013-06-12 14:26:36 -05:00
Translation updater bot 22f4d9e8a5 Localisation updates from http://translatewiki.net.
Change-Id: Ida69a3eaa923f2010ee69137931b5b9142c99100
2013-06-10 07:22:25 +00:00
Subramanya Sastry d6a53a5874 Enable wrapped extensions to parse and RT correctly
* Temporarily hacked sanitizer to pass through typeof attribute
  so that mw:DOMFragment wrapper for extension tags can get to
  the DOM post processor and get unwrapped.

* Implemented getArgDict for the extension handler since data-mw
  for extensions has a different form than that for templates.

* Extracted common functionality into Util.js and used it in Cite.js
  and ExtensionHandler.js

* Tested with timeline extension (test snippet below) and verified
  that it parses and RTs both with editMode true and false.

  TODO: Long overdue. Extension testing.

--------
<timeline>
ImageSize  = width:250 height:200
PlotArea   = left:40 right:10 top:10 bottom:20
TimeAxis   = orientation:horizontal
AlignBars  = justify
Colors =
  id:gray1 value:gray(0.9)

DateFormat = yyyy
Period     = from:1960 till:2010
ScaleMajor = unit:year increment:10 start:1960

PlotData =
  bar:3000 color:gray1 width:1
  from:start till:end
  bar:2000 color:gray1
  from:start till:end
  bar:1000 color:gray1
  from:start till:end
  bar:0 color:gray1

LineData =
  layer:front
  points:(48,96)(84,111) color:blue  width:2 #1962 tot 1968. Inwonertal 1962: 1348 1968: 1610
  points:(84,111)(100,112)    color:blue    width:2 #1975: 1627
  points:(100,112)(128,116)   color:blue    width:2 #1982: 1699
  points:(128,116)(160,135)   color:blue    width:2 #1990: 2036
  points:(160,135)(196,146)   color:blue    width:2 #1999: 2217
  points:(196,146)(228,158)     color:blue    width:2 #2004/5

</timeline>
--------

Change-Id: Ia8d2f82e893047e2447cf809e04cc7f508f5899b
2013-06-05 19:04:58 -05:00
Subramanya Sastry 882f530b92 (Bug 49182) Emit data-mw for references extension as well
* data-mw wasn't being emitted for references -- there was a FIXME
  for it.

* Tested fixes on example from 3c88b310.

* Removed meta-placeholder that was being emitted for <references />
  tags without any refs to emit since VE might add references and
  this wont be valid anymore.  Serializer can also handle references
  output without any content.  So, no need for that hack anymore.

  Verified by testing with "<references />" input

Change-Id: I3d2852f2c6a88bf22145add9b2173fd99d152775
2013-06-05 11:09:53 -05:00
Translation updater bot e3471ad713 Localisation updates from http://translatewiki.net.
Change-Id: Ie9a1fcc155880e5ba73ebd6f6087bf88cf154d4e
2013-06-03 18:18:32 +00:00
Translation updater bot 0ac1335435 Localisation updates from http://translatewiki.net.
Change-Id: I8f959c1af170d6eaf71c1352aea0c57b1f73b4e6
2013-06-03 11:40:46 +00:00
Subramanya Sastry 23359fb60b Minor tweak to data-mw output for <ref name='foo' /> tags
* Serializer was complaining about missing source for these tags.
  Tweaked code to serialize these back to self-closed tag form.

* Tested with which rts this with the regular serializer in edit mode.
echo "one <ref name='foo'>bar</ref> two<ref name='foo' />\n<references/>" | node parse --extensions ref,references --wt2wt

Change-Id: Iaac63b26660d8b03af937d00d04540c3b8c0c86c
2013-06-01 17:05:59 -05:00