blob: a013c20f819e7a805e594f4e71c6576f4ee193b0 [file] [log] [blame]
/*
* Copyright (C) 2020-2024 Apple Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/* https://w3c.github.io/mathml-core/#user-agent-stylesheet */
#if defined(ENABLE_MATHML) && ENABLE_MATHML
@namespace "http://www.w3.org/1998/Math/MathML";
:any-link {
color: -webkit-link;
cursor: auto;
}
:any-link:active {
color: -webkit-activelink;
}
:focus {
outline: auto 5px -webkit-focus-ring-color
}
/* Universal rules */
* {
writing-mode: horizontal-tb !important;
/* FIXME: It should be 'display: block math'. (webkit.org/b/278533) */
display: block;
}
/* The <math> element */
math {
direction: ltr;
text-indent: 0;
letter-spacing: normal;
line-height: normal;
word-spacing: normal;
font-style: normal;
font-weight: normal;
display: inline;
math-shift: normal;
math-style: compact;
math-depth: 0;
/*
We use the exact bounding boxes of glyphs to avoid excessive gaps in mathematical formulas.
FIXME: Should we replace this with a more general handling of ink/logical ascent/descent?
See http://webkit.org/b/130326, http://webkit.org/b/156841 and
http://www.mathml-association.org/MathMLinHTML5/S3.html#SS1.SSS1
*/
-webkit-line-box-contain: glyphs replaced;
/*
Inheriting the font-family is likely to make MathML use text fonts that are not designed for
math layout and thus would cause very poor mathematical rendering. Consequently, the default
font-family on the <math> tag is set to the generic math font
(https://www.w3.org/TR/css-fonts-4/#valdef-font-family-math).
See `Source/WebCore/css/CSSFontSelector.cpp` for the fallback math font list.
For best rendering, authors and readers are encouraged to use text and math fonts with consistent
style (appearance, size...), see http://trac.webkit.org/wiki/MathML/Fonts#CustomizingMathFont
*/
font-family: math;
}
math[display="block" i] {
/* FIXME: It should be 'display: block math'. (webkit.org/b/278533) */
display: block;
page-break-inside: avoid;
math-style: normal;
}
math[display="inline" i] {
/* FIXME: It should be 'display: inline math'. (webkit.org/b/278533) */
display: inline;
math-style: compact;
}
/* <mrow>-like elements */
merror {
border: 1px solid red;
background-color: lightYellow;
}
mphantom {
visibility: hidden;
}
/* Token elements */
ms, mtext, mi, mn, mo, annotation, mtd {
white-space: nowrap !important;
}
/* Tables */
mtable {
display: inline-table;
text-align: center;
math-style: compact;
}
mtr {
display: table-row;
}
mtd {
display: table-cell;
padding: 0.5ex;
}
/* Use inline-block for children so that the text-align property is taken into account */
mtd > * {
display: inline-block;
}
mtable[columnalign="left"], mtr[columnalign="left"], mtd[columnalign="left"] {
text-align: left;
}
mtable[columnalign="right"], mtr[columnalign="right"], mtd[columnalign="right"] {
text-align: right;
}
mtable[rowalign="top"] mtd, mtable mtr[rowalign="top"] mtd, mtable mtr mtd[rowalign="top"] {
vertical-align: top;
}
mtable[rowalign="bottom"] mtd, mtable mtr[rowalign="bottom"] mtd, mtable mtr mtd[rowalign="bottom"] {
vertical-align: bottom;
}
mtable[rowalign="center"] mtd, mtable mtr[rowalign="center"] mtd, mtable mtr mtd[rowalign="center"] {
vertical-align: middle;
}
mtable[frame="solid"] {
border: solid thin;
}
mtable[frame="dashed"] {
border: dashed thin;
}
mtable[rowlines="solid"], mtable[rowlines="dashed"], mtable[columnlines="solid"], mtable[columnlines="dashed"] {
border-collapse: collapse;
}
mtable[rowlines="solid"] > mtr + mtr {
border-top: solid thin;
}
mtable[rowlines="dashed"] > mtr + mtr {
border-top: dashed thin;
}
mtable[columnlines="solid"] > mtr > mtd + mtd {
border-left: solid thin;
}
mtable[columnlines="dashed"] > mtr > mtd + mtd {
border-left: dashed thin;
}
/* Fractions */
mfrac {
padding-inline: 1px;
}
mfrac > * {
math-depth: auto-add;
math-style: compact;
}
mfrac > :nth-child(2) {
math-shift: compact;
}
/* Other rules for scriptlevel, displaystyle and math-shift */
mroot > :not(:first-child) {
math-depth: add(2);
math-style: compact;
}
mroot, msqrt {
math-shift: compact;
}
msub > :not(:first-child),
msup > :not(:first-child),
msubsup > :not(:first-child),
mmultiscripts > :not(:first-child),
munder > :not(:first-child),
mover > :not(:first-child),
munderover > :not(:first-child) {
math-depth: add(1);
math-style: compact;
}
munder[accentunder="true" i] > :nth-child(2),
mover[accent="true" i] > :nth-child(2),
munderover[accentunder="true" i] > :nth-child(2),
munderover[accent="true" i] > :nth-child(3) {
font-size: inherit;
}
msub > :nth-child(2),
msubsup > :nth-child(2),
mmultiscripts > :nth-child(even),
mmultiscripts > mprescripts ~ :nth-child(odd),
mover[accent="true" i] > :first-child,
munderover[accent="true" i] > :first-child {
math-shift: compact;
}
mmultiscripts > mprescripts ~ :nth-child(even) {
math-shift: inherit;
}
#endif