|  | @@ -135,7 +135,11 @@ public: | 
														
													
														
															
																|  |  | return face.typeface; |  |  | return face.typeface; | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | Typeface::Ptr defaultFace; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | Typeface::Ptr getDefaultFace() const noexcept | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | const ScopedReadLock slr (lock); | 
														
													
														
															
																|  |  |  |  |  | return defaultFace; | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | private: |  |  | private: | 
														
													
														
															
																|  |  | struct CachedFace |  |  | struct CachedFace | 
														
													
												
													
														
															
																|  | @@ -151,6 +155,7 @@ private: | 
														
													
														
															
																|  |  | Typeface::Ptr typeface; |  |  | Typeface::Ptr typeface; | 
														
													
														
															
																|  |  | }; |  |  | }; | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | Typeface::Ptr defaultFace; | 
														
													
														
															
																|  |  | ReadWriteLock lock; |  |  | ReadWriteLock lock; | 
														
													
														
															
																|  |  | Array<CachedFace> faces; |  |  | Array<CachedFace> faces; | 
														
													
														
															
																|  |  | size_t counter = 0; |  |  | size_t counter = 0; | 
														
													
												
													
														
															
																|  | @@ -182,7 +187,7 @@ class Font::SharedFontInternal  : public ReferenceCountedObject | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | public: |  |  | public: | 
														
													
														
															
																|  |  | SharedFontInternal() noexcept |  |  | SharedFontInternal() noexcept | 
														
													
														
															
																|  |  | : typeface (TypefaceCache::getInstance()->defaultFace), |  |  |  | 
														
													
														
															
																|  |  |  |  |  | : typeface (TypefaceCache::getInstance()->getDefaultFace()), | 
														
													
														
															
																|  |  | typefaceName (Font::getDefaultSansSerifFontName()), |  |  | typefaceName (Font::getDefaultSansSerifFontName()), | 
														
													
														
															
																|  |  | typefaceStyle (Font::getDefaultStyle()), |  |  | typefaceStyle (Font::getDefaultStyle()), | 
														
													
														
															
																|  |  | height (FontValues::defaultFontHeight) |  |  | height (FontValues::defaultFontHeight) | 
														
													
												
													
														
															
																|  | @@ -196,7 +201,7 @@ public: | 
														
													
														
															
																|  |  | underline ((styleFlags & underlined) != 0) |  |  | underline ((styleFlags & underlined) != 0) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | if (styleFlags == plain) |  |  | if (styleFlags == plain) | 
														
													
														
															
																|  |  | typeface = TypefaceCache::getInstance()->defaultFace; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | typeface = TypefaceCache::getInstance()->getDefaultFace(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | SharedFontInternal (const String& name, int styleFlags, float fontHeight) noexcept |  |  | SharedFontInternal (const String& name, int styleFlags, float fontHeight) noexcept | 
														
													
												
													
														
															
																|  | @@ -206,7 +211,7 @@ public: | 
														
													
														
															
																|  |  | underline ((styleFlags & underlined) != 0) |  |  | underline ((styleFlags & underlined) != 0) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | if (styleFlags == plain && typefaceName.isEmpty()) |  |  | if (styleFlags == plain && typefaceName.isEmpty()) | 
														
													
														
															
																|  |  | typeface = TypefaceCache::getInstance()->defaultFace; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | typeface = TypefaceCache::getInstance()->getDefaultFace(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | SharedFontInternal (const String& name, const String& style, float fontHeight) noexcept |  |  | SharedFontInternal (const String& name, const String& style, float fontHeight) noexcept | 
														
													
												
													
														
															
																|  | @@ -248,10 +253,119 @@ public: | 
														
													
														
															
																|  |  | && typefaceStyle == other.typefaceStyle; |  |  | && typefaceStyle == other.typefaceStyle; | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | /*  The typeface and ascent data members may be read/set from multiple threads | 
														
													
														
															
																|  |  |  |  |  | simultaneously, e.g. in the case that two Font instances reference the same | 
														
													
														
															
																|  |  |  |  |  | SharedFontInternal and call getTypefacePtr() simultaneously. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | We lock in functions that modify the typeface or ascent in order to | 
														
													
														
															
																|  |  |  |  |  | ensure thread safety. | 
														
													
														
															
																|  |  |  |  |  | */ | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | Typeface::Ptr getTypefacePtr (const Font& f) | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | const ScopedLock lock (mutex); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (typeface == nullptr) | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | typeface = TypefaceCache::getInstance()->findTypefaceFor (f); | 
														
													
														
															
																|  |  |  |  |  | jassert (typeface != nullptr); | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | return typeface; | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | void checkTypefaceSuitability (const Font& f) | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | const ScopedLock lock (mutex); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (typeface != nullptr && ! typeface->isSuitableForFont (f)) | 
														
													
														
															
																|  |  |  |  |  | typeface = nullptr; | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | float getAscent (const Font& f) | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | const ScopedLock lock (mutex); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (ascent == 0.0f) | 
														
													
														
															
																|  |  |  |  |  | ascent = getTypefacePtr (f)->getAscent(); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | return height * ascent; | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | /*  We do not need to lock in these functions, as it's guaranteed | 
														
													
														
															
																|  |  |  |  |  | that these data members can only change if there is a single Font | 
														
													
														
															
																|  |  |  |  |  | instance referencing the shared state. | 
														
													
														
															
																|  |  |  |  |  | */ | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | String getTypefaceName() const          { return typefaceName; } | 
														
													
														
															
																|  |  |  |  |  | String getTypefaceStyle() const         { return typefaceStyle; } | 
														
													
														
															
																|  |  |  |  |  | float getHeight() const                 { return height; } | 
														
													
														
															
																|  |  |  |  |  | float getHorizontalScale() const        { return horizontalScale; } | 
														
													
														
															
																|  |  |  |  |  | float getKerning() const                { return kerning; } | 
														
													
														
															
																|  |  |  |  |  | bool getUnderline() const               { return underline; } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | /*  This shared state may be shared between two or more Font instances that are being | 
														
													
														
															
																|  |  |  |  |  | read/modified from multiple threads. | 
														
													
														
															
																|  |  |  |  |  | Before modifying a shared instance you *must* call dupeInternalIfShared to | 
														
													
														
															
																|  |  |  |  |  | ensure that only one Font instance is pointing to the SharedFontInternal instance | 
														
													
														
															
																|  |  |  |  |  | during the modification. | 
														
													
														
															
																|  |  |  |  |  | */ | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | void setTypeface (Typeface::Ptr x) | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | jassert (getReferenceCount() == 1); | 
														
													
														
															
																|  |  |  |  |  | typeface = std::move (x); | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | void setTypefaceName (String x) | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | jassert (getReferenceCount() == 1); | 
														
													
														
															
																|  |  |  |  |  | typefaceName = std::move (x); | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | void setTypefaceStyle (String x) | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | jassert (getReferenceCount() == 1); | 
														
													
														
															
																|  |  |  |  |  | typefaceStyle = std::move (x); | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | void setHeight (float x) | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | jassert (getReferenceCount() == 1); | 
														
													
														
															
																|  |  |  |  |  | height = x; | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | void setHorizontalScale (float x) | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | jassert (getReferenceCount() == 1); | 
														
													
														
															
																|  |  |  |  |  | horizontalScale = x; | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | void setKerning (float x) | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | jassert (getReferenceCount() == 1); | 
														
													
														
															
																|  |  |  |  |  | kerning = x; | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | void setAscent (float x) | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | jassert (getReferenceCount() == 1); | 
														
													
														
															
																|  |  |  |  |  | ascent = x; | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | void setUnderline (bool x) | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | jassert (getReferenceCount() == 1); | 
														
													
														
															
																|  |  |  |  |  | underline = x; | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | private: | 
														
													
														
															
																|  |  | Typeface::Ptr typeface; |  |  | Typeface::Ptr typeface; | 
														
													
														
															
																|  |  | String typefaceName, typefaceStyle; |  |  | String typefaceName, typefaceStyle; | 
														
													
														
															
																|  |  | float height, horizontalScale = 1.0f, kerning = 0, ascent = 0; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | float height = 0.0f, horizontalScale = 1.0f, kerning = 0.0f, ascent = 0.0f; | 
														
													
														
															
																|  |  | bool underline = false; |  |  | bool underline = false; | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | CriticalSection mutex; | 
														
													
														
															
																|  |  | }; |  |  | }; | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | //============================================================================== |  |  | //============================================================================== | 
														
													
												
													
														
															
																|  | @@ -291,9 +405,7 @@ Font& Font::operator= (Font&& other) noexcept | 
														
													
														
															
																|  |  | return *this; |  |  | return *this; | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | Font::~Font() noexcept |  |  |  | 
														
													
														
															
																|  |  | { |  |  |  | 
														
													
														
															
																|  |  | } |  |  |  | 
														
													
														
															
																|  |  |  |  |  | Font::~Font() noexcept = default; | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | bool Font::operator== (const Font& other) const noexcept |  |  | bool Font::operator== (const Font& other) const noexcept | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
												
													
														
															
																|  | @@ -314,8 +426,7 @@ void Font::dupeInternalIfShared() | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | void Font::checkTypefaceSuitability() |  |  | void Font::checkTypefaceSuitability() | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | if (font->typeface != nullptr && ! font->typeface->isSuitableForFont (*this)) |  |  |  | 
														
													
														
															
																|  |  | font->typeface = nullptr; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | font->checkTypefaceSuitability (*this); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | //============================================================================== |  |  | //============================================================================== | 
														
													
												
													
														
															
																|  | @@ -346,30 +457,30 @@ const String& Font::getDefaultSerifFontName()           { return getFontPlacehol | 
														
													
														
															
																|  |  | const String& Font::getDefaultMonospacedFontName()      { return getFontPlaceholderNames().mono; } |  |  | const String& Font::getDefaultMonospacedFontName()      { return getFontPlaceholderNames().mono; } | 
														
													
														
															
																|  |  | const String& Font::getDefaultStyle()                   { return getFontPlaceholderNames().regular; } |  |  | const String& Font::getDefaultStyle()                   { return getFontPlaceholderNames().regular; } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | const String& Font::getTypefaceName() const noexcept    { return font->typefaceName; } |  |  |  | 
														
													
														
															
																|  |  | const String& Font::getTypefaceStyle() const noexcept   { return font->typefaceStyle; } |  |  |  | 
														
													
														
															
																|  |  |  |  |  | String Font::getTypefaceName() const noexcept           { return font->getTypefaceName(); } | 
														
													
														
															
																|  |  |  |  |  | String Font::getTypefaceStyle() const noexcept          { return font->getTypefaceStyle(); } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | void Font::setTypefaceName (const String& faceName) |  |  | void Font::setTypefaceName (const String& faceName) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | if (faceName != font->typefaceName) |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (faceName != font->getTypefaceName()) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | jassert (faceName.isNotEmpty()); |  |  | jassert (faceName.isNotEmpty()); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | dupeInternalIfShared(); |  |  | dupeInternalIfShared(); | 
														
													
														
															
																|  |  | font->typefaceName = faceName; |  |  |  | 
														
													
														
															
																|  |  | font->typeface = nullptr; |  |  |  | 
														
													
														
															
																|  |  | font->ascent = 0; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | font->setTypefaceName (faceName); | 
														
													
														
															
																|  |  |  |  |  | font->setTypeface (nullptr); | 
														
													
														
															
																|  |  |  |  |  | font->setAscent (0); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | void Font::setTypefaceStyle (const String& typefaceStyle) |  |  | void Font::setTypefaceStyle (const String& typefaceStyle) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | if (typefaceStyle != font->typefaceStyle) |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (typefaceStyle != font->getTypefaceStyle()) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | dupeInternalIfShared(); |  |  | dupeInternalIfShared(); | 
														
													
														
															
																|  |  | font->typefaceStyle = typefaceStyle; |  |  |  | 
														
													
														
															
																|  |  | font->typeface = nullptr; |  |  |  | 
														
													
														
															
																|  |  | font->ascent = 0; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | font->setTypefaceStyle (typefaceStyle); | 
														
													
														
															
																|  |  |  |  |  | font->setTypeface (nullptr); | 
														
													
														
															
																|  |  |  |  |  | font->setAscent (0); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
												
													
														
															
																|  | @@ -382,18 +493,17 @@ Font Font::withTypefaceStyle (const String& newStyle) const | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | StringArray Font::getAvailableStyles() const |  |  | StringArray Font::getAvailableStyles() const | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | return findAllTypefaceStyles (getTypeface()->getName()); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | return findAllTypefaceStyles (getTypefacePtr()->getName()); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | Typeface* Font::getTypeface() const |  |  |  | 
														
													
														
															
																|  |  |  |  |  | Typeface::Ptr Font::getTypefacePtr() const | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | if (font->typeface == nullptr) |  |  |  | 
														
													
														
															
																|  |  | { |  |  |  | 
														
													
														
															
																|  |  | font->typeface = TypefaceCache::getInstance()->findTypefaceFor (*this); |  |  |  | 
														
													
														
															
																|  |  | jassert (font->typeface != nullptr); |  |  |  | 
														
													
														
															
																|  |  | } |  |  |  | 
														
													
														
															
																|  |  |  |  |  | return font->getTypefacePtr (*this); | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | return font->typeface.get(); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | Typeface* Font::getTypeface() const | 
														
													
														
															
																|  |  |  |  |  | { | 
														
													
														
															
																|  |  |  |  |  | return getTypefacePtr().get(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | //============================================================================== |  |  | //============================================================================== | 
														
													
												
													
														
															
																|  | @@ -435,7 +545,7 @@ Font Font::withHeight (const float newHeight) const | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | float Font::getHeightToPointsFactor() const |  |  | float Font::getHeightToPointsFactor() const | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | return getTypeface()->getHeightToPointsFactor(); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | return getTypefacePtr()->getHeightToPointsFactor(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | Font Font::withPointHeight (float heightInPoints) const |  |  | Font Font::withPointHeight (float heightInPoints) const | 
														
													
												
													
														
															
																|  | @@ -449,10 +559,10 @@ void Font::setHeight (float newHeight) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | newHeight = FontValues::limitFontHeight (newHeight); |  |  | newHeight = FontValues::limitFontHeight (newHeight); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | if (font->height != newHeight) |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (font->getHeight() != newHeight) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | dupeInternalIfShared(); |  |  | dupeInternalIfShared(); | 
														
													
														
															
																|  |  | font->height = newHeight; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | font->setHeight (newHeight); | 
														
													
														
															
																|  |  | checkTypefaceSuitability(); |  |  | checkTypefaceSuitability(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
												
													
														
															
																|  | @@ -461,18 +571,18 @@ void Font::setHeightWithoutChangingWidth (float newHeight) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | newHeight = FontValues::limitFontHeight (newHeight); |  |  | newHeight = FontValues::limitFontHeight (newHeight); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | if (font->height != newHeight) |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (font->getHeight() != newHeight) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | dupeInternalIfShared(); |  |  | dupeInternalIfShared(); | 
														
													
														
															
																|  |  | font->horizontalScale *= (font->height / newHeight); |  |  |  | 
														
													
														
															
																|  |  | font->height = newHeight; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | font->setHorizontalScale (font->getHorizontalScale() * (font->getHeight() / newHeight)); | 
														
													
														
															
																|  |  |  |  |  | font->setHeight (newHeight); | 
														
													
														
															
																|  |  | checkTypefaceSuitability(); |  |  | checkTypefaceSuitability(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | int Font::getStyleFlags() const noexcept |  |  | int Font::getStyleFlags() const noexcept | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | int styleFlags = font->underline ? underlined : plain; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | int styleFlags = font->getUnderline() ? underlined : plain; | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | if (isBold())    styleFlags |= bold; |  |  | if (isBold())    styleFlags |= bold; | 
														
													
														
															
																|  |  | if (isItalic())  styleFlags |= italic; |  |  | if (isItalic())  styleFlags |= italic; | 
														
													
												
													
														
															
																|  | @@ -492,10 +602,10 @@ void Font::setStyleFlags (const int newFlags) | 
														
													
														
															
																|  |  | if (getStyleFlags() != newFlags) |  |  | if (getStyleFlags() != newFlags) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | dupeInternalIfShared(); |  |  | dupeInternalIfShared(); | 
														
													
														
															
																|  |  | font->typeface = nullptr; |  |  |  | 
														
													
														
															
																|  |  | font->typefaceStyle = FontStyleHelpers::getStyleName (newFlags); |  |  |  | 
														
													
														
															
																|  |  | font->underline = (newFlags & underlined) != 0; |  |  |  | 
														
													
														
															
																|  |  | font->ascent = 0; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | font->setTypeface (nullptr); | 
														
													
														
															
																|  |  |  |  |  | font->setTypefaceStyle (FontStyleHelpers::getStyleName (newFlags)); | 
														
													
														
															
																|  |  |  |  |  | font->setUnderline ((newFlags & underlined) != 0); | 
														
													
														
															
																|  |  |  |  |  | font->setAscent (0); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
												
													
														
															
																|  | @@ -506,14 +616,14 @@ void Font::setSizeAndStyle (float newHeight, | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | newHeight = FontValues::limitFontHeight (newHeight); |  |  | newHeight = FontValues::limitFontHeight (newHeight); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | if (font->height != newHeight |  |  |  | 
														
													
														
															
																|  |  | || font->horizontalScale != newHorizontalScale |  |  |  | 
														
													
														
															
																|  |  | || font->kerning != newKerningAmount) |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (font->getHeight() != newHeight | 
														
													
														
															
																|  |  |  |  |  | || font->getHorizontalScale() != newHorizontalScale | 
														
													
														
															
																|  |  |  |  |  | || font->getKerning() != newKerningAmount) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | dupeInternalIfShared(); |  |  | dupeInternalIfShared(); | 
														
													
														
															
																|  |  | font->height = newHeight; |  |  |  | 
														
													
														
															
																|  |  | font->horizontalScale = newHorizontalScale; |  |  |  | 
														
													
														
															
																|  |  | font->kerning = newKerningAmount; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | font->setHeight (newHeight); | 
														
													
														
															
																|  |  |  |  |  | font->setHorizontalScale (newHorizontalScale); | 
														
													
														
															
																|  |  |  |  |  | font->setKerning (newKerningAmount); | 
														
													
														
															
																|  |  | checkTypefaceSuitability(); |  |  | checkTypefaceSuitability(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
												
													
														
															
																|  | @@ -527,14 +637,14 @@ void Font::setSizeAndStyle (float newHeight, | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | newHeight = FontValues::limitFontHeight (newHeight); |  |  | newHeight = FontValues::limitFontHeight (newHeight); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | if (font->height != newHeight |  |  |  | 
														
													
														
															
																|  |  | || font->horizontalScale != newHorizontalScale |  |  |  | 
														
													
														
															
																|  |  | || font->kerning != newKerningAmount) |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (font->getHeight() != newHeight | 
														
													
														
															
																|  |  |  |  |  | || font->getHorizontalScale() != newHorizontalScale | 
														
													
														
															
																|  |  |  |  |  | || font->getKerning() != newKerningAmount) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | dupeInternalIfShared(); |  |  | dupeInternalIfShared(); | 
														
													
														
															
																|  |  | font->height = newHeight; |  |  |  | 
														
													
														
															
																|  |  | font->horizontalScale = newHorizontalScale; |  |  |  | 
														
													
														
															
																|  |  | font->kerning = newKerningAmount; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | font->setHeight (newHeight); | 
														
													
														
															
																|  |  |  |  |  | font->setHorizontalScale (newHorizontalScale); | 
														
													
														
															
																|  |  |  |  |  | font->setKerning (newKerningAmount); | 
														
													
														
															
																|  |  | checkTypefaceSuitability(); |  |  | checkTypefaceSuitability(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
												
													
														
															
																|  | @@ -551,18 +661,18 @@ Font Font::withHorizontalScale (const float newHorizontalScale) const | 
														
													
														
															
																|  |  | void Font::setHorizontalScale (const float scaleFactor) |  |  | void Font::setHorizontalScale (const float scaleFactor) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | dupeInternalIfShared(); |  |  | dupeInternalIfShared(); | 
														
													
														
															
																|  |  | font->horizontalScale = scaleFactor; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | font->setHorizontalScale (scaleFactor); | 
														
													
														
															
																|  |  | checkTypefaceSuitability(); |  |  | checkTypefaceSuitability(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | float Font::getHorizontalScale() const noexcept |  |  | float Font::getHorizontalScale() const noexcept | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | return font->horizontalScale; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | return font->getHorizontalScale(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | float Font::getExtraKerningFactor() const noexcept |  |  | float Font::getExtraKerningFactor() const noexcept | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | return font->kerning; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | return font->getKerning(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | Font Font::withExtraKerningFactor (const float extraKerning) const |  |  | Font Font::withExtraKerningFactor (const float extraKerning) const | 
														
													
												
													
														
															
																|  | @@ -575,16 +685,16 @@ Font Font::withExtraKerningFactor (const float extraKerning) const | 
														
													
														
															
																|  |  | void Font::setExtraKerningFactor (const float extraKerning) |  |  | void Font::setExtraKerningFactor (const float extraKerning) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | dupeInternalIfShared(); |  |  | dupeInternalIfShared(); | 
														
													
														
															
																|  |  | font->kerning = extraKerning; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | font->setKerning (extraKerning); | 
														
													
														
															
																|  |  | checkTypefaceSuitability(); |  |  | checkTypefaceSuitability(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | Font Font::boldened() const                 { return withStyle (getStyleFlags() | bold); } |  |  | Font Font::boldened() const                 { return withStyle (getStyleFlags() | bold); } | 
														
													
														
															
																|  |  | Font Font::italicised() const               { return withStyle (getStyleFlags() | italic); } |  |  | Font Font::italicised() const               { return withStyle (getStyleFlags() | italic); } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | bool Font::isBold() const noexcept          { return FontStyleHelpers::isBold   (font->typefaceStyle); } |  |  |  | 
														
													
														
															
																|  |  | bool Font::isItalic() const noexcept        { return FontStyleHelpers::isItalic (font->typefaceStyle); } |  |  |  | 
														
													
														
															
																|  |  | bool Font::isUnderlined() const noexcept    { return font->underline; } |  |  |  | 
														
													
														
															
																|  |  |  |  |  | bool Font::isBold() const noexcept          { return FontStyleHelpers::isBold   (font->getTypefaceStyle()); } | 
														
													
														
															
																|  |  |  |  |  | bool Font::isItalic() const noexcept        { return FontStyleHelpers::isItalic (font->getTypefaceStyle()); } | 
														
													
														
															
																|  |  |  |  |  | bool Font::isUnderlined() const noexcept    { return font->getUnderline(); } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | void Font::setBold (const bool shouldBeBold) |  |  | void Font::setBold (const bool shouldBeBold) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
												
													
														
															
																|  | @@ -603,20 +713,17 @@ void Font::setItalic (const bool shouldBeItalic) | 
														
													
														
															
																|  |  | void Font::setUnderline (const bool shouldBeUnderlined) |  |  | void Font::setUnderline (const bool shouldBeUnderlined) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | dupeInternalIfShared(); |  |  | dupeInternalIfShared(); | 
														
													
														
															
																|  |  | font->underline = shouldBeUnderlined; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | font->setUnderline (shouldBeUnderlined); | 
														
													
														
															
																|  |  | checkTypefaceSuitability(); |  |  | checkTypefaceSuitability(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | float Font::getAscent() const |  |  | float Font::getAscent() const | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | if (font->ascent == 0.0f) |  |  |  | 
														
													
														
															
																|  |  | font->ascent = getTypeface()->getAscent(); |  |  |  | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | return font->height * font->ascent; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | return font->getAscent (*this); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | float Font::getHeight() const noexcept      { return font->height; } |  |  |  | 
														
													
														
															
																|  |  | float Font::getDescent() const              { return font->height - getAscent(); } |  |  |  | 
														
													
														
															
																|  |  |  |  |  | float Font::getHeight() const noexcept      { return font->getHeight(); } | 
														
													
														
															
																|  |  |  |  |  | float Font::getDescent() const              { return font->getHeight() - getAscent(); } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | float Font::getHeightInPoints() const       { return getHeight()  * getHeightToPointsFactor(); } |  |  | float Font::getHeightInPoints() const       { return getHeight()  * getHeightToPointsFactor(); } | 
														
													
														
															
																|  |  | float Font::getAscentInPoints() const       { return getAscent()  * getHeightToPointsFactor(); } |  |  | float Font::getAscentInPoints() const       { return getAscent()  * getHeightToPointsFactor(); } | 
														
													
												
													
														
															
																|  | @@ -629,35 +736,27 @@ int Font::getStringWidth (const String& text) const | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | float Font::getStringWidthFloat (const String& text) const |  |  | float Font::getStringWidthFloat (const String& text) const | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | // This call isn't thread-safe when there's a message thread running |  |  |  | 
														
													
														
															
																|  |  | jassert (MessageManager::getInstanceWithoutCreating() == nullptr |  |  |  | 
														
													
														
															
																|  |  | || MessageManager::getInstanceWithoutCreating()->currentThreadHasLockedMessageManager()); |  |  |  | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | auto w = getTypeface()->getStringWidth (text); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | auto w = getTypefacePtr()->getStringWidth (text); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | if (font->kerning != 0.0f) |  |  |  | 
														
													
														
															
																|  |  | w += font->kerning * (float) text.length(); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (font->getKerning() != 0.0f) | 
														
													
														
															
																|  |  |  |  |  | w += font->getKerning() * (float) text.length(); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | return w * font->height * font->horizontalScale; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | return w * font->getHeight() * font->getHorizontalScale(); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | void Font::getGlyphPositions (const String& text, Array<int>& glyphs, Array<float>& xOffsets) const |  |  | void Font::getGlyphPositions (const String& text, Array<int>& glyphs, Array<float>& xOffsets) const | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | // This call isn't thread-safe when there's a message thread running |  |  |  | 
														
													
														
															
																|  |  | jassert (MessageManager::getInstanceWithoutCreating() == nullptr |  |  |  | 
														
													
														
															
																|  |  | || MessageManager::getInstanceWithoutCreating()->currentThreadHasLockedMessageManager()); |  |  |  | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | getTypeface()->getGlyphPositions (text, glyphs, xOffsets); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | getTypefacePtr()->getGlyphPositions (text, glyphs, xOffsets); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | if (auto num = xOffsets.size()) |  |  | if (auto num = xOffsets.size()) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | auto scale = font->height * font->horizontalScale; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | auto scale = font->getHeight() * font->getHorizontalScale(); | 
														
													
														
															
																|  |  | auto* x = xOffsets.getRawDataPointer(); |  |  | auto* x = xOffsets.getRawDataPointer(); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | if (font->kerning != 0.0f) |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (font->getKerning() != 0.0f) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | for (int i = 0; i < num; ++i) |  |  | for (int i = 0; i < num; ++i) | 
														
													
														
															
																|  |  | x[i] = (x[i] + (float) i * font->kerning) * scale; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | x[i] = (x[i] + (float) i * font->getKerning()) * scale; | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | else |  |  | else | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
												
													
														
															
																|  | 
 |