ProseMirror / prosemirror

The ProseMirror WYSIWYM editor
http://prosemirror.net/
MIT License
7.53k stars 334 forks source link

Incorrect and slow parsing of base64 encoded CSS property values #1470

Closed marlass closed 1 month ago

marlass commented 1 month ago

Running DOMParser.fromSchema(schema).parse(dom, options).toJSON() on HTML with base64 encoded CSS values is extremely slow and incorrect.

Minimal HTML example to parse:

<div style="
width: 200px;
background-image: url(data:image/svg+xml;base64,<?xml version="1.0" encoding="utf-8"?>
<!-- Generator: Adobe Illustrator 27.5.0, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
	 viewBox="0 0 3147 2000" style="enable-background:new 0 0 3147 2000;" xml:space="preserve">
<g>
	<rect style="fill:#FFFFFF;" width="3147" height="2000"/>
	<g>
		<g>
			<path style="opacity:0.3;fill:#9BC1F9;" d="M2844.717,1539.645h-351.244c37.594-34.547,61.563-86.866,61.563-145.429v-43.034
				c0-124.663,90.629-225.723,202.425-225.723l0,0c114.604,0,207.508-103.597,207.508-231.391v-0.001
				c0-127.794-92.904-231.391-207.508-231.391h-33.995c-111.796,0-202.425-101.06-202.425-225.723v-0.001
				c0-104.027-75.626-188.357-168.916-188.357H1032.276c-103.835,0-188.01,93.863-188.01,209.649v0
				c0,79.154,39.344,148.053,97.409,183.732H709.827c-96.691,0-175.074,80.89-175.074,180.673v0
				c0,119.577-93.933,216.514-209.805,216.514h-35.234c-118.781,0-215.072,99.371-215.072,221.95v0.001
				c0,122.58,96.292,221.95,215.072,221.95h0c115.872,0,209.804,96.937,209.804,216.514v41.278
				c0,99.783,78.383,180.673,175.074,180.673h814.656c6.146,0.595,12.373,0.909,18.674,0.909h1336.794
				c105.706,0,191.397-85.691,191.397-191.397v0C3036.114,1625.336,2950.423,1539.645,2844.717,1539.645z"/>
			<g>
				<path style="fill:#466EB6;" d="M920.697,1309.903c-5.33-0.013-9.666,6.134-9.685,13.729c-0.019,7.596,4.287,13.763,9.617,13.777
					c5.33,0.013,9.666-6.134,9.685-13.729C930.333,1316.084,926.027,1309.916,920.697,1309.903z M920.688,1313.789
					c2.861,0.007,5.176,1.438,5.172,3.197c-0.004,1.759-2.327,3.179-5.188,3.172c-2.861-0.007-5.176-1.438-5.172-3.197
					C915.504,1315.202,917.827,1313.782,920.688,1313.789z M920.642,1332.248c-4.035-0.01-7.301-2.217-7.294-4.929
					c0.007-2.713,3.283-4.904,7.318-4.894c4.035,0.01,7.301,2.217,7.294,4.929C927.954,1330.067,924.677,1332.258,920.642,1332.248z
					"/>
				<path style="fill:#7F1CA0;" d="M898.787,1340.27c-2.026,4.373-3.088,9.124-3.1,13.938L895.44,1454.9
					c-0.015,6.081,4.953,11.023,11.096,11.038l57.578,0.141c6.143,0.015,11.135-4.902,11.15-10.983l0.247-100.692
					c0.012-4.813-1.027-9.569-3.031-13.952L898.787,1340.27z"/>
				<path style="fill:#7F1CA0;" d="M898.787,1340.27c-2.026,4.373-3.088,9.124-3.1,13.938L895.44,1454.9
					c-0.015,6.081,4.953,11.023,11.096,11.038l57.578,0.141c6.143,0.015,11.135-4.902,11.15-10.983l0.247-100.692
					c0.012-4.813-1.027-9.569-3.031-13.952L898.787,1340.27z"/>
				<path style="fill:#F47458;" d="M975.516,1354.401l-0.247,100.7c-0.015,6.075-5.013,10.998-11.15,10.983l-57.577-0.141
					c-6.15-0.015-11.111-4.963-11.096-11.038l0.247-100.7c0.012-4.805,1.07-9.557,3.096-13.93l73.686,0.181
					C974.479,1344.839,975.528,1349.595,975.516,1354.401z"/>
				<path style="fill:#F48C7F;" d="M910.706,1454.937l0.247-100.692c0.012-4.813,1.074-9.564,3.1-13.937l-15.267-0.038
					c-2.026,4.373-3.088,9.124-3.1,13.937L895.44,1454.9c-0.015,6.081,4.953,11.023,11.096,11.038l15.267,0.038
					C915.659,1465.96,910.691,1461.018,910.706,1454.937z"/>
				<path style="fill:#B75742;" d="M975.516,1354.401l-0.247,100.7c-0.015,6.075-5.013,10.998-11.15,10.983l-23.541-0.058
					c6.203,0.015,11.253-4.908,11.268-10.983l0.247-100.699c0.012-4.805-1.05-9.562-3.067-13.945l23.45,0.057
					C974.479,1344.839,975.528,1349.595,975.516,1354.401z"/>
				<path style="fill:#13375B;" d="M972.479,1340.451l-73.699-0.181l0,0c0.008-3.219,2.651-5.822,5.903-5.814l61.922,0.152
					C969.857,1334.615,972.487,1337.232,972.479,1340.451L972.479,1340.451z"/>
				
					<rect x="929.134" y="1401.464" transform="matrix(0.0025 -1 1 0.0025 -508.2772 2373.2239)" style="fill:#355389;" width="12.513" height="79.823"/>
			</g>
			<g>
				<path style="fill:#86B1F2;" d="M826.258,1307.853h8.804c-1.44-0.985-3.242-1.574-5.202-1.574H609.303
					c-11.539,0-20.894,8.292-20.894,18.521v11.764c0,10.229,9.354,18.521,20.894,18.521l218.089-0.065L826.258,1307.853z"/>
				<path style="fill:#466EB6;" d="M701.043,1306.322c-11.035,0-19.981,7.93-19.981,17.712v13.295
					c0,9.782,8.946,17.712,19.981,17.712h137.302v-2.974h-0.567l-34.905-2.93l-7.055-24.534c0,0,13.617-13.557,14.505-13.907
					c0.888-0.35,27.455-1.411,27.455-1.411l0.567-0.005v-2.958H701.043z"/>
				<path style="fill:#FAE0B2;" d="M829.44,1330.594c0-14.344,8.362-21.298,8.362-21.298H703.855
					c-10.136,0-18.353,7.284-18.353,16.269v10.234c0,8.985,8.217,16.269,18.353,16.269h133.947
					C837.802,1352.067,829.44,1348.656,829.44,1330.594z"/>
				<path style="fill:#DAEEF7;" d="M685.502,1325.564v10.234c0,1.345,0.188,2.651,0.535,3.902
					c4.518-9.798,13.176-19.235,29.659-22.27c38.482-7.085,122.106-8.134,122.106-8.134H703.855
					C693.719,1309.296,685.502,1316.579,685.502,1325.564z"/>
				<path style="fill:#50BFA5;" d="M822.626,1405.405h9.964c-1.63-1.233-3.67-1.971-5.888-1.971H577.075
					c-13.06,0-23.648,10.379-23.648,23.183v14.725c0,12.804,10.587,23.183,23.648,23.183l246.835-0.082L822.626,1405.405z"/>
				<path style="fill:#3C8F7C;" d="M680.907,1403.49c-12.49,0-22.615,9.926-22.615,22.17v16.641c0,12.244,10.125,22.17,22.615,22.17
					h155.399v-3.722h-0.642l-39.506-3.668l-7.985-30.71c0,0,15.412-16.97,16.417-17.408s31.074-1.765,31.074-1.765l0.642-0.007
					v-3.702H680.907z"/>
				<path style="fill:#FAE0B2;" d="M826.228,1433.871c0-17.955,9.465-26.659,9.465-26.659H684.09
					c-11.472,0-20.772,9.117-20.772,20.364v12.809c0,11.247,9.3,20.364,20.772,20.364h151.602
					C835.692,1460.749,826.228,1456.479,826.228,1433.871z"/>
				<path style="fill:#DAEEF7;" d="M663.318,1427.576v12.809c0,1.684,0.213,3.319,0.606,4.884
					c5.113-12.264,14.913-24.077,33.568-27.875c43.554-8.868,138.201-10.182,138.201-10.182H684.09
					C672.618,1407.212,663.318,1416.329,663.318,1427.576z"/>
				<path style="fill:#F47458;" d="M545.2,1356.524h-9.968c1.631-0.978,3.671-1.564,5.891-1.564h249.725
					c13.065,0,23.657,8.236,23.657,18.395v11.684c0,10.159-10.592,18.395-23.657,18.395l-246.932-0.065L545.2,1356.524z"/>
				<path style="fill:#B75742;" d="M686.974,1355.004c12.495,0,22.623,7.876,22.623,17.592v13.204
					c0,9.716-10.129,17.592-22.623,17.592h-155.46v-2.954h0.643l39.521-2.91l7.988-24.368c0,0-15.418-13.465-16.423-13.813
					c-1.005-0.347-31.086-1.401-31.086-1.401l-0.643-0.005v-2.938H686.974z"/>
				<path style="fill:#FAE0B2;" d="M541.597,1379.111c0-14.247-9.468-21.153-9.468-21.153H683.79c11.477,0,20.78,7.234,20.78,16.158
					v10.164c0,8.924-9.304,16.158-20.78,16.158H532.129C532.129,1400.438,541.597,1397.05,541.597,1379.111z"/>
				<path style="fill:#DAEEF7;" d="M704.57,1374.115v10.164c0,1.336-0.213,2.633-0.606,3.875
					c-5.115-9.731-14.919-19.104-33.581-22.119c-43.571-7.036-138.255-8.079-138.255-8.079H683.79
					C695.267,1357.957,704.57,1365.192,704.57,1374.115z"/>
			</g>
			
				<rect x="1387.364" y="1375.53" transform="matrix(0.9825 0.1862 -0.1862 0.9825 331.4749 -231.7409)" style="fill:#184655;" width="23.829" height="546.036"/>
			<polygon style="fill:#184655;" points="2136.892,1921.498 2165.053,1921.498 2060.107,1378.038 2036.695,1382.475 			"/>
			<polygon style="fill:#184655;" points="1621.321,1921.498 1649.482,1921.498 1544.536,1378.038 1521.124,1382.475 			"/>
			<polygon style="fill:#184655;" points="1880.307,1921.498 1857.444,1921.771 1958.057,1380.477 1981.469,1384.915 			"/>
			<path style="fill:#FAE0B2;" d="M1778.162,646.125c92.709,9.929,212.686,20.403,333.132,224.798
				c131.64,223.393,62.344,557.087-41.556,649.815c-103.901,92.729-443.243,207.225-728.503,35.817
				c0,0-172.243-103.876-83.846-276.272c136.032-265.297,116.811-320.619,177.634-424.588S1581.37,625.05,1778.162,646.125z"/>
			<path style="fill:#F7CC7F;" d="M2111.295,870.923c-82.209-139.507-164.196-188.665-237.447-208.98
				c28.333,29.321,57.057,67.041,85.808,115.831c131.64,223.393,62.344,557.086-41.557,649.815
				c-92.141,82.233-369.439,181.552-629.98,83.443c26.787,29.643,53.115,45.522,53.115,45.522
				c285.26,171.409,624.603,56.913,728.504-35.816C2173.638,1428.01,2242.934,1094.316,2111.295,870.923z"/>
			<path style="fill:#F48C7F;" d="M491.947,804.464c-2.63,20.723,18.952,37.17,38.146,35.873
				c21.218-1.434,39.216-18.835,42.319-39.685c3.359-22.569-10.201-40.618-31.181-42.272c-20.422-1.61-33.486,16.567-27.588,34.91
				c4.229,13.151,16.233,18.054,22.28,14.425c4.713-2.828,4.428-9.96-1.278-11.219c-2.287-0.504-4.644,0.771-5.859,2.526
				c-4.995-1.983-9.748-11.077-6.522-20.896c4.12-12.542,19.977-13.26,29.824-7.41c12.535,7.446,14.505,23.479,9.908,36.254
				c-4.827,13.415-18.001,23.981-32.344,24.999c-16.247,1.153-30.546-11.301-31.843-27.486
				C497.503,800.662,492.418,800.755,491.947,804.464z"/>
			<g>
				<path style="fill:#FAE0B2;" d="M1920.46,112.707c-95.953-0.569-174.022,46.753-174.372,105.696
					c-0.175,29.471,19.113,56.268,50.439,75.769l-39.458,86.674l82.352-67.072c23.861,7.754,50.986,12.215,79.772,12.386
					c95.953,0.569,174.022-46.753,174.372-105.696C2093.915,161.521,2016.413,113.276,1920.46,112.707z"/>
				<g>
					<path style="fill:#F7CC7F;" d="M1853.987,229.594c8.522,32.339,41.642,51.644,73.976,43.117
						c32.333-8.526,51.636-41.654,43.114-73.994c-8.522-32.339-41.642-51.643-73.975-43.117
						C1864.768,164.127,1845.465,197.255,1853.987,229.594z"/>
					<path style="fill:#EFEFEF;" d="M1946.278,215.178c4.557,17.29-5.764,35.002-23.051,39.561
						c-17.287,4.559-34.995-5.763-39.551-23.052L1946.278,215.178z"/>
				</g>
			</g>
			<g>
				<path style="fill:#F47458;" d="M930.017,949.579l264.919-1.989c6.05-0.045,10.917-4.987,10.872-11.036l-1.329-177.116
					c-0.045-6.05-4.986-10.917-11.036-10.872l-264.92,1.989c-6.05,0.045-10.917,4.987-10.872,11.036l1.329,177.116
					C919.027,944.757,923.968,949.624,930.017,949.579z"/>
				<polygon style="fill:#F47458;" points="1196.357,847.086 1281.893,934.253 1176.374,914.557 				"/>
				<g>
					<path style="fill:#FFFFFF;" d="M1119.185,834.803l-25.741-0.461c0,0-32.437-24.223-33.429-32.784
						c-0.993-8.561,4.325-26.678-0.707-28.953c-5.031-2.274-15.687-4.072-22.419,7.264c-4.887,8.228-0.819,38.265-3.844,40.274
						c-1.892,1.258-16.694,1.409-27.51,1.346c-7.112-0.042-13.649,3.87-16.983,10.153l-0.011,0.018
						c-2.253,4.246-1.227,9.491,2.461,12.575l5.741,4.801l-4.519,6.003c-3.363,4.47-2.489,10.816,1.96,14.208l4.533,3.458
						l-3.104,3.536c-3.998,4.553-3.154,11.568,1.808,15.044l4.03,2.824l-0.605,1.115c-2.516,4.636-1.072,10.425,3.326,13.337
						l4.048,2.679l68.558,1.217c6.423,0.114,12.802-1.086,18.744-3.526l24.183-3.558c2.598-0.383,4.527-2.609,4.534-5.236
						l0.155-60.012C1124.403,837.223,1122.083,834.855,1119.185,834.803z"/>
				</g>
			</g>
			<polygon style="fill:#F79C8D;" points="1480.514,985.671 1456.685,1057.158 1529.305,1028.595 			"/>
			<path style="fill:#042A44;" d="M1555.378,772.937c-4.842,0.2-18.107,4.624-37.508,41.163
				c-24.774,46.661-60.983,187.617-60.983,187.617l108.081,40.114l13.885-29.421l22.869-226.502
				C1601.723,785.909,1556.72,772.881,1555.378,772.937z"/>
			<path style="fill:#07345A;" d="M1698.25,752.619c-30.906,0.041-107.377,9.028-142.871,20.329c0,0-26.074,223.344,23.475,393.055
				c11.091,37.99-9.174,157.484-9.174,157.484l320.257-4.212c0,0-37.94-288.881-23.648-335.543
				c14.293-46.661,14.634-209.283,14.634-209.283s-2.194-0.341-71.954-12.358C1776.432,756.487,1731.248,752.576,1698.25,752.619z"
				/>
			<path style="fill:#F7A491;" d="M1735.567,1738.023c0,0-7.085,81.496-20.111,104.065c-13.027,22.568,0.685,60.934,1.371,66.2
				c0.686,5.266,27.425,12.789,69.933,8.275c42.508-4.514,41.823-14.293,38.394-30.091c-3.428-15.797-26.053-36.109-27.425-51.155
				c-1.371-15.046,13.027-69.209,13.027-69.209L1735.567,1738.023z"/>
			<path style="fill:#327F6B;" d="M1605.814,1256.221c0,0-221.073-12.234-270.441,17.563c-49.367,29.797,8.927,90.983,8.927,90.983
				s179.978,77.986,481.289,95.316c71.351,4.104,77.501-185.412,64.159-201.095
				C1876.406,1243.306,1605.814,1256.221,1605.814,1256.221z"/>
			<path style="fill:#355389;" d="M1792.062,1922.889c43.772-4.648,38.359-26.079,34.829-42.347
				c-2.21-10.186-14.767-22.194-22.252-33.552c-3.913,3.106-10.277,8.591-29.286,14.186c-19.74,5.811-46.799-5.689-64.042-12.892
				c-6.146,22.794-6.426,51.863-5.852,56.272C1706.165,1909.978,1748.29,1927.537,1792.062,1922.889z"/>
			<path style="fill:#3C8F7C;" d="M1767.901,1413.842c-8.832,66.609-52.564,398.204-52.564,398.204l101.471,12.538
				c0,0,124.782-432.809,118.383-499.009c-6.399-66.2-53.108-71.77-53.108-71.77S1791.279,1237.517,1767.901,1413.842z"/>
			<path style="fill:#07345A;" d="M1670.694,470.845c0,0,33.714-35.546,60.831,7.695c0,0,20.888-11.726,35.546,9.162
				c0,0,37.745-11.36,46.906,45.074c0,0,19.422-3.665,21.987,19.422c2.565,23.087-9.161,38.478-9.161,38.478
				s10.911,8.182,5.955,29.408c-4.214,18.048-19.147,20.796-19.147,20.796s-4.031,30.416-17.223,39.577
				c-13.192,9.161-31.148,4.765-31.148,4.765s-4.764,16.49-20.155,15.024c-15.391-1.466-34.447-16.124-51.67-9.528
				c-17.223,6.596-61.931-0.367-61.931-0.367s-50.203-22.353-35.179-73.657c0,0-26.385-23.819-3.298-52.403
				c0,0-16.857-44.707,16.49-71.092C1642.844,466.814,1670.694,470.845,1670.694,470.845z"/>
			<path style="fill:#F7A491;" d="M1676.39,712.171l-6.103,45.276c0,0-13.671,65.23,3.917,77.805
				c17.588,12.576,74.795-79.665,74.795-79.665l-6.042-114.727L1676.39,712.171z"/>
			<path style="fill:#F47458;" d="M1744.909,678.042c-14.528,39.131-49.131,63.185-73.693,72.515l5.175-38.386l66.567-71.311
				L1744.909,678.042z"/>
			<path style="fill:#F7A491;" d="M1702.313,520.328c-35.693-12.286-73.739,11.424-79.186,48.217
				c-2.367,15.992-4.51,36.102-4.91,58.089c-0.96,52.882,26.415,104.349,50.429,104.349c24.014,0,90.379-34.233,92.781-109.307
				C1762.909,575.326,1739.769,533.222,1702.313,520.328z"/>
			<path style="fill:#F7A491;" d="M1743.733,627.612c0,11.665,7.734,21.122,17.273,21.122c9.539,0,17.272-9.457,17.272-21.122
				c0-11.665-7.734-21.122-17.272-21.122C1751.467,606.49,1743.733,615.947,1743.733,627.612z"/>
			<path style="fill:#07345A;" d="M1598.279,494.016c-24.804,19.65-33.497,49.506-19.415,66.687
				c14.081,17.18,45.605,15.178,70.409-4.471c24.804-19.65,33.497-49.507,19.415-66.687
				C1654.607,472.365,1623.083,474.367,1598.279,494.016z"/>
			<path style="fill:#F7A491;" d="M1884.41,799.275c-29.944-11.195-44.592,257.689-48.629,368.362
				c-53.026,5.084-145.451,0.038-168.464-1.684c-10.824-0.81-35.78-9.92-46.544-11.325c-11.031-1.44-21.03-2.189-26.453-1.249
				c-1.991,0.345-57.262,22.871-61.991,27.812c-5.864,6.126-21.715,21.578-19.04,28.262c2.675,6.683,30.488-18.619,30.488-18.619
				l13.592-7.6c-16.921,16.474-49.195,38.17-44.546,46.071c4.534,7.705,33.647-14.313,54.396-29.319
				c-17.797,16.021-39.907,44.689-34.813,49.158c4.578,4.017,29.728-29.173,56.606-38.731c9.96-3.542,19.888,6.267,27.723,7.452
				c5.759,0.871,14.649,2.724,20.298,1.128l29.102-8.226c9.914,0.894,10.163,6.738,20.173,8.862
				c11.622,2.465,30.69,5.061,45.492,8.665c85.23,20.753,113.657,30.391,139.752,30.375
				C1950.593,1258.62,1955.177,825.732,1884.41,799.275z"/>
			<path style="fill:#07345A;" d="M1941.236,1051.71c5.609-113.364,4.788-253.09-58.977-276.929
				c-25.16-9.406-69.513,47.151-61.536,279.232C1854.764,1056.814,1904.739,1059.069,1941.236,1051.71z"/>
			<polygon style="fill:#F79C8D;" points="1584.494,1003.001 1590.993,1003.001 1688.705,1242.311 1681.976,1241.29 			"/>
			<path style="fill:#F7A491;" d="M1438.845,1807.733c0,0,8.854,28.291-7,47c-15.854,18.708-81.732,37.065-90.379,47.198
				c-8.647,10.133-7.993,18.763-7.993,18.763l184.899-5.072l-2.014-55.652l-8.514-39.991L1438.845,1807.733z"/>
			<path style="fill:#355389;" d="M1420.345,1864.062c0,0,47.51,19.153,70.458,7.813c22.949-11.34,22.256-14.481,28.897-10.253
				c6.641,4.229,9.019,56.398,9.019,56.398l-207.914,6.089c-14.469-0.332-21.783-10.951-10.028-20.042
				c8.059-6.233,17.374-10.407,22.668-13.432C1349.71,1881.34,1420.345,1864.062,1420.345,1864.062z"/>
			<path style="fill:#3C8F7C;" d="M1445.853,1308.444c-14.29-29.972-46.793-68.995-103.981-45.492
				c-54.544,22.416-69.182,77.508-51.974,133.922s130.501,388.043,134.45,433.64l90.456,0.597c0,0-16.439-262.589-20.472-326.061
				C1490.451,1443.978,1470.586,1360.318,1445.853,1308.444z"/>
			<path style="fill:#F47458;" d="M1299.007,1003.001h302.372c8,0,15.207,4.834,18.242,12.236l93.103,227.074h166.699
				c4.661,0,8.44,3.776,8.44,8.434l0,0c0,4.658-3.779,8.434-8.44,8.434h-474.441c-13.044,0-24.873-7.656-30.214-19.556
				l-93.747-208.832C1275.165,1017.746,1284.708,1003.001,1299.007,1003.001z"/>
			<path style="fill:#FFFFFF;" d="M1461.804,1135.228c2.042,10.2,10.939,17.02,19.871,15.234
				c8.932-1.786,14.517-11.502,12.475-21.702c-2.043-10.199-10.939-17.02-19.871-15.234
				C1465.347,1115.312,1459.762,1125.028,1461.804,1135.228z"/>
			<ellipse style="opacity:0.3;fill:#9BC1F9;" cx="2311.899" cy="532.184" rx="149.301" ry="149.612"/>
			<g>
				<g>
					<g>
						<rect x="2151.332" y="529.239" style="fill:#184655;" width="55.04" height="4.238"/>
					</g>
					<g>
						<rect x="2417.765" y="529.239" style="fill:#184655;" width="55.04" height="4.238"/>
					</g>
					<g>
						<rect x="2309.553" y="372.412" style="fill:#184655;" width="4.229" height="55.155"/>
					</g>
					<g>
						<rect x="2309.553" y="638.332" style="fill:#184655;" width="4.229" height="55.155"/>
					</g>
					<path style="fill:#184655;" d="M2316.455,532.184c0,2.522-2.04,4.566-4.556,4.566c-2.516,0-4.556-2.044-4.556-4.566
						c0-2.521,2.04-4.565,4.556-4.565C2314.415,527.618,2316.455,529.662,2316.455,532.184z"/>
					<g>
						<path style="fill:#184655;" d="M2311.898,534.225c-0.521,0-1.043-0.199-1.44-0.598l-81.867-82.038
							c-0.796-0.797-0.796-2.089,0-2.886c0.795-0.797,2.085-0.797,2.88,0l81.867,82.038c0.796,0.797,0.796,2.089,0,2.886
							C2312.941,534.026,2312.42,534.225,2311.898,534.225z"/>
					</g>
					<g>
						<path style="fill:#184655;" d="M2338.222,615.092c-0.338-0.171-0.613-0.471-0.741-0.86l-26.462-80.097
							c-0.257-0.778,0.164-1.618,0.94-1.875c0.776-0.258,1.615,0.164,1.872,0.942l26.462,80.097
							c0.257,0.778-0.164,1.618-0.941,1.875C2338.964,615.304,2338.56,615.263,2338.222,615.092z"/>
					</g>
				</g>
			</g>
			<path style="fill:#07345A;" d="M2549.853,869.647l13.326-21.645l-10.701-4.34c-2.342-0.95-3.47-3.618-2.521-5.96l0,0
				c0.95-2.342,3.618-3.471,5.96-2.521l12.341,5.005l11.914-19.438l-11.43-4.635c-2.342-0.95-3.47-3.618-2.521-5.96l0,0
				c0.95-2.342,3.618-3.47,5.96-2.52l13.07,5.3l13.837-22.259c1.176-1.891,3.542-2.661,5.605-1.825l1.996,0.809
				c2.619,1.062,3.658,4.221,2.182,6.631l-12.869,21.004l18.95,7.685l13.836-22.259c1.176-1.891,3.542-2.661,5.606-1.825
				l2.178,0.883c2.619,1.062,3.658,4.221,2.182,6.631l-12.869,21.004l10.701,4.34c2.342,0.95,3.47,3.618,2.521,5.96l0,0
				c-0.949,2.342-3.618,3.47-5.96,2.521l-12.342-5.005l-11.732,19.511l11.431,4.635c2.342,0.95,3.47,3.618,2.521,5.96l0,0
				c-0.95,2.342-3.618,3.47-5.96,2.521l-13.07-5.301l-14.133,22.955c-1.171,1.903-3.546,2.681-5.616,1.842l-2.334-0.947
				c-2.623-1.063-3.66-4.229-2.177-6.639l13.326-21.645l-18.95-7.685l-14.133,22.955c-1.171,1.903-3.545,2.681-5.616,1.841
				l-2.333-0.946C2549.408,875.222,2548.37,872.057,2549.853,869.647z M2598.142,852.305l11.914-19.438l-18.95-7.685l-11.914,19.438
				L2598.142,852.305z"/>
			<path style="fill:#F48C7F;" d="M1380.777,280.88l13.625-30.753l-17.609-28.658c-2.006-3.264,0.602-7.411,4.413-7.018
				l33.458,3.455l21.814-25.603c2.484-2.916,7.234-1.717,8.038,2.029l7.053,32.888l31.091,12.835
				c3.541,1.462,3.869,6.35,0.555,8.271l-29.099,16.871l-2.599,33.535c-0.296,3.82-4.844,5.642-7.695,3.084l-25.037-22.462
				l-32.697,7.892C1382.363,288.144,1379.225,284.382,1380.777,280.88z"/>
			<path style="fill:#F7CC7F;" d="M2367.797,280.849l10.22-23.067l-13.208-21.497c-1.504-2.448,0.452-5.559,3.31-5.264l25.097,2.592
				l16.363-19.205c1.864-2.187,5.427-1.288,6.029,1.522l5.29,24.669l23.321,9.627c2.656,1.097,2.902,4.763,0.416,6.204
				l-21.827,12.655l-1.949,25.155c-0.222,2.865-3.633,4.232-5.772,2.313l-18.78-16.848l-24.526,5.919
				C2368.987,286.298,2366.633,283.476,2367.797,280.849z"/>
			<path style="fill:#F48C7F;" d="M2266.351,939.923l-1.619-19.108l-16.659-9.499c-1.897-1.082-1.73-3.87,0.282-4.718l17.672-7.445
				l3.886-18.779c0.443-2.139,3.146-2.842,4.574-1.19l12.542,14.507l19.061-2.107c2.171-0.24,3.675,2.114,2.545,3.983l-9.921,16.411
				l7.894,17.476c0.899,1.991-0.875,4.148-3.001,3.651l-18.673-4.365l-14.182,12.908
				C2269.136,943.12,2266.536,942.1,2266.351,939.923z"/>
			<path style="fill:#F7CC7F;" d="M737.663,658.995l7.495-16.916l-9.686-15.764c-1.103-1.796,0.331-4.077,2.427-3.86l18.404,1.901
				l11.999-14.084c1.367-1.604,3.979-0.944,4.421,1.116l3.88,18.091l17.102,7.06c1.948,0.804,2.128,3.493,0.305,4.55l-16.006,9.28
				l-1.43,18.447c-0.163,2.101-2.664,3.103-4.233,1.696l-13.772-12.355l-17.986,4.341
				C738.536,662.991,736.81,660.922,737.663,658.995z"/>
			<path style="fill:#50BFA5;" d="M1317.757,628.385l7.495-16.916l-9.686-15.764c-1.103-1.796,0.331-4.077,2.427-3.86l18.404,1.901
				l11.999-14.083c1.367-1.604,3.979-0.945,4.421,1.116l3.88,18.091l17.102,7.06c1.948,0.804,2.128,3.493,0.305,4.55l-16.006,9.28
				l-1.429,18.447c-0.163,2.101-2.664,3.103-4.233,1.696l-13.772-12.355l-17.986,4.341
				C1318.629,632.381,1316.903,630.311,1317.757,628.385z"/>
			<polygon style="fill:#50BFA5;" points="1028.938,354.35 1058.639,350.043 1070.849,397.065 1115.052,396.121 1129.943,429.817 
				1147,422.278 1127.084,377.212 1085.195,378.106 1072.491,329.189 1027.799,335.672 			"/>
			<polygon style="fill:#07345A;" points="965.256,1142.007 987.732,1122.12 1023.726,1154.748 1060.174,1129.722 
				1091.103,1149.736 1101.234,1134.079 1059.868,1107.311 1025.327,1131.028 987.882,1097.085 954.062,1127.011 			"/>
			<path style="fill:#50BFA5;" d="M612.253,1166.609l18.861-30.634l-15.146-6.142c-3.314-1.344-4.911-5.12-3.567-8.435l0,0
				c1.344-3.315,5.121-4.912,8.435-3.568l17.467,7.083l16.862-27.51l-16.177-6.56c-3.314-1.344-4.912-5.12-3.568-8.435l0,0
				c1.344-3.314,5.12-4.911,8.435-3.568l18.498,7.502l19.583-31.504c1.664-2.677,5.013-3.767,7.934-2.583l2.824,1.146
				c3.706,1.503,5.178,5.974,3.088,9.384l-18.213,29.727l26.82,10.877l19.583-31.504c1.664-2.677,5.013-3.767,7.934-2.583
				l3.082,1.25c3.706,1.503,5.178,5.974,3.088,9.384l-18.213,29.727l15.146,6.142c3.314,1.344,4.911,5.12,3.567,8.435l0,0
				c-1.344,3.314-5.12,4.912-8.435,3.568l-17.467-7.083l-16.604,27.615l16.177,6.561c3.315,1.344,4.912,5.12,3.568,8.435l0,0
				c-1.344,3.314-5.121,4.912-8.435,3.567l-18.499-7.502l-20.003,32.489c-1.658,2.693-5.018,3.795-7.948,2.606l-3.303-1.339
				c-3.712-1.505-5.181-5.985-3.081-9.396l18.861-30.634l-26.821-10.877l-20.003,32.488c-1.658,2.693-5.018,3.794-7.948,2.606
				l-3.302-1.339C611.622,1174.5,610.153,1170.02,612.253,1166.609z M680.596,1142.066l16.862-27.51l-26.82-10.877l-16.862,27.51
				L680.596,1142.066z"/>
			<g>
				<path style="fill:#3C8F7C;" d="M2325.584,1554.155c-1.918-16.941-4.196-34.269-12.06-49.389
					c-9.562-18.383-26.359-31.648-41.035-46.258c-27.422-27.3-48.524-60.935-61.189-97.531
					c-9.793-28.298-14.676-58.447-28.172-85.171c-8.241-16.318-19.479-30.906-28.839-46.606
					c-22.125-37.107-34.166-80.962-64.168-112.02c-5.773,37.657,5.636,77.616,30.412,106.514
					c7.389,8.618,15.959,16.387,21.588,26.25c10.219,17.903,9.288,39.748,10.485,60.338c2.25,38.697,13.155,76.865,31.684,110.892
					c19.683,36.146,48.095,68.333,58.62,108.137c7.886,29.828,5.543,63.286,22.356,89.137c1.822,2.801,3.907,5.616,4.354,8.929
					c0.251,1.862-0.04,3.749-0.331,5.605c-0.376,2.401-0.753,4.803-1.129,7.204c-3.826,24.413-7.778,55.476,13.2,73.747
					c14.539,12.663,33.251,12.946,43.693-3.874c10.514-16.936,9.582-41.723,8.801-60.784
					C2332.556,1617.536,2329.157,1585.707,2325.584,1554.155z"/>
				<path style="fill:#327F6B;" d="M2363.37,1534.519c-8.162-28.26-20.829-55.175-27.177-83.898
					c-6.157-27.861-6.205-56.664-6.226-85.2c-0.022-31.269-0.044-62.538-0.067-93.807c-0.014-19.467-0.036-39.04-3.253-58.238
					c-6.922-41.307-28.39-79.502-32.027-121.229c-1.573-18.044,0.253-36.281-1.73-54.285c-1.134-10.285-3.773-20.783-8.533-29.908
					c-5.12-9.813-19.266-9.38-23.905,0.671c-10.428,22.593-17.041,47.015-12.828,71.222c2.527,14.52,8.816,28.063,13.512,42.032
					c20.911,62.205,9.81,131.064,25.99,194.67c4.884,19.199,12.269,38.027,13.128,57.822c2.056,47.375-33.327,90.651-30.082,137.96
					c2.661,38.788,30.548,70.888,42.252,107.956c6.552,20.751,7.956,42.901,14.976,63.498c5.454,16.003,18.137,35.436,37.839,30.579
					c18.703-4.611,13.052-19.878,12.217-34.46C2374.629,1630.574,2377.289,1582.711,2363.37,1534.519z"/>
				<path style="fill:#3C8F7C;" d="M2406.181,1560.415c-0.823-14.684-3.302-29.449-1.249-44.012
					c1.735-12.299,6.63-23.889,10.126-35.806c6.552-22.33,8.176-45.768,9.762-68.989c2.884-42.211,5.768-84.421,8.652-126.632
					c4.483-65.614,8.99-131.414,21.257-196.022c3.406-17.939,7.231-37.375-0.831-53.751c-1.699-3.452-5.044-7.114-8.71-5.965
					c-2.611,0.818-3.893,3.695-4.84,6.268c-26.816,72.879-36.953,151.343-66.885,222.994c-7.17,17.164-15.51,34.051-19.223,52.283
					c-4.457,21.892-2.009,44.506-1.434,66.842c0.825,32.034-2.294,64.312-11.14,95.107c-4.628,16.112-10.825,31.86-13.361,48.433
					c-3.162,20.664-0.507,41.712,1.472,62.523c3.805,40.01,5.095,80.259,3.858,120.431c-0.727,23.617,19.209,22.999,32.417,8.489
					c9.236-10.147,9.151-21.286,12.313-33.918C2388.749,1637.221,2408.702,1605.376,2406.181,1560.415z"/>
				<path style="fill:#327F6B;" d="M2281.625,1624.457c-17.629-28.325-52.748-44.429-64.015-75.844
					c-2.867-7.995-3.987-16.592-7.49-24.328c-7.78-17.181-25.467-26.891-42.856-34.795c-2.415-1.098-5.159,0.652-5.196,3.309l0,0
					c-0.058,4.224,1.945,8.254,5.444,10.61c13.395,9.018,23.576,22.803,28.108,38.337c5.371,18.411,3.041,38.594,9.717,56.572
					c5.604,15.092,17.143,27.429,22.563,42.589c4.955,13.859,4.434,28.999,6.763,43.533c2.329,14.534,8.785,29.957,22.131,36.107
					C2305.083,1742.797,2293.014,1642.756,2281.625,1624.457z"/>
				<path style="fill:#3C8F7C;" d="M2482.469,1615.109c-0.752,13.694,1.342,28.051-4.017,40.672
					c-3.428,8.074-9.596,14.602-14.658,21.762c-17.775,25.143-24.222,60.768-51.535,74.922c-1.802,0.934-3.813,1.77-5.807,1.398
					c-2.799-0.522-4.633-3.219-5.758-5.84c-6.696-15.601,0.818-33.177,5.267-49.564c0.778-2.868,1.432-6.063,0.065-8.7
					c-1.503-2.9-4.931-4.158-7.271-6.434c-4.667-4.539-4.227-12.049-3.301-18.5c2.316-16.116,5.571-32.097,9.742-47.833
					c2.366-8.924,5.098-17.925,10.24-25.586c5.66-8.434,13.88-14.73,21.575-21.35c34.01-29.258,60.063-67.715,74.645-110.189
					c3.157-9.195,5.971-18.902,12.492-26.103c6.521-7.201,18.144-10.907,26.085-5.319c5.65,3.976-17.494,41.203-20.192,45.667
					c-7.71,12.756-7.813,23.857-12.171,38.024C2507.191,1546.848,2484.512,1577.917,2482.469,1615.109z"/>
				<path style="fill:#327F6B;" d="M2455.549,1630.945c5.052-13.064,10.147-26.298,11.812-40.209
					c1.851-15.464-0.604-31.279,2.037-46.628c3.396-19.732,14.901-37.088,20.596-56.28c4.113-13.86,5.123-28.423,7.593-42.669
					c7.064-40.738,26.217-80.546,20.72-121.526c-1.196-8.914-5.219-19.304-14.065-20.824c-8.008-1.376-15.3,5.947-17.382,13.816
					c-2.083,7.87-0.529,16.171,0.043,24.292c1.595,22.649-4.867,45.786-17.962,64.315c-12.582,17.802-30.836,31.207-42.159,49.84
					c-13.888,22.855-15.778,50.755-22.864,76.554c-14.093,51.306-49.439,96.063-55.883,148.884
					c-2.564,21.018,2.369,46.567,21.767,54.964C2425.905,1759.76,2442.84,1663.811,2455.549,1630.945z"/>
				<path style="fill:#F47458;" d="M2357.474,1696.059h-8.973h-119.779c-8.803,0-15.298,8.236-13.262,16.818l46.935,197.915
					c1.46,6.156,6.948,10.502,13.262,10.502h72.845h8.973h72.844c6.315,0,11.803-4.346,13.263-10.502l46.935-197.915
					c2.035-8.582-4.46-16.818-13.263-16.818H2357.474z"/>
			</g>
			<g>
				<rect x="439.843" y="1464.416" style="fill:#184655;" width="625.852" height="32.325"/>
				<rect x="451.157" y="1651.927" style="fill:#184655;" width="409.182" height="28.284"/>
				<rect x="977.877" y="1480.578" style="fill:#184655;" width="26.399" height="440.865"/>
				<rect x="604.522" y="1480.578" style="fill:#184655;" width="26.399" height="440.865"/>
				<polygon style="fill:#184655;" points="790.104,1921.442 932.317,1484.369 909.006,1476.786 764.326,1921.442 				"/>
				<polygon style="fill:#184655;" points="390.06,1921.442 511.696,1483.413 488.076,1476.854 364.618,1921.442 				"/>
			</g>
			<path style="fill:#184655;" d="M2311.898,357.454c-96.3,0-174.366,78.229-174.366,174.73s78.066,174.73,174.366,174.73
				c96.301,0,174.367-78.229,174.367-174.73S2408.199,357.454,2311.898,357.454z M2321.25,681.503
				c-82.295,5.175-153.195-57.482-158.36-139.948c-5.164-82.466,57.362-153.514,139.657-158.689
				c82.295-5.175,153.195,57.482,158.359,139.948C2466.071,605.279,2403.545,676.327,2321.25,681.503z"/>
		</g>
		<rect x="199.099" y="1918.739" style="fill:#042A44;" width="2874.635" height="19.496"/>
	</g>
	<path style="fill:#FFFFFF;" d="M1646.892,672.286l46.489-0.759c0,0-0.783,17.675-21.217,18.599
		C1647.248,691.253,1646.892,672.286,1646.892,672.286z"/>
</g>
</svg>
);
height: 100px;">Test</div>`

After digging a bit into the code it seems that the problem might be in tokenizer for style attribute

Assumption that ; can be present only at the end of CSS rule is not correct. I think the common use case where that is not true is base64 encoded images (like in the example above). Tokenizer only returns beggining of the encoded value ('url(data:image/svg+xml').

To make this even worse these values are often long (not hard to find ~10kb strings in the wild) which contributes to slow performance of regex.

Sample fix idea:

function parseStyles(style: string): string[] {
+  let re = /\s*([\w-]+)\s*:\s*((url\(.*?\)[^;]*|[^;]+))/g,
-  let re = /\s*([\w-]+)\s*:\s*([^;]+)/g,
    m,
    result = []
  while ((m = re.exec(style))) result.push(m[1], m[2].trim())
  return result
}

I'm sure that there are probably more cases than url() which could potentially cause this issue. content: "Random content:;" comes into my mind, but I don't think it is that common (and especially in inline styles).

That might be one of these cases where it's hard to find the right balance between spec compliance and correctness vs parsing speed.

marijnh commented 1 month ago

On closer look, it appears there's no need to split these ourselves at all, given that the DOM element style property already has this information. Does attached patch look reasonable to you?

marlass commented 1 month ago

Thanks! That looks nice. I'm not only sure if the access to CSS property value through [name] is fully compatible with theCSSStyleDeclaration interface. I'm having trouble accessing it like this in the browser.

We are using zeed-dom as a lightweight DOM parser and this change exposed the same issue there as well 😅 and additionally it seems that its style getter interface is not at all compatible with CSSStyleDeclaration. I'll report the issue there as well.

marijnh commented 1 month ago

I'm not only sure if the access to CSS property value through [name] is fully compatible with theCSSStyleDeclaration interface. I'm having trouble accessing it like this in the browser.

Could you elaborate on this? What exactly is going wrong?

marlass commented 1 month ago

I guess for 99.9% of the use cases it's alright, but for example with CSS vars different access methods return different result.

image
marijnh commented 1 month ago

Oh, indeed. I didn't know getPropertyValue exists. That seems like a preferable approach. Adjusted in attached patch.

marlass commented 1 month ago

Thanks for such a quick fix! I guess it can be closed now 🎉