Source code

Revision control

Other Tools

Test Info:

<!DOCTYPE HTML>
<!--
Any copyright is dedicated to the Public Domain.
-->
<html><head>
<meta charset="utf-8">
<title>CSS Test: Testing definite placement with non-existent line names</title>
<link rel="author" title="Mats Palmgren" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1146051">
<link rel="match" href="grid-placement-definite-implicit-002-ref.html">
<style type="text/css">
html,body {
font-size: 16px;
font-family: monospace;
padding:0; margin:0;
}
span {
background: lime;
border: 1px solid;
grid-row: 1;
}
.grid {
display: grid;
grid-template-columns: [A] 20px [A] 20px;
grid-template-rows: 20px 20px;
grid-auto-columns: 20px;
}
/* Legend:
X = line name with no match
x = ditto with span
A = existing line name
a = ditto with span
N = line number
n = ditto with span
e = on the end side
s = on the start side
*/
.XeN { grid-column: X 3 / 2; }
.XsN { grid-column: X -3 / 2; }
.NeX { grid-column: 2 / X 3; }
.NsX { grid-column: 2 / X -3; }
.XeA { grid-column: X 3 / A; }
.XsA { grid-column: X -3 / A; }
.XsA2 { grid-column: X -3 / A 2; }
.XsA3 { grid-column: X -3 / A 3; }
.AsX { grid-column: A / X -3; }
.xsN { grid-column: span X / 1; }
.x2sN { grid-column: span X 2 / 1; }
.xsN2 { grid-column: span X / 2; }
.xXs { grid-column: span X / X -2; }
.aXs { grid-column: span A / X -2; }
.aXe { grid-column: span A / X 2; }
.xXe { grid-column: span X / X 2; }
.AXe { grid-column: A / X 2; }
.A2Xe { grid-column: A 2 / X 2; }
.XXe { grid-column: X / X 2; }
.XX3e { grid-column: X / X 3; }
.XbXe { grid-column: X -2 / X; }
.XX0b { grid-column: X -3 / X -3; }
.XX1b { grid-column: X -3 / X -2; }
.XX2b { grid-column: X -3 / X -1; }
.XbN1 { grid-column: X -3 / 1; }
.XbN2 { grid-column: X -3 / 2; }
.Xbb { grid-column: X -3 / X -4; }
.Xee { grid-column: X 3 / X; }
.nX2s { grid-column: span 2 / X -2; }
.nXs { grid-column: span 2 / X -1; }
.nXe { grid-column: span 2 / X; }
.nX2e { grid-column: span 2 / X 2; }
.nX3e { grid-column: span 2 / X 3; }
.n3Xe { grid-column: span 3 / X; }
.n4Xe { grid-column: span 4 / X; }
.Xen3 { grid-column: X / span 3; }
.Xea { grid-column: X / span A; }
.Xea2 { grid-column: X / span A 2; }
.Xea3 { grid-column: X / span A 3; }
.Xsa { grid-column: X -1 / span A; }
.Xsa2 { grid-column: X -1 / span A 2; }
.Xsa4 { grid-column: X -1 / span A 4; }
.Xs2a { grid-column: X -2 / span A; }
.Xs2a2 { grid-column: X -2 / span A 2; }
.Xs2a4 { grid-column: X -2 / span A 4; }
.Xs3a { grid-column: X -3 / span A; }
.Xs3a2 { grid-column: X -3 / span A 2; }
.Xs3a4 { grid-column: X -3 / span A 4; }
.nxe { grid-column: 1 / span X; }
.nx3e { grid-column: 1 / span X 3; }
.n2x3e { grid-column: 2 / span X 3; }
.Axe { grid-column: A / span X; }
.A2xe { grid-column: A 2 / span X; }
.Ax3e { grid-column: A / span X 3; }
.A2x3e { grid-column: A 2 / span X 3; }
.Aa { grid-column: A / span A; }
.A2a { grid-column: A 2 / span A; }
.Aa3 { grid-column: A / span A 3; }
.AXs { grid-column: A / X -2; }
.A2Xs { grid-column: A 2 / X -2; }
._Xs { grid-column: auto / X -2; }
._Xe { grid-column: auto / X 2; }
._xe { grid-column: auto / span X; }
._x3e { grid-column: auto / span X 3; }
._xa { grid-column: auto / span A; }
._xa3 { grid-column: auto / span A 3; }
._xn3 { grid-column: auto / span 3; }
._xn5 { grid-column: auto / span 5; }
.Xs_ { grid-column: X -1 / auto; }
.X2s_ { grid-column: X -2 / auto; }
.X2e_ { grid-column: X 2 / auto; }
.A_ { grid-column: A / auto; }
.A2_ { grid-column: A 2 / auto; }
.x3_ { grid-column: span X 3 / auto; }
.a2_ { grid-column: span A 2 / auto; }
.a-2_ { grid-column: span A -2 / auto; } /*intentionally invalid span*/
._n { grid-column: auto / 1; }
._n2 { grid-column: auto / 2; }
.A3Xe { grid-column: A 3 / X 2; }
.asA { grid-column: span A / A; }
.asA2 { grid-column: span A / A 2; }
.a2sA2 { grid-column: span A 2 / A 2; }
.as1 { grid-column: span A / 1; }
.as2 { grid-column: span A / 2; }
.as3 { grid-column: span A / 3; }
.c1 { grid-column:1; grid-row:auto; background:grey; }
</style>
</head>
<body>
<div style="float:left; width:140px">
<div class="grid"><span class="XeN" ></span><span class="c1"></span></div>
<div class="grid"><span class="XsN" ></span><span class="c1"></span></div>
<div class="grid"><span class="NeX" ></span><span class="c1"></span></div>
<div class="grid"><span class="NsX" ></span><span class="c1"></span></div>
<div class="grid"><span class="XeA" ></span><span class="c1"></span></div>
<div class="grid"><span class="XsA" ></span><span class="c1"></span></div>
<div class="grid"><span class="XsA2"></span><span class="c1"></span></div>
<div class="grid"><span class="XsA3"></span><span class="c1"></span></div>
<div class="grid"><span class="AsX" ></span><span class="c1"></span></div>
<div class="grid"><span class="xsN" ></span><span class="c1"></span></div>
<div class="grid"><span class="x2sN"></span><span class="c1"></span></div>
<div class="grid"><span class="xsN2"></span><span class="c1"></span></div>
<div class="grid"><span class="xXs" ></span><span class="c1"></span></div>
<div class="grid"><span class="aXs" ></span><span class="c1"></span></div>
<div class="grid"><span class="aXe" ></span><span class="c1"></span></div>
<div class="grid"><span class="xXe" ></span><span class="c1"></span></div>
</div>
<div style="float:left; width:140px">
<div class="grid"><span class="AXe" ></span><span class="c1"></span></div>
<div class="grid"><span class="A2Xe"></span><span class="c1"></span></div>
<div class="grid"><span class="XXe" ></span><span class="c1"></span></div>
<div class="grid"><span class="XX3e"></span><span class="c1"></span></div>
<div class="grid"><span class="XbXe"></span><span class="c1"></span></div>
<div class="grid"><span class="XX0b"></span><span class="c1"></span></div>
<div class="grid"><span class="XX1b"></span><span class="c1"></span></div>
<div class="grid"><span class="XX2b"></span><span class="c1"></span></div>
<div class="grid"><span class="XbN1"></span><span class="c1"></span></div>
<div class="grid"><span class="XbN2"></span><span class="c1"></span></div>
<div class="grid"><span class="Xbb" ></span><span class="c1"></span></div>
<div class="grid"><span class="Xee" ></span><span class="c1"></span></div>
<div class="grid"><span class="nX2s"></span><span class="c1"></span></div>
<div class="grid"><span class="nXs" ></span><span class="c1"></span></div>
<div class="grid"><span class="nXe" ></span><span class="c1"></span></div>
<div class="grid"><span class="nX2e"></span><span class="c1"></span></div>
</div>
<div style="float:left; width:140px">
<div class="grid"><span class="nX3e" ></span><span class="c1"></span></div>
<div class="grid"><span class="n3Xe" ></span><span class="c1"></span></div>
<div class="grid"><span class="n4Xe" ></span><span class="c1"></span></div>
<div class="grid"><span class="Xen3" ></span><span class="c1"></span></div>
<div class="grid"><span class="Xea" ></span><span class="c1"></span></div>
<div class="grid"><span class="Xea2" ></span><span class="c1"></span></div>
<div class="grid"><span class="Xea3" ></span><span class="c1"></span></div>
<div class="grid"><span class="Xsa" ></span><span class="c1"></span></div>
<div class="grid"><span class="Xsa2" ></span><span class="c1"></span></div>
<div class="grid"><span class="Xsa4" ></span><span class="c1"></span></div>
<div class="grid"><span class="Xs2a" ></span><span class="c1"></span></div>
<div class="grid"><span class="Xs2a2"></span><span class="c1"></span></div>
<div class="grid"><span class="Xs2a4"></span><span class="c1"></span></div>
<div class="grid"><span class="Xs3a" ></span><span class="c1"></span></div>
<div class="grid"><span class="Xs3a2"></span><span class="c1"></span></div>
<div class="grid"><span class="Xs3a4"></span><span class="c1"></span></div>
</div>
<div style="float:left; width:140px">
<div class="grid"><span class="nxe" ></span><span class="c1"></span></div>
<div class="grid"><span class="nx3e" ></span><span class="c1"></span></div>
<div class="grid"><span class="n2x3e"></span><span class="c1"></span></div>
<div class="grid"><span class="Axe" ></span><span class="c1"></span></div>
<div class="grid"><span class="A2xe" ></span><span class="c1"></span></div>
<div class="grid"><span class="Ax3e" ></span><span class="c1"></span></div>
<div class="grid"><span class="A2x3e"></span><span class="c1"></span></div>
<div class="grid"><span class="Aa" ></span><span class="c1"></span></div>
<div class="grid"><span class="A2a" ></span><span class="c1"></span></div>
<div class="grid"><span class="Aa3" ></span><span class="c1"></span></div>
<div class="grid"><span class="AXs" ></span><span class="c1"></span></div>
<div class="grid"><span class="A2Xs" ></span><span class="c1"></span></div>
<div class="grid"><span class="_Xs" ></span><span class="c1"></span></div>
<div class="grid"><span class="_Xe" ></span><span class="c1"></span></div>
<div class="grid"><span class="_xe" ></span><span class="c1"></span></div>
<div class="grid"><span class="_x3e" ></span><span class="c1"></span></div>
</div>
<div style="float:left; width:140px">
<div class="grid"><span class="_xa" ></span><span class="c1"></span></div>
<div class="grid"><span class="_xa3"></span><span class="c1"></span></div>
<div class="grid"><span class="_xn3"></span><span class="c1"></span></div>
<div class="grid"><span class="_xn5"></span><span class="c1"></span></div>
<div class="grid"><span class="Xs_" ></span><span class="c1"></span></div>
<div class="grid"><span class="X2s_"></span><span class="c1"></span></div>
<div class="grid"><span class="X2e_"></span><span class="c1"></span></div>
<div class="grid"><span class="A_" ></span><span class="c1"></span></div>
<div class="grid"><span class="A2_" ></span><span class="c1"></span></div>
<div class="grid"><span class="x3_" ></span><span class="c1"></span></div>
<div class="grid"><span class="a2_" ></span><span class="c1"></span></div>
<div class="grid"><span class="a-2_"></span><span class="c1"></span></div>
<div class="grid"><span class="_n" ></span><span class="c1"></span></div>
<div class="grid"><span class="_n2" ></span><span class="c1"></span></div>
<div class="grid"><span class="A3Xe"></span><span class="c1"></span></div>
<div class="grid"><span class="asA"></span><span class="c1"></span></div>
</div>
<div style="float:left; width:140px; clear:both">
<div class="grid"><span class="asA2"></span><span class="c1"></span></div>
<div class="grid"><span class="a2sA2"></span><span class="c1"></span></div>
<div class="grid"><span class="as1"></span><span class="c1"></span></div>
<div class="grid"><span class="as2"></span><span class="c1"></span></div>
<div class="grid"><span class="as3"></span><span class="c1"></span></div>
</div>
</body>
</html>