Changeset 136640 in webkit
- Timestamp:
- Dec 4, 2012, 10:18:22 PM (12 years ago)
- Location:
- trunk
- Files:
-
- 3 added
- 21 edited
- 1 moved
Legend:
- Unmodified
- Added
- Removed
-
trunk/LayoutTests/platform/chromium/TestExpectations
r136614 r136640 4337 4337 # Flaky on mac debug since r136472 or earlier 4338 4338 webkit.org/b/104023 [ Mac Debug ] fast/dom/HTMLTemplateElement/inertContents.html [ Failure Pass ] 4339 4340 # Needs platform-specific results 4341 webkit.org/b/104035 fast/text/orientation-sideways.html [ Missing ] -
trunk/Source/WebCore/ChangeLog
r136638 r136640 1 2012-12-04 Dan Bernstein <mitz@apple.com> 2 3 Support text-orientation: sideways-right (and sideways when it maps to sideways-right) 4 https://bugs.webkit.org/show_bug.cgi?id=104035 5 6 Reviewed by Anders Carlsson. 7 8 Test: fast/text/orientation-sideways.html 9 10 * GNUmakefile.list.am: Updated for rename of TextOrientation.h. 11 12 * WebCore.gypi: Ditto. 13 14 * WebCore.xcodeproj/project.pbxproj: Ditto. 15 16 * css/CSSComputedStyleDeclaration.cpp: 17 (WebCore::CSSComputedStyleDeclaration::getPropertyCSSValue): Changed to retrieve 18 text-orientation from RenderStyle rather than from the font description. 19 20 * css/CSSParser.cpp: 21 (WebCore::CSSParser::parseValue): Added sideways and sideways-right as acceptable 22 text-orientation values. 23 24 * css/CSSPrimitiveValueMappings.h: 25 (WebCore::CSSPrimitiveValue::CSSPrimitiveValue): Added mappings for sideways and 26 sideways-right. 27 (WebCore::CSSPrimitiveValue::operator TextOrientation): Ditto. 28 29 * css/CSSValueKeywords.in: Added sideways and sideways-right. 30 31 * css/StyleBuilder.cpp: 32 (WebCore::StyleBuilder::StyleBuilder): Removed text-orientation property handler, as it is 33 now handled in CSSStyleResolver. 34 35 * css/StyleResolver.cpp: 36 (WebCore::getFontAndGlyphOrientation): Added this helper function that determines the font 37 orientation and non-CJK glyph orientation based on writing-mode and text-orientation. 38 (WebCore::StyleResolver::styleForDocument): Added code to set the font orientation and 39 non-CJK glyph orientation in the document style. 40 (WebCore::checkForOrientationChange): Added. Sets the font orientation and non-CJK glyph 41 orientation in the child style if the difference between the parent and child styles requires 42 doing so. 43 (WebCore::StyleResolver::updateFont): Added call to checkForOrientationChange(). 44 (WebCore::StyleResolver::applyProperty): Changed the writing-mode case to call the new 45 setWritingMode helper, which dirties the font as needed, rather than changing the font 46 here. Moved handling of text-orientation here, by calling setTextOrientation, which also 47 dirties the font as needed. 48 49 * css/StyleResolver.h: 50 (WebCore::StyleResolver::setWritingMode): Added. Dirties the font if the writing mode changes. 51 (WebCore::StyleResolver::setTextOrientation): Ditto for text orientation. 52 53 * platform/graphics/FontDescription.h: 54 (WebCore::FontDescription::FontDescription): Updated initializer for rename. 55 (WebCore::FontDescription::nonCJKGlyphOrientation): Renamed textOrientation to this. 56 (WebCore::FontDescription::setNonCJKGlyphOrientation): Renamed setTextOrientation to this. 57 (FontDescription): Renamed member variable m_textOrientation to m_nonCJKGlyphOrientation. 58 (WebCore::FontDescription::operator==): Updated for rename. 59 60 * platform/graphics/FontFastPath.cpp: 61 (WebCore::glyphDataAndPageForNonCJKCharacterWithGlyphOrientation): Renamed 62 glyphDataAndPageForCharacterWithTextOrientation to this and changed the parameter type from 63 TextOrientation to NonCJKGlyphOrientation. 64 (WebCore::Font::glyphDataAndPageForCharacter): Updated for above rename. 65 66 * platform/graphics/mac/FontComplexTextMac.cpp: 67 (WebCore::Font::fontDataForCombiningCharacterSequence): Updated for rename of 68 FontDescription::textOrientation(). 69 70 * platform/text/NonCJKGlyphOrientation.h: Renamed TextOrientation.h to this, and renamed 71 the enum and its values to better reflect that they describe how glyphs for non-CJK 72 characters are to be rendered in vertical text. 73 74 * rendering/InlineFlowBox.cpp: 75 (WebCore::InlineFlowBox::requiresIdeographicBaseline): Updated for rename of 76 FontDescription::textOrientation(). 77 78 * rendering/style/RenderStyle.cpp: 79 (WebCore::RenderStyle::diff): Made text-orientation change a layout change. 80 81 * rendering/style/RenderStyle.h: 82 (WebCore::RenderStyle::setTextOrientation): Added. 83 84 * rendering/style/RenderStyleConstants.h: Added a new TextOrientation enum here. 85 86 * rendering/style/StyleRareInheritedData.cpp: 87 (WebCore::StyleRareInheritedData::StyleRareInheritedData): Added initialization and copying 88 of m_textOrientation member variable. 89 (WebCore::StyleRareInheritedData::operator==): Added comparing of m_textOrientation. 90 91 * rendering/style/StyleRareInheritedData.h: 92 (StyleRareInheritedData): Added m_textOrientation member variable. 93 1 94 2012-12-04 Kentaro Hara <haraken@chromium.org> 2 95 -
trunk/Source/WebCore/GNUmakefile.list.am
r136613 r136640 5863 5863 Source/WebCore/platform/text/LocaleToScriptMapping.h \ 5864 5864 Source/WebCore/platform/text/LocaleToScriptMappingDefault.cpp \ 5865 Source/WebCore/platform/text/NonCJKGlyphOrientation.h \ 5865 5866 Source/WebCore/platform/text/ParserUtilities.h \ 5866 5867 Source/WebCore/platform/text/PlatformLocale.cpp \ … … 5898 5899 Source/WebCore/platform/text/TextEncodingRegistry.cpp \ 5899 5900 Source/WebCore/platform/text/TextEncodingRegistry.h \ 5900 Source/WebCore/platform/text/TextOrientation.h \5901 5901 Source/WebCore/platform/text/TextStream.cpp \ 5902 5902 Source/WebCore/platform/text/TextStream.h \ -
trunk/Source/WebCore/WebCore.gypi
r136613 r136640 516 516 'platform/text/LineBreakIteratorPoolICU.h', 517 517 'platform/text/LineEnding.h', 518 'platform/text/NonCJKGlyphOrientation.h', 518 519 'platform/text/QuotedPrintable.h', 519 520 'platform/text/RegularExpression.h', … … 532 533 'platform/text/TextEncoding.h', 533 534 'platform/text/TextEncodingRegistry.h', 534 'platform/text/TextOrientation.h',535 535 'platform/text/TextStream.h', 536 536 'platform/text/UnicodeBidi.h', -
trunk/Source/WebCore/WebCore.xcodeproj/project.pbxproj
r136613 r136640 5702 5702 BCD0FBD00DBD625E00B2F630 /* DOMAbstractView.mm in Sources */ = {isa = PBXBuildFile; fileRef = BCD0FBCF0DBD625E00B2F630 /* DOMAbstractView.mm */; }; 5703 5703 BCD0FC4F0DBD720B00B2F630 /* DOMRGBColorInternal.h in Headers */ = {isa = PBXBuildFile; fileRef = BCD0FC4E0DBD720B00B2F630 /* DOMRGBColorInternal.h */; }; 5704 BCD3F9831326C93700098A60 /* TextOrientation.h in Headers */ = {isa = PBXBuildFile; fileRef = BCD3F9821326C93700098A60 /* TextOrientation.h */; settings = {ATTRIBUTES = (Private, ); }; };5704 BCD3F9831326C93700098A60 /* NonCJKGlyphOrientation.h in Headers */ = {isa = PBXBuildFile; fileRef = BCD3F9821326C93700098A60 /* NonCJKGlyphOrientation.h */; settings = {ATTRIBUTES = (Private, ); }; }; 5705 5705 BCD41ABB0C060DE800C0E446 /* JSHTMLFrameSetElementCustom.cpp in Sources */ = {isa = PBXBuildFile; fileRef = BCD41ABA0C060DE800C0E446 /* JSHTMLFrameSetElementCustom.cpp */; }; 5706 5706 BCD533640ED6848900887468 /* CachedScriptSourceProvider.h in Headers */ = {isa = PBXBuildFile; fileRef = BCD533630ED6848900887468 /* CachedScriptSourceProvider.h */; }; … … 13113 13113 BCD0FBCF0DBD625E00B2F630 /* DOMAbstractView.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; path = DOMAbstractView.mm; sourceTree = "<group>"; }; 13114 13114 BCD0FC4E0DBD720B00B2F630 /* DOMRGBColorInternal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = DOMRGBColorInternal.h; sourceTree = "<group>"; }; 13115 BCD3F9821326C93700098A60 /* TextOrientation.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = TextOrientation.h; sourceTree = "<group>"; };13115 BCD3F9821326C93700098A60 /* NonCJKGlyphOrientation.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = NonCJKGlyphOrientation.h; sourceTree = "<group>"; }; 13116 13116 BCD41ABA0C060DE800C0E446 /* JSHTMLFrameSetElementCustom.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = JSHTMLFrameSetElementCustom.cpp; sourceTree = "<group>"; }; 13117 13117 BCD533630ED6848900887468 /* CachedScriptSourceProvider.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CachedScriptSourceProvider.h; sourceTree = "<group>"; }; … … 20268 20268 7633A72413D8B33A008501B6 /* LocaleToScriptMapping.h */, 20269 20269 7633A72513D8B33A008501B6 /* LocaleToScriptMappingDefault.cpp */, 20270 BCD3F9821326C93700098A60 /* NonCJKGlyphOrientation.h */, 20270 20271 BC76AC110DD7AD5C00415F34 /* ParserUtilities.h */, 20271 20272 F544F78615CFB2A800AF33A8 /* PlatformLocale.cpp */, … … 20307 20308 B2C3DA180D006C1D00EF6F26 /* TextEncodingRegistry.cpp */, 20308 20309 B2C3DA190D006C1D00EF6F26 /* TextEncodingRegistry.h */, 20309 BCD3F9821326C93700098A60 /* TextOrientation.h */,20310 20310 B2C3DA1A0D006C1D00EF6F26 /* TextStream.cpp */, 20311 20311 B2C3DA1B0D006C1D00EF6F26 /* TextStream.h */, … … 25617 25617 93309E1C099E64920056E581 /* TextIterator.h in Headers */, 25618 25618 BCEF45E90E687767001C1287 /* TextMetrics.h in Headers */, 25619 BCD3F9831326C93700098A60 /* TextOrientation.h in Headers */,25619 BCD3F9831326C93700098A60 /* NonCJKGlyphOrientation.h in Headers */, 25620 25620 930FC68A1072B9280045293E /* TextRenderingMode.h in Headers */, 25621 25621 93F198F608245E59001E9ABC /* TextResourceDecoder.h in Headers */, -
trunk/Source/WebCore/css/CSSComputedStyleDeclaration.cpp
r136588 r136640 2487 2487 return cssValuePool().createValue(style->textCombine()); 2488 2488 case CSSPropertyWebkitTextOrientation: 2489 return CSSPrimitiveValue::create(style-> fontDescription().textOrientation());2489 return CSSPrimitiveValue::create(style->textOrientation()); 2490 2490 case CSSPropertyWebkitLineBoxContain: 2491 2491 return createLineBoxContainValue(style->lineBoxContain()); -
trunk/Source/WebCore/css/CSSParser.cpp
r136588 r136640 2720 2720 2721 2721 case CSSPropertyWebkitTextOrientation: 2722 // FIXME: For now just support upright and vertical-right.2723 if (id == CSSValue VerticalRight || id == CSSValueUpright)2722 // FIXME: For now just support sideways, sideways-right, upright and vertical-right. 2723 if (id == CSSValueSideways || id == CSSValueSidewaysRight || id == CSSValueVerticalRight || id == CSSValueUpright) 2724 2724 validPrimitive = true; 2725 2725 break; -
trunk/Source/WebCore/css/CSSPrimitiveValueMappings.h
r136380 r136640 47 47 #include "SVGRenderStyleDefs.h" 48 48 #include "TextDirection.h" 49 #include "TextOrientation.h"50 49 #include "TextRenderingMode.h" 51 50 #include "ThemeTypes.h" … … 2985 2984 m_primitiveUnitType = CSS_IDENT; 2986 2985 switch (e) { 2986 case TextOrientationSideways: 2987 m_value.ident = CSSValueSideways; 2988 break; 2989 case TextOrientationSidewaysRight: 2990 m_value.ident = CSSValueSidewaysRight; 2991 break; 2987 2992 case TextOrientationVerticalRight: 2988 2993 m_value.ident = CSSValueVerticalRight; … … 2997 3002 { 2998 3003 switch (m_value.ident) { 3004 case CSSValueSideways: 3005 return TextOrientationSideways; 3006 case CSSValueSidewaysRight: 3007 return TextOrientationSidewaysRight; 2999 3008 case CSSValueVerticalRight: 3000 3009 return TextOrientationVerticalRight; -
trunk/Source/WebCore/css/CSSValueKeywords.in
r136275 r136640 896 896 897 897 // -webkit-text-orientation 898 sideways 899 sideways-right 898 900 upright 899 901 vertical-right -
trunk/Source/WebCore/css/StyleBuilder.cpp
r136275 r136640 2056 2056 setPropertyHandler(CSSPropertyWebkitTextEmphasisStyle, ApplyPropertyTextEmphasisStyle::createHandler()); 2057 2057 setPropertyHandler(CSSPropertyWebkitTextFillColor, ApplyPropertyColor<NoInheritFromParent, &RenderStyle::textFillColor, &RenderStyle::setTextFillColor, &RenderStyle::setVisitedLinkTextFillColor, &RenderStyle::color>::createHandler()); 2058 setPropertyHandler(CSSPropertyWebkitTextOrientation, ApplyPropertyFont<TextOrientation, &FontDescription::textOrientation, &FontDescription::setTextOrientation, TextOrientationVerticalRight>::createHandler());2059 2058 setPropertyHandler(CSSPropertyWebkitTextSecurity, ApplyPropertyDefault<ETextSecurity, &RenderStyle::textSecurity, ETextSecurity, &RenderStyle::setTextSecurity, ETextSecurity, &RenderStyle::initialTextSecurity>::createHandler()); 2060 2059 setPropertyHandler(CSSPropertyWebkitTextStrokeColor, ApplyPropertyColor<NoInheritFromParent, &RenderStyle::textStrokeColor, &RenderStyle::setTextStrokeColor, &RenderStyle::setVisitedLinkTextStrokeColor, &RenderStyle::color>::createHandler()); -
trunk/Source/WebCore/css/StyleResolver.cpp
r136629 r136640 1407 1407 } 1408 1408 1409 static void getFontAndGlyphOrientation(const RenderStyle* style, FontOrientation& fontOrientation, NonCJKGlyphOrientation& glyphOrientation) 1410 { 1411 if (style->isHorizontalWritingMode()) { 1412 fontOrientation = Horizontal; 1413 glyphOrientation = NonCJKGlyphOrientationVerticalRight; 1414 return; 1415 } 1416 1417 switch (style->textOrientation()) { 1418 case TextOrientationVerticalRight: 1419 fontOrientation = Vertical; 1420 glyphOrientation = NonCJKGlyphOrientationVerticalRight; 1421 return; 1422 case TextOrientationUpright: 1423 fontOrientation = Vertical; 1424 glyphOrientation = NonCJKGlyphOrientationUpright; 1425 return; 1426 case TextOrientationSideways: 1427 if (style->writingMode() == LeftToRightWritingMode) { 1428 // FIXME: This should map to sideways-left, which is not supported yet. 1429 fontOrientation = Vertical; 1430 glyphOrientation = NonCJKGlyphOrientationVerticalRight; 1431 return; 1432 } 1433 fontOrientation = Horizontal; 1434 glyphOrientation = NonCJKGlyphOrientationVerticalRight; 1435 return; 1436 case TextOrientationSidewaysRight: 1437 fontOrientation = Horizontal; 1438 glyphOrientation = NonCJKGlyphOrientationVerticalRight; 1439 return; 1440 } 1441 } 1442 1409 1443 PassRefPtr<RenderStyle> StyleResolver::styleForDocument(Document* document, CSSFontSelector* fontSelector) 1410 1444 { … … 1487 1521 } else 1488 1522 fontDescription.setUsePrinterFont(document->printing()); 1523 1524 FontOrientation fontOrientation; 1525 NonCJKGlyphOrientation glyphOrientation; 1526 getFontAndGlyphOrientation(documentStyle.get(), fontOrientation, glyphOrientation); 1527 fontDescription.setOrientation(fontOrientation); 1528 fontDescription.setNonCJKGlyphOrientation(glyphOrientation); 1489 1529 1490 1530 documentStyle->setFontDescription(fontDescription); … … 2105 2145 } 2106 2146 2147 static void checkForOrientationChange(RenderStyle* style, const RenderStyle* parentStyle) 2148 { 2149 FontOrientation childFontOrientation; 2150 NonCJKGlyphOrientation childGlyphOrientation; 2151 getFontAndGlyphOrientation(style, childFontOrientation, childGlyphOrientation); 2152 2153 FontOrientation parentFontOrientation; 2154 NonCJKGlyphOrientation parentGlyphOrientation; 2155 getFontAndGlyphOrientation(parentStyle, parentFontOrientation, parentGlyphOrientation); 2156 2157 if (childFontOrientation == parentFontOrientation && childGlyphOrientation == parentGlyphOrientation) 2158 return; 2159 2160 const FontDescription& childFont = style->fontDescription(); 2161 FontDescription newFontDescription(childFont); 2162 newFontDescription.setNonCJKGlyphOrientation(childGlyphOrientation); 2163 newFontDescription.setOrientation(childFontOrientation); 2164 style->setFontDescription(newFontDescription); 2165 } 2166 2107 2167 void StyleResolver::updateFont() 2108 2168 { … … 2113 2173 checkForGenericFamilyChange(style(), m_parentStyle); 2114 2174 checkForZoomChange(style(), m_parentStyle); 2175 checkForOrientationChange(style(), m_parentStyle); 2115 2176 m_style->font().update(m_fontSelector); 2116 2177 m_fontDirty = false; … … 3537 3598 3538 3599 if (primitiveValue) 3539 m_style->setWritingMode(*primitiveValue);3540 3600 setWritingMode(*primitiveValue); 3601 3541 3602 // FIXME: It is not ok to modify document state while applying style. 3542 3603 if (m_element && m_element == m_element->document()->documentElement()) 3543 3604 m_element->document()->setWritingModeSetOnDocumentElement(true); 3544 FontDescription fontDescription = m_style->fontDescription(); 3545 fontDescription.setOrientation(m_style->isHorizontalWritingMode() ? Horizontal : Vertical); 3546 setFontDescription(fontDescription); 3605 3606 return; 3607 } 3608 3609 case CSSPropertyWebkitTextOrientation: { 3610 HANDLE_INHERIT_AND_INITIAL(textOrientation, TextOrientation); 3611 3612 if (primitiveValue) 3613 setTextOrientation(*primitiveValue); 3614 3547 3615 return; 3548 3616 } … … 3870 3938 case CSSPropertyWebkitTextEmphasisStyle: 3871 3939 case CSSPropertyWebkitTextFillColor: 3872 case CSSPropertyWebkitTextOrientation:3873 3940 case CSSPropertyWebkitTextSecurity: 3874 3941 case CSSPropertyWebkitTextStrokeColor: -
trunk/Source/WebCore/css/StyleResolver.h
r136615 r136640 166 166 void setEffectiveZoom(float f) { m_fontDirty |= style()->setEffectiveZoom(f); } 167 167 void setTextSizeAdjust(bool b) { m_fontDirty |= style()->setTextSizeAdjust(b); } 168 void setWritingMode(WritingMode writingMode) { m_fontDirty |= style()->setWritingMode(writingMode); } 169 void setTextOrientation(TextOrientation textOrientation) { m_fontDirty |= style()->setTextOrientation(textOrientation); } 168 170 bool hasParentNode() const { return m_parentNode; } 169 171 -
trunk/Source/WebCore/platform/graphics/FontDescription.h
r117868 r136640 33 33 #include "FontTraitsMask.h" 34 34 #include "FontWidthVariant.h" 35 #include " TextOrientation.h"35 #include "NonCJKGlyphOrientation.h" 36 36 #include "TextRenderingMode.h" 37 37 #include "WebKitFontFamilyNames.h" … … 81 81 , m_computedSize(0) 82 82 , m_orientation(Horizontal) 83 , m_ textOrientation(TextOrientationVerticalRight)83 , m_nonCJKGlyphOrientation(NonCJKGlyphOrientationVerticalRight) 84 84 , m_widthVariant(RegularWidth) 85 85 , m_italic(FontItalicOff) … … 133 133 bool isSpecifiedFont() const { return m_isSpecifiedFont; } 134 134 FontOrientation orientation() const { return static_cast<FontOrientation>(m_orientation); } 135 TextOrientation textOrientation() const { return static_cast<TextOrientation>(m_textOrientation); }135 NonCJKGlyphOrientation nonCJKGlyphOrientation() const { return static_cast<NonCJKGlyphOrientation>(m_nonCJKGlyphOrientation); } 136 136 FontWidthVariant widthVariant() const { return static_cast<FontWidthVariant>(m_widthVariant); } 137 137 FontFeatureSettings* featureSettings() const { return m_featureSettings.get(); } … … 163 163 void setIsSpecifiedFont(bool isSpecifiedFont) { m_isSpecifiedFont = isSpecifiedFont; } 164 164 void setOrientation(FontOrientation orientation) { m_orientation = orientation; } 165 void set TextOrientation(TextOrientation textOrientation) { m_textOrientation = textOrientation; }165 void setNonCJKGlyphOrientation(NonCJKGlyphOrientation orientation) { m_nonCJKGlyphOrientation = orientation; } 166 166 void setWidthVariant(FontWidthVariant widthVariant) { m_widthVariant = widthVariant; } 167 167 void setScript(UScriptCode s) { m_script = s; } … … 177 177 178 178 unsigned m_orientation : 1; // FontOrientation - Whether the font is rendering on a horizontal line or a vertical line. 179 unsigned m_ textOrientation : 1; // TextOrientation - Only used by vertical text. Determines the default orientation for non-ideograph glyphs.179 unsigned m_nonCJKGlyphOrientation : 1; // NonCJKGlyphOrientation - Only used by vertical text. Determines the default orientation for non-ideograph glyphs. 180 180 181 181 unsigned m_widthVariant : 2; // FontWidthVariant … … 227 227 && m_isSpecifiedFont == other.m_isSpecifiedFont 228 228 && m_orientation == other.m_orientation 229 && m_ textOrientation == other.m_textOrientation229 && m_nonCJKGlyphOrientation == other.m_nonCJKGlyphOrientation 230 230 && m_widthVariant == other.m_widthVariant 231 231 && m_script == other.m_script -
trunk/Source/WebCore/platform/graphics/FontFastPath.cpp
r131468 r136640 43 43 namespace WebCore { 44 44 45 static inline std::pair<GlyphData, GlyphPage*> glyphDataAndPageFor CharacterWithTextOrientation(UChar32 character, TextOrientation orientation, GlyphData& data, GlyphPage* page, unsigned pageNumber)46 { 47 if (orientation == TextOrientationVerticalRight) {45 static inline std::pair<GlyphData, GlyphPage*> glyphDataAndPageForNonCJKCharacterWithGlyphOrientation(UChar32 character, NonCJKGlyphOrientation orientation, GlyphData& data, GlyphPage* page, unsigned pageNumber) 46 { 47 if (orientation == NonCJKGlyphOrientationVerticalRight) { 48 48 RefPtr<SimpleFontData> verticalRightFontData = data.fontData->verticalRightOrientationFontData(); 49 49 GlyphPageTreeNode* verticalRightNode = GlyphPageTreeNode::getRootChild(verticalRightFontData.get(), pageNumber); … … 59 59 return make_pair(verticalRightData, verticalRightPage); 60 60 } 61 } else if (orientation == TextOrientationUpright) {61 } else if (orientation == NonCJKGlyphOrientationUpright) { 62 62 RefPtr<SimpleFontData> uprightFontData = data.fontData->uprightOrientationFontData(); 63 63 GlyphPageTreeNode* uprightNode = GlyphPageTreeNode::getRootChild(uprightFontData.get(), pageNumber); … … 126 126 } 127 127 } else 128 return glyphDataAndPageFor CharacterWithTextOrientation(c, m_fontDescription.textOrientation(), data, page, pageNumber);128 return glyphDataAndPageForNonCJKCharacterWithGlyphOrientation(c, m_fontDescription.nonCJKGlyphOrientation(), data, page, pageNumber); 129 129 130 130 return make_pair(data, page); … … 222 222 data.fontData->setMaxGlyphPageTreeLevel(max(data.fontData->maxGlyphPageTreeLevel(), node->level())); 223 223 if (!isCJKIdeographOrSymbol(c) && data.fontData->platformData().orientation() != Horizontal && !data.fontData->isTextOrientationFallback()) 224 return glyphDataAndPageFor CharacterWithTextOrientation(c, m_fontDescription.textOrientation(), data, fallbackPage, pageNumber);224 return glyphDataAndPageForNonCJKCharacterWithGlyphOrientation(c, m_fontDescription.nonCJKGlyphOrientation(), data, fallbackPage, pageNumber); 225 225 #endif 226 226 } -
trunk/Source/WebCore/platform/graphics/mac/FontComplexTextMac.cpp
r131703 r136640 193 193 variant = BrokenIdeographVariant; 194 194 simpleFontData = simpleFontData->brokenIdeographFontData().get(); 195 } else if (m_fontDescription. textOrientation() == TextOrientationVerticalRight) {195 } else if (m_fontDescription.nonCJKGlyphOrientation() == NonCJKGlyphOrientationVerticalRight) { 196 196 SimpleFontData* verticalRightFontData = simpleFontData->verticalRightOrientationFontData().get(); 197 197 Glyph verticalRightGlyph = verticalRightFontData->glyphForCharacter(baseCharacter); -
trunk/Source/WebCore/platform/text/NonCJKGlyphOrientation.h
r136629 r136640 1 1 /* 2 * Copyright (C) 2011 Apple Computer, Inc.All rights reserved.2 * Copyright (C) 2011 Apple Inc. All rights reserved. 3 3 * 4 4 * Redistribution and use in source and binary forms, with or without … … 11 11 * documentation and/or other materials provided with the distribution. 12 12 * 13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' 14 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 15 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS 17 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 18 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 19 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 20 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 21 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 22 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF 23 * THE POSSIBILITY OF SUCH DAMAGE. 24 24 */ 25 25 26 #ifndef TextOrientation_h27 #define TextOrientation_h26 #ifndef NonCJKGlyphOrientation_h 27 #define NonCJKGlyphOrientation_h 28 28 29 29 namespace WebCore { 30 30 31 enum TextOrientation { TextOrientationVerticalRight, TextOrientationUpright };31 enum NonCJKGlyphOrientation { NonCJKGlyphOrientationVerticalRight, NonCJKGlyphOrientationUpright }; 32 32 33 33 } 34 34 35 #endif 35 #endif // NonCJKGlyphOrientation_h -
trunk/Source/WebCore/rendering/InlineFlowBox.cpp
r136275 r136640 443 443 return false; 444 444 445 if (renderer()->style(isFirstLineStyle())->fontDescription(). textOrientation() == TextOrientationUpright445 if (renderer()->style(isFirstLineStyle())->fontDescription().nonCJKGlyphOrientation() == NonCJKGlyphOrientationUpright 446 446 || renderer()->style(isFirstLineStyle())->font().primaryFont()->hasVerticalGlyphs()) 447 447 return true; -
trunk/Source/WebCore/rendering/style/RenderStyle.cpp
r136275 r136640 482 482 || rareInheritedData->textEmphasisPosition != other->rareInheritedData->textEmphasisPosition 483 483 || rareInheritedData->textEmphasisCustomMark != other->rareInheritedData->textEmphasisCustomMark 484 || rareInheritedData->m_textOrientation != other->rareInheritedData->m_textOrientation 484 485 || rareInheritedData->m_tabSize != other->rareInheritedData->m_tabSize 485 486 || rareInheritedData->m_lineBoxContain != other->rareInheritedData->m_lineBoxContain -
trunk/Source/WebCore/rendering/style/RenderStyle.h
r136275 r136640 65 65 #include "StyleVisualData.h" 66 66 #include "TextDirection.h" 67 #include "TextOrientation.h"68 67 #include "ThemeTypes.h" 69 68 #include "TransformOperations.h" … … 836 835 TextEmphasisPosition textEmphasisPosition() const { return static_cast<TextEmphasisPosition>(rareInheritedData->textEmphasisPosition); } 837 836 const AtomicString& textEmphasisMarkString() const; 837 838 TextOrientation textOrientation() const { return static_cast<TextOrientation>(rareInheritedData->m_textOrientation); } 838 839 839 840 // Return true if any transform related property (currently transform, transformStyle3D or perspective) … … 1300 1301 void setTextEmphasisCustomMark(const AtomicString& mark) { SET_VAR(rareInheritedData, textEmphasisCustomMark, mark); } 1301 1302 void setTextEmphasisPosition(TextEmphasisPosition position) { SET_VAR(rareInheritedData, textEmphasisPosition, position); } 1303 bool setTextOrientation(TextOrientation); 1302 1304 1303 1305 #if ENABLE(CSS_FILTERS) … … 1469 1471 } 1470 1472 1471 void setWritingMode(WritingMode v) { inherited_flags.m_writingMode = v; } 1473 bool setWritingMode(WritingMode v) 1474 { 1475 if (v == writingMode()) 1476 return false; 1477 1478 inherited_flags.m_writingMode = v; 1479 return true; 1480 } 1472 1481 1473 1482 // A unique style is one that has matches something that makes it impossible to share. … … 1788 1797 } 1789 1798 1799 inline bool RenderStyle::setTextOrientation(TextOrientation textOrientation) 1800 { 1801 if (compareEqual(rareInheritedData->m_textOrientation, textOrientation)) 1802 return false; 1803 1804 rareInheritedData.access()->m_textOrientation = textOrientation; 1805 return true; 1806 } 1807 1790 1808 } // namespace WebCore 1791 1809 -
trunk/Source/WebCore/rendering/style/RenderStyleConstants.h
r136378 r136640 455 455 enum TextEmphasisPosition { TextEmphasisPositionOver, TextEmphasisPositionUnder }; 456 456 457 enum TextOrientation { TextOrientationVerticalRight, TextOrientationUpright, TextOrientationSideways, TextOrientationSidewaysRight }; 458 457 459 enum TextOverflow { TextOverflowClip = 0, TextOverflowEllipsis }; 458 460 -
trunk/Source/WebCore/rendering/style/StyleRareInheritedData.cpp
r136275 r136640 86 86 , textEmphasisMark(TextEmphasisMarkNone) 87 87 , textEmphasisPosition(TextEmphasisPositionOver) 88 , m_textOrientation(TextOrientationVerticalRight) 88 89 , m_lineBoxContain(RenderStyle::initialLineBoxContain()) 89 90 #if ENABLE(CSS_IMAGE_ORIENTATION) … … 152 153 , textEmphasisMark(o.textEmphasisMark) 153 154 , textEmphasisPosition(o.textEmphasisPosition) 155 , m_textOrientation(o.m_textOrientation) 154 156 , m_lineBoxContain(o.m_lineBoxContain) 155 157 #if ENABLE(CSS_IMAGE_ORIENTATION) … … 242 244 && textEmphasisMark == o.textEmphasisMark 243 245 && textEmphasisPosition == o.textEmphasisPosition 246 && m_textOrientation == o.m_textOrientation 244 247 && m_lineBoxContain == o.m_lineBoxContain 245 248 && hyphenationString == o.hyphenationString -
trunk/Source/WebCore/rendering/style/StyleRareInheritedData.h
r136275 r136640 99 99 unsigned textEmphasisMark : 3; // TextEmphasisMark 100 100 unsigned textEmphasisPosition : 1; // TextEmphasisPosition 101 unsigned m_textOrientation : 2; // TextOrientation 101 102 unsigned m_lineBoxContain: 7; // LineBoxContain 102 103 // CSS Image Values Level 3
Note:
See TracChangeset
for help on using the changeset viewer.