-- Hoogle documentation, generated by Haddock -- See Hoogle, http://www.haskell.org/hoogle/ -- | Pango bindings -- -- Bindings for Pango, autogenerated by haskell-gi. @package gi-pango @version 1.0.21 module GI.Pango.Config overrides :: Text module GI.Pango.Constants -- | A macro that should be defined by the user prior to including the -- pango.h header. The definition should be one of the predefined Pango -- version macros: PANGO_VERSION_1_2, -- PANGO_VERSION_1_4,... -- -- This macro defines the earliest version of Pango that the package is -- required to be able to compile against. -- -- If the compiler is configured to warn about the use of deprecated -- functions, then using functions that were deprecated in version -- VERSION_MIN_REQUIRED or earlier will cause warnings (but using -- functions deprecated in later releases will not). -- -- Since: 1.42 -- | No description available in the introspection data. -- | No description available in the introspection data. -- | The SCALE macro represents the scale between dimensions used -- for Pango distances and device units. (The definition of device units -- is dependent on the output device; it will typically be pixels for a -- screen, and points for a printer.) SCALE is currently 1024, but -- this may be changed in the future. -- -- When setting font sizes, device units are always considered to be -- points (as in "12 point font"), rather than pixels. -- | A string constant defining the render type for engines that are not -- rendering-system specific. -- | Deprecated: (Since version 1.38) -- | The GLYPH_UNKNOWN_FLAG macro is a flag value that can be added -- to a gunichar value of a valid Unicode character, to -- produce a PangoGlyph value, representing an -- unknown-character glyph for the respective gunichar. -- | The GLYPH_INVALID_INPUT macro represents a -- PangoGlyph value that has a special meaning of invalid -- input. Layout produces one such glyph per invalid input UTF-8 -- byte and such a glyph is rendered as a crossed box. -- -- Note that this value is defined such that it has the -- GLYPH_UNKNOWN_FLAG on. -- -- Since: 1.20 -- | The GLYPH_EMPTY macro represents a PangoGlyph -- value that has a special meaning, which is a zero-width empty glyph. -- This is useful for example in shaper modules, to use as the glyph for -- various zero-width Unicode characters (those passing -- isZeroWidth). -- | A string constant defining the engine type for shaping engines. These -- engines derive from EngineShape. -- | Deprecated: (Since version 1.38) -- | A string constant defining the engine type for language engines. These -- engines derive from EngineLang. -- | Deprecated: (Since version 1.38) -- | This value can be used to set the start_index member of a -- Attribute such that the attribute covers from the beginning of -- the text. -- -- Since: 1.24 -- | This flag is used to mark runs that hold ellipsized text, in an -- ellipsized layout. -- -- Since: 1.36.7 -- | Whether the segment should be shifted to center around the baseline. -- Used in vertical writing directions mostly. -- -- Since: 1.16 module GI.Pango.Enums -- | A Alignment describes how to align the lines of a Layout -- within the available space. If the Layout is set to justify -- using layoutSetJustify, this only has effect for partial lines. data Alignment -- | Put all available space on the right AlignmentLeft :: Alignment -- | Center the line within the available space AlignmentCenter :: Alignment -- | Put all available space on the left AlignmentRight :: Alignment -- | Catch-all for unknown values AnotherAlignment :: Int -> Alignment -- | The AttrType distinguishes between different types of -- attributes. Along with the predefined values, it is possible to -- allocate additional values for custom attributes using -- attrTypeRegister. The predefined values are given below. The -- type of structure used to store the attribute is listed in parentheses -- after the description. data AttrType -- | does not happen AttrTypeInvalid :: AttrType -- | language (AttrLanguage) AttrTypeLanguage :: AttrType -- | font family name list (AttrString) AttrTypeFamily :: AttrType -- | font slant style (AttrInt) AttrTypeStyle :: AttrType -- | font weight (AttrInt) AttrTypeWeight :: AttrType -- | font variant (normal or small caps) (AttrInt) AttrTypeVariant :: AttrType -- | font stretch (AttrInt) AttrTypeStretch :: AttrType -- | font size in points scaled by SCALE (AttrInt) AttrTypeSize :: AttrType -- | font description (AttrFontDesc) AttrTypeFontDesc :: AttrType -- | foreground color (AttrColor) AttrTypeForeground :: AttrType -- | background color (AttrColor) AttrTypeBackground :: AttrType -- | whether the text has an underline (AttrInt) AttrTypeUnderline :: AttrType -- | whether the text is struck-through (AttrInt) AttrTypeStrikethrough :: AttrType -- | baseline displacement (AttrInt) AttrTypeRise :: AttrType -- | shape (AttrShape) AttrTypeShape :: AttrType -- | font size scale factor (AttrFloat) AttrTypeScale :: AttrType -- | whether fallback is enabled (AttrInt) AttrTypeFallback :: AttrType -- | letter spacing (AttrInt) AttrTypeLetterSpacing :: AttrType -- | underline color (AttrColor) AttrTypeUnderlineColor :: AttrType -- | strikethrough color (AttrColor) AttrTypeStrikethroughColor :: AttrType -- | font size in pixels scaled by SCALE (AttrInt) AttrTypeAbsoluteSize :: AttrType -- | base text gravity (AttrInt) AttrTypeGravity :: AttrType -- | gravity hint (AttrInt) AttrTypeGravityHint :: AttrType -- | OpenType font features (AttrString). Since 1.38 AttrTypeFontFeatures :: AttrType -- | foreground alpha (AttrInt). Since 1.38 AttrTypeForegroundAlpha :: AttrType -- | background alpha (AttrInt). Since 1.38 AttrTypeBackgroundAlpha :: AttrType -- | Catch-all for unknown values AnotherAttrType :: Int -> AttrType -- | The BidiType type represents the bidirectional character type -- of a Unicode character as specified by the <ulink -- url="http://www.unicode.org/reports/tr9/">Unicode bidirectional -- algorithm</ulink>. -- -- Since: 1.22 -- | Deprecated: (Since version 1.44)Use fribidi for this -- information data BidiType -- | Left-to-Right BidiTypeL :: BidiType -- | Left-to-Right Embedding BidiTypeLre :: BidiType -- | Left-to-Right Override BidiTypeLro :: BidiType -- | Right-to-Left BidiTypeR :: BidiType -- | Right-to-Left Arabic BidiTypeAl :: BidiType -- | Right-to-Left Embedding BidiTypeRle :: BidiType -- | Right-to-Left Override BidiTypeRlo :: BidiType -- | Pop Directional Format BidiTypePdf :: BidiType -- | European Number BidiTypeEn :: BidiType -- | European Number Separator BidiTypeEs :: BidiType -- | European Number Terminator BidiTypeEt :: BidiType -- | Arabic Number BidiTypeAn :: BidiType -- | Common Number Separator BidiTypeCs :: BidiType -- | Nonspacing Mark BidiTypeNsm :: BidiType -- | Boundary Neutral BidiTypeBn :: BidiType -- | Paragraph Separator BidiTypeB :: BidiType -- | Segment Separator BidiTypeS :: BidiType -- | Whitespace BidiTypeWs :: BidiType -- | Other Neutrals BidiTypeOn :: BidiType -- | Catch-all for unknown values AnotherBidiType :: Int -> BidiType -- | Used to indicate how well a font can represent a particular Unicode -- character point for a particular script. data CoverageLevel -- | The character is not representable with the font. CoverageLevelNone :: CoverageLevel -- | The character is represented in a way that may be comprehensible but -- is not the correct graphical form. For instance, a Hangul character -- represented as a a sequence of Jamos, or a Latin transliteration of a -- Cyrillic word. CoverageLevelFallback :: CoverageLevel -- | The character is represented as basically the correct graphical form, -- but with a stylistic variant inappropriate for the current script. CoverageLevelApproximate :: CoverageLevel -- | The character is represented as the correct graphical form. CoverageLevelExact :: CoverageLevel -- | Catch-all for unknown values AnotherCoverageLevel :: Int -> CoverageLevel -- | The Direction type represents a direction in the Unicode -- bidirectional algorithm; not every value in this enumeration makes -- sense for every usage of Direction; for example, the return -- value of unicharDirection and findBaseDir cannot be -- DirectionWeakLtr or DirectionWeakRtl, since every -- character is either neutral or has a strong direction; on the other -- hand DirectionNeutral doesn't make sense to pass to -- itemizeWithBaseDir. -- -- The DirectionTtbLtr, DirectionTtbRtl values come from an -- earlier interpretation of this enumeration as the writing direction of -- a block of text and are no longer used; See Gravity for how -- vertical text is handled in Pango. -- -- If you are interested in text direction, you should really use fribidi -- directly. PangoDirection is only retained because it is used in some -- public apis. data Direction -- | A strong left-to-right direction DirectionLtr :: Direction -- | A strong right-to-left direction DirectionRtl :: Direction -- | Deprecated value; treated the same as DirectionRtl. DirectionTtbLtr :: Direction -- | Deprecated value; treated the same as DirectionLtr DirectionTtbRtl :: Direction -- | A weak left-to-right direction DirectionWeakLtr :: Direction -- | A weak right-to-left direction DirectionWeakRtl :: Direction -- | No direction specified DirectionNeutral :: Direction -- | Catch-all for unknown values AnotherDirection :: Int -> Direction -- | The EllipsizeMode type describes what sort of (if any) -- ellipsization should be applied to a line of text. In the -- ellipsization process characters are removed from the text in order to -- make it fit to a given width and replaced with an ellipsis. data EllipsizeMode -- | No ellipsization EllipsizeModeNone :: EllipsizeMode -- | Omit characters at the start of the text EllipsizeModeStart :: EllipsizeMode -- | Omit characters in the middle of the text EllipsizeModeMiddle :: EllipsizeMode -- | Omit characters at the end of the text EllipsizeModeEnd :: EllipsizeMode -- | Catch-all for unknown values AnotherEllipsizeMode :: Int -> EllipsizeMode -- | The Gravity type represents the orientation of glyphs in a -- segment of text. This is useful when rendering vertical text layouts. -- In those situations, the layout is rotated using a non-identity -- PangoMatrix, and then glyph orientation is controlled using -- Gravity. Not every value in this enumeration makes sense for -- every usage of Gravity; for example, GravityAuto only -- can be passed to contextSetBaseGravity and can only be returned -- by contextGetBaseGravity. -- -- See also: GravityHint -- -- Since: 1.16 data Gravity -- | Glyphs stand upright (default) GravitySouth :: Gravity -- | Glyphs are rotated 90 degrees clockwise GravityEast :: Gravity -- | Glyphs are upside-down GravityNorth :: Gravity -- | Glyphs are rotated 90 degrees counter-clockwise GravityWest :: Gravity -- | Gravity is resolved from the context matrix GravityAuto :: Gravity -- | Catch-all for unknown values AnotherGravity :: Int -> Gravity -- | The GravityHint defines how horizontal scripts should behave in -- a vertical context. That is, English excerpt in a vertical paragraph -- for example. -- -- See Gravity. -- -- Since: 1.16 data GravityHint -- | scripts will take their natural gravity based on the base gravity and -- the script. This is the default. GravityHintNatural :: GravityHint -- | always use the base gravity set, regardless of the script. GravityHintStrong :: GravityHint -- | for scripts not in their natural direction (eg. Latin in East -- gravity), choose per-script gravity such that every script respects -- the line progression. This means, Latin and Arabic will take opposite -- gravities and both flow top-to-bottom for example. GravityHintLine :: GravityHint -- | Catch-all for unknown values AnotherGravityHint :: Int -> GravityHint -- | RenderPart defines different items to render for such purposes -- as setting colors. -- -- Since: 1.8 data RenderPart -- | the text itself RenderPartForeground :: RenderPart -- | the area behind the text RenderPartBackground :: RenderPart -- | underlines RenderPartUnderline :: RenderPart -- | strikethrough lines RenderPartStrikethrough :: RenderPart -- | Catch-all for unknown values AnotherRenderPart :: Int -> RenderPart -- | The Script enumeration identifies different writing systems. -- The values correspond to the names as defined in the Unicode standard. -- Note that new types may be added in the future. Applications should be -- ready to handle unknown values. This enumeration is interchangeable -- with UnicodeScript. See <ulink -- url="http://www.unicode.org/reports/tr24/">Unicode Standard Annex -- 24: Script names</ulink>. data Script -- | a value never returned from scriptForUnichar ScriptInvalidCode :: Script -- | a character used by multiple different scripts ScriptCommon :: Script -- | a mark glyph that takes its script from the base glyph to which it is -- attached ScriptInherited :: Script -- | Arabic ScriptArabic :: Script -- | Armenian ScriptArmenian :: Script -- | Bengali ScriptBengali :: Script -- | Bopomofo ScriptBopomofo :: Script -- | Cherokee ScriptCherokee :: Script -- | Coptic ScriptCoptic :: Script -- | Cyrillic ScriptCyrillic :: Script -- | Deseret ScriptDeseret :: Script -- | Devanagari ScriptDevanagari :: Script -- | Ethiopic ScriptEthiopic :: Script -- | Georgian ScriptGeorgian :: Script -- | Gothic ScriptGothic :: Script -- | Greek ScriptGreek :: Script -- | Gujarati ScriptGujarati :: Script -- | Gurmukhi ScriptGurmukhi :: Script -- | Han ScriptHan :: Script -- | Hangul ScriptHangul :: Script -- | Hebrew ScriptHebrew :: Script -- | Hiragana ScriptHiragana :: Script -- | Kannada ScriptKannada :: Script -- | Katakana ScriptKatakana :: Script -- | Khmer ScriptKhmer :: Script -- | Lao ScriptLao :: Script -- | Latin ScriptLatin :: Script -- | Malayalam ScriptMalayalam :: Script -- | Mongolian ScriptMongolian :: Script -- | Myanmar ScriptMyanmar :: Script -- | Ogham ScriptOgham :: Script -- | Old Italic ScriptOldItalic :: Script -- | Oriya ScriptOriya :: Script -- | Runic ScriptRunic :: Script -- | Sinhala ScriptSinhala :: Script -- | Syriac ScriptSyriac :: Script -- | Tamil ScriptTamil :: Script -- | Telugu ScriptTelugu :: Script -- | Thaana ScriptThaana :: Script -- | Thai ScriptThai :: Script -- | Tibetan ScriptTibetan :: Script -- | Canadian Aboriginal ScriptCanadianAboriginal :: Script -- | Yi ScriptYi :: Script -- | Tagalog ScriptTagalog :: Script -- | Hanunoo ScriptHanunoo :: Script -- | Buhid ScriptBuhid :: Script -- | Tagbanwa ScriptTagbanwa :: Script -- | Braille ScriptBraille :: Script -- | Cypriot ScriptCypriot :: Script -- | Limbu ScriptLimbu :: Script -- | Osmanya ScriptOsmanya :: Script -- | Shavian ScriptShavian :: Script -- | Linear B ScriptLinearB :: Script -- | Tai Le ScriptTaiLe :: Script -- | Ugaritic ScriptUgaritic :: Script -- | New Tai Lue. Since 1.10 ScriptNewTaiLue :: Script -- | Buginese. Since 1.10 ScriptBuginese :: Script -- | Glagolitic. Since 1.10 ScriptGlagolitic :: Script -- | Tifinagh. Since 1.10 ScriptTifinagh :: Script -- | Syloti Nagri. Since 1.10 ScriptSylotiNagri :: Script -- | Old Persian. Since 1.10 ScriptOldPersian :: Script -- | Kharoshthi. Since 1.10 ScriptKharoshthi :: Script -- | an unassigned code point. Since 1.14 ScriptUnknown :: Script -- | Balinese. Since 1.14 ScriptBalinese :: Script -- | Cuneiform. Since 1.14 ScriptCuneiform :: Script -- | Phoenician. Since 1.14 ScriptPhoenician :: Script -- | Phags-pa. Since 1.14 ScriptPhagsPa :: Script -- | N'Ko. Since 1.14 ScriptNko :: Script -- | Kayah Li. Since 1.20.1 ScriptKayahLi :: Script -- | Lepcha. Since 1.20.1 ScriptLepcha :: Script -- | Rejang. Since 1.20.1 ScriptRejang :: Script -- | Sundanese. Since 1.20.1 ScriptSundanese :: Script -- | Saurashtra. Since 1.20.1 ScriptSaurashtra :: Script -- | Cham. Since 1.20.1 ScriptCham :: Script -- | Ol Chiki. Since 1.20.1 ScriptOlChiki :: Script -- | Vai. Since 1.20.1 ScriptVai :: Script -- | Carian. Since 1.20.1 ScriptCarian :: Script -- | Lycian. Since 1.20.1 ScriptLycian :: Script -- | Lydian. Since 1.20.1 ScriptLydian :: Script -- | Batak. Since 1.32 ScriptBatak :: Script -- | Brahmi. Since 1.32 ScriptBrahmi :: Script -- | Mandaic. Since 1.32 ScriptMandaic :: Script -- | Chakma. Since: 1.32 ScriptChakma :: Script -- | Meroitic Cursive. Since: 1.32 ScriptMeroiticCursive :: Script -- | Meroitic Hieroglyphs. Since: 1.32 ScriptMeroiticHieroglyphs :: Script -- | Miao. Since: 1.32 ScriptMiao :: Script -- | Sharada. Since: 1.32 ScriptSharada :: Script -- | Sora Sompeng. Since: 1.32 ScriptSoraSompeng :: Script -- | Takri. Since: 1.32 ScriptTakri :: Script -- | Bassa. Since: 1.40 ScriptBassaVah :: Script -- | Caucasian Albanian. Since: 1.40 ScriptCaucasianAlbanian :: Script -- | Duployan. Since: 1.40 ScriptDuployan :: Script -- | Elbasan. Since: 1.40 ScriptElbasan :: Script -- | Grantha. Since: 1.40 ScriptGrantha :: Script -- | Kjohki. Since: 1.40 ScriptKhojki :: Script -- | Khudawadi, Sindhi. Since: 1.40 ScriptKhudawadi :: Script -- | Linear A. Since: 1.40 ScriptLinearA :: Script -- | Mahajani. Since: 1.40 ScriptMahajani :: Script -- | Manichaean. Since: 1.40 ScriptManichaean :: Script -- | Mende Kikakui. Since: 1.40 ScriptMendeKikakui :: Script -- | Modi. Since: 1.40 ScriptModi :: Script -- | Mro. Since: 1.40 ScriptMro :: Script -- | Nabataean. Since: 1.40 ScriptNabataean :: Script -- | Old North Arabian. Since: 1.40 ScriptOldNorthArabian :: Script -- | Old Permic. Since: 1.40 ScriptOldPermic :: Script -- | Pahawh Hmong. Since: 1.40 ScriptPahawhHmong :: Script -- | Palmyrene. Since: 1.40 ScriptPalmyrene :: Script -- | Pau Cin Hau. Since: 1.40 ScriptPauCinHau :: Script -- | Psalter Pahlavi. Since: 1.40 ScriptPsalterPahlavi :: Script -- | Siddham. Since: 1.40 ScriptSiddham :: Script -- | Tirhuta. Since: 1.40 ScriptTirhuta :: Script -- | Warang Citi. Since: 1.40 ScriptWarangCiti :: Script -- | Ahom. Since: 1.40 ScriptAhom :: Script -- | Anatolian Hieroglyphs. Since: 1.40 ScriptAnatolianHieroglyphs :: Script -- | Hatran. Since: 1.40 ScriptHatran :: Script -- | Multani. Since: 1.40 ScriptMultani :: Script -- | Old Hungarian. Since: 1.40 ScriptOldHungarian :: Script -- | Signwriting. Since: 1.40 ScriptSignwriting :: Script -- | Catch-all for unknown values AnotherScript :: Int -> Script -- | An enumeration specifying the width of the font relative to other -- designs within a family. data Stretch -- | ultra condensed width StretchUltraCondensed :: Stretch -- | extra condensed width StretchExtraCondensed :: Stretch -- | condensed width StretchCondensed :: Stretch -- | semi condensed width StretchSemiCondensed :: Stretch -- | the normal width StretchNormal :: Stretch -- | semi expanded width StretchSemiExpanded :: Stretch -- | expanded width StretchExpanded :: Stretch -- | extra expanded width StretchExtraExpanded :: Stretch -- | ultra expanded width StretchUltraExpanded :: Stretch -- | Catch-all for unknown values AnotherStretch :: Int -> Stretch -- | An enumeration specifying the various slant styles possible for a -- font. data Style -- | the font is upright. StyleNormal :: Style -- | the font is slanted, but in a roman style. StyleOblique :: Style -- | the font is slanted in an italic style. StyleItalic :: Style -- | Catch-all for unknown values AnotherStyle :: Int -> Style -- | A TabAlign specifies where a tab stop appears relative to the -- text. data TabAlign -- | the tab stop appears to the left of the text. TabAlignLeft :: TabAlign -- | Catch-all for unknown values AnotherTabAlign :: Int -> TabAlign -- | The Underline enumeration is used to specify whether text -- should be underlined, and if so, the type of underlining. data Underline -- | no underline should be drawn UnderlineNone :: Underline -- | a single underline should be drawn UnderlineSingle :: Underline -- | a double underline should be drawn UnderlineDouble :: Underline -- | a single underline should be drawn at a position beneath the ink -- extents of the text being underlined. This should be used only for -- underlining single characters, such as for keyboard accelerators. -- UnderlineSingle should be used for extended portions of text. UnderlineLow :: Underline -- | a wavy underline should be drawn below. This underline is typically -- used to indicate an error such as a possilble mispelling; in some -- cases a contrasting color may automatically be used. This type of -- underlining is available since Pango 1.4. UnderlineError :: Underline -- | Catch-all for unknown values AnotherUnderline :: Int -> Underline -- | An enumeration specifying capitalization variant of the font. data Variant -- | A normal font. VariantNormal :: Variant -- | A font with the lower case characters replaced by smaller variants of -- the capital characters. VariantSmallCaps :: Variant -- | Catch-all for unknown values AnotherVariant :: Int -> Variant -- | An enumeration specifying the weight (boldness) of a font. This is a -- numerical value ranging from 100 to 1000, but there are some -- predefined values: data Weight -- | the thin weight (= 100; Since: 1.24) WeightThin :: Weight -- | the ultralight weight (= 200) WeightUltralight :: Weight -- | the light weight (= 300) WeightLight :: Weight -- | the semilight weight (= 350; Since: 1.36.7) WeightSemilight :: Weight -- | the book weight (= 380; Since: 1.24) WeightBook :: Weight -- | the default weight (= 400) WeightNormal :: Weight -- | the normal weight (= 500; Since: 1.24) WeightMedium :: Weight -- | the semibold weight (= 600) WeightSemibold :: Weight -- | the bold weight (= 700) WeightBold :: Weight -- | the ultrabold weight (= 800) WeightUltrabold :: Weight -- | the heavy weight (= 900) WeightHeavy :: Weight -- | the ultraheavy weight (= 1000; Since: 1.24) WeightUltraheavy :: Weight -- | Catch-all for unknown values AnotherWeight :: Int -> Weight -- | A WrapMode describes how to wrap the lines of a Layout -- to the desired width. data WrapMode -- | wrap lines at word boundaries. WrapModeWord :: WrapMode -- | wrap lines at character boundaries. WrapModeChar :: WrapMode -- | wrap lines at word boundaries, but fall back to character boundaries -- if there is not enough space for a full word. WrapModeWordChar :: WrapMode -- | Catch-all for unknown values AnotherWrapMode :: Int -> WrapMode instance GHC.Classes.Eq GI.Pango.Enums.Alignment instance GHC.Show.Show GI.Pango.Enums.Alignment instance GHC.Classes.Eq GI.Pango.Enums.AttrType instance GHC.Show.Show GI.Pango.Enums.AttrType instance GHC.Classes.Eq GI.Pango.Enums.BidiType instance GHC.Show.Show GI.Pango.Enums.BidiType instance GHC.Classes.Eq GI.Pango.Enums.CoverageLevel instance GHC.Show.Show GI.Pango.Enums.CoverageLevel instance GHC.Classes.Eq GI.Pango.Enums.Direction instance GHC.Show.Show GI.Pango.Enums.Direction instance GHC.Classes.Eq GI.Pango.Enums.EllipsizeMode instance GHC.Show.Show GI.Pango.Enums.EllipsizeMode instance GHC.Classes.Eq GI.Pango.Enums.Gravity instance GHC.Show.Show GI.Pango.Enums.Gravity instance GHC.Classes.Eq GI.Pango.Enums.GravityHint instance GHC.Show.Show GI.Pango.Enums.GravityHint instance GHC.Classes.Eq GI.Pango.Enums.RenderPart instance GHC.Show.Show GI.Pango.Enums.RenderPart instance GHC.Classes.Eq GI.Pango.Enums.Script instance GHC.Show.Show GI.Pango.Enums.Script instance GHC.Classes.Eq GI.Pango.Enums.Stretch instance GHC.Show.Show GI.Pango.Enums.Stretch instance GHC.Classes.Eq GI.Pango.Enums.Style instance GHC.Show.Show GI.Pango.Enums.Style instance GHC.Classes.Eq GI.Pango.Enums.TabAlign instance GHC.Show.Show GI.Pango.Enums.TabAlign instance GHC.Classes.Eq GI.Pango.Enums.Underline instance GHC.Show.Show GI.Pango.Enums.Underline instance GHC.Classes.Eq GI.Pango.Enums.Variant instance GHC.Show.Show GI.Pango.Enums.Variant instance GHC.Classes.Eq GI.Pango.Enums.Weight instance GHC.Show.Show GI.Pango.Enums.Weight instance GHC.Classes.Eq GI.Pango.Enums.WrapMode instance GHC.Show.Show GI.Pango.Enums.WrapMode instance GHC.Enum.Enum GI.Pango.Enums.Alignment instance GHC.Classes.Ord GI.Pango.Enums.Alignment instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.Alignment instance GHC.Enum.Enum GI.Pango.Enums.AttrType instance GHC.Classes.Ord GI.Pango.Enums.AttrType instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.AttrType instance GHC.Enum.Enum GI.Pango.Enums.BidiType instance GHC.Classes.Ord GI.Pango.Enums.BidiType instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.BidiType instance GHC.Enum.Enum GI.Pango.Enums.CoverageLevel instance GHC.Classes.Ord GI.Pango.Enums.CoverageLevel instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.CoverageLevel instance GHC.Enum.Enum GI.Pango.Enums.Direction instance GHC.Classes.Ord GI.Pango.Enums.Direction instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.Direction instance GHC.Enum.Enum GI.Pango.Enums.EllipsizeMode instance GHC.Classes.Ord GI.Pango.Enums.EllipsizeMode instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.EllipsizeMode instance GHC.Enum.Enum GI.Pango.Enums.Gravity instance GHC.Classes.Ord GI.Pango.Enums.Gravity instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.Gravity instance GHC.Enum.Enum GI.Pango.Enums.GravityHint instance GHC.Classes.Ord GI.Pango.Enums.GravityHint instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.GravityHint instance GHC.Enum.Enum GI.Pango.Enums.RenderPart instance GHC.Classes.Ord GI.Pango.Enums.RenderPart instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.RenderPart instance GHC.Enum.Enum GI.Pango.Enums.Script instance GHC.Classes.Ord GI.Pango.Enums.Script instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.Script instance GHC.Enum.Enum GI.Pango.Enums.Stretch instance GHC.Classes.Ord GI.Pango.Enums.Stretch instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.Stretch instance GHC.Enum.Enum GI.Pango.Enums.Style instance GHC.Classes.Ord GI.Pango.Enums.Style instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.Style instance GHC.Enum.Enum GI.Pango.Enums.TabAlign instance GHC.Classes.Ord GI.Pango.Enums.TabAlign instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.TabAlign instance GHC.Enum.Enum GI.Pango.Enums.Underline instance GHC.Classes.Ord GI.Pango.Enums.Underline instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.Underline instance GHC.Enum.Enum GI.Pango.Enums.Variant instance GHC.Classes.Ord GI.Pango.Enums.Variant instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.Variant instance GHC.Enum.Enum GI.Pango.Enums.Weight instance GHC.Classes.Ord GI.Pango.Enums.Weight instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.Weight instance GHC.Enum.Enum GI.Pango.Enums.WrapMode instance GHC.Classes.Ord GI.Pango.Enums.WrapMode instance Data.GI.Base.BasicTypes.BoxedEnum GI.Pango.Enums.WrapMode module GI.Pango.Flags -- | The bits in a FontMask correspond to fields in a -- FontDescription that have been set. data FontMask -- | the font family is specified. FontMaskFamily :: FontMask -- | the font style is specified. FontMaskStyle :: FontMask -- | the font variant is specified. FontMaskVariant :: FontMask -- | the font weight is specified. FontMaskWeight :: FontMask -- | the font stretch is specified. FontMaskStretch :: FontMask -- | the font size is specified. FontMaskSize :: FontMask -- | the font gravity is specified (Since: 1.16.) FontMaskGravity :: FontMask -- | OpenType font variations are specified (Since: 1.42) FontMaskVariations :: FontMask -- | Catch-all for unknown values AnotherFontMask :: Int -> FontMask instance GHC.Classes.Eq GI.Pango.Flags.FontMask instance GHC.Show.Show GI.Pango.Flags.FontMask instance GHC.Enum.Enum GI.Pango.Flags.FontMask instance GHC.Classes.Ord GI.Pango.Flags.FontMask instance Data.GI.Base.BasicTypes.BoxedFlags GI.Pango.Flags.FontMask instance Data.GI.Base.BasicTypes.IsGFlag GI.Pango.Flags.FontMask -- | Engine is the base class for all types of language and script -- specific engines. It has no functionality by itself. module GI.Pango.Objects.Engine -- | Memory-managed wrapper type. newtype Engine Engine :: ManagedPtr Engine -> Engine -- | Type class for types which can be safely cast to Engine, for -- instance with toEngine. class (GObject o, IsDescendantOf Engine o) => IsEngine o -- | Cast to Engine, for types for which this is known to be safe. -- For general casts, use castTo. toEngine :: (MonadIO m, IsEngine o) => o -> m Engine -- | A convenience alias for Nothing :: Maybe Engine. noEngine :: Maybe Engine instance (Data.GI.Base.BasicTypes.GObject o, Data.GI.Base.Overloading.IsDescendantOf GI.Pango.Objects.Engine.Engine o) => GI.Pango.Objects.Engine.IsEngine o instance Data.GI.Base.BasicTypes.GObject GI.Pango.Objects.Engine.Engine instance Data.GI.Base.Overloading.HasParentTypes GI.Pango.Objects.Engine.Engine -- | The EngineLang class is implemented by engines that customize -- the rendering-system independent part of the Pango pipeline for a -- particular script or language. For instance, a custom -- EngineLang could be provided for Thai to implement the -- dictionary-based word boundary lookups needed for that language. module GI.Pango.Objects.EngineLang -- | Memory-managed wrapper type. newtype EngineLang EngineLang :: ManagedPtr EngineLang -> EngineLang -- | Type class for types which can be safely cast to EngineLang, -- for instance with toEngineLang. class (GObject o, IsDescendantOf EngineLang o) => IsEngineLang o -- | Cast to EngineLang, for types for which this is known to be -- safe. For general casts, use castTo. toEngineLang :: (MonadIO m, IsEngineLang o) => o -> m EngineLang -- | A convenience alias for Nothing :: Maybe -- EngineLang. noEngineLang :: Maybe EngineLang instance (Data.GI.Base.BasicTypes.GObject o, Data.GI.Base.Overloading.IsDescendantOf GI.Pango.Objects.EngineLang.EngineLang o) => GI.Pango.Objects.EngineLang.IsEngineLang o instance Data.GI.Base.BasicTypes.GObject GI.Pango.Objects.EngineLang.EngineLang instance Data.GI.Base.Overloading.HasParentTypes GI.Pango.Objects.EngineLang.EngineLang -- | The EngineShape class is implemented by engines that customize -- the rendering-system dependent part of the Pango pipeline for a -- particular script or language. A EngineShape implementation is -- then specific to both a particular rendering system or group of -- rendering systems and to a particular script. For instance, there is -- one EngineShape implementation to handle shaping Arabic for -- Fontconfig-based backends. module GI.Pango.Objects.EngineShape -- | Memory-managed wrapper type. newtype EngineShape EngineShape :: ManagedPtr EngineShape -> EngineShape -- | Type class for types which can be safely cast to EngineShape, -- for instance with toEngineShape. class (GObject o, IsDescendantOf EngineShape o) => IsEngineShape o -- | Cast to EngineShape, for types for which this is known to be -- safe. For general casts, use castTo. toEngineShape :: (MonadIO m, IsEngineShape o) => o -> m EngineShape -- | A convenience alias for Nothing :: Maybe -- EngineShape. noEngineShape :: Maybe EngineShape instance (Data.GI.Base.BasicTypes.GObject o, Data.GI.Base.Overloading.IsDescendantOf GI.Pango.Objects.EngineShape.EngineShape o) => GI.Pango.Objects.EngineShape.IsEngineShape o instance Data.GI.Base.BasicTypes.GObject GI.Pango.Objects.EngineShape.EngineShape instance Data.GI.Base.Overloading.HasParentTypes GI.Pango.Objects.EngineShape.EngineShape -- | The FontFamily structure is used to represent a family of -- related font faces. The faces in a family share a common design, but -- differ in slant, weight, width and other aspects. module GI.Pango.Objects.FontFamily -- | Memory-managed wrapper type. newtype FontFamily FontFamily :: ManagedPtr FontFamily -> FontFamily -- | Type class for types which can be safely cast to FontFamily, -- for instance with toFontFamily. class (GObject o, IsDescendantOf FontFamily o) => IsFontFamily o -- | Cast to FontFamily, for types for which this is known to be -- safe. For general casts, use castTo. toFontFamily :: (MonadIO m, IsFontFamily o) => o -> m FontFamily -- | A convenience alias for Nothing :: Maybe -- FontFamily. noFontFamily :: Maybe FontFamily -- | Gets the name of the family. The name is unique among all fonts for -- the font backend and can be used in a FontDescription to -- specify that a face from this family is desired. fontFamilyGetName :: (HasCallStack, MonadIO m, IsFontFamily a) => a -> m Text -- | A monospace font is a font designed for text display where the the -- characters form a regular grid. For Western languages this would mean -- that the advance width of all characters are the same, but this -- categorization also includes Asian fonts which include double-width -- characters: characters that occupy two grid cells. -- unicharIswide returns a result that indicates whether a -- character is typically double-width in a monospace font. -- -- The best way to find out the grid-cell size is to call -- fontMetricsGetApproximateDigitWidth, since the results of -- fontMetricsGetApproximateCharWidth may be affected by -- double-width characters. -- -- Since: 1.4 fontFamilyIsMonospace :: (HasCallStack, MonadIO m, IsFontFamily a) => a -> m Bool -- | A variable font is a font which has axes that can be modified to -- produce different faces. -- -- Since: 1.44 fontFamilyIsVariable :: (HasCallStack, MonadIO m, IsFontFamily a) => a -> m Bool -- | Lists the different font faces that make up family. -- The faces in a family share a common design, but differ in slant, -- weight, width and other aspects. fontFamilyListFaces :: (HasCallStack, MonadIO m, IsFontFamily a) => a -> m [FontFace] instance (Data.GI.Base.BasicTypes.GObject o, Data.GI.Base.Overloading.IsDescendantOf GI.Pango.Objects.FontFamily.FontFamily o) => GI.Pango.Objects.FontFamily.IsFontFamily o instance Data.GI.Base.BasicTypes.GObject GI.Pango.Objects.FontFamily.FontFamily instance Data.GI.Base.Overloading.HasParentTypes GI.Pango.Objects.FontFamily.FontFamily -- | The AttrString structure is used to represent attributes with a -- string value. module GI.Pango.Structs.AttrString -- | Memory-managed wrapper type. newtype AttrString AttrString :: ManagedPtr AttrString -> AttrString -- | Construct a AttrString struct initialized to zero. newZeroAttrString :: MonadIO m => m AttrString -- | A convenience alias for Nothing :: Maybe -- AttrString. noAttrString :: Maybe AttrString -- | Get the value of the “attr” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrString #attr
--   
getAttrStringAttr :: MonadIO m => AttrString -> m Attribute -- | Set the value of the “value” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #value
--   
clearAttrStringValue :: MonadIO m => AttrString -> m () -- | Get the value of the “value” field. When overloading -- is enabled, this is equivalent to -- --
--   get attrString #value
--   
getAttrStringValue :: MonadIO m => AttrString -> m (Maybe Text) -- | Set the value of the “value” field. When overloading -- is enabled, this is equivalent to -- --
--   set attrString [ #value := value ]
--   
setAttrStringValue :: MonadIO m => AttrString -> CString -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.AttrString.AttrString instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.AttrString.AttrString tag -- | The AttrSize structure is used to represent attributes which -- set font size. module GI.Pango.Structs.AttrSize -- | Memory-managed wrapper type. newtype AttrSize AttrSize :: ManagedPtr AttrSize -> AttrSize -- | Construct a AttrSize struct initialized to zero. newZeroAttrSize :: MonadIO m => m AttrSize -- | A convenience alias for Nothing :: Maybe -- AttrSize. noAttrSize :: Maybe AttrSize -- | Create a new font-size attribute in fractional points. attrSizeNew :: (HasCallStack, MonadIO m) => Int32 -> m Attribute -- | Get the value of the “absolute” field. When -- overloading is enabled, this is equivalent to -- --
--   get attrSize #absolute
--   
getAttrSizeAbsolute :: MonadIO m => AttrSize -> m Word32 -- | Set the value of the “absolute” field. When -- overloading is enabled, this is equivalent to -- --
--   set attrSize [ #absolute := value ]
--   
setAttrSizeAbsolute :: MonadIO m => AttrSize -> Word32 -> m () -- | Get the value of the “attr” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrSize #attr
--   
getAttrSizeAttr :: MonadIO m => AttrSize -> m Attribute -- | Get the value of the “size” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrSize #size
--   
getAttrSizeSize :: MonadIO m => AttrSize -> m Int32 -- | Set the value of the “size” field. When overloading is -- enabled, this is equivalent to -- --
--   set attrSize [ #size := value ]
--   
setAttrSizeSize :: MonadIO m => AttrSize -> Int32 -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.AttrSize.AttrSize instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.AttrSize.AttrSize tag -- | The AttrInt structure is used to represent attributes with an -- integer or enumeration value. module GI.Pango.Structs.AttrInt -- | Memory-managed wrapper type. newtype AttrInt AttrInt :: ManagedPtr AttrInt -> AttrInt -- | Construct a AttrInt struct initialized to zero. newZeroAttrInt :: MonadIO m => m AttrInt -- | A convenience alias for Nothing :: Maybe AttrInt. noAttrInt :: Maybe AttrInt -- | Get the value of the “attr” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrInt #attr
--   
getAttrIntAttr :: MonadIO m => AttrInt -> m Attribute -- | Get the value of the “value” field. When overloading -- is enabled, this is equivalent to -- --
--   get attrInt #value
--   
getAttrIntValue :: MonadIO m => AttrInt -> m Int32 -- | Set the value of the “value” field. When overloading -- is enabled, this is equivalent to -- --
--   set attrInt [ #value := value ]
--   
setAttrIntValue :: MonadIO m => AttrInt -> Int32 -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.AttrInt.AttrInt instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.AttrInt.AttrInt tag -- | The AttrFontFeatures structure is used to represent OpenType -- font features as an attribute. -- -- Since: 1.38 module GI.Pango.Structs.AttrFontFeatures -- | Memory-managed wrapper type. newtype AttrFontFeatures AttrFontFeatures :: ManagedPtr AttrFontFeatures -> AttrFontFeatures -- | Construct a AttrFontFeatures struct initialized to zero. newZeroAttrFontFeatures :: MonadIO m => m AttrFontFeatures -- | A convenience alias for Nothing :: Maybe -- AttrFontFeatures. noAttrFontFeatures :: Maybe AttrFontFeatures -- | Create a new font features tag attribute. -- -- Since: 1.38 attrFontFeaturesNew :: (HasCallStack, MonadIO m) => Text -> m Attribute -- | Get the value of the “attr” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrFontFeatures #attr
--   
getAttrFontFeaturesAttr :: MonadIO m => AttrFontFeatures -> m Attribute -- | Set the value of the “features” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #features
--   
clearAttrFontFeaturesFeatures :: MonadIO m => AttrFontFeatures -> m () -- | Get the value of the “features” field. When -- overloading is enabled, this is equivalent to -- --
--   get attrFontFeatures #features
--   
getAttrFontFeaturesFeatures :: MonadIO m => AttrFontFeatures -> m (Maybe Text) -- | Set the value of the “features” field. When -- overloading is enabled, this is equivalent to -- --
--   set attrFontFeatures [ #features := value ]
--   
setAttrFontFeaturesFeatures :: MonadIO m => AttrFontFeatures -> CString -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.AttrFontFeatures.AttrFontFeatures instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.AttrFontFeatures.AttrFontFeatures tag -- | The AttrFloat structure is used to represent attributes with a -- float or double value. module GI.Pango.Structs.AttrFloat -- | Memory-managed wrapper type. newtype AttrFloat AttrFloat :: ManagedPtr AttrFloat -> AttrFloat -- | Construct a AttrFloat struct initialized to zero. newZeroAttrFloat :: MonadIO m => m AttrFloat -- | A convenience alias for Nothing :: Maybe -- AttrFloat. noAttrFloat :: Maybe AttrFloat -- | Get the value of the “attr” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrFloat #attr
--   
getAttrFloatAttr :: MonadIO m => AttrFloat -> m Attribute -- | Get the value of the “value” field. When overloading -- is enabled, this is equivalent to -- --
--   get attrFloat #value
--   
getAttrFloatValue :: MonadIO m => AttrFloat -> m Double -- | Set the value of the “value” field. When overloading -- is enabled, this is equivalent to -- --
--   set attrFloat [ #value := value ]
--   
setAttrFloatValue :: MonadIO m => AttrFloat -> Double -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.AttrFloat.AttrFloat instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.AttrFloat.AttrFloat tag -- | The Attribute structure represents the common portions of all -- attributes. Particular types of attributes include this structure as -- their initial portion. The common portion of the attribute holds the -- range to which the value in the type-specific part of the attribute -- applies and should be initialized using attributeInit. By -- default an attribute will have an all-inclusive range of -- [0,G_MAXUINT]. module GI.Pango.Structs.Attribute -- | Memory-managed wrapper type. newtype Attribute Attribute :: ManagedPtr Attribute -> Attribute -- | A convenience alias for Nothing :: Maybe -- Attribute. noAttribute :: Maybe Attribute -- | Destroy a Attribute and free all associated memory. attributeDestroy :: (HasCallStack, MonadIO m) => Attribute -> m () -- | Compare two attributes for equality. This compares only the actual -- value of the two attributes and not the ranges that the attributes -- apply to. attributeEqual :: (HasCallStack, MonadIO m) => Attribute -> Attribute -> m Bool -- | Initializes attr's klass to klass, -- it's start_index to ATTR_INDEX_FROM_TEXT_BEGINNING and -- end_index to PANGO_ATTR_INDEX_TO_TEXT_END such that -- the attribute applies to the entire text by default. -- -- Since: 1.20 attributeInit :: (HasCallStack, MonadIO m) => Attribute -> AttrClass -> m () -- | Get the value of the “end_index” field. When -- overloading is enabled, this is equivalent to -- --
--   get attribute #endIndex
--   
getAttributeEndIndex :: MonadIO m => Attribute -> m Word32 -- | Set the value of the “end_index” field. When -- overloading is enabled, this is equivalent to -- --
--   set attribute [ #endIndex := value ]
--   
setAttributeEndIndex :: MonadIO m => Attribute -> Word32 -> m () -- | Set the value of the “klass” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #klass
--   
clearAttributeKlass :: MonadIO m => Attribute -> m () -- | Get the value of the “klass” field. When overloading -- is enabled, this is equivalent to -- --
--   get attribute #klass
--   
getAttributeKlass :: MonadIO m => Attribute -> m (Maybe AttrClass) -- | Set the value of the “klass” field. When overloading -- is enabled, this is equivalent to -- --
--   set attribute [ #klass := value ]
--   
setAttributeKlass :: MonadIO m => Attribute -> Ptr AttrClass -> m () -- | Get the value of the “start_index” field. When -- overloading is enabled, this is equivalent to -- --
--   get attribute #startIndex
--   
getAttributeStartIndex :: MonadIO m => Attribute -> m Word32 -- | Set the value of the “start_index” field. When -- overloading is enabled, this is equivalent to -- --
--   set attribute [ #startIndex := value ]
--   
setAttributeStartIndex :: MonadIO m => Attribute -> Word32 -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.Attribute.Attribute -- | The AttrColor structure is used to represent attributes that -- are colors. module GI.Pango.Structs.AttrColor -- | Memory-managed wrapper type. newtype AttrColor AttrColor :: ManagedPtr AttrColor -> AttrColor -- | Construct a AttrColor struct initialized to zero. newZeroAttrColor :: MonadIO m => m AttrColor -- | A convenience alias for Nothing :: Maybe -- AttrColor. noAttrColor :: Maybe AttrColor -- | Get the value of the “attr” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrColor #attr
--   
getAttrColorAttr :: MonadIO m => AttrColor -> m Attribute -- | Get the value of the “color” field. When overloading -- is enabled, this is equivalent to -- --
--   get attrColor #color
--   
getAttrColorColor :: MonadIO m => AttrColor -> m Color instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.AttrColor.AttrColor instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.AttrColor.AttrColor tag -- | The Color structure is used to represent a color in an -- uncalibrated RGB color-space. module GI.Pango.Structs.Color -- | Memory-managed wrapper type. newtype Color Color :: ManagedPtr Color -> Color -- | Construct a Color struct initialized to zero. newZeroColor :: MonadIO m => m Color -- | A convenience alias for Nothing :: Maybe Color. noColor :: Maybe Color -- | Creates a copy of src, which should be freed with -- colorFree. Primarily used by language bindings, not that useful -- otherwise (since colors can just be copied by assignment in C). colorCopy :: (HasCallStack, MonadIO m) => Color -> m (Maybe Color) -- | Frees a color allocated by colorCopy. colorFree :: (HasCallStack, MonadIO m) => Color -> m () -- | Fill in the fields of a color from a string specification. The string -- can either one of a large set of standard names. (Taken from the CSS -- <ulink -- url="http://dev.w3.org/csswg/css-color/named-colors">specification</ulink>), -- or it can be a hexadecimal value in the form '&num;rgb' -- '&num;rrggbb' '&num;rrrgggbbb' or '&num;rrrrggggbbbb' -- where 'r', 'g' and 'b' are hex digits of the red, green, and blue -- components of the color, respectively. (White in the four forms is -- '&num;fff' '&num;ffffff' '&num;fffffffff' and -- '&num;ffffffffffff') colorParse :: (HasCallStack, MonadIO m) => Color -> Text -> m Bool -- | Returns a textual specification of color in the -- hexadecimal form <literal>&num;rrrrggggbbbb</literal>, -- where <literal>r</literal>, -- <literal>g</literal> and <literal>b</literal> -- are hex digits representing the red, green, and blue components -- respectively. -- -- Since: 1.16 colorToString :: (HasCallStack, MonadIO m) => Color -> m Text -- | Get the value of the “blue” field. When overloading is -- enabled, this is equivalent to -- --
--   get color #blue
--   
getColorBlue :: MonadIO m => Color -> m Word16 -- | Set the value of the “blue” field. When overloading is -- enabled, this is equivalent to -- --
--   set color [ #blue := value ]
--   
setColorBlue :: MonadIO m => Color -> Word16 -> m () -- | Get the value of the “green” field. When overloading -- is enabled, this is equivalent to -- --
--   get color #green
--   
getColorGreen :: MonadIO m => Color -> m Word16 -- | Set the value of the “green” field. When overloading -- is enabled, this is equivalent to -- --
--   set color [ #green := value ]
--   
setColorGreen :: MonadIO m => Color -> Word16 -> m () -- | Get the value of the “red” field. When overloading is -- enabled, this is equivalent to -- --
--   get color #red
--   
getColorRed :: MonadIO m => Color -> m Word16 -- | Set the value of the “red” field. When overloading is -- enabled, this is equivalent to -- --
--   set color [ #red := value ]
--   
setColorRed :: MonadIO m => Color -> Word16 -> m () instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.Color.Color instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.Color.Color tag -- | The Coverage structure represents a map from Unicode characters -- to CoverageLevel. It is an opaque structure with no public -- fields. module GI.Pango.Structs.Coverage -- | Memory-managed wrapper type. newtype Coverage Coverage :: ManagedPtr Coverage -> Coverage -- | A convenience alias for Nothing :: Maybe -- Coverage. noCoverage :: Maybe Coverage -- | Determine whether a particular index is covered by -- coverage coverageGet :: (HasCallStack, MonadIO m) => Coverage -> Int32 -> m CoverageLevel -- | Set the coverage for each index in coverage to be the -- max (better) value of the current coverage for the index and the -- coverage for the corresponding index in other. coverageMax :: (HasCallStack, MonadIO m) => Coverage -> Coverage -> m () -- | Modify a particular index within coverage coverageSet :: (HasCallStack, MonadIO m) => Coverage -> Int32 -> CoverageLevel -> m () -- | Convert a Coverage structure into a flat binary format coverageToBytes :: (HasCallStack, MonadIO m) => Coverage -> m ByteString -- | Decrease the reference count on the Coverage by one. If the -- result is zero, free the coverage and all associated memory. coverageUnref :: (HasCallStack, MonadIO m) => Coverage -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.Coverage.Coverage module GI.Pango.Callbacks -- | No description available in the introspection data. type AttrClassDestroyFieldCallback = Attribute -> IO () -- | Type for the callback on the (unwrapped) C side. type C_AttrClassDestroyFieldCallback = Ptr Attribute -> IO () -- | Given a pointer to a foreign C function, wrap it into a function -- callable from Haskell. dynamic_AttrClassDestroyFieldCallback :: (HasCallStack, MonadIO m) => FunPtr C_AttrClassDestroyFieldCallback -> Attribute -> m () -- | Wrap the callback into a GClosure. genClosure_AttrClassDestroyFieldCallback :: MonadIO m => AttrClassDestroyFieldCallback -> m (GClosure C_AttrClassDestroyFieldCallback) -- | Generate a function pointer callable from C code, from a -- C_AttrClassDestroyFieldCallback. mk_AttrClassDestroyFieldCallback :: C_AttrClassDestroyFieldCallback -> IO (FunPtr C_AttrClassDestroyFieldCallback) -- | A convenience synonym for Nothing :: Maybe -- AttrClassDestroyFieldCallback. noAttrClassDestroyFieldCallback :: Maybe AttrClassDestroyFieldCallback -- | Wrap a AttrClassDestroyFieldCallback into a -- C_AttrClassDestroyFieldCallback. wrap_AttrClassDestroyFieldCallback :: Maybe (Ptr (FunPtr C_AttrClassDestroyFieldCallback)) -> AttrClassDestroyFieldCallback -> C_AttrClassDestroyFieldCallback -- | No description available in the introspection data. type AttrClassEqualFieldCallback = Attribute -> Attribute -> IO Bool -- | Type for the callback on the (unwrapped) C side. type C_AttrClassEqualFieldCallback = Ptr Attribute -> Ptr Attribute -> IO CInt -- | Given a pointer to a foreign C function, wrap it into a function -- callable from Haskell. dynamic_AttrClassEqualFieldCallback :: (HasCallStack, MonadIO m) => FunPtr C_AttrClassEqualFieldCallback -> Attribute -> Attribute -> m Bool -- | Wrap the callback into a GClosure. genClosure_AttrClassEqualFieldCallback :: MonadIO m => AttrClassEqualFieldCallback -> m (GClosure C_AttrClassEqualFieldCallback) -- | Generate a function pointer callable from C code, from a -- C_AttrClassEqualFieldCallback. mk_AttrClassEqualFieldCallback :: C_AttrClassEqualFieldCallback -> IO (FunPtr C_AttrClassEqualFieldCallback) -- | A convenience synonym for Nothing :: Maybe -- AttrClassEqualFieldCallback. noAttrClassEqualFieldCallback :: Maybe AttrClassEqualFieldCallback -- | Wrap a AttrClassEqualFieldCallback into a -- C_AttrClassEqualFieldCallback. wrap_AttrClassEqualFieldCallback :: Maybe (Ptr (FunPtr C_AttrClassEqualFieldCallback)) -> AttrClassEqualFieldCallback -> C_AttrClassEqualFieldCallback -- | Type of a function that can duplicate user data for an attribute. type AttrDataCopyFunc = IO (Ptr ()) " __Returns:__ new copy of /@userData@/. " -- | Type of a function that can duplicate user data for an attribute. type AttrDataCopyFunc_WithClosures = Ptr () " /@userData@/: user data to copy " -> IO (Ptr ()) " __Returns:__ new copy of /@userData@/. " -- | Type for the callback on the (unwrapped) C side. type C_AttrDataCopyFunc = Ptr () -> IO (Ptr ()) -- | A simple wrapper that ignores the closure arguments. drop_closures_AttrDataCopyFunc :: AttrDataCopyFunc -> AttrDataCopyFunc_WithClosures -- | Given a pointer to a foreign C function, wrap it into a function -- callable from Haskell. dynamic_AttrDataCopyFunc :: (HasCallStack, MonadIO m) => FunPtr C_AttrDataCopyFunc -> Ptr () -> m (Ptr ()) -- | Wrap the callback into a GClosure. genClosure_AttrDataCopyFunc :: MonadIO m => AttrDataCopyFunc -> m (GClosure C_AttrDataCopyFunc) -- | Generate a function pointer callable from C code, from a -- C_AttrDataCopyFunc. mk_AttrDataCopyFunc :: C_AttrDataCopyFunc -> IO (FunPtr C_AttrDataCopyFunc) -- | A convenience synonym for Nothing :: Maybe -- AttrDataCopyFunc. noAttrDataCopyFunc :: Maybe AttrDataCopyFunc -- | A convenience synonym for Nothing :: Maybe -- AttrDataCopyFunc_WithClosures. noAttrDataCopyFunc_WithClosures :: Maybe AttrDataCopyFunc_WithClosures -- | Wrap a AttrDataCopyFunc into a C_AttrDataCopyFunc. wrap_AttrDataCopyFunc :: Maybe (Ptr (FunPtr C_AttrDataCopyFunc)) -> AttrDataCopyFunc_WithClosures -> C_AttrDataCopyFunc -- | Type of a function filtering a list of attributes. type AttrFilterFunc = Attribute " /@attribute@/: a Pango attribute " -> IO Bool " __Returns:__ 'True' if the attribute should be selected for filtering, 'False' otherwise. " -- | Type of a function filtering a list of attributes. type AttrFilterFunc_WithClosures = Attribute " /@attribute@/: a Pango attribute " -> Ptr () " /@userData@/: user data passed to the function " -> IO Bool " __Returns:__ 'True' if the attribute should be selected for filtering, 'False' otherwise. " -- | Type for the callback on the (unwrapped) C side. type C_AttrFilterFunc = Ptr Attribute -> Ptr () -> IO CInt -- | A simple wrapper that ignores the closure arguments. drop_closures_AttrFilterFunc :: AttrFilterFunc -> AttrFilterFunc_WithClosures -- | Given a pointer to a foreign C function, wrap it into a function -- callable from Haskell. dynamic_AttrFilterFunc :: (HasCallStack, MonadIO m) => FunPtr C_AttrFilterFunc -> Attribute -> Ptr () -> m Bool -- | Wrap the callback into a GClosure. genClosure_AttrFilterFunc :: MonadIO m => AttrFilterFunc -> m (GClosure C_AttrFilterFunc) -- | Generate a function pointer callable from C code, from a -- C_AttrFilterFunc. mk_AttrFilterFunc :: C_AttrFilterFunc -> IO (FunPtr C_AttrFilterFunc) -- | A convenience synonym for Nothing :: Maybe -- AttrFilterFunc. noAttrFilterFunc :: Maybe AttrFilterFunc -- | A convenience synonym for Nothing :: Maybe -- AttrFilterFunc_WithClosures. noAttrFilterFunc_WithClosures :: Maybe AttrFilterFunc_WithClosures -- | Wrap a AttrFilterFunc into a C_AttrFilterFunc. wrap_AttrFilterFunc :: Maybe (Ptr (FunPtr C_AttrFilterFunc)) -> AttrFilterFunc_WithClosures -> C_AttrFilterFunc -- | Type for the callback on the (unwrapped) C side. type C_FontsetForeachFunc = Ptr Fontset -> Ptr Font -> Ptr () -> IO CInt -- | A callback function used by fontsetForeach when enumerating the -- fonts in a fontset. -- -- Since: 1.4 type FontsetForeachFunc = Fontset " /@fontset@/: a 'GI.Pango.Objects.Fontset.Fontset' " -> Font " /@font@/: a font from /@fontset@/ " -> IO Bool " __Returns:__ if 'True', stop iteration and return immediately. " -- | A callback function used by fontsetForeach when enumerating the -- fonts in a fontset. -- -- Since: 1.4 type FontsetForeachFunc_WithClosures = Fontset " /@fontset@/: a 'GI.Pango.Objects.Fontset.Fontset' " -> Font " /@font@/: a font from /@fontset@/ " -> Ptr () " /@userData@/: callback data " -> IO Bool " __Returns:__ if 'True', stop iteration and return immediately. " -- | A simple wrapper that ignores the closure arguments. drop_closures_FontsetForeachFunc :: FontsetForeachFunc -> FontsetForeachFunc_WithClosures -- | Given a pointer to a foreign C function, wrap it into a function -- callable from Haskell. dynamic_FontsetForeachFunc :: (HasCallStack, MonadIO m, IsFontset a, IsFont b) => FunPtr C_FontsetForeachFunc -> a -> b -> Ptr () -> m Bool -- | Wrap the callback into a GClosure. genClosure_FontsetForeachFunc :: MonadIO m => FontsetForeachFunc -> m (GClosure C_FontsetForeachFunc) -- | Generate a function pointer callable from C code, from a -- C_FontsetForeachFunc. mk_FontsetForeachFunc :: C_FontsetForeachFunc -> IO (FunPtr C_FontsetForeachFunc) -- | A convenience synonym for Nothing :: Maybe -- FontsetForeachFunc. noFontsetForeachFunc :: Maybe FontsetForeachFunc -- | A convenience synonym for Nothing :: Maybe -- FontsetForeachFunc_WithClosures. noFontsetForeachFunc_WithClosures :: Maybe FontsetForeachFunc_WithClosures -- | Wrap a FontsetForeachFunc into a C_FontsetForeachFunc. wrap_FontsetForeachFunc :: Maybe (Ptr (FunPtr C_FontsetForeachFunc)) -> FontsetForeachFunc_WithClosures -> C_FontsetForeachFunc -- | Type for the callback on the (unwrapped) C side. type C_IncludedModuleExitFieldCallback = IO () -- | No description available in the introspection data. type IncludedModuleExitFieldCallback = IO () -- | Given a pointer to a foreign C function, wrap it into a function -- callable from Haskell. dynamic_IncludedModuleExitFieldCallback :: (HasCallStack, MonadIO m) => FunPtr C_IncludedModuleExitFieldCallback -> m () -- | Wrap the callback into a GClosure. genClosure_IncludedModuleExitFieldCallback :: MonadIO m => IncludedModuleExitFieldCallback -> m (GClosure C_IncludedModuleExitFieldCallback) -- | Generate a function pointer callable from C code, from a -- C_IncludedModuleExitFieldCallback. mk_IncludedModuleExitFieldCallback :: C_IncludedModuleExitFieldCallback -> IO (FunPtr C_IncludedModuleExitFieldCallback) -- | A convenience synonym for Nothing :: Maybe -- IncludedModuleExitFieldCallback. noIncludedModuleExitFieldCallback :: Maybe IncludedModuleExitFieldCallback -- | Wrap a IncludedModuleExitFieldCallback into a -- C_IncludedModuleExitFieldCallback. wrap_IncludedModuleExitFieldCallback :: Maybe (Ptr (FunPtr C_IncludedModuleExitFieldCallback)) -> IncludedModuleExitFieldCallback -> C_IncludedModuleExitFieldCallback -- | Type for the callback on the (unwrapped) C side. type C_IncludedModuleInitFieldCallback = Ptr TypeModule -> IO () -- | No description available in the introspection data. type IncludedModuleInitFieldCallback = TypeModule -> IO () -- | Given a pointer to a foreign C function, wrap it into a function -- callable from Haskell. dynamic_IncludedModuleInitFieldCallback :: (HasCallStack, MonadIO m, IsTypeModule a) => FunPtr C_IncludedModuleInitFieldCallback -> a -> m () -- | Wrap the callback into a GClosure. genClosure_IncludedModuleInitFieldCallback :: MonadIO m => IncludedModuleInitFieldCallback -> m (GClosure C_IncludedModuleInitFieldCallback) -- | Generate a function pointer callable from C code, from a -- C_IncludedModuleInitFieldCallback. mk_IncludedModuleInitFieldCallback :: C_IncludedModuleInitFieldCallback -> IO (FunPtr C_IncludedModuleInitFieldCallback) -- | A convenience synonym for Nothing :: Maybe -- IncludedModuleInitFieldCallback. noIncludedModuleInitFieldCallback :: Maybe IncludedModuleInitFieldCallback -- | Wrap a IncludedModuleInitFieldCallback into a -- C_IncludedModuleInitFieldCallback. wrap_IncludedModuleInitFieldCallback :: Maybe (Ptr (FunPtr C_IncludedModuleInitFieldCallback)) -> IncludedModuleInitFieldCallback -> C_IncludedModuleInitFieldCallback -- | Type for the callback on the (unwrapped) C side. type C_IncludedModuleListFieldCallback = Ptr EngineInfo -> Int32 -> IO () -- | No description available in the introspection data. type IncludedModuleListFieldCallback = EngineInfo -> Int32 -> IO () -- | Given a pointer to a foreign C function, wrap it into a function -- callable from Haskell. dynamic_IncludedModuleListFieldCallback :: (HasCallStack, MonadIO m) => FunPtr C_IncludedModuleListFieldCallback -> EngineInfo -> Int32 -> m () -- | Wrap the callback into a GClosure. genClosure_IncludedModuleListFieldCallback :: MonadIO m => IncludedModuleListFieldCallback -> m (GClosure C_IncludedModuleListFieldCallback) -- | Generate a function pointer callable from C code, from a -- C_IncludedModuleListFieldCallback. mk_IncludedModuleListFieldCallback :: C_IncludedModuleListFieldCallback -> IO (FunPtr C_IncludedModuleListFieldCallback) -- | A convenience synonym for Nothing :: Maybe -- IncludedModuleListFieldCallback. noIncludedModuleListFieldCallback :: Maybe IncludedModuleListFieldCallback -- | Wrap a IncludedModuleListFieldCallback into a -- C_IncludedModuleListFieldCallback. wrap_IncludedModuleListFieldCallback :: Maybe (Ptr (FunPtr C_IncludedModuleListFieldCallback)) -> IncludedModuleListFieldCallback -> C_IncludedModuleListFieldCallback -- | The AttrList structure represents a list of attributes that -- apply to a section of text. The attributes are, in general, allowed to -- overlap in an arbitrary fashion, however, if the attributes are -- manipulated only through attrListChange, the overlap between -- properties will meet stricter criteria. -- -- Since the AttrList structure is stored as a linear list, it is -- not suitable for storing attributes for large amounts of text. In -- general, you should not use a single AttrList for more than one -- paragraph of text. module GI.Pango.Structs.AttrList -- | Memory-managed wrapper type. newtype AttrList AttrList :: ManagedPtr AttrList -> AttrList -- | A convenience alias for Nothing :: Maybe -- AttrList. noAttrList :: Maybe AttrList -- | Insert the given attribute into the AttrList. It will replace -- any attributes of the same type on that segment and be merged with any -- adjoining attributes that are identical. -- -- This function is slower than attrListInsert for creating a -- attribute list in order (potentially much slower for large lists). -- However, attrListInsert is not suitable for continually -- changing a set of attributes since it never removes or combines -- existing attributes. attrListChange :: (HasCallStack, MonadIO m) => AttrList -> Attribute -> m () -- | Copy list and return an identical new list. attrListCopy :: (HasCallStack, MonadIO m) => AttrList -> m (Maybe AttrList) -- | Given a AttrList and callback function, removes any elements of -- list for which func returns -- True and inserts them into a new list. -- -- Since: 1.2 attrListFilter :: (HasCallStack, MonadIO m) => AttrList -> AttrFilterFunc -> m (Maybe AttrList) -- | Insert the given attribute into the AttrList. It will be -- inserted after all other attributes with a matching -- startIndex. attrListInsert :: (HasCallStack, MonadIO m) => AttrList -> Attribute -> m () -- | Insert the given attribute into the AttrList. It will be -- inserted before all other attributes with a matching -- startIndex. attrListInsertBefore :: (HasCallStack, MonadIO m) => AttrList -> Attribute -> m () -- | Create a new empty attribute list with a reference count of one. attrListNew :: (HasCallStack, MonadIO m) => m AttrList -- | Increase the reference count of the given attribute list by one. -- -- Since: 1.10 attrListRef :: (HasCallStack, MonadIO m) => AttrList -> m AttrList -- | This function opens up a hole in list, fills it in -- with attributes from the left, and then merges other -- on top of the hole. -- -- This operation is equivalent to stretching every attribute that -- applies at position pos in list by an -- amount len, and then calling attrListChange -- with a copy of each attribute in other in sequence -- (offset in position by pos). -- -- This operation proves useful for, for instance, inserting a pre-edit -- string in the middle of an edit buffer. attrListSplice :: (HasCallStack, MonadIO m) => AttrList -> AttrList -> Int32 -> Int32 -> m () -- | Decrease the reference count of the given attribute list by one. If -- the result is zero, free the attribute list and the attributes it -- contains. attrListUnref :: (HasCallStack, MonadIO m) => AttrList -> m () instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.AttrList.AttrList -- | The AttrClass structure stores the type and operations for a -- particular type of attribute. The functions in this structure should -- not be called directly. Instead, one should use the wrapper functions -- provided for Attribute. module GI.Pango.Structs.AttrClass -- | Memory-managed wrapper type. newtype AttrClass AttrClass :: ManagedPtr AttrClass -> AttrClass -- | Construct a AttrClass struct initialized to zero. newZeroAttrClass :: MonadIO m => m AttrClass -- | A convenience alias for Nothing :: Maybe -- AttrClass. noAttrClass :: Maybe AttrClass -- | Set the value of the “destroy” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #destroy
--   
clearAttrClassDestroy :: MonadIO m => AttrClass -> m () -- | Get the value of the “destroy” field. When overloading -- is enabled, this is equivalent to -- --
--   get attrClass #destroy
--   
getAttrClassDestroy :: MonadIO m => AttrClass -> m (Maybe AttrClassDestroyFieldCallback) -- | Set the value of the “destroy” field. When overloading -- is enabled, this is equivalent to -- --
--   set attrClass [ #destroy := value ]
--   
setAttrClassDestroy :: MonadIO m => AttrClass -> FunPtr C_AttrClassDestroyFieldCallback -> m () -- | Set the value of the “equal” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #equal
--   
clearAttrClassEqual :: MonadIO m => AttrClass -> m () -- | Get the value of the “equal” field. When overloading -- is enabled, this is equivalent to -- --
--   get attrClass #equal
--   
getAttrClassEqual :: MonadIO m => AttrClass -> m (Maybe AttrClassEqualFieldCallback) -- | Set the value of the “equal” field. When overloading -- is enabled, this is equivalent to -- --
--   set attrClass [ #equal := value ]
--   
setAttrClassEqual :: MonadIO m => AttrClass -> FunPtr C_AttrClassEqualFieldCallback -> m () -- | Get the value of the “type” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrClass #type
--   
getAttrClassType :: MonadIO m => AttrClass -> m AttrType -- | Set the value of the “type” field. When overloading is -- enabled, this is equivalent to -- --
--   set attrClass [ #type := value ]
--   
setAttrClassType :: MonadIO m => AttrClass -> AttrType -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.AttrClass.AttrClass instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.AttrClass.AttrClass tag -- | The EngineInfo structure contains information about a -- particular engine. It contains the following fields: module GI.Pango.Structs.EngineInfo -- | Memory-managed wrapper type. newtype EngineInfo EngineInfo :: ManagedPtr EngineInfo -> EngineInfo -- | Construct a EngineInfo struct initialized to zero. newZeroEngineInfo :: MonadIO m => m EngineInfo -- | A convenience alias for Nothing :: Maybe -- EngineInfo. noEngineInfo :: Maybe EngineInfo -- | Set the value of the “engine_type” field to Nothing. -- When overloading is enabled, this is equivalent to -- --
--   clear #engineType
--   
clearEngineInfoEngineType :: MonadIO m => EngineInfo -> m () -- | Get the value of the “engine_type” field. When -- overloading is enabled, this is equivalent to -- --
--   get engineInfo #engineType
--   
getEngineInfoEngineType :: MonadIO m => EngineInfo -> m (Maybe Text) -- | Set the value of the “engine_type” field. When -- overloading is enabled, this is equivalent to -- --
--   set engineInfo [ #engineType := value ]
--   
setEngineInfoEngineType :: MonadIO m => EngineInfo -> CString -> m () -- | Set the value of the “id” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #id
--   
clearEngineInfoId :: MonadIO m => EngineInfo -> m () -- | Get the value of the “id” field. When overloading is -- enabled, this is equivalent to -- --
--   get engineInfo #id
--   
getEngineInfoId :: MonadIO m => EngineInfo -> m (Maybe Text) -- | Set the value of the “id” field. When overloading is -- enabled, this is equivalent to -- --
--   set engineInfo [ #id := value ]
--   
setEngineInfoId :: MonadIO m => EngineInfo -> CString -> m () -- | Get the value of the “n_scripts” field. When -- overloading is enabled, this is equivalent to -- --
--   get engineInfo #nScripts
--   
getEngineInfoNScripts :: MonadIO m => EngineInfo -> m Int32 -- | Set the value of the “n_scripts” field. When -- overloading is enabled, this is equivalent to -- --
--   set engineInfo [ #nScripts := value ]
--   
setEngineInfoNScripts :: MonadIO m => EngineInfo -> Int32 -> m () -- | Set the value of the “render_type” field to Nothing. -- When overloading is enabled, this is equivalent to -- --
--   clear #renderType
--   
clearEngineInfoRenderType :: MonadIO m => EngineInfo -> m () -- | Get the value of the “render_type” field. When -- overloading is enabled, this is equivalent to -- --
--   get engineInfo #renderType
--   
getEngineInfoRenderType :: MonadIO m => EngineInfo -> m (Maybe Text) -- | Set the value of the “render_type” field. When -- overloading is enabled, this is equivalent to -- --
--   set engineInfo [ #renderType := value ]
--   
setEngineInfoRenderType :: MonadIO m => EngineInfo -> CString -> m () -- | Set the value of the “scripts” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #scripts
--   
clearEngineInfoScripts :: MonadIO m => EngineInfo -> m () -- | Get the value of the “scripts” field. When overloading -- is enabled, this is equivalent to -- --
--   get engineInfo #scripts
--   
getEngineInfoScripts :: MonadIO m => EngineInfo -> m (Maybe EngineScriptInfo) -- | Set the value of the “scripts” field. When overloading -- is enabled, this is equivalent to -- --
--   set engineInfo [ #scripts := value ]
--   
setEngineInfoScripts :: MonadIO m => EngineInfo -> Ptr EngineScriptInfo -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.EngineInfo.EngineInfo instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.EngineInfo.EngineInfo tag -- | The EngineScriptInfo structure contains information about how -- the shaper covers a particular script. module GI.Pango.Structs.EngineScriptInfo -- | Memory-managed wrapper type. newtype EngineScriptInfo EngineScriptInfo :: ManagedPtr EngineScriptInfo -> EngineScriptInfo -- | Construct a EngineScriptInfo struct initialized to zero. newZeroEngineScriptInfo :: MonadIO m => m EngineScriptInfo -- | A convenience alias for Nothing :: Maybe -- EngineScriptInfo. noEngineScriptInfo :: Maybe EngineScriptInfo -- | Set the value of the “langs” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #langs
--   
clearEngineScriptInfoLangs :: MonadIO m => EngineScriptInfo -> m () -- | Get the value of the “langs” field. When overloading -- is enabled, this is equivalent to -- --
--   get engineScriptInfo #langs
--   
getEngineScriptInfoLangs :: MonadIO m => EngineScriptInfo -> m (Maybe Text) -- | Set the value of the “langs” field. When overloading -- is enabled, this is equivalent to -- --
--   set engineScriptInfo [ #langs := value ]
--   
setEngineScriptInfoLangs :: MonadIO m => EngineScriptInfo -> CString -> m () -- | Get the value of the “script” field. When overloading -- is enabled, this is equivalent to -- --
--   get engineScriptInfo #script
--   
getEngineScriptInfoScript :: MonadIO m => EngineScriptInfo -> m Script -- | Set the value of the “script” field. When overloading -- is enabled, this is equivalent to -- --
--   set engineScriptInfo [ #script := value ]
--   
setEngineScriptInfoScript :: MonadIO m => EngineScriptInfo -> Script -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.EngineScriptInfo.EngineScriptInfo instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.EngineScriptInfo.EngineScriptInfo tag -- | The AttrFontDesc structure is used to store an attribute that -- sets all aspects of the font description at once. module GI.Pango.Structs.AttrFontDesc -- | Memory-managed wrapper type. newtype AttrFontDesc AttrFontDesc :: ManagedPtr AttrFontDesc -> AttrFontDesc -- | Construct a AttrFontDesc struct initialized to zero. newZeroAttrFontDesc :: MonadIO m => m AttrFontDesc -- | A convenience alias for Nothing :: Maybe -- AttrFontDesc. noAttrFontDesc :: Maybe AttrFontDesc -- | Create a new font description attribute. This attribute allows setting -- family, style, weight, variant, stretch, and size simultaneously. attrFontDescNew :: (HasCallStack, MonadIO m) => FontDescription -> m Attribute -- | Get the value of the “attr” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrFontDesc #attr
--   
getAttrFontDescAttr :: MonadIO m => AttrFontDesc -> m Attribute -- | Set the value of the “desc” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #desc
--   
clearAttrFontDescDesc :: MonadIO m => AttrFontDesc -> m () -- | Get the value of the “desc” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrFontDesc #desc
--   
getAttrFontDescDesc :: MonadIO m => AttrFontDesc -> m (Maybe FontDescription) -- | Set the value of the “desc” field. When overloading is -- enabled, this is equivalent to -- --
--   set attrFontDesc [ #desc := value ]
--   
setAttrFontDescDesc :: MonadIO m => AttrFontDesc -> Ptr FontDescription -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.AttrFontDesc.AttrFontDesc instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.AttrFontDesc.AttrFontDesc tag -- | The FontFace structure is used to represent a group of fonts -- with the same family, slant, weight, width, but varying sizes. module GI.Pango.Objects.FontFace -- | Memory-managed wrapper type. newtype FontFace FontFace :: ManagedPtr FontFace -> FontFace -- | Type class for types which can be safely cast to FontFace, for -- instance with toFontFace. class (GObject o, IsDescendantOf FontFace o) => IsFontFace o -- | Cast to FontFace, for types for which this is known to be safe. -- For general casts, use castTo. toFontFace :: (MonadIO m, IsFontFace o) => o -> m FontFace -- | A convenience alias for Nothing :: Maybe -- FontFace. noFontFace :: Maybe FontFace -- | Returns the family, style, variant, weight and stretch of a -- FontFace. The size field of the resulting font description will -- be unset. fontFaceDescribe :: (HasCallStack, MonadIO m, IsFontFace a) => a -> m FontDescription -- | Gets a name representing the style of this face among the different -- faces in the FontFamily for the face. This name is unique among -- all faces in the family and is suitable for displaying to users. fontFaceGetFaceName :: (HasCallStack, MonadIO m, IsFontFace a) => a -> m Text -- | Returns whether a FontFace is synthesized by the underlying -- font rendering engine from another face, perhaps by shearing, -- emboldening, or lightening it. -- -- Since: 1.18 fontFaceIsSynthesized :: (HasCallStack, MonadIO m, IsFontFace a) => a -> m Bool -- | List the available sizes for a font. This is only applicable to bitmap -- fonts. For scalable fonts, stores Nothing at the location -- pointed to by sizes and 0 at the location pointed to -- by nSizes. The sizes returned are in Pango units and -- are sorted in ascending order. -- -- Since: 1.4 fontFaceListSizes :: (HasCallStack, MonadIO m, IsFontFace a) => a -> m (Maybe [Int32]) instance (Data.GI.Base.BasicTypes.GObject o, Data.GI.Base.Overloading.IsDescendantOf GI.Pango.Objects.FontFace.FontFace o) => GI.Pango.Objects.FontFace.IsFontFace o instance Data.GI.Base.BasicTypes.GObject GI.Pango.Objects.FontFace.FontFace instance Data.GI.Base.Overloading.HasParentTypes GI.Pango.Objects.FontFace.FontFace -- | The FontDescription structure represents the description of an -- ideal font. These structures are used both to list what fonts are -- available on the system and also for specifying the characteristics of -- a font to load. module GI.Pango.Structs.FontDescription -- | Memory-managed wrapper type. newtype FontDescription FontDescription :: ManagedPtr FontDescription -> FontDescription -- | A convenience alias for Nothing :: Maybe -- FontDescription. noFontDescription :: Maybe FontDescription -- | Determines if the style attributes of newMatch are a -- closer match for desc than those of -- oldMatch are, or if oldMatch is -- Nothing, determines if newMatch is a match at -- all. Approximate matching is done for weight and style; other style -- attributes must match exactly. Style attributes are all attributes -- other than family and size-related attributes. Approximate matching -- for style considers PANGO_STYLE_OBLIQUE and PANGO_STYLE_ITALIC as -- matches, but not as good a match as when the styles are equal. -- -- Note that oldMatch must match desc. fontDescriptionBetterMatch :: (HasCallStack, MonadIO m) => FontDescription -> Maybe FontDescription -> FontDescription -> m Bool -- | Make a copy of a FontDescription. fontDescriptionCopy :: (HasCallStack, MonadIO m) => FontDescription -> m (Maybe FontDescription) -- | Like fontDescriptionCopy, but only a shallow copy is made of -- the family name and other allocated fields. The result can only be -- used until desc is modified or freed. This is meant to -- be used when the copy is only needed temporarily. fontDescriptionCopyStatic :: (HasCallStack, MonadIO m) => FontDescription -> m (Maybe FontDescription) -- | Compares two font descriptions for equality. Two font descriptions are -- considered equal if the fonts they describe are provably identical. -- This means that their masks do not have to match, as long as other -- fields are all the same. (Two font descriptions may result in -- identical fonts being loaded, but still compare False.) fontDescriptionEqual :: (HasCallStack, MonadIO m) => FontDescription -> FontDescription -> m Bool -- | Frees a font description. fontDescriptionFree :: (HasCallStack, MonadIO m) => FontDescription -> m () -- | Creates a new font description from a string representation in the -- form "[FAMILY-LIST] [STYLE-OPTIONS] [SIZE]", where FAMILY-LIST is a -- comma separated list of families optionally terminated by a comma, -- STYLE_OPTIONS is a whitespace separated list of words where each word -- describes one of style, variant, weight, stretch, or gravity, and SIZE -- is a decimal number (size in points) or optionally followed by the -- unit modifier "px" for absolute size. Any one of the options may be -- absent. If FAMILY-LIST is absent, then the family_name field of the -- resulting font description will be initialized to Nothing. If -- STYLE-OPTIONS is missing, then all style options will be set to the -- default values. If SIZE is missing, the size in the resulting font -- description will be set to 0. fontDescriptionFromString :: (HasCallStack, MonadIO m) => Text -> m FontDescription -- | Gets the family name field of a font description. See -- fontDescriptionSetFamily. fontDescriptionGetFamily :: (HasCallStack, MonadIO m) => FontDescription -> m (Maybe Text) -- | Gets the gravity field of a font description. See -- fontDescriptionSetGravity. -- -- Since: 1.16 fontDescriptionGetGravity :: (HasCallStack, MonadIO m) => FontDescription -> m Gravity -- | Determines which fields in a font description have been set. fontDescriptionGetSetFields :: (HasCallStack, MonadIO m) => FontDescription -> m [FontMask] -- | Gets the size field of a font description. See -- fontDescriptionSetSize. fontDescriptionGetSize :: (HasCallStack, MonadIO m) => FontDescription -> m Int32 -- | Determines whether the size of the font is in points (not absolute) or -- device units (absolute). See fontDescriptionSetSize and -- fontDescriptionSetAbsoluteSize. -- -- Since: 1.8 fontDescriptionGetSizeIsAbsolute :: (HasCallStack, MonadIO m) => FontDescription -> m Bool -- | Gets the stretch field of a font description. See -- fontDescriptionSetStretch. fontDescriptionGetStretch :: (HasCallStack, MonadIO m) => FontDescription -> m Stretch -- | Gets the style field of a FontDescription. See -- fontDescriptionSetStyle. fontDescriptionGetStyle :: (HasCallStack, MonadIO m) => FontDescription -> m Style -- | Gets the variant field of a FontDescription. See -- fontDescriptionSetVariant. fontDescriptionGetVariant :: (HasCallStack, MonadIO m) => FontDescription -> m Variant -- | Gets the variations field of a font description. See -- fontDescriptionSetVariations. -- -- Since: 1.42 fontDescriptionGetVariations :: (HasCallStack, MonadIO m) => FontDescription -> m (Maybe Text) -- | Gets the weight field of a font description. See -- fontDescriptionSetWeight. fontDescriptionGetWeight :: (HasCallStack, MonadIO m) => FontDescription -> m Weight -- | Computes a hash of a FontDescription structure suitable to be -- used, for example, as an argument to -- g_hash_table_new(). The hash value is independent of -- desc->mask. fontDescriptionHash :: (HasCallStack, MonadIO m) => FontDescription -> m Word32 -- | Merges the fields that are set in descToMerge into the -- fields in desc. If replaceExisting is -- False, only fields in desc that are not already -- set are affected. If True, then fields that are already set -- will be replaced as well. -- -- If descToMerge is Nothing, this function -- performs nothing. fontDescriptionMerge :: (HasCallStack, MonadIO m) => FontDescription -> Maybe FontDescription -> Bool -> m () -- | Like fontDescriptionMerge, but only a shallow copy is made of -- the family name and other allocated fields. desc can -- only be used until descToMerge is modified or freed. -- This is meant to be used when the merged font description is only -- needed temporarily. fontDescriptionMergeStatic :: (HasCallStack, MonadIO m) => FontDescription -> FontDescription -> Bool -> m () -- | Creates a new font description structure with all fields unset. fontDescriptionNew :: (HasCallStack, MonadIO m) => m FontDescription -- | Sets the size field of a font description, in device units. This is -- mutually exclusive with fontDescriptionSetSize which sets the -- font size in points. -- -- Since: 1.8 fontDescriptionSetAbsoluteSize :: (HasCallStack, MonadIO m) => FontDescription -> Double -> m () -- | Sets the family name field of a font description. The family name -- represents a family of related font styles, and will resolve to a -- particular FontFamily. In some uses of FontDescription, -- it is also possible to use a comma separated list of family names for -- this field. fontDescriptionSetFamily :: (HasCallStack, MonadIO m) => FontDescription -> Text -> m () -- | Like fontDescriptionSetFamily, except that no copy of -- family is made. The caller must make sure that the -- string passed in stays around until desc has been -- freed or the name is set again. This function can be used if -- family is a static string such as a C string literal, -- or if desc is only needed temporarily. fontDescriptionSetFamilyStatic :: (HasCallStack, MonadIO m) => FontDescription -> Text -> m () -- | Sets the gravity field of a font description. The gravity field -- specifies how the glyphs should be rotated. If gravity -- is GravityAuto, this actually unsets the gravity mask on the -- font description. -- -- This function is seldom useful to the user. Gravity should normally be -- set on a Context. -- -- Since: 1.16 fontDescriptionSetGravity :: (HasCallStack, MonadIO m) => FontDescription -> Gravity -> m () -- | Sets the size field of a font description in fractional points. This -- is mutually exclusive with fontDescriptionSetAbsoluteSize. fontDescriptionSetSize :: (HasCallStack, MonadIO m) => FontDescription -> Int32 -> m () -- | Sets the stretch field of a font description. The stretch field -- specifies how narrow or wide the font should be. fontDescriptionSetStretch :: (HasCallStack, MonadIO m) => FontDescription -> Stretch -> m () -- | Sets the style field of a FontDescription. The Style -- enumeration describes whether the font is slanted and the manner in -- which it is slanted; it can be either -- PANGO_STYLE_NORMAL, -- PANGO_STYLE_ITALIC, or -- PANGO_STYLE_OBLIQUE. Most fonts will either have a -- italic style or an oblique style, but not both, and font matching in -- Pango will match italic specifications with oblique fonts and -- vice-versa if an exact match is not found. fontDescriptionSetStyle :: (HasCallStack, MonadIO m) => FontDescription -> Style -> m () -- | Sets the variant field of a font description. The Variant can -- either be VariantNormal or VariantSmallCaps. fontDescriptionSetVariant :: (HasCallStack, MonadIO m) => FontDescription -> Variant -> m () -- | Sets the variations field of a font description. OpenType font -- variations allow to select a font instance by specifying values for a -- number of axes, such as width or weight. -- -- The format of the variations string is AXIS1=VALUE,AXIS2=VALUE..., -- with each AXIS a 4 character tag that identifies a font axis, and each -- VALUE a floating point number. Unknown axes are ignored, and values -- are clamped to their allowed range. -- -- Pango does not currently have a way to find supported axes of a font. -- Both harfbuzz or freetype have API for this. -- -- Since: 1.42 fontDescriptionSetVariations :: (HasCallStack, MonadIO m) => FontDescription -> Text -> m () -- | Like fontDescriptionSetVariations, except that no copy of -- variations is made. The caller must make sure that the -- string passed in stays around until desc has been -- freed or the name is set again. This function can be used if -- variations is a static string such as a C string -- literal, or if desc is only needed temporarily. -- -- Since: 1.42 fontDescriptionSetVariationsStatic :: (HasCallStack, MonadIO m) => FontDescription -> Text -> m () -- | Sets the weight field of a font description. The weight field -- specifies how bold or light the font should be. In addition to the -- values of the Weight enumeration, other intermediate numeric -- values are possible. fontDescriptionSetWeight :: (HasCallStack, MonadIO m) => FontDescription -> Weight -> m () -- | Creates a filename representation of a font description. The filename -- is identical to the result from calling -- fontDescriptionToString, but with underscores instead of -- characters that are untypical in filenames, and in lower case only. fontDescriptionToFilename :: (HasCallStack, MonadIO m) => FontDescription -> m Text -- | Creates a string representation of a font description. See -- fontDescriptionFromString for a description of the format of -- the string representation. The family list in the string description -- will only have a terminating comma if the last word of the list is a -- valid style option. fontDescriptionToString :: (HasCallStack, MonadIO m) => FontDescription -> m Text -- | Unsets some of the fields in a FontDescription. The unset -- fields will get back to their default values. fontDescriptionUnsetFields :: (HasCallStack, MonadIO m) => FontDescription -> [FontMask] -> m () instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.FontDescription.FontDescription -- | A Fontset represents a set of Font to use when rendering -- text. It is the result of resolving a FontDescription against a -- particular Context. It has operations for finding the component -- font for a particular Unicode character, and for finding a composite -- set of metrics for the entire fontset. module GI.Pango.Objects.Fontset -- | Memory-managed wrapper type. newtype Fontset Fontset :: ManagedPtr Fontset -> Fontset -- | Type class for types which can be safely cast to Fontset, for -- instance with toFontset. class (GObject o, IsDescendantOf Fontset o) => IsFontset o -- | Cast to Fontset, for types for which this is known to be safe. -- For general casts, use castTo. toFontset :: (MonadIO m, IsFontset o) => o -> m Fontset -- | A convenience alias for Nothing :: Maybe Fontset. noFontset :: Maybe Fontset -- | Iterates through all the fonts in a fontset, calling -- func for each one. If func returns -- True, that stops the iteration. -- -- Since: 1.4 fontsetForeach :: (HasCallStack, MonadIO m, IsFontset a) => a -> FontsetForeachFunc -> m () -- | Returns the font in the fontset that contains the best glyph for the -- Unicode character wc. fontsetGetFont :: (HasCallStack, MonadIO m, IsFontset a) => a -> Word32 -> m Font -- | Get overall metric information for the fonts in the fontset. fontsetGetMetrics :: (HasCallStack, MonadIO m, IsFontset a) => a -> m FontMetrics instance (Data.GI.Base.BasicTypes.GObject o, Data.GI.Base.Overloading.IsDescendantOf GI.Pango.Objects.Fontset.Fontset o) => GI.Pango.Objects.Fontset.IsFontset o instance Data.GI.Base.BasicTypes.GObject GI.Pango.Objects.Fontset.Fontset instance Data.GI.Base.Overloading.HasParentTypes GI.Pango.Objects.Fontset.Fontset -- | A FontMetrics structure holds the overall metric information -- for a font (possibly restricted to a script). The fields of this -- structure are private to implementations of a font backend. See the -- documentation of the corresponding getters for documentation of their -- meaning. module GI.Pango.Structs.FontMetrics -- | Memory-managed wrapper type. newtype FontMetrics FontMetrics :: ManagedPtr FontMetrics -> FontMetrics -- | Construct a FontMetrics struct initialized to zero. newZeroFontMetrics :: MonadIO m => m FontMetrics -- | A convenience alias for Nothing :: Maybe -- FontMetrics. noFontMetrics :: Maybe FontMetrics -- | Gets the approximate character width for a font metrics structure. -- This is merely a representative value useful, for example, for -- determining the initial size for a window. Actual characters in text -- will be wider and narrower than this. fontMetricsGetApproximateCharWidth :: (HasCallStack, MonadIO m) => FontMetrics -> m Int32 -- | Gets the approximate digit width for a font metrics structure. This is -- merely a representative value useful, for example, for determining the -- initial size for a window. Actual digits in text can be wider or -- narrower than this, though this value is generally somewhat more -- accurate than the result of fontMetricsGetApproximateCharWidth -- for digits. fontMetricsGetApproximateDigitWidth :: (HasCallStack, MonadIO m) => FontMetrics -> m Int32 -- | Gets the ascent from a font metrics structure. The ascent is the -- distance from the baseline to the logical top of a line of text. (The -- logical top may be above or below the top of the actual drawn ink. It -- is necessary to lay out the text to figure where the ink will be.) fontMetricsGetAscent :: (HasCallStack, MonadIO m) => FontMetrics -> m Int32 -- | Gets the descent from a font metrics structure. The descent is the -- distance from the baseline to the logical bottom of a line of text. -- (The logical bottom may be above or below the bottom of the actual -- drawn ink. It is necessary to lay out the text to figure where the ink -- will be.) fontMetricsGetDescent :: (HasCallStack, MonadIO m) => FontMetrics -> m Int32 -- | Gets the suggested position to draw the strikethrough. The value -- returned is the distance <emphasis>above</emphasis> the -- baseline of the top of the strikethrough. -- -- Since: 1.6 fontMetricsGetStrikethroughPosition :: (HasCallStack, MonadIO m) => FontMetrics -> m Int32 -- | Gets the suggested thickness to draw for the strikethrough. -- -- Since: 1.6 fontMetricsGetStrikethroughThickness :: (HasCallStack, MonadIO m) => FontMetrics -> m Int32 -- | Gets the suggested position to draw the underline. The value returned -- is the distance <emphasis>above</emphasis> the baseline of -- the top of the underline. Since most fonts have underline positions -- beneath the baseline, this value is typically negative. -- -- Since: 1.6 fontMetricsGetUnderlinePosition :: (HasCallStack, MonadIO m) => FontMetrics -> m Int32 -- | Gets the suggested thickness to draw for the underline. -- -- Since: 1.6 fontMetricsGetUnderlineThickness :: (HasCallStack, MonadIO m) => FontMetrics -> m Int32 -- | Creates a new FontMetrics structure. This is only for internal -- use by Pango backends and there is no public way to set the fields of -- the structure. fontMetricsNew :: (HasCallStack, MonadIO m) => m FontMetrics -- | Increase the reference count of a font metrics structure by one. fontMetricsRef :: (HasCallStack, MonadIO m) => FontMetrics -> m (Maybe FontMetrics) -- | Decrease the reference count of a font metrics structure by one. If -- the result is zero, frees the structure and any associated memory. fontMetricsUnref :: (HasCallStack, MonadIO m) => FontMetrics -> m () instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.FontMetrics.FontMetrics instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.FontMetrics.FontMetrics tag -- | The GlyphGeometry structure contains width and positioning -- information for a single glyph. module GI.Pango.Structs.GlyphGeometry -- | Memory-managed wrapper type. newtype GlyphGeometry GlyphGeometry :: ManagedPtr GlyphGeometry -> GlyphGeometry -- | Construct a GlyphGeometry struct initialized to zero. newZeroGlyphGeometry :: MonadIO m => m GlyphGeometry -- | A convenience alias for Nothing :: Maybe -- GlyphGeometry. noGlyphGeometry :: Maybe GlyphGeometry -- | Get the value of the “width” field. When overloading -- is enabled, this is equivalent to -- --
--   get glyphGeometry #width
--   
getGlyphGeometryWidth :: MonadIO m => GlyphGeometry -> m Int32 -- | Set the value of the “width” field. When overloading -- is enabled, this is equivalent to -- --
--   set glyphGeometry [ #width := value ]
--   
setGlyphGeometryWidth :: MonadIO m => GlyphGeometry -> Int32 -> m () -- | Get the value of the “x_offset” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphGeometry #xOffset
--   
getGlyphGeometryXOffset :: MonadIO m => GlyphGeometry -> m Int32 -- | Set the value of the “x_offset” field. When -- overloading is enabled, this is equivalent to -- --
--   set glyphGeometry [ #xOffset := value ]
--   
setGlyphGeometryXOffset :: MonadIO m => GlyphGeometry -> Int32 -> m () -- | Get the value of the “y_offset” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphGeometry #yOffset
--   
getGlyphGeometryYOffset :: MonadIO m => GlyphGeometry -> m Int32 -- | Set the value of the “y_offset” field. When -- overloading is enabled, this is equivalent to -- --
--   set glyphGeometry [ #yOffset := value ]
--   
setGlyphGeometryYOffset :: MonadIO m => GlyphGeometry -> Int32 -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.GlyphGeometry.GlyphGeometry instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.GlyphGeometry.GlyphGeometry tag -- | A GlyphItemIter is an iterator over the clusters in a -- GlyphItem. The <firstterm>forward -- direction</firstterm> of the iterator is the logical direction -- of text. That is, with increasing startIndex and -- startChar values. If glyphItem is -- right-to-left (that is, if -- <literal>glyphItem->item->analysis.level</literal> -- is odd), then startGlyph decreases as the iterator -- moves forward. Moreover, in right-to-left cases, -- startGlyph is greater than endGlyph. -- -- An iterator should be initialized using either of -- glyphItemIterInitStart and glyphItemIterInitEnd, for -- forward and backward iteration respectively, and walked over using any -- desired mixture of glyphItemIterNextCluster and -- glyphItemIterPrevCluster. A common idiom for doing a forward -- iteration over the clusters is: <programlisting> -- PangoGlyphItemIter cluster_iter; gboolean have_cluster; -- -- for (have_cluster = pango_glyph_item_iter_init_start -- (&amp;cluster_iter, glyph_item, text); have_cluster; have_cluster -- = pango_glyph_item_iter_next_cluster (&amp;cluster_iter)) { ... } -- </programlisting> -- -- Note that text is the start of the text for layout, -- which is then indexed by -- <literal>glyphItem->item->offset</literal> -- to get to the text of glyphItem. The -- startIndex and endIndex values can -- directly index into text. The -- startGlyph, endGlyph, -- startChar, and endChar values however -- are zero-based for the glyphItem. For each cluster, -- the item pointed at by the start variables is included in the cluster -- while the one pointed at by end variables is not. -- -- None of the members of a GlyphItemIter should be modified -- manually. -- -- Since: 1.22 module GI.Pango.Structs.GlyphItemIter -- | Memory-managed wrapper type. newtype GlyphItemIter GlyphItemIter :: ManagedPtr GlyphItemIter -> GlyphItemIter -- | Construct a GlyphItemIter struct initialized to zero. newZeroGlyphItemIter :: MonadIO m => m GlyphItemIter -- | A convenience alias for Nothing :: Maybe -- GlyphItemIter. noGlyphItemIter :: Maybe GlyphItemIter -- | Make a shallow copy of an existing GlyphItemIter structure. -- -- Since: 1.22 glyphItemIterCopy :: (HasCallStack, MonadIO m) => GlyphItemIter -> m (Maybe GlyphItemIter) -- | Frees a GlyphItemIter created by glyphItemIterCopy. -- -- Since: 1.22 glyphItemIterFree :: (HasCallStack, MonadIO m) => GlyphItemIter -> m () -- | Initializes a GlyphItemIter structure to point to the last -- cluster in a glyph item. See GlyphItemIter for details of -- cluster orders. -- -- Since: 1.22 glyphItemIterInitEnd :: (HasCallStack, MonadIO m) => GlyphItemIter -> GlyphItem -> Text -> m Bool -- | Initializes a GlyphItemIter structure to point to the first -- cluster in a glyph item. See GlyphItemIter for details of -- cluster orders. -- -- Since: 1.22 glyphItemIterInitStart :: (HasCallStack, MonadIO m) => GlyphItemIter -> GlyphItem -> Text -> m Bool -- | Advances the iterator to the next cluster in the glyph item. See -- GlyphItemIter for details of cluster orders. -- -- Since: 1.22 glyphItemIterNextCluster :: (HasCallStack, MonadIO m) => GlyphItemIter -> m Bool -- | Moves the iterator to the preceding cluster in the glyph item. See -- GlyphItemIter for details of cluster orders. -- -- Since: 1.22 glyphItemIterPrevCluster :: (HasCallStack, MonadIO m) => GlyphItemIter -> m Bool -- | Get the value of the “end_char” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphItemIter #endChar
--   
getGlyphItemIterEndChar :: MonadIO m => GlyphItemIter -> m Int32 -- | Set the value of the “end_char” field. When -- overloading is enabled, this is equivalent to -- --
--   set glyphItemIter [ #endChar := value ]
--   
setGlyphItemIterEndChar :: MonadIO m => GlyphItemIter -> Int32 -> m () -- | Get the value of the “end_glyph” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphItemIter #endGlyph
--   
getGlyphItemIterEndGlyph :: MonadIO m => GlyphItemIter -> m Int32 -- | Set the value of the “end_glyph” field. When -- overloading is enabled, this is equivalent to -- --
--   set glyphItemIter [ #endGlyph := value ]
--   
setGlyphItemIterEndGlyph :: MonadIO m => GlyphItemIter -> Int32 -> m () -- | Get the value of the “end_index” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphItemIter #endIndex
--   
getGlyphItemIterEndIndex :: MonadIO m => GlyphItemIter -> m Int32 -- | Set the value of the “end_index” field. When -- overloading is enabled, this is equivalent to -- --
--   set glyphItemIter [ #endIndex := value ]
--   
setGlyphItemIterEndIndex :: MonadIO m => GlyphItemIter -> Int32 -> m () -- | Set the value of the “glyph_item” field to Nothing. -- When overloading is enabled, this is equivalent to -- --
--   clear #glyphItem
--   
clearGlyphItemIterGlyphItem :: MonadIO m => GlyphItemIter -> m () -- | Get the value of the “glyph_item” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphItemIter #glyphItem
--   
getGlyphItemIterGlyphItem :: MonadIO m => GlyphItemIter -> m (Maybe GlyphItem) -- | Set the value of the “glyph_item” field. When -- overloading is enabled, this is equivalent to -- --
--   set glyphItemIter [ #glyphItem := value ]
--   
setGlyphItemIterGlyphItem :: MonadIO m => GlyphItemIter -> Ptr GlyphItem -> m () -- | Get the value of the “start_char” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphItemIter #startChar
--   
getGlyphItemIterStartChar :: MonadIO m => GlyphItemIter -> m Int32 -- | Set the value of the “start_char” field. When -- overloading is enabled, this is equivalent to -- --
--   set glyphItemIter [ #startChar := value ]
--   
setGlyphItemIterStartChar :: MonadIO m => GlyphItemIter -> Int32 -> m () -- | Get the value of the “start_glyph” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphItemIter #startGlyph
--   
getGlyphItemIterStartGlyph :: MonadIO m => GlyphItemIter -> m Int32 -- | Set the value of the “start_glyph” field. When -- overloading is enabled, this is equivalent to -- --
--   set glyphItemIter [ #startGlyph := value ]
--   
setGlyphItemIterStartGlyph :: MonadIO m => GlyphItemIter -> Int32 -> m () -- | Get the value of the “start_index” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphItemIter #startIndex
--   
getGlyphItemIterStartIndex :: MonadIO m => GlyphItemIter -> m Int32 -- | Set the value of the “start_index” field. When -- overloading is enabled, this is equivalent to -- --
--   set glyphItemIter [ #startIndex := value ]
--   
setGlyphItemIterStartIndex :: MonadIO m => GlyphItemIter -> Int32 -> m () -- | Set the value of the “text” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #text
--   
clearGlyphItemIterText :: MonadIO m => GlyphItemIter -> m () -- | Get the value of the “text” field. When overloading is -- enabled, this is equivalent to -- --
--   get glyphItemIter #text
--   
getGlyphItemIterText :: MonadIO m => GlyphItemIter -> m (Maybe Text) -- | Set the value of the “text” field. When overloading is -- enabled, this is equivalent to -- --
--   set glyphItemIter [ #text := value ]
--   
setGlyphItemIterText :: MonadIO m => GlyphItemIter -> CString -> m () instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.GlyphItemIter.GlyphItemIter instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.GlyphItemIter.GlyphItemIter tag -- | The GlyphInfo structure represents a single glyph together with -- positioning information and visual attributes. It contains the -- following fields. module GI.Pango.Structs.GlyphInfo -- | Memory-managed wrapper type. newtype GlyphInfo GlyphInfo :: ManagedPtr GlyphInfo -> GlyphInfo -- | Construct a GlyphInfo struct initialized to zero. newZeroGlyphInfo :: MonadIO m => m GlyphInfo -- | A convenience alias for Nothing :: Maybe -- GlyphInfo. noGlyphInfo :: Maybe GlyphInfo -- | Get the value of the “attr” field. When overloading is -- enabled, this is equivalent to -- --
--   get glyphInfo #attr
--   
getGlyphInfoAttr :: MonadIO m => GlyphInfo -> m GlyphVisAttr -- | Get the value of the “geometry” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphInfo #geometry
--   
getGlyphInfoGeometry :: MonadIO m => GlyphInfo -> m GlyphGeometry -- | Get the value of the “glyph” field. When overloading -- is enabled, this is equivalent to -- --
--   get glyphInfo #glyph
--   
getGlyphInfoGlyph :: MonadIO m => GlyphInfo -> m Word32 -- | Set the value of the “glyph” field. When overloading -- is enabled, this is equivalent to -- --
--   set glyphInfo [ #glyph := value ]
--   
setGlyphInfoGlyph :: MonadIO m => GlyphInfo -> Word32 -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.GlyphInfo.GlyphInfo instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.GlyphInfo.GlyphInfo tag -- | The PangoGlyphVisAttr is used to communicate information between the -- shaping phase and the rendering phase. More attributes may be added in -- the future. module GI.Pango.Structs.GlyphVisAttr -- | Memory-managed wrapper type. newtype GlyphVisAttr GlyphVisAttr :: ManagedPtr GlyphVisAttr -> GlyphVisAttr -- | Construct a GlyphVisAttr struct initialized to zero. newZeroGlyphVisAttr :: MonadIO m => m GlyphVisAttr -- | A convenience alias for Nothing :: Maybe -- GlyphVisAttr. noGlyphVisAttr :: Maybe GlyphVisAttr -- | Get the value of the “is_cluster_start” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphVisAttr #isClusterStart
--   
getGlyphVisAttrIsClusterStart :: MonadIO m => GlyphVisAttr -> m Word32 -- | Set the value of the “is_cluster_start” field. When -- overloading is enabled, this is equivalent to -- --
--   set glyphVisAttr [ #isClusterStart := value ]
--   
setGlyphVisAttrIsClusterStart :: MonadIO m => GlyphVisAttr -> Word32 -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.GlyphVisAttr.GlyphVisAttr instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.GlyphVisAttr.GlyphVisAttr tag -- | The IncludedModule structure for a statically linked module -- contains the functions that would otherwise be loaded from a -- dynamically loaded module. module GI.Pango.Structs.IncludedModule -- | Memory-managed wrapper type. newtype IncludedModule IncludedModule :: ManagedPtr IncludedModule -> IncludedModule -- | Construct a IncludedModule struct initialized to zero. newZeroIncludedModule :: MonadIO m => m IncludedModule -- | A convenience alias for Nothing :: Maybe -- IncludedModule. noIncludedModule :: Maybe IncludedModule -- | Set the value of the “exit” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #exit
--   
clearIncludedModuleExit :: MonadIO m => IncludedModule -> m () -- | Get the value of the “exit” field. When overloading is -- enabled, this is equivalent to -- --
--   get includedModule #exit
--   
getIncludedModuleExit :: MonadIO m => IncludedModule -> m (Maybe IncludedModuleExitFieldCallback) -- | Set the value of the “exit” field. When overloading is -- enabled, this is equivalent to -- --
--   set includedModule [ #exit := value ]
--   
setIncludedModuleExit :: MonadIO m => IncludedModule -> FunPtr C_IncludedModuleExitFieldCallback -> m () -- | Set the value of the “init” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #init
--   
clearIncludedModuleInit :: MonadIO m => IncludedModule -> m () -- | Get the value of the “init” field. When overloading is -- enabled, this is equivalent to -- --
--   get includedModule #init
--   
getIncludedModuleInit :: MonadIO m => IncludedModule -> m (Maybe IncludedModuleInitFieldCallback) -- | Set the value of the “init” field. When overloading is -- enabled, this is equivalent to -- --
--   set includedModule [ #init := value ]
--   
setIncludedModuleInit :: MonadIO m => IncludedModule -> FunPtr C_IncludedModuleInitFieldCallback -> m () -- | Set the value of the “list” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #list
--   
clearIncludedModuleList :: MonadIO m => IncludedModule -> m () -- | Get the value of the “list” field. When overloading is -- enabled, this is equivalent to -- --
--   get includedModule #list
--   
getIncludedModuleList :: MonadIO m => IncludedModule -> m (Maybe IncludedModuleListFieldCallback) -- | Set the value of the “list” field. When overloading is -- enabled, this is equivalent to -- --
--   set includedModule [ #list := value ]
--   
setIncludedModuleList :: MonadIO m => IncludedModule -> FunPtr C_IncludedModuleListFieldCallback -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.IncludedModule.IncludedModule instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.IncludedModule.IncludedModule tag -- | The Item structure stores information about a segment of text. module GI.Pango.Structs.Item -- | Memory-managed wrapper type. newtype Item Item :: ManagedPtr Item -> Item -- | Construct a Item struct initialized to zero. newZeroItem :: MonadIO m => m Item -- | A convenience alias for Nothing :: Maybe Item. noItem :: Maybe Item -- | Copy an existing Item structure. itemCopy :: (HasCallStack, MonadIO m) => Item -> m (Maybe Item) -- | Free a Item and all associated memory. itemFree :: (HasCallStack, MonadIO m) => Item -> m () -- | Creates a new Item structure initialized to default values. itemNew :: (HasCallStack, MonadIO m) => m Item -- | Modifies orig to cover only the text after -- splitIndex, and returns a new item that covers the -- text before splitIndex that used to be in -- orig. You can think of splitIndex as -- the length of the returned item. splitIndex may not be -- 0, and it may not be greater than or equal to the length of -- orig (that is, there must be at least one byte -- assigned to each item, you can't create a zero-length item). -- splitOffset is the length of the first item in chars, -- and must be provided because the text used to generate the item isn't -- available, so itemSplit can't count the char length of the -- split items itself. itemSplit :: (HasCallStack, MonadIO m) => Item -> Int32 -> Int32 -> m Item -- | Get the value of the “analysis” field. When -- overloading is enabled, this is equivalent to -- --
--   get item #analysis
--   
getItemAnalysis :: MonadIO m => Item -> m Analysis -- | Get the value of the “length” field. When overloading -- is enabled, this is equivalent to -- --
--   get item #length
--   
getItemLength :: MonadIO m => Item -> m Int32 -- | Set the value of the “length” field. When overloading -- is enabled, this is equivalent to -- --
--   set item [ #length := value ]
--   
setItemLength :: MonadIO m => Item -> Int32 -> m () -- | Get the value of the “num_chars” field. When -- overloading is enabled, this is equivalent to -- --
--   get item #numChars
--   
getItemNumChars :: MonadIO m => Item -> m Int32 -- | Set the value of the “num_chars” field. When -- overloading is enabled, this is equivalent to -- --
--   set item [ #numChars := value ]
--   
setItemNumChars :: MonadIO m => Item -> Int32 -> m () -- | Get the value of the “offset” field. When overloading -- is enabled, this is equivalent to -- --
--   get item #offset
--   
getItemOffset :: MonadIO m => Item -> m Int32 -- | Set the value of the “offset” field. When overloading -- is enabled, this is equivalent to -- --
--   set item [ #offset := value ]
--   
setItemOffset :: MonadIO m => Item -> Int32 -> m () instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.Item.Item instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.Item.Item tag -- | The AttrLanguage structure is used to represent attributes that -- are languages. module GI.Pango.Structs.AttrLanguage -- | Memory-managed wrapper type. newtype AttrLanguage AttrLanguage :: ManagedPtr AttrLanguage -> AttrLanguage -- | Construct a AttrLanguage struct initialized to zero. newZeroAttrLanguage :: MonadIO m => m AttrLanguage -- | A convenience alias for Nothing :: Maybe -- AttrLanguage. noAttrLanguage :: Maybe AttrLanguage -- | Create a new language tag attribute. attrLanguageNew :: (HasCallStack, MonadIO m) => Language -> m Attribute -- | Get the value of the “attr” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrLanguage #attr
--   
getAttrLanguageAttr :: MonadIO m => AttrLanguage -> m Attribute -- | Set the value of the “value” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #value
--   
clearAttrLanguageValue :: MonadIO m => AttrLanguage -> m () -- | Get the value of the “value” field. When overloading -- is enabled, this is equivalent to -- --
--   get attrLanguage #value
--   
getAttrLanguageValue :: MonadIO m => AttrLanguage -> m (Maybe Language) -- | Set the value of the “value” field. When overloading -- is enabled, this is equivalent to -- --
--   set attrLanguage [ #value := value ]
--   
setAttrLanguageValue :: MonadIO m => AttrLanguage -> Ptr Language -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.AttrLanguage.AttrLanguage instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.AttrLanguage.AttrLanguage tag -- | The AttrIterator structure is used to represent an iterator -- through a AttrList. A new iterator is created with -- pango_attr_list_get_iterator(). Once the iterator is -- created, it can be advanced through the style changes in the text -- using attrIteratorNext. At each style change, the range of the -- current style segment and the attributes currently in effect can be -- queried. module GI.Pango.Structs.AttrIterator -- | Memory-managed wrapper type. newtype AttrIterator AttrIterator :: ManagedPtr AttrIterator -> AttrIterator -- | A convenience alias for Nothing :: Maybe -- AttrIterator. noAttrIterator :: Maybe AttrIterator -- | Destroy a AttrIterator and free all associated memory. attrIteratorDestroy :: (HasCallStack, MonadIO m) => AttrIterator -> m () -- | Gets a list of all attributes at the current position of the iterator. -- -- Since: 1.2 attrIteratorGetAttrs :: (HasCallStack, MonadIO m) => AttrIterator -> m [Attribute] -- | Get the font and other attributes at the current iterator position. attrIteratorGetFont :: (HasCallStack, MonadIO m) => AttrIterator -> FontDescription -> Maybe Language -> [Attribute] -> m () -- | Advance the iterator until the next change of style. attrIteratorNext :: (HasCallStack, MonadIO m) => AttrIterator -> m Bool -- | Get the range of the current segment. Note that the stored return -- values are signed, not unsigned like the values in Attribute. -- To deal with this API oversight, stored return values that wouldn't -- fit into a signed integer are clamped to G_MAXINT. attrIteratorRange :: (HasCallStack, MonadIO m) => AttrIterator -> m (Int32, Int32) instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.AttrIterator.AttrIterator -- | The Analysis structure stores information about the properties -- of a segment of text. module GI.Pango.Structs.Analysis -- | Memory-managed wrapper type. newtype Analysis Analysis :: ManagedPtr Analysis -> Analysis -- | Construct a Analysis struct initialized to zero. newZeroAnalysis :: MonadIO m => m Analysis -- | A convenience alias for Nothing :: Maybe -- Analysis. noAnalysis :: Maybe Analysis -- | Set the value of the “extra_attrs” field to Nothing. -- When overloading is enabled, this is equivalent to -- --
--   clear #extraAttrs
--   
clearAnalysisExtraAttrs :: MonadIO m => Analysis -> m () -- | Get the value of the “extra_attrs” field. When -- overloading is enabled, this is equivalent to -- --
--   get analysis #extraAttrs
--   
getAnalysisExtraAttrs :: MonadIO m => Analysis -> m [Ptr ()] -- | Set the value of the “extra_attrs” field. When -- overloading is enabled, this is equivalent to -- --
--   set analysis [ #extraAttrs := value ]
--   
setAnalysisExtraAttrs :: MonadIO m => Analysis -> Ptr (GSList (Ptr ())) -> m () -- | Get the value of the “flags” field. When overloading -- is enabled, this is equivalent to -- --
--   get analysis #flags
--   
getAnalysisFlags :: MonadIO m => Analysis -> m Word8 -- | Set the value of the “flags” field. When overloading -- is enabled, this is equivalent to -- --
--   set analysis [ #flags := value ]
--   
setAnalysisFlags :: MonadIO m => Analysis -> Word8 -> m () -- | Set the value of the “font” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #font
--   
clearAnalysisFont :: MonadIO m => Analysis -> m () -- | Get the value of the “font” field. When overloading is -- enabled, this is equivalent to -- --
--   get analysis #font
--   
getAnalysisFont :: MonadIO m => Analysis -> m (Maybe Font) -- | Set the value of the “font” field. When overloading is -- enabled, this is equivalent to -- --
--   set analysis [ #font := value ]
--   
setAnalysisFont :: MonadIO m => Analysis -> Ptr Font -> m () -- | Get the value of the “gravity” field. When overloading -- is enabled, this is equivalent to -- --
--   get analysis #gravity
--   
getAnalysisGravity :: MonadIO m => Analysis -> m Word8 -- | Set the value of the “gravity” field. When overloading -- is enabled, this is equivalent to -- --
--   set analysis [ #gravity := value ]
--   
setAnalysisGravity :: MonadIO m => Analysis -> Word8 -> m () -- | Set the value of the “lang_engine” field to Nothing. -- When overloading is enabled, this is equivalent to -- --
--   clear #langEngine
--   
clearAnalysisLangEngine :: MonadIO m => Analysis -> m () -- | Get the value of the “lang_engine” field. When -- overloading is enabled, this is equivalent to -- --
--   get analysis #langEngine
--   
getAnalysisLangEngine :: MonadIO m => Analysis -> m (Maybe EngineLang) -- | Set the value of the “lang_engine” field. When -- overloading is enabled, this is equivalent to -- --
--   set analysis [ #langEngine := value ]
--   
setAnalysisLangEngine :: MonadIO m => Analysis -> Ptr EngineLang -> m () -- | Set the value of the “language” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #language
--   
clearAnalysisLanguage :: MonadIO m => Analysis -> m () -- | Get the value of the “language” field. When -- overloading is enabled, this is equivalent to -- --
--   get analysis #language
--   
getAnalysisLanguage :: MonadIO m => Analysis -> m (Maybe Language) -- | Set the value of the “language” field. When -- overloading is enabled, this is equivalent to -- --
--   set analysis [ #language := value ]
--   
setAnalysisLanguage :: MonadIO m => Analysis -> Ptr Language -> m () -- | Get the value of the “level” field. When overloading -- is enabled, this is equivalent to -- --
--   get analysis #level
--   
getAnalysisLevel :: MonadIO m => Analysis -> m Word8 -- | Set the value of the “level” field. When overloading -- is enabled, this is equivalent to -- --
--   set analysis [ #level := value ]
--   
setAnalysisLevel :: MonadIO m => Analysis -> Word8 -> m () -- | Get the value of the “script” field. When overloading -- is enabled, this is equivalent to -- --
--   get analysis #script
--   
getAnalysisScript :: MonadIO m => Analysis -> m Word8 -- | Set the value of the “script” field. When overloading -- is enabled, this is equivalent to -- --
--   set analysis [ #script := value ]
--   
setAnalysisScript :: MonadIO m => Analysis -> Word8 -> m () -- | Set the value of the “shape_engine” field to Nothing. -- When overloading is enabled, this is equivalent to -- --
--   clear #shapeEngine
--   
clearAnalysisShapeEngine :: MonadIO m => Analysis -> m () -- | Get the value of the “shape_engine” field. When -- overloading is enabled, this is equivalent to -- --
--   get analysis #shapeEngine
--   
getAnalysisShapeEngine :: MonadIO m => Analysis -> m (Maybe EngineShape) -- | Set the value of the “shape_engine” field. When -- overloading is enabled, this is equivalent to -- --
--   set analysis [ #shapeEngine := value ]
--   
setAnalysisShapeEngine :: MonadIO m => Analysis -> Ptr EngineShape -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.Analysis.Analysis instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.Analysis.Analysis tag -- | FontsetSimple is a implementation of the abstract -- Fontset base class in terms of an array of fonts, which the -- creator provides when constructing the FontsetSimple. module GI.Pango.Objects.FontsetSimple -- | Memory-managed wrapper type. newtype FontsetSimple FontsetSimple :: ManagedPtr FontsetSimple -> FontsetSimple -- | Type class for types which can be safely cast to FontsetSimple, -- for instance with toFontsetSimple. class (GObject o, IsDescendantOf FontsetSimple o) => IsFontsetSimple o -- | Cast to FontsetSimple, for types for which this is known to be -- safe. For general casts, use castTo. toFontsetSimple :: (MonadIO m, IsFontsetSimple o) => o -> m FontsetSimple -- | A convenience alias for Nothing :: Maybe -- FontsetSimple. noFontsetSimple :: Maybe FontsetSimple -- | Adds a font to the fontset. fontsetSimpleAppend :: (HasCallStack, MonadIO m, IsFontsetSimple a, IsFont b) => a -> b -> m () -- | Creates a new FontsetSimple for the given language. fontsetSimpleNew :: (HasCallStack, MonadIO m) => Language -> m FontsetSimple -- | Returns the number of fonts in the fontset. fontsetSimpleSize :: (HasCallStack, MonadIO m, IsFontsetSimple a) => a -> m Int32 instance (Data.GI.Base.BasicTypes.GObject o, Data.GI.Base.Overloading.IsDescendantOf GI.Pango.Objects.FontsetSimple.FontsetSimple o) => GI.Pango.Objects.FontsetSimple.IsFontsetSimple o instance Data.GI.Base.BasicTypes.GObject GI.Pango.Objects.FontsetSimple.FontsetSimple instance Data.GI.Base.Overloading.HasParentTypes GI.Pango.Objects.FontsetSimple.FontsetSimple -- | The FontMap represents the set of fonts available for a -- particular rendering system. This is a virtual object with -- implementations being specific to particular rendering systems. To -- create an implementation of a FontMap, the rendering-system -- specific code should allocate a larger structure that contains a -- nested FontMap, fill in the -- <structfield>klass</structfield> member of the nested -- FontMap with a pointer to a appropriate FontMapClass, -- then call pango_font_map_init() on the structure. -- -- The FontMap structure contains one member which the -- implementation fills in. module GI.Pango.Objects.FontMap -- | Memory-managed wrapper type. newtype FontMap FontMap :: ManagedPtr FontMap -> FontMap -- | Type class for types which can be safely cast to FontMap, for -- instance with toFontMap. class (GObject o, IsDescendantOf FontMap o) => IsFontMap o -- | Cast to FontMap, for types for which this is known to be safe. -- For general casts, use castTo. toFontMap :: (MonadIO m, IsFontMap o) => o -> m FontMap -- | A convenience alias for Nothing :: Maybe FontMap. noFontMap :: Maybe FontMap -- | Forces a change in the context, which will cause any Context -- using this fontmap to change. -- -- This function is only useful when implementing a new backend for -- Pango, something applications won't do. Backends should call this -- function if they have attached extra data to the context and such data -- is changed. -- -- Since: 1.34 fontMapChanged :: (HasCallStack, MonadIO m, IsFontMap a) => a -> m () -- | Creates a Context connected to fontmap. This is -- equivalent to contextNew followed by contextSetFontMap. -- -- If you are using Pango as part of a higher-level system, that system -- may have it's own way of create a Context. For instance, the -- GTK+ toolkit has, among others, -- gdk_pango_context_get_for_screen(), and -- gtk_widget_get_pango_context(). Use those instead. -- -- Since: 1.22 fontMapCreateContext :: (HasCallStack, MonadIO m, IsFontMap a) => a -> m Context -- | Returns the current serial number of fontmap. The -- serial number is initialized to an small number larger than zero when -- a new fontmap is created and is increased whenever the fontmap is -- changed. It may wrap, but will never have the value 0. Since it can -- wrap, never compare it with "less than", always use "not equals". -- -- The fontmap can only be changed using backend-specific API, like -- changing fontmap resolution. -- -- This can be used to automatically detect changes to a FontMap, -- like in Context. -- -- Since: 1.32.4 fontMapGetSerial :: (HasCallStack, MonadIO m, IsFontMap a) => a -> m Word32 -- | Returns the render ID for shape engines for this fontmap. See the -- <structfield>render_type</structfield> field of -- EngineInfo. -- -- Since: 1.4 -- | Deprecated: (Since version 1.38) fontMapGetShapeEngineType :: (HasCallStack, MonadIO m, IsFontMap a) => a -> m Text -- | List all families for a fontmap. fontMapListFamilies :: (HasCallStack, MonadIO m, IsFontMap a) => a -> m [FontFamily] -- | Load the font in the fontmap that is the closest match for -- desc. fontMapLoadFont :: (HasCallStack, MonadIO m, IsFontMap a, IsContext b) => a -> b -> FontDescription -> m (Maybe Font) -- | Load a set of fonts in the fontmap that can be used to render a font -- matching desc. fontMapLoadFontset :: (HasCallStack, MonadIO m, IsFontMap a, IsContext b) => a -> b -> FontDescription -> Language -> m (Maybe Fontset) instance (Data.GI.Base.BasicTypes.GObject o, Data.GI.Base.Overloading.IsDescendantOf GI.Pango.Objects.FontMap.FontMap o) => GI.Pango.Objects.FontMap.IsFontMap o instance Data.GI.Base.BasicTypes.GObject GI.Pango.Objects.FontMap.FontMap instance Data.GI.Base.Overloading.HasParentTypes GI.Pango.Objects.FontMap.FontMap -- | The Language structure is used to represent a language. -- -- Language pointers can be efficiently copied and compared with -- each other. module GI.Pango.Structs.Language -- | Memory-managed wrapper type. newtype Language Language :: ManagedPtr Language -> Language -- | A convenience alias for Nothing :: Maybe -- Language. noLanguage :: Maybe Language -- | Take a RFC-3066 format language tag as a string and convert it to a -- Language pointer that can be efficiently copied (copy the -- pointer) and compared with other language tags (compare the pointer.) -- -- This function first canonicalizes the string by converting it to -- lowercase, mapping '_' to '-', and stripping all characters other than -- letters and '-'. -- -- Use languageGetDefault if you want to get the Language -- for the current locale of the process. languageFromString :: (HasCallStack, MonadIO m) => Maybe Text -> m (Maybe Language) -- | Returns the Language for the current locale of the process. -- Note that this can change over the life of an application. -- -- On Unix systems, this is the return value is derived from -- <literal>setlocale(LC_CTYPE, NULL)</literal>, and the user -- can affect this through the environment variables LC_ALL, LC_CTYPE or -- LANG (checked in that order). The locale string typically is in the -- form lang_COUNTRY, where lang is an ISO-639 language code, and COUNTRY -- is an ISO-3166 country code. For instance, sv_FI for Swedish as -- written in Finland or pt_BR for Portuguese as written in Brazil. -- -- On Windows, the C library does not use any such environment variables, -- and setting them won't affect the behavior of functions like -- ctime(). The user sets the locale through the Regional -- Options in the Control Panel. The C library (in the -- setlocale() function) does not use country and -- language codes, but country and language names spelled out in English. -- However, this function does check the above environment variables, and -- does return a Unix-style locale string based on either said -- environment variables or the thread's current locale. -- -- Your application should call <literal>setlocale(LC_ALL, -- "");</literal> for the user settings to take effect. Gtk+ does -- this in its initialization functions automatically (by calling -- gtk_set_locale()). See <literal>man -- setlocale</literal> for more details. -- -- Since: 1.16 languageGetDefault :: (HasCallStack, MonadIO m) => m Language -- | Get a string that is representative of the characters needed to render -- a particular language. -- -- The sample text may be a pangram, but is not necessarily. It is chosen -- to be demonstrative of normal text in the language, as well as -- exposing font feature requirements unique to the language. It is -- suitable for use as sample text in a font selection dialog. -- -- If language is Nothing, the default language as -- found by languageGetDefault is used. -- -- If Pango does not have a sample string for language, -- the classic "The quick brown fox..." is returned. This can be detected -- by comparing the returned pointer value to that returned for -- (non-existent) language code "xx". That is, compare to: -- <informalexample><programlisting> -- pango_language_get_sample_string (pango_language_from_string ("xx")) -- </programlisting></informalexample> languageGetSampleString :: (HasCallStack, MonadIO m) => Language -> m Text -- | Determines if script is one of the scripts used to -- write language. The returned value is conservative; if -- nothing is known about the language tag language, -- True will be returned, since, as far as Pango knows, -- script might be used to write -- language. -- -- This routine is used in Pango's itemization process when determining -- if a supplied language tag is relevant to a particular section of -- text. It probably is not useful for applications in most -- circumstances. -- -- This function uses languageGetScripts internally. -- -- Since: 1.4 languageIncludesScript :: (HasCallStack, MonadIO m) => Language -> Script -> m Bool -- | Checks if a language tag matches one of the elements in a list of -- language ranges. A language tag is considered to match a range in the -- list if the range is '*', the range is exactly the tag, or the range -- is a prefix of the tag, and the character after it in the tag is '-'. languageMatches :: (HasCallStack, MonadIO m) => Language -> Text -> m Bool -- | Gets the RFC-3066 format string representing the given language tag. languageToString :: (HasCallStack, MonadIO m) => Language -> m Text instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.Language.Language -- | A GlyphItem is a pair of a Item and the glyphs resulting -- from shaping the text corresponding to an item. As an example of the -- usage of GlyphItem, the results of shaping text with -- Layout is a list of LayoutLine, each of which contains a -- list of GlyphItem. module GI.Pango.Structs.GlyphItem -- | Memory-managed wrapper type. newtype GlyphItem GlyphItem :: ManagedPtr GlyphItem -> GlyphItem -- | Construct a GlyphItem struct initialized to zero. newZeroGlyphItem :: MonadIO m => m GlyphItem -- | A convenience alias for Nothing :: Maybe -- GlyphItem. noGlyphItem :: Maybe GlyphItem -- | Splits a shaped item (PangoGlyphItem) into multiple items based on an -- attribute list. The idea is that if you have attributes that don't -- affect shaping, such as color or underline, to avoid affecting -- shaping, you filter them out (attrListFilter), apply the -- shaping process and then reapply them to the result using this -- function. -- -- All attributes that start or end inside a cluster are applied to that -- cluster; for instance, if half of a cluster is underlined and the -- other-half strikethrough, then the cluster will end up with both -- underline and strikethrough attributes. In these cases, it may happen -- that item->extra_attrs for some of the result items can have -- multiple attributes of the same type. -- -- This function takes ownership of glyphItem; it will be -- reused as one of the elements in the list. -- -- Since: 1.2 glyphItemApplyAttrs :: (HasCallStack, MonadIO m) => GlyphItem -> Text -> AttrList -> m [GlyphItem] -- | Make a deep copy of an existing GlyphItem structure. -- -- Since: 1.20 glyphItemCopy :: (HasCallStack, MonadIO m) => GlyphItem -> m (Maybe GlyphItem) -- | Frees a GlyphItem and resources to which it points. -- -- Since: 1.6 glyphItemFree :: (HasCallStack, MonadIO m) => GlyphItem -> m () -- | Given a GlyphItem and the corresponding text, determine the -- screen width corresponding to each character. When multiple characters -- compose a single cluster, the width of the entire cluster is divided -- equally among the characters. -- -- See also glyphStringGetLogicalWidths. -- -- Since: 1.26 glyphItemGetLogicalWidths :: (HasCallStack, MonadIO m) => GlyphItem -> Text -> [Int32] -> m () -- | Adds spacing between the graphemes of glyphItem to -- give the effect of typographic letter spacing. -- -- Since: 1.6 glyphItemLetterSpace :: (HasCallStack, MonadIO m) => GlyphItem -> Text -> [LogAttr] -> Int32 -> m () -- | Modifies orig to cover only the text after -- splitIndex, and returns a new item that covers the -- text before splitIndex that used to be in -- orig. You can think of splitIndex as -- the length of the returned item. splitIndex may not be -- 0, and it may not be greater than or equal to the length of -- orig (that is, there must be at least one byte -- assigned to each item, you can't create a zero-length item). -- -- This function is similar in function to itemSplit (and uses it -- internally.) -- -- Since: 1.2 glyphItemSplit :: (HasCallStack, MonadIO m) => GlyphItem -> Text -> Int32 -> m GlyphItem -- | Set the value of the “glyphs” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #glyphs
--   
clearGlyphItemGlyphs :: MonadIO m => GlyphItem -> m () -- | Get the value of the “glyphs” field. When overloading -- is enabled, this is equivalent to -- --
--   get glyphItem #glyphs
--   
getGlyphItemGlyphs :: MonadIO m => GlyphItem -> m (Maybe GlyphString) -- | Set the value of the “glyphs” field. When overloading -- is enabled, this is equivalent to -- --
--   set glyphItem [ #glyphs := value ]
--   
setGlyphItemGlyphs :: MonadIO m => GlyphItem -> Ptr GlyphString -> m () -- | Set the value of the “item” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #item
--   
clearGlyphItemItem :: MonadIO m => GlyphItem -> m () -- | Get the value of the “item” field. When overloading is -- enabled, this is equivalent to -- --
--   get glyphItem #item
--   
getGlyphItemItem :: MonadIO m => GlyphItem -> m (Maybe Item) -- | Set the value of the “item” field. When overloading is -- enabled, this is equivalent to -- --
--   set glyphItem [ #item := value ]
--   
setGlyphItemItem :: MonadIO m => GlyphItem -> Ptr Item -> m () instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.GlyphItem.GlyphItem instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.GlyphItem.GlyphItem tag -- | The LogAttr structure stores information about the attributes -- of a single character. module GI.Pango.Structs.LogAttr -- | Memory-managed wrapper type. newtype LogAttr LogAttr :: ManagedPtr LogAttr -> LogAttr -- | Construct a LogAttr struct initialized to zero. newZeroLogAttr :: MonadIO m => m LogAttr -- | A convenience alias for Nothing :: Maybe LogAttr. noLogAttr :: Maybe LogAttr -- | Get the value of the “backspace_deletes_character” field. -- When overloading is enabled, this is equivalent to -- --
--   get logAttr #backspaceDeletesCharacter
--   
getLogAttrBackspaceDeletesCharacter :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “backspace_deletes_character” field. -- When overloading is enabled, this is equivalent to -- --
--   set logAttr [ #backspaceDeletesCharacter := value ]
--   
setLogAttrBackspaceDeletesCharacter :: MonadIO m => LogAttr -> Word32 -> m () -- | Get the value of the “is_char_break” field. When -- overloading is enabled, this is equivalent to -- --
--   get logAttr #isCharBreak
--   
getLogAttrIsCharBreak :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “is_char_break” field. When -- overloading is enabled, this is equivalent to -- --
--   set logAttr [ #isCharBreak := value ]
--   
setLogAttrIsCharBreak :: MonadIO m => LogAttr -> Word32 -> m () -- | Get the value of the “is_cursor_position” field. When -- overloading is enabled, this is equivalent to -- --
--   get logAttr #isCursorPosition
--   
getLogAttrIsCursorPosition :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “is_cursor_position” field. When -- overloading is enabled, this is equivalent to -- --
--   set logAttr [ #isCursorPosition := value ]
--   
setLogAttrIsCursorPosition :: MonadIO m => LogAttr -> Word32 -> m () -- | Get the value of the “is_expandable_space” field. When -- overloading is enabled, this is equivalent to -- --
--   get logAttr #isExpandableSpace
--   
getLogAttrIsExpandableSpace :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “is_expandable_space” field. When -- overloading is enabled, this is equivalent to -- --
--   set logAttr [ #isExpandableSpace := value ]
--   
setLogAttrIsExpandableSpace :: MonadIO m => LogAttr -> Word32 -> m () -- | Get the value of the “is_line_break” field. When -- overloading is enabled, this is equivalent to -- --
--   get logAttr #isLineBreak
--   
getLogAttrIsLineBreak :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “is_line_break” field. When -- overloading is enabled, this is equivalent to -- --
--   set logAttr [ #isLineBreak := value ]
--   
setLogAttrIsLineBreak :: MonadIO m => LogAttr -> Word32 -> m () -- | Get the value of the “is_mandatory_break” field. When -- overloading is enabled, this is equivalent to -- --
--   get logAttr #isMandatoryBreak
--   
getLogAttrIsMandatoryBreak :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “is_mandatory_break” field. When -- overloading is enabled, this is equivalent to -- --
--   set logAttr [ #isMandatoryBreak := value ]
--   
setLogAttrIsMandatoryBreak :: MonadIO m => LogAttr -> Word32 -> m () -- | Get the value of the “is_sentence_boundary” field. When -- overloading is enabled, this is equivalent to -- --
--   get logAttr #isSentenceBoundary
--   
getLogAttrIsSentenceBoundary :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “is_sentence_boundary” field. When -- overloading is enabled, this is equivalent to -- --
--   set logAttr [ #isSentenceBoundary := value ]
--   
setLogAttrIsSentenceBoundary :: MonadIO m => LogAttr -> Word32 -> m () -- | Get the value of the “is_sentence_end” field. When -- overloading is enabled, this is equivalent to -- --
--   get logAttr #isSentenceEnd
--   
getLogAttrIsSentenceEnd :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “is_sentence_end” field. When -- overloading is enabled, this is equivalent to -- --
--   set logAttr [ #isSentenceEnd := value ]
--   
setLogAttrIsSentenceEnd :: MonadIO m => LogAttr -> Word32 -> m () -- | Get the value of the “is_sentence_start” field. When -- overloading is enabled, this is equivalent to -- --
--   get logAttr #isSentenceStart
--   
getLogAttrIsSentenceStart :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “is_sentence_start” field. When -- overloading is enabled, this is equivalent to -- --
--   set logAttr [ #isSentenceStart := value ]
--   
setLogAttrIsSentenceStart :: MonadIO m => LogAttr -> Word32 -> m () -- | Get the value of the “is_white” field. When -- overloading is enabled, this is equivalent to -- --
--   get logAttr #isWhite
--   
getLogAttrIsWhite :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “is_white” field. When -- overloading is enabled, this is equivalent to -- --
--   set logAttr [ #isWhite := value ]
--   
setLogAttrIsWhite :: MonadIO m => LogAttr -> Word32 -> m () -- | Get the value of the “is_word_boundary” field. When -- overloading is enabled, this is equivalent to -- --
--   get logAttr #isWordBoundary
--   
getLogAttrIsWordBoundary :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “is_word_boundary” field. When -- overloading is enabled, this is equivalent to -- --
--   set logAttr [ #isWordBoundary := value ]
--   
setLogAttrIsWordBoundary :: MonadIO m => LogAttr -> Word32 -> m () -- | Get the value of the “is_word_end” field. When -- overloading is enabled, this is equivalent to -- --
--   get logAttr #isWordEnd
--   
getLogAttrIsWordEnd :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “is_word_end” field. When -- overloading is enabled, this is equivalent to -- --
--   set logAttr [ #isWordEnd := value ]
--   
setLogAttrIsWordEnd :: MonadIO m => LogAttr -> Word32 -> m () -- | Get the value of the “is_word_start” field. When -- overloading is enabled, this is equivalent to -- --
--   get logAttr #isWordStart
--   
getLogAttrIsWordStart :: MonadIO m => LogAttr -> m Word32 -- | Set the value of the “is_word_start” field. When -- overloading is enabled, this is equivalent to -- --
--   set logAttr [ #isWordStart := value ]
--   
setLogAttrIsWordStart :: MonadIO m => LogAttr -> Word32 -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.LogAttr.LogAttr instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.LogAttr.LogAttr tag -- | No description available in the introspection data. module GI.Pango.Structs.Map -- | Memory-managed wrapper type. newtype Map Map :: ManagedPtr Map -> Map -- | A convenience alias for Nothing :: Maybe Map. noMap :: Maybe Map instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.Map.Map -- | No description available in the introspection data. module GI.Pango.Structs.MapEntry -- | Memory-managed wrapper type. newtype MapEntry MapEntry :: ManagedPtr MapEntry -> MapEntry -- | A convenience alias for Nothing :: Maybe -- MapEntry. noMapEntry :: Maybe MapEntry instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.MapEntry.MapEntry -- | Renderer is a base class for objects that are used to render -- Pango objects such as GlyphString and Layout. -- -- Since: 1.8 module GI.Pango.Objects.Renderer -- | Memory-managed wrapper type. newtype Renderer Renderer :: ManagedPtr Renderer -> Renderer -- | Type class for types which can be safely cast to Renderer, for -- instance with toRenderer. class (GObject o, IsDescendantOf Renderer o) => IsRenderer o -- | Cast to Renderer, for types for which this is known to be safe. -- For general casts, use castTo. toRenderer :: (MonadIO m, IsRenderer o) => o -> m Renderer -- | A convenience alias for Nothing :: Maybe -- Renderer. noRenderer :: Maybe Renderer -- | Does initial setup before rendering operations on -- renderer. rendererDeactivate should be called -- when done drawing. Calls such as rendererDrawLayout -- automatically activate the layout before drawing on it. Calls to -- rendererActivate and rendererDeactivate can be nested -- and the renderer will only be initialized and deinitialized once. -- -- Since: 1.8 rendererActivate :: (HasCallStack, MonadIO m, IsRenderer a) => a -> m () -- | Cleans up after rendering operations on renderer. See -- docs for rendererActivate. -- -- Since: 1.8 rendererDeactivate :: (HasCallStack, MonadIO m, IsRenderer a) => a -> m () -- | Draw a squiggly line that approximately covers the given rectangle in -- the style of an underline used to indicate a spelling error. (The -- width of the underline is rounded to an integer number of up/down -- segments and the resulting rectangle is centered in the original -- rectangle) -- -- This should be called while renderer is already -- active. Use rendererActivate to activate a renderer. -- -- Since: 1.8 rendererDrawErrorUnderline :: (HasCallStack, MonadIO m, IsRenderer a) => a -> Int32 -> Int32 -> Int32 -> Int32 -> m () -- | Draws a single glyph with coordinates in device space. -- -- Since: 1.8 rendererDrawGlyph :: (HasCallStack, MonadIO m, IsRenderer a, IsFont b) => a -> b -> Word32 -> Double -> Double -> m () -- | Draws the glyphs in glyphItem with the specified -- Renderer, embedding the text associated with the glyphs in the -- output if the output format supports it (PDF for example). -- -- Note that text is the start of the text for layout, -- which is then indexed by -- <literal>glyphItem->item->offset</literal>. -- -- If text is Nothing, this simply calls -- rendererDrawGlyphs. -- -- The default implementation of this method simply falls back to -- rendererDrawGlyphs. -- -- Since: 1.22 rendererDrawGlyphItem :: (HasCallStack, MonadIO m, IsRenderer a) => a -> Maybe Text -> GlyphItem -> Int32 -> Int32 -> m () -- | Draws the glyphs in glyphs with the specified -- Renderer. -- -- Since: 1.8 rendererDrawGlyphs :: (HasCallStack, MonadIO m, IsRenderer a, IsFont b) => a -> b -> GlyphString -> Int32 -> Int32 -> m () -- | Draws layout with the specified Renderer. -- -- Since: 1.8 rendererDrawLayout :: (HasCallStack, MonadIO m, IsRenderer a, IsLayout b) => a -> b -> Int32 -> Int32 -> m () -- | Draws line with the specified Renderer. -- -- Since: 1.8 rendererDrawLayoutLine :: (HasCallStack, MonadIO m, IsRenderer a) => a -> LayoutLine -> Int32 -> Int32 -> m () -- | Draws an axis-aligned rectangle in user space coordinates with the -- specified Renderer. -- -- This should be called while renderer is already -- active. Use rendererActivate to activate a renderer. -- -- Since: 1.8 rendererDrawRectangle :: (HasCallStack, MonadIO m, IsRenderer a) => a -> RenderPart -> Int32 -> Int32 -> Int32 -> Int32 -> m () -- | Draws a trapezoid with the parallel sides aligned with the X axis -- using the given Renderer; coordinates are in device space. -- -- Since: 1.8 rendererDrawTrapezoid :: (HasCallStack, MonadIO m, IsRenderer a) => a -> RenderPart -> Double -> Double -> Double -> Double -> Double -> Double -> m () -- | Gets the current alpha for the specified part. -- -- Since: 1.38 rendererGetAlpha :: (HasCallStack, MonadIO m, IsRenderer a) => a -> RenderPart -> m Word16 -- | Gets the current rendering color for the specified part. -- -- Since: 1.8 rendererGetColor :: (HasCallStack, MonadIO m, IsRenderer a) => a -> RenderPart -> m (Maybe Color) -- | Gets the layout currently being rendered using -- renderer. Calling this function only makes sense from -- inside a subclass's methods, like in its draw_shape<!---->() for -- example. -- -- The returned layout should not be modified while still being rendered. -- -- Since: 1.20 rendererGetLayout :: (HasCallStack, MonadIO m, IsRenderer a) => a -> m (Maybe Layout) -- | Gets the layout line currently being rendered using -- renderer. Calling this function only makes sense from -- inside a subclass's methods, like in its draw_shape<!---->() for -- example. -- -- The returned layout line should not be modified while still being -- rendered. -- -- Since: 1.20 rendererGetLayoutLine :: (HasCallStack, MonadIO m, IsRenderer a) => a -> m (Maybe LayoutLine) -- | Gets the transformation matrix that will be applied when rendering. -- See rendererSetMatrix. -- -- Since: 1.8 rendererGetMatrix :: (HasCallStack, MonadIO m, IsRenderer a) => a -> m (Maybe Matrix) -- | Informs Pango that the way that the rendering is done for -- part has changed in a way that would prevent multiple -- pieces being joined together into one drawing call. For instance, if a -- subclass of Renderer was to add a stipple option for drawing -- underlines, it needs to call -- -- <informalexample><programlisting> -- pango_renderer_part_changed (render, PANGO_RENDER_PART_UNDERLINE); -- </programlisting></informalexample> -- -- When the stipple changes or underlines with different stipples might -- be joined together. Pango automatically calls this for changes to -- colors. (See rendererSetColor) -- -- Since: 1.8 rendererPartChanged :: (HasCallStack, MonadIO m, IsRenderer a) => a -> RenderPart -> m () -- | Sets the alpha for part of the rendering. Note that the alpha may only -- be used if a color is specified for part as well. -- -- Since: 1.38 rendererSetAlpha :: (HasCallStack, MonadIO m, IsRenderer a) => a -> RenderPart -> Word16 -> m () -- | Sets the color for part of the rendering. Also see -- rendererSetAlpha. -- -- Since: 1.8 rendererSetColor :: (HasCallStack, MonadIO m, IsRenderer a) => a -> RenderPart -> Maybe Color -> m () -- | Sets the transformation matrix that will be applied when rendering. -- -- Since: 1.8 rendererSetMatrix :: (HasCallStack, MonadIO m, IsRenderer a) => a -> Maybe Matrix -> m () instance (Data.GI.Base.BasicTypes.GObject o, Data.GI.Base.Overloading.IsDescendantOf GI.Pango.Objects.Renderer.Renderer o) => GI.Pango.Objects.Renderer.IsRenderer o instance Data.GI.Base.BasicTypes.GObject GI.Pango.Objects.Renderer.Renderer instance Data.GI.Base.Overloading.HasParentTypes GI.Pango.Objects.Renderer.Renderer -- | The Context structure stores global information used to control -- the itemization process. module GI.Pango.Objects.Context -- | Memory-managed wrapper type. newtype Context Context :: ManagedPtr Context -> Context -- | Type class for types which can be safely cast to Context, for -- instance with toContext. class (GObject o, IsDescendantOf Context o) => IsContext o -- | Cast to Context, for types for which this is known to be safe. -- For general casts, use castTo. toContext :: (MonadIO m, IsContext o) => o -> m Context -- | A convenience alias for Nothing :: Maybe Context. noContext :: Maybe Context -- | Forces a change in the context, which will cause any Layout -- using this context to re-layout. -- -- This function is only useful when implementing a new backend for -- Pango, something applications won't do. Backends should call this -- function if they have attached extra data to the context and such data -- is changed. -- -- Since: 1.32.4 contextChanged :: (HasCallStack, MonadIO m, IsContext a) => a -> m () -- | Retrieves the base direction for the context. See -- contextSetBaseDir. contextGetBaseDir :: (HasCallStack, MonadIO m, IsContext a) => a -> m Direction -- | Retrieves the base gravity for the context. See -- contextSetBaseGravity. -- -- Since: 1.16 contextGetBaseGravity :: (HasCallStack, MonadIO m, IsContext a) => a -> m Gravity -- | Retrieve the default font description for the context. contextGetFontDescription :: (HasCallStack, MonadIO m, IsContext a) => a -> m FontDescription -- | Gets the FontMap used to look up fonts for this context. -- -- Since: 1.6 contextGetFontMap :: (HasCallStack, MonadIO m, IsContext a) => a -> m FontMap -- | Retrieves the gravity for the context. This is similar to -- contextGetBaseGravity, except for when the base gravity is -- GravityAuto for which gravityGetForMatrix is used to -- return the gravity from the current context matrix. -- -- Since: 1.16 contextGetGravity :: (HasCallStack, MonadIO m, IsContext a) => a -> m Gravity -- | Retrieves the gravity hint for the context. See -- contextSetGravityHint for details. -- -- Since: 1.16 contextGetGravityHint :: (HasCallStack, MonadIO m, IsContext a) => a -> m GravityHint -- | Retrieves the global language tag for the context. contextGetLanguage :: (HasCallStack, MonadIO m, IsContext a) => a -> m Language -- | Gets the transformation matrix that will be applied when rendering -- with this context. See contextSetMatrix. -- -- Since: 1.6 contextGetMatrix :: (HasCallStack, MonadIO m, IsContext a) => a -> m (Maybe Matrix) -- | Get overall metric information for a particular font description. -- Since the metrics may be substantially different for different -- scripts, a language tag can be provided to indicate that the metrics -- should be retrieved that correspond to the script(s) used by that -- language. -- -- The FontDescription is interpreted in the same way as by -- itemize, and the family name may be a comma separated list of -- figures. If characters from multiple of these families would be used -- to render the string, then the returned fonts would be a composite of -- the metrics for the fonts loaded for the individual families. contextGetMetrics :: (HasCallStack, MonadIO m, IsContext a) => a -> Maybe FontDescription -> Maybe Language -> m FontMetrics -- | Returns the current serial number of context. The -- serial number is initialized to an small number larger than zero when -- a new context is created and is increased whenever the context is -- changed using any of the setter functions, or the FontMap it -- uses to find fonts has changed. The serial may wrap, but will never -- have the value 0. Since it can wrap, never compare it with "less -- than", always use "not equals". -- -- This can be used to automatically detect changes to a Context, -- and is only useful when implementing objects that need update when -- their Context changes, like Layout. -- -- Since: 1.32.4 contextGetSerial :: (HasCallStack, MonadIO m, IsContext a) => a -> m Word32 -- | List all families for a context. contextListFamilies :: (HasCallStack, MonadIO m, IsContext a) => a -> m [FontFamily] -- | Loads the font in one of the fontmaps in the context that is the -- closest match for desc. contextLoadFont :: (HasCallStack, MonadIO m, IsContext a) => a -> FontDescription -> m (Maybe Font) -- | Load a set of fonts in the context that can be used to render a font -- matching desc. contextLoadFontset :: (HasCallStack, MonadIO m, IsContext a) => a -> FontDescription -> Language -> m (Maybe Fontset) -- | Creates a new Context initialized to default values. -- -- This function is not particularly useful as it should always be -- followed by a contextSetFontMap call, and the function -- fontMapCreateContext does these two steps together and hence -- users are recommended to use that. -- -- If you are using Pango as part of a higher-level system, that system -- may have it's own way of create a Context. For instance, the -- GTK+ toolkit has, among others, -- gdk_pango_context_get_for_screen(), and -- gtk_widget_get_pango_context(). Use those instead. contextNew :: (HasCallStack, MonadIO m) => m Context -- | Sets the base direction for the context. -- -- The base direction is used in applying the Unicode bidirectional -- algorithm; if the direction is DirectionLtr or -- DirectionRtl, then the value will be used as the paragraph -- direction in the Unicode bidirectional algorithm. A value of -- DirectionWeakLtr or DirectionWeakRtl is used only for -- paragraphs that do not contain any strong characters themselves. contextSetBaseDir :: (HasCallStack, MonadIO m, IsContext a) => a -> Direction -> m () -- | Sets the base gravity for the context. -- -- The base gravity is used in laying vertical text out. -- -- Since: 1.16 contextSetBaseGravity :: (HasCallStack, MonadIO m, IsContext a) => a -> Gravity -> m () -- | Set the default font description for the context contextSetFontDescription :: (HasCallStack, MonadIO m, IsContext a) => a -> FontDescription -> m () -- | Sets the font map to be searched when fonts are looked-up in this -- context. This is only for internal use by Pango backends, a -- Context obtained via one of the recommended methods should -- already have a suitable font map. contextSetFontMap :: (HasCallStack, MonadIO m, IsContext a, IsFontMap b) => a -> b -> m () -- | Sets the gravity hint for the context. -- -- The gravity hint is used in laying vertical text out, and is only -- relevant if gravity of the context as returned by -- contextGetGravity is set GravityEast or -- GravityWest. -- -- Since: 1.16 contextSetGravityHint :: (HasCallStack, MonadIO m, IsContext a) => a -> GravityHint -> m () -- | Sets the global language tag for the context. The default language for -- the locale of the running process can be found using -- languageGetDefault. contextSetLanguage :: (HasCallStack, MonadIO m, IsContext a) => a -> Language -> m () -- | Sets the transformation matrix that will be applied when rendering -- with this context. Note that reported metrics are in the user space -- coordinates before the application of the matrix, not device-space -- coordinates after the application of the matrix. So, they don't scale -- with the matrix, though they may change slightly for different -- matrices, depending on how the text is fit to the pixel grid. -- -- Since: 1.6 contextSetMatrix :: (HasCallStack, MonadIO m, IsContext a) => a -> Maybe Matrix -> m () instance (Data.GI.Base.BasicTypes.GObject o, Data.GI.Base.Overloading.IsDescendantOf GI.Pango.Objects.Context.Context o) => GI.Pango.Objects.Context.IsContext o instance Data.GI.Base.BasicTypes.GObject GI.Pango.Objects.Context.Context instance Data.GI.Base.Overloading.HasParentTypes GI.Pango.Objects.Context.Context -- | A structure specifying a transformation between user-space coordinates -- and device coordinates. The transformation is given by -- -- <programlisting> x_device = x_user * matrix->xx + y_user * -- matrix->xy + matrix->x0; y_device = x_user * matrix->yx + -- y_user * matrix->yy + matrix->y0; </programlisting> -- -- Since: 1.6 module GI.Pango.Structs.Matrix -- | Memory-managed wrapper type. newtype Matrix Matrix :: ManagedPtr Matrix -> Matrix -- | Construct a Matrix struct initialized to zero. newZeroMatrix :: MonadIO m => m Matrix -- | A convenience alias for Nothing :: Maybe Matrix. noMatrix :: Maybe Matrix -- | Changes the transformation represented by matrix to be -- the transformation given by first applying transformation given by -- newMatrix then applying the original transformation. -- -- Since: 1.6 matrixConcat :: (HasCallStack, MonadIO m) => Matrix -> Matrix -> m () -- | Copies a Matrix. -- -- Since: 1.6 matrixCopy :: (HasCallStack, MonadIO m) => Matrix -> m (Maybe Matrix) -- | Free a Matrix created with matrixCopy. -- -- Since: 1.6 matrixFree :: (HasCallStack, MonadIO m) => Matrix -> m () -- | Returns the scale factor of a matrix on the height of the font. That -- is, the scale factor in the direction perpendicular to the vector that -- the X coordinate is mapped to. If the scale in the X coordinate is -- needed as well, use matrixGetFontScaleFactors. -- -- Since: 1.12 matrixGetFontScaleFactor :: (HasCallStack, MonadIO m) => Matrix -> m Double -- | Calculates the scale factor of a matrix on the width and height of the -- font. That is, xscale is the scale factor in the -- direction of the X coordinate, and yscale is the scale -- factor in the direction perpendicular to the vector that the X -- coordinate is mapped to. -- -- Note that output numbers will always be non-negative. -- -- Since: 1.38 matrixGetFontScaleFactors :: (HasCallStack, MonadIO m) => Matrix -> m (Double, Double) -- | Changes the transformation represented by matrix to be -- the transformation given by first rotating by degrees -- degrees counter-clockwise then applying the original transformation. -- -- Since: 1.6 matrixRotate :: (HasCallStack, MonadIO m) => Matrix -> Double -> m () -- | Changes the transformation represented by matrix to be -- the transformation given by first scaling by sx in the -- X direction and sy in the Y direction then applying -- the original transformation. -- -- Since: 1.6 matrixScale :: (HasCallStack, MonadIO m) => Matrix -> Double -> Double -> m () -- | Transforms the distance vector (dx,dy) -- by matrix. This is similar to -- matrixTransformPoint except that the translation components of -- the transformation are ignored. The calculation of the returned vector -- is as follows: -- -- <programlisting> dx2 = dx1 * xx + dy1 * xy; dy2 = dx1 * yx + dy1 -- * yy; </programlisting> -- -- Affine transformations are position invariant, so the same vector -- always transforms to the same vector. If -- (x1,y1) transforms to -- (x2,y2) then -- (x1+dx1,y1+dy1) -- will transform to -- (x1+dx2,y1+dy2) -- for all values of x1 and x2. -- -- Since: 1.16 matrixTransformDistance :: (HasCallStack, MonadIO m) => Matrix -> Double -> Double -> m (Double, Double) -- | First transforms the rect using -- matrix, then calculates the bounding box of the -- transformed rectangle. The rectangle should be in device units -- (pixels). -- -- This function is useful for example when you want to draw a rotated -- pangoLayout to an image buffer, and want to know how -- large the image should be and how much you should shift the layout -- when rendering. -- -- For better accuracy, you should use matrixTransformRectangle on -- original rectangle in Pango units and convert to pixels afterward -- using 'GI.Pango.Functions.extentsToPixels'\'s first argument. -- -- Since: 1.16 matrixTransformPixelRectangle :: (HasCallStack, MonadIO m) => Matrix -> Maybe Rectangle -> m () -- | Transforms the point (x, y) by -- matrix. -- -- Since: 1.16 matrixTransformPoint :: (HasCallStack, MonadIO m) => Matrix -> Double -> Double -> m (Double, Double) -- | Changes the transformation represented by matrix to be -- the transformation given by first translating by (tx, -- ty) then applying the original transformation. -- -- Since: 1.6 matrixTranslate :: (HasCallStack, MonadIO m) => Matrix -> Double -> Double -> m () -- | Get the value of the “x0” field. When overloading is -- enabled, this is equivalent to -- --
--   get matrix #x0
--   
getMatrixX0 :: MonadIO m => Matrix -> m Double -- | Set the value of the “x0” field. When overloading is -- enabled, this is equivalent to -- --
--   set matrix [ #x0 := value ]
--   
setMatrixX0 :: MonadIO m => Matrix -> Double -> m () -- | Get the value of the “xx” field. When overloading is -- enabled, this is equivalent to -- --
--   get matrix #xx
--   
getMatrixXx :: MonadIO m => Matrix -> m Double -- | Set the value of the “xx” field. When overloading is -- enabled, this is equivalent to -- --
--   set matrix [ #xx := value ]
--   
setMatrixXx :: MonadIO m => Matrix -> Double -> m () -- | Get the value of the “xy” field. When overloading is -- enabled, this is equivalent to -- --
--   get matrix #xy
--   
getMatrixXy :: MonadIO m => Matrix -> m Double -- | Set the value of the “xy” field. When overloading is -- enabled, this is equivalent to -- --
--   set matrix [ #xy := value ]
--   
setMatrixXy :: MonadIO m => Matrix -> Double -> m () -- | Get the value of the “y0” field. When overloading is -- enabled, this is equivalent to -- --
--   get matrix #y0
--   
getMatrixY0 :: MonadIO m => Matrix -> m Double -- | Set the value of the “y0” field. When overloading is -- enabled, this is equivalent to -- --
--   set matrix [ #y0 := value ]
--   
setMatrixY0 :: MonadIO m => Matrix -> Double -> m () -- | Get the value of the “yx” field. When overloading is -- enabled, this is equivalent to -- --
--   get matrix #yx
--   
getMatrixYx :: MonadIO m => Matrix -> m Double -- | Set the value of the “yx” field. When overloading is -- enabled, this is equivalent to -- --
--   set matrix [ #yx := value ]
--   
setMatrixYx :: MonadIO m => Matrix -> Double -> m () -- | Get the value of the “yy” field. When overloading is -- enabled, this is equivalent to -- --
--   get matrix #yy
--   
getMatrixYy :: MonadIO m => Matrix -> m Double -- | Set the value of the “yy” field. When overloading is -- enabled, this is equivalent to -- --
--   set matrix [ #yy := value ]
--   
setMatrixYy :: MonadIO m => Matrix -> Double -> m () instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.Matrix.Matrix instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.Matrix.Matrix tag -- | The LayoutLine structure represents one of the lines resulting -- from laying out a paragraph via Layout. LayoutLine -- structures are obtained by calling layoutGetLine and are only -- valid until the text, attributes, or settings of the parent -- Layout are modified. -- -- Routines for rendering PangoLayout objects are provided in code -- specific to each rendering system. module GI.Pango.Structs.LayoutLine -- | Memory-managed wrapper type. newtype LayoutLine LayoutLine :: ManagedPtr LayoutLine -> LayoutLine -- | Construct a LayoutLine struct initialized to zero. newZeroLayoutLine :: MonadIO m => m LayoutLine -- | A convenience alias for Nothing :: Maybe -- LayoutLine. noLayoutLine :: Maybe LayoutLine -- | Computes the logical and ink extents of a layout line. See -- fontGetGlyphExtents for details about the interpretation of the -- rectangles. layoutLineGetExtents :: (HasCallStack, MonadIO m) => LayoutLine -> m (Rectangle, Rectangle) -- | Computes the logical and ink extents of layoutLine in -- device units. This function just calls layoutLineGetExtents -- followed by two extentsToPixels calls, rounding -- inkRect and logicalRect such that the -- rounded rectangles fully contain the unrounded one (that is, passes -- them as first argument to extentsToPixels). layoutLineGetPixelExtents :: (HasCallStack, MonadIO m) => LayoutLine -> m (Rectangle, Rectangle) -- | Gets a list of visual ranges corresponding to a given logical range. -- This list is not necessarily minimal - there may be consecutive ranges -- which are adjacent. The ranges will be sorted from left to right. The -- ranges are with respect to the left edge of the entire layout, not -- with respect to the line. layoutLineGetXRanges :: (HasCallStack, MonadIO m) => LayoutLine -> Int32 -> Int32 -> m [Int32] -- | Converts an index within a line to a X position. layoutLineIndexToX :: (HasCallStack, MonadIO m) => LayoutLine -> Int32 -> Bool -> m Int32 -- | Increase the reference count of a LayoutLine by one. -- -- Since: 1.10 layoutLineRef :: (HasCallStack, MonadIO m) => LayoutLine -> m LayoutLine -- | Decrease the reference count of a LayoutLine by one. If the -- result is zero, the line and all associated memory will be freed. layoutLineUnref :: (HasCallStack, MonadIO m) => LayoutLine -> m () -- | Converts from x offset to the byte index of the corresponding -- character within the text of the layout. If xPos is -- outside the line, index_ and trailing -- will point to the very first or very last position in the line. This -- determination is based on the resolved direction of the paragraph; for -- example, if the resolved direction is right-to-left, then an X -- position to the right of the line (after it) results in 0 being stored -- in index_ and trailing. An X position -- to the left of the line results in index_ pointing to -- the (logical) last grapheme in the line and trailing -- being set to the number of characters in that grapheme. The reverse is -- true for a left-to-right line. layoutLineXToIndex :: (HasCallStack, MonadIO m) => LayoutLine -> Int32 -> m (Bool, Int32, Int32) -- | Get the value of the “is_paragraph_start” field. When -- overloading is enabled, this is equivalent to -- --
--   get layoutLine #isParagraphStart
--   
getLayoutLineIsParagraphStart :: MonadIO m => LayoutLine -> m Word32 -- | Set the value of the “is_paragraph_start” field. When -- overloading is enabled, this is equivalent to -- --
--   set layoutLine [ #isParagraphStart := value ]
--   
setLayoutLineIsParagraphStart :: MonadIO m => LayoutLine -> Word32 -> m () -- | Set the value of the “layout” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #layout
--   
clearLayoutLineLayout :: MonadIO m => LayoutLine -> m () -- | Get the value of the “layout” field. When overloading -- is enabled, this is equivalent to -- --
--   get layoutLine #layout
--   
getLayoutLineLayout :: MonadIO m => LayoutLine -> m (Maybe Layout) -- | Set the value of the “layout” field. When overloading -- is enabled, this is equivalent to -- --
--   set layoutLine [ #layout := value ]
--   
setLayoutLineLayout :: MonadIO m => LayoutLine -> Ptr Layout -> m () -- | Get the value of the “length” field. When overloading -- is enabled, this is equivalent to -- --
--   get layoutLine #length
--   
getLayoutLineLength :: MonadIO m => LayoutLine -> m Int32 -- | Set the value of the “length” field. When overloading -- is enabled, this is equivalent to -- --
--   set layoutLine [ #length := value ]
--   
setLayoutLineLength :: MonadIO m => LayoutLine -> Int32 -> m () -- | Get the value of the “resolved_dir” field. When -- overloading is enabled, this is equivalent to -- --
--   get layoutLine #resolvedDir
--   
getLayoutLineResolvedDir :: MonadIO m => LayoutLine -> m Word32 -- | Set the value of the “resolved_dir” field. When -- overloading is enabled, this is equivalent to -- --
--   set layoutLine [ #resolvedDir := value ]
--   
setLayoutLineResolvedDir :: MonadIO m => LayoutLine -> Word32 -> m () -- | Set the value of the “runs” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #runs
--   
clearLayoutLineRuns :: MonadIO m => LayoutLine -> m () -- | Get the value of the “runs” field. When overloading is -- enabled, this is equivalent to -- --
--   get layoutLine #runs
--   
getLayoutLineRuns :: MonadIO m => LayoutLine -> m [GlyphItem] -- | Set the value of the “runs” field. When overloading is -- enabled, this is equivalent to -- --
--   set layoutLine [ #runs := value ]
--   
setLayoutLineRuns :: MonadIO m => LayoutLine -> Ptr (GSList (Ptr GlyphItem)) -> m () -- | Get the value of the “start_index” field. When -- overloading is enabled, this is equivalent to -- --
--   get layoutLine #startIndex
--   
getLayoutLineStartIndex :: MonadIO m => LayoutLine -> m Int32 -- | Set the value of the “start_index” field. When -- overloading is enabled, this is equivalent to -- --
--   set layoutLine [ #startIndex := value ]
--   
setLayoutLineStartIndex :: MonadIO m => LayoutLine -> Int32 -> m () instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.LayoutLine.LayoutLine instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.LayoutLine.LayoutLine tag -- | A LayoutIter structure can be used to iterate over the visual -- extents of a Layout. -- -- The LayoutIter structure is opaque, and has no user-visible -- fields. module GI.Pango.Structs.LayoutIter -- | Memory-managed wrapper type. newtype LayoutIter LayoutIter :: ManagedPtr LayoutIter -> LayoutIter -- | A convenience alias for Nothing :: Maybe -- LayoutIter. noLayoutIter :: Maybe LayoutIter -- | Determines whether iter is on the last line of the -- layout. layoutIterAtLastLine :: (HasCallStack, MonadIO m) => LayoutIter -> m Bool -- | Copies a LayoutIter. -- -- Since: 1.20 layoutIterCopy :: (HasCallStack, MonadIO m) => LayoutIter -> m (Maybe LayoutIter) -- | Frees an iterator that's no longer in use. layoutIterFree :: (HasCallStack, MonadIO m) => LayoutIter -> m () -- | Gets the Y position of the current line's baseline, in layout -- coordinates (origin at top left of the entire layout). layoutIterGetBaseline :: (HasCallStack, MonadIO m) => LayoutIter -> m Int32 -- | Gets the extents of the current character, in layout coordinates -- (origin is the top left of the entire layout). Only logical extents -- can sensibly be obtained for characters; ink extents make sense only -- down to the level of clusters. layoutIterGetCharExtents :: (HasCallStack, MonadIO m) => LayoutIter -> m Rectangle -- | Gets the extents of the current cluster, in layout coordinates (origin -- is the top left of the entire layout). layoutIterGetClusterExtents :: (HasCallStack, MonadIO m) => LayoutIter -> m (Rectangle, Rectangle) -- | Gets the current byte index. Note that iterating forward by char moves -- in visual order, not logical order, so indexes may not be sequential. -- Also, the index may be equal to the length of the text in the layout, -- if on the Nothing run (see layoutIterGetRun). layoutIterGetIndex :: (HasCallStack, MonadIO m) => LayoutIter -> m Int32 -- | Gets the layout associated with a LayoutIter. -- -- Since: 1.20 layoutIterGetLayout :: (HasCallStack, MonadIO m) => LayoutIter -> m Layout -- | Obtains the extents of the Layout being iterated over. -- inkRect or logicalRect can be -- Nothing if you aren't interested in them. layoutIterGetLayoutExtents :: (HasCallStack, MonadIO m) => LayoutIter -> m (Rectangle, Rectangle) -- | Gets the current line. -- -- Use the faster layoutIterGetLineReadonly if you do not plan to -- modify the contents of the line (glyphs, glyph widths, etc.). layoutIterGetLine :: (HasCallStack, MonadIO m) => LayoutIter -> m LayoutLine -- | Obtains the extents of the current line. inkRect or -- logicalRect can be Nothing if you aren't -- interested in them. Extents are in layout coordinates (origin is the -- top-left corner of the entire Layout). Thus the extents -- returned by this function will be the same width/height but not at the -- same x/y as the extents returned from layoutLineGetExtents. layoutIterGetLineExtents :: (HasCallStack, MonadIO m) => LayoutIter -> m (Rectangle, Rectangle) -- | Gets the current line for read-only access. -- -- This is a faster alternative to layoutIterGetLine, but the user -- is not expected to modify the contents of the line (glyphs, glyph -- widths, etc.). -- -- Since: 1.16 layoutIterGetLineReadonly :: (HasCallStack, MonadIO m) => LayoutIter -> m LayoutLine -- | Divides the vertical space in the Layout being iterated over -- between the lines in the layout, and returns the space belonging to -- the current line. A line's range includes the line's logical extents, -- plus half of the spacing above and below the line, if -- layoutSetSpacing has been called to set layout spacing. The Y -- positions are in layout coordinates (origin at top left of the entire -- layout). layoutIterGetLineYrange :: (HasCallStack, MonadIO m) => LayoutIter -> m (Int32, Int32) -- | Gets the current run. When iterating by run, at the end of each line, -- there's a position with a Nothing run, so this function can -- return Nothing. The Nothing run at the end of each line -- ensures that all lines have at least one run, even lines consisting of -- only a newline. -- -- Use the faster layoutIterGetRunReadonly if you do not plan to -- modify the contents of the run (glyphs, glyph widths, etc.). layoutIterGetRun :: (HasCallStack, MonadIO m) => LayoutIter -> m (Maybe GlyphItem) -- | Gets the extents of the current run in layout coordinates (origin is -- the top left of the entire layout). layoutIterGetRunExtents :: (HasCallStack, MonadIO m) => LayoutIter -> m (Rectangle, Rectangle) -- | Gets the current run. When iterating by run, at the end of each line, -- there's a position with a Nothing run, so this function can -- return Nothing. The Nothing run at the end of each line -- ensures that all lines have at least one run, even lines consisting of -- only a newline. -- -- This is a faster alternative to layoutIterGetRun, but the user -- is not expected to modify the contents of the run (glyphs, glyph -- widths, etc.). -- -- Since: 1.16 layoutIterGetRunReadonly :: (HasCallStack, MonadIO m) => LayoutIter -> m (Maybe GlyphItem) -- | Moves iter forward to the next character in visual -- order. If iter was already at the end of the layout, -- returns False. layoutIterNextChar :: (HasCallStack, MonadIO m) => LayoutIter -> m Bool -- | Moves iter forward to the next cluster in visual -- order. If iter was already at the end of the layout, -- returns False. layoutIterNextCluster :: (HasCallStack, MonadIO m) => LayoutIter -> m Bool -- | Moves iter forward to the start of the next line. If -- iter is already on the last line, returns -- False. layoutIterNextLine :: (HasCallStack, MonadIO m) => LayoutIter -> m Bool -- | Moves iter forward to the next run in visual order. If -- iter was already at the end of the layout, returns -- False. layoutIterNextRun :: (HasCallStack, MonadIO m) => LayoutIter -> m Bool instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.LayoutIter.LayoutIter -- | The GlyphString structure is used to store strings of glyphs -- with geometry and visual attribute information. The storage for the -- glyph information is owned by the structure which simplifies memory -- management. module GI.Pango.Structs.GlyphString -- | Memory-managed wrapper type. newtype GlyphString GlyphString :: ManagedPtr GlyphString -> GlyphString -- | Construct a GlyphString struct initialized to zero. newZeroGlyphString :: MonadIO m => m GlyphString -- | A convenience alias for Nothing :: Maybe -- GlyphString. noGlyphString :: Maybe GlyphString -- | Copy a glyph string and associated storage. glyphStringCopy :: (HasCallStack, MonadIO m) => GlyphString -> m (Maybe GlyphString) -- | Compute the logical and ink extents of a glyph string. See the -- documentation for fontGetGlyphExtents for details about the -- interpretation of the rectangles. glyphStringExtents :: (HasCallStack, MonadIO m, IsFont a) => GlyphString -> a -> m (Rectangle, Rectangle) -- | Computes the extents of a sub-portion of a glyph string. The extents -- are relative to the start of the glyph string range (the origin of -- their coordinate system is at the start of the range, not at the start -- of the entire glyph string). glyphStringExtentsRange :: (HasCallStack, MonadIO m, IsFont a) => GlyphString -> Int32 -> Int32 -> a -> m (Rectangle, Rectangle) -- | Free a glyph string and associated storage. glyphStringFree :: (HasCallStack, MonadIO m) => GlyphString -> m () -- | Given a GlyphString resulting from shape and the -- corresponding text, determine the screen width corresponding to each -- character. When multiple characters compose a single cluster, the -- width of the entire cluster is divided equally among the characters. -- -- See also glyphItemGetLogicalWidths. glyphStringGetLogicalWidths :: (HasCallStack, MonadIO m) => GlyphString -> Text -> Int32 -> Int32 -> [Int32] -> m () -- | Computes the logical width of the glyph string as can also be computed -- using glyphStringExtents. However, since this only computes the -- width, it's much faster. This is in fact only a convenience function -- that computes the sum of geometry.width for each glyph in the -- glyphs. -- -- Since: 1.14 glyphStringGetWidth :: (HasCallStack, MonadIO m) => GlyphString -> m Int32 -- | Converts from character position to x position. (X position is -- measured from the left edge of the run). Character positions are -- computed by dividing up each cluster into equal portions. glyphStringIndexToX :: (HasCallStack, MonadIO m) => GlyphString -> Text -> Int32 -> Analysis -> Int32 -> Bool -> m Int32 -- | Create a new GlyphString. glyphStringNew :: (HasCallStack, MonadIO m) => m GlyphString -- | Resize a glyph string to the given length. glyphStringSetSize :: (HasCallStack, MonadIO m) => GlyphString -> Int32 -> m () -- | Convert from x offset to character position. Character positions are -- computed by dividing up each cluster into equal portions. In scripts -- where positioning within a cluster is not allowed (such as Thai), the -- returned value may not be a valid cursor position; the caller must -- combine the result with the logical attributes for the text to compute -- the valid cursor position. glyphStringXToIndex :: (HasCallStack, MonadIO m) => GlyphString -> Text -> Int32 -> Analysis -> Int32 -> m (Int32, Int32) -- | Get the value of the “log_clusters” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphString #logClusters
--   
getGlyphStringLogClusters :: MonadIO m => GlyphString -> m Int32 -- | Set the value of the “log_clusters” field. When -- overloading is enabled, this is equivalent to -- --
--   set glyphString [ #logClusters := value ]
--   
setGlyphStringLogClusters :: MonadIO m => GlyphString -> Int32 -> m () -- | Get the value of the “num_glyphs” field. When -- overloading is enabled, this is equivalent to -- --
--   get glyphString #numGlyphs
--   
getGlyphStringNumGlyphs :: MonadIO m => GlyphString -> m Int32 -- | Set the value of the “num_glyphs” field. When -- overloading is enabled, this is equivalent to -- --
--   set glyphString [ #numGlyphs := value ]
--   
setGlyphStringNumGlyphs :: MonadIO m => GlyphString -> Int32 -> m () instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.GlyphString.GlyphString instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.GlyphString.GlyphString tag -- | The AttrShape structure is used to represent attributes which -- impose shape restrictions. module GI.Pango.Structs.AttrShape -- | Memory-managed wrapper type. newtype AttrShape AttrShape :: ManagedPtr AttrShape -> AttrShape -- | Construct a AttrShape struct initialized to zero. newZeroAttrShape :: MonadIO m => m AttrShape -- | A convenience alias for Nothing :: Maybe -- AttrShape. noAttrShape :: Maybe AttrShape -- | Create a new shape attribute. A shape is used to impose a particular -- ink and logical rectangle on the result of shaping a particular glyph. -- This might be used, for instance, for embedding a picture or a widget -- inside a Layout. attrShapeNew :: (HasCallStack, MonadIO m) => Rectangle -> Rectangle -> m Attribute -- | Get the value of the “attr” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrShape #attr
--   
getAttrShapeAttr :: MonadIO m => AttrShape -> m Attribute -- | Set the value of the “copy_func” field to Nothing. -- When overloading is enabled, this is equivalent to -- --
--   clear #copyFunc
--   
clearAttrShapeCopyFunc :: MonadIO m => AttrShape -> m () -- | Get the value of the “copy_func” field. When -- overloading is enabled, this is equivalent to -- --
--   get attrShape #copyFunc
--   
getAttrShapeCopyFunc :: MonadIO m => AttrShape -> m (Maybe AttrDataCopyFunc_WithClosures) -- | Set the value of the “copy_func” field. When -- overloading is enabled, this is equivalent to -- --
--   set attrShape [ #copyFunc := value ]
--   
setAttrShapeCopyFunc :: MonadIO m => AttrShape -> FunPtr C_AttrDataCopyFunc -> m () -- | Set the value of the “data” field to Nothing. When -- overloading is enabled, this is equivalent to -- --
--   clear #data
--   
clearAttrShapeData :: MonadIO m => AttrShape -> m () -- | Get the value of the “data” field. When overloading is -- enabled, this is equivalent to -- --
--   get attrShape #data
--   
getAttrShapeData :: MonadIO m => AttrShape -> m (Ptr ()) -- | Set the value of the “data” field. When overloading is -- enabled, this is equivalent to -- --
--   set attrShape [ #data := value ]
--   
setAttrShapeData :: MonadIO m => AttrShape -> Ptr () -> m () -- | Set the value of the “destroy_func” field to Nothing. -- When overloading is enabled, this is equivalent to -- --
--   clear #destroyFunc
--   
clearAttrShapeDestroyFunc :: MonadIO m => AttrShape -> m () -- | Get the value of the “destroy_func” field. When -- overloading is enabled, this is equivalent to -- --
--   get attrShape #destroyFunc
--   
getAttrShapeDestroyFunc :: MonadIO m => AttrShape -> m (Maybe DestroyNotify) -- | Set the value of the “destroy_func” field. When -- overloading is enabled, this is equivalent to -- --
--   set attrShape [ #destroyFunc := value ]
--   
setAttrShapeDestroyFunc :: MonadIO m => AttrShape -> FunPtr C_DestroyNotify -> m () -- | Get the value of the “ink_rect” field. When -- overloading is enabled, this is equivalent to -- --
--   get attrShape #inkRect
--   
getAttrShapeInkRect :: MonadIO m => AttrShape -> m Rectangle -- | Get the value of the “logical_rect” field. When -- overloading is enabled, this is equivalent to -- --
--   get attrShape #logicalRect
--   
getAttrShapeLogicalRect :: MonadIO m => AttrShape -> m Rectangle instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.AttrShape.AttrShape instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.AttrShape.AttrShape tag -- | The Font structure is used to represent a font in a -- rendering-system-independent matter. To create an implementation of a -- Font, the rendering-system specific code should allocate a -- larger structure that contains a nested Font, fill in the -- <structfield>klass</structfield> member of the nested -- Font with a pointer to a appropriate FontClass, then -- call pango_font_init() on the structure. -- -- The Font structure contains one member which the implementation -- fills in. module GI.Pango.Objects.Font -- | Memory-managed wrapper type. newtype Font Font :: ManagedPtr Font -> Font -- | Type class for types which can be safely cast to Font, for -- instance with toFont. class (GObject o, IsDescendantOf Font o) => IsFont o -- | Cast to Font, for types for which this is known to be safe. For -- general casts, use castTo. toFont :: (MonadIO m, IsFont o) => o -> m Font -- | A convenience alias for Nothing :: Maybe Font. noFont :: Maybe Font -- | Returns a description of the font, with font size set in points. Use -- fontDescribeWithAbsoluteSize if you want the font size in -- device units. fontDescribe :: (HasCallStack, MonadIO m, IsFont a) => a -> m FontDescription -- | Returns a description of the font, with absolute font size set (in -- device units). Use fontDescribe if you want the font size in -- points. -- -- Since: 1.14 fontDescribeWithAbsoluteSize :: (HasCallStack, MonadIO m, IsFont a) => a -> m FontDescription -- | Frees an array of font descriptions. fontDescriptionsFree :: (HasCallStack, MonadIO m) => Maybe [FontDescription] -> m () -- | Finds the best matching shaper for a font for a particular language -- tag and character point. fontFindShaper :: (HasCallStack, MonadIO m, IsFont a) => a -> Language -> Word32 -> m EngineShape -- | Gets the font map for which the font was created. -- -- Note that the font maintains a <firstterm>weak</firstterm> -- reference to the font map, so if all references to font map are -- dropped, the font map will be finalized even if there are fonts -- created with the font map that are still alive. In that case this -- function will return Nothing. It is the responsibility of the -- user to ensure that the font map is kept alive. In most uses this is -- not an issue as a Context holds a reference to the font map. -- -- Since: 1.10 fontGetFontMap :: (HasCallStack, MonadIO m, IsFont a) => a -> m (Maybe FontMap) -- | Gets the logical and ink extents of a glyph within a font. The -- coordinate system for each rectangle has its origin at the base line -- and horizontal origin of the character with increasing coordinates -- extending to the right and down. The macros -- PANGO_ASCENT(), PANGO_DESCENT(), -- PANGO_LBEARING(), and PANGO_RBEARING() -- can be used to convert from the extents rectangle to more traditional -- font metrics. The units of the rectangles are in 1/PANGO_SCALE of a -- device unit. -- -- If font is Nothing, this function gracefully -- sets some sane values in the output variables and returns. fontGetGlyphExtents :: (HasCallStack, MonadIO m, IsFont a) => a -> Word32 -> m (Rectangle, Rectangle) -- | Gets overall metric information for a font. Since the metrics may be -- substantially different for different scripts, a language tag can be -- provided to indicate that the metrics should be retrieved that -- correspond to the script(s) used by that language. -- -- If font is Nothing, this function gracefully -- sets some sane values in the output variables and returns. fontGetMetrics :: (HasCallStack, MonadIO m, IsFont a) => a -> Maybe Language -> m FontMetrics instance (Data.GI.Base.BasicTypes.GObject o, Data.GI.Base.Overloading.IsDescendantOf GI.Pango.Objects.Font.Font o) => GI.Pango.Objects.Font.IsFont o instance Data.GI.Base.BasicTypes.GObject GI.Pango.Objects.Font.Font instance Data.GI.Base.Overloading.HasParentTypes GI.Pango.Objects.Font.Font module GI.Pango.Functions -- | Create a new background alpha attribute. -- -- Since: 1.38 attrBackgroundAlphaNew :: (HasCallStack, MonadIO m) => Word16 -> m Attribute -- | Create a new background color attribute. attrBackgroundNew :: (HasCallStack, MonadIO m) => Word16 -> Word16 -> Word16 -> m Attribute -- | Create a new font fallback attribute. -- -- If fallback is disabled, characters will only be used from the closest -- matching font on the system. No fallback will be done to other fonts -- on the system that might contain the characters in the text. -- -- Since: 1.4 attrFallbackNew :: (HasCallStack, MonadIO m) => Bool -> m Attribute -- | Create a new font family attribute. attrFamilyNew :: (HasCallStack, MonadIO m) => Text -> m Attribute -- | Create a new foreground alpha attribute. -- -- Since: 1.38 attrForegroundAlphaNew :: (HasCallStack, MonadIO m) => Word16 -> m Attribute -- | Create a new foreground color attribute. attrForegroundNew :: (HasCallStack, MonadIO m) => Word16 -> Word16 -> Word16 -> m Attribute -- | Create a new gravity hint attribute. -- -- Since: 1.16 attrGravityHintNew :: (HasCallStack, MonadIO m) => GravityHint -> m Attribute -- | Create a new gravity attribute. -- -- Since: 1.16 attrGravityNew :: (HasCallStack, MonadIO m) => Gravity -> m Attribute -- | Create a new letter-spacing attribute. -- -- Since: 1.6 attrLetterSpacingNew :: (HasCallStack, MonadIO m) => Int32 -> m Attribute -- | Create a new baseline displacement attribute. attrRiseNew :: (HasCallStack, MonadIO m) => Int32 -> m Attribute -- | Create a new font size scale attribute. The base font for the affected -- text will have its size multiplied by scaleFactor. attrScaleNew :: (HasCallStack, MonadIO m) => Double -> m Attribute -- | Create a new font stretch attribute attrStretchNew :: (HasCallStack, MonadIO m) => Stretch -> m Attribute -- | Create a new strikethrough color attribute. This attribute modifies -- the color of strikethrough lines. If not set, strikethrough lines will -- use the foreground color. -- -- Since: 1.8 attrStrikethroughColorNew :: (HasCallStack, MonadIO m) => Word16 -> Word16 -> Word16 -> m Attribute -- | Create a new strike-through attribute. attrStrikethroughNew :: (HasCallStack, MonadIO m) => Bool -> m Attribute -- | Create a new font slant style attribute. attrStyleNew :: (HasCallStack, MonadIO m) => Style -> m Attribute -- | Create a new underline color attribute. This attribute modifies the -- color of underlines. If not set, underlines will use the foreground -- color. -- -- Since: 1.8 attrUnderlineColorNew :: (HasCallStack, MonadIO m) => Word16 -> Word16 -> Word16 -> m Attribute -- | Create a new underline-style attribute. attrUnderlineNew :: (HasCallStack, MonadIO m) => Underline -> m Attribute -- | Create a new font variant attribute (normal or small caps) attrVariantNew :: (HasCallStack, MonadIO m) => Variant -> m Attribute -- | Create a new font weight attribute. attrWeightNew :: (HasCallStack, MonadIO m) => Weight -> m Attribute -- | Determines possible line, word, and character breaks for a string of -- Unicode text with a single analysis. For most purposes you may want to -- use getLogAttrs. break :: (HasCallStack, MonadIO m) => Text -> Int32 -> Analysis -> [LogAttr] -> m () -- | Do not use. Does not do anything. -- | Deprecated: (Since version 1.38) configKeyGet :: (HasCallStack, MonadIO m) => Text -> m Text -- | Do not use. Does not do anything. -- | Deprecated: (Since version 1.38) configKeyGetSystem :: (HasCallStack, MonadIO m) => Text -> m Text -- | This is the default break algorithm, used if no language engine -- overrides it. Normally you should use break instead. Unlike -- break, analysis can be Nothing, but only -- do that if you know what you're doing. If you need an analysis to pass -- to break, you need to itemize. In most cases however you -- should simply use getLogAttrs. defaultBreak :: (HasCallStack, MonadIO m) => Text -> Int32 -> Maybe Analysis -> LogAttr -> Int32 -> m () -- | Converts extents from Pango units to device units, dividing by the -- SCALE factor and performing rounding. -- -- The inclusive rectangle is converted by flooring the -- x/y coordinates and extending width/height, such that the final -- rectangle completely includes the original rectangle. -- -- The nearest rectangle is converted by rounding the -- coordinates of the rectangle to the nearest device unit (pixel). -- -- The rule to which argument to use is: if you want the resulting -- device-space rectangle to completely contain the original rectangle, -- pass it in as inclusive. If you want two -- touching-but-not-overlapping rectangles stay -- touching-but-not-overlapping after rounding to device units, pass them -- in as nearest. -- -- Since: 1.16 extentsToPixels :: (HasCallStack, MonadIO m) => Maybe Rectangle -> Maybe Rectangle -> m () -- | Searches a string the first character that has a strong direction, -- according to the Unicode bidirectional algorithm. -- -- Since: 1.4 findBaseDir :: (HasCallStack, MonadIO m) => Text -> Int32 -> m Direction -- | Locates a paragraph boundary in text. A boundary is -- caused by delimiter characters, such as a newline, carriage return, -- carriage return-newline pair, or Unicode paragraph separator -- character. The index of the run of delimiters is returned in -- paragraphDelimiterIndex. The index of the start of the -- paragraph (index after all delimiters) is stored in -- nextParagraphStart. -- -- If no delimiters are found, both -- paragraphDelimiterIndex and -- nextParagraphStart are filled with the length of -- text (an index one off the end). findParagraphBoundary :: (HasCallStack, MonadIO m) => Text -> Int32 -> m (Int32, Int32) -- | Returns the name of the "pango" subdirectory of LIBDIR (which is set -- at compile time). -- | Deprecated: (Since version 1.38) getLibSubdirectory :: (HasCallStack, MonadIO m) => m Text -- | Computes a LogAttr for each character in text. -- The logAttrs array must have one LogAttr for -- each position in text; if text -- contains N characters, it has N+1 positions, including the last -- position at the end of the text. text should be an -- entire paragraph; logical attributes can't be computed without context -- (for example you need to see spaces on either side of a word to know -- the word is a word). getLogAttrs :: (HasCallStack, MonadIO m) => Text -> Int32 -> Int32 -> Language -> [LogAttr] -> m () -- | If ch has the Unicode mirrored property and there is -- another Unicode character that typically has a glyph that is the -- mirror image of ch's glyph, puts that character in the -- address pointed to by mirroredCh. -- -- Use unicharGetMirrorChar instead; the docs for that function -- provide full details. getMirrorChar :: (HasCallStack, MonadIO m) => Char -> Char -> m Bool -- | Returns the name of the "pango" subdirectory of SYSCONFDIR (which is -- set at compile time). -- | Deprecated: (Since version 1.38) getSysconfSubdirectory :: (HasCallStack, MonadIO m) => m Text -- | Checks ch to see if it is a character that should not -- be normally rendered on the screen. This includes all Unicode -- characters with "ZERO WIDTH" in their name, as well as -- <firstterm>bidi</firstterm> formatting characters, and a -- few other ones. This is totally different from -- unicharIszerowidth and is at best misnamed. -- -- Since: 1.10 isZeroWidth :: (HasCallStack, MonadIO m) => Char -> m Bool -- | Breaks a piece of text into segments with consistent directional level -- and shaping engine. Each byte of text will be -- contained in exactly one of the items in the returned list; the -- generated list of items will be in logical order (the start offsets of -- the items are ascending). -- -- cachedIter should be an iterator over -- attrs currently positioned at a range before or -- containing startIndex; cachedIter will -- be advanced to the range covering the position just after -- startIndex + length. (i.e. if -- itemizing in a loop, just keep passing in the same -- cachedIter). itemize :: (HasCallStack, MonadIO m, IsContext a) => a -> Text -> Int32 -> Int32 -> AttrList -> Maybe AttrIterator -> m [Item] -- | Like itemize, but the base direction to use when computing -- bidirectional levels (see pango_context_set_base_dir ()), is specified -- explicitly rather than gotten from the Context. -- -- Since: 1.4 itemizeWithBaseDir :: (HasCallStack, MonadIO m, IsContext a) => a -> Direction -> Text -> Int32 -> Int32 -> AttrList -> Maybe AttrIterator -> m [Item] -- | This will return the bidirectional embedding levels of the input -- paragraph as defined by the Unicode Bidirectional Algorithm available -- at: -- -- http://www.unicode.org/reports/tr9/ -- -- If the input base direction is a weak direction, the direction of the -- characters in the text will determine the final resolved direction. -- -- Since: 1.4 log2visGetEmbeddingLevels :: (HasCallStack, MonadIO m) => Text -> Int32 -> Direction -> m Word8 -- | Look up all user defined aliases for the alias -- fontname. The resulting font family names will be -- stored in families, and the number of families in -- nFamilies. -- | Deprecated: (Since version 1.32)This function is not -- thread-safe. lookupAliases :: (HasCallStack, MonadIO m) => Text -> m [Text] -- | After feeding a pango markup parser some data with -- markupParseContextParse, use this function to get the list of -- pango attributes and text out of the markup. This function will not -- free context, use markupParseContextFree to do -- so. -- -- Since: 1.31.0 markupParserFinish :: (HasCallStack, MonadIO m) => MarkupParseContext -> m (AttrList, Text, Char) -- | Parses marked-up text (see <link -- linkend="PangoMarkupFormat">markup format</link>) to create a -- plain-text string and an attribute list. -- -- If accelMarker is nonzero, the given character will -- mark the character following it as an accelerator. For example, -- accelMarker might be an ampersand or underscore. All -- characters marked as an accelerator will receive a UnderlineLow -- attribute, and the first character so marked will be returned in -- accelChar, when calling finish(). Two -- accelMarker characters following each other produce a -- single literal accelMarker character. -- -- To feed markup to the parser, use markupParseContextParse on -- the returned MarkupParseContext. When done with feeding markup -- to the parser, use markupParserFinish to get the data out of -- it, and then use markupParseContextFree to free it. -- -- This function is designed for applications that read pango markup from -- streams. To simply parse a string containing pango markup, the simpler -- parseMarkup API is recommended instead. -- -- Since: 1.31.0 markupParserNew :: (HasCallStack, MonadIO m) => Char -> m MarkupParseContext -- | Do not use. Does not do anything. -- | Deprecated: (Since version 1.38) moduleRegister :: (HasCallStack, MonadIO m) => IncludedModule -> m () -- | Parses an enum type and stores the result in value. -- -- If str does not match the nick name of any of the -- possible values for the enum and is not an integer, False is -- returned, a warning is issued if warn is True, -- and a string representing the list of possible values is stored in -- possibleValues. The list is slash-separated, eg. -- "none/start/middle/end". If failed and possibleValues -- is not Nothing, returned string should be freed using -- free. -- -- Since: 1.16 -- | Deprecated: (Since version 1.38) parseEnum :: (HasCallStack, MonadIO m) => GType -> Maybe Text -> Bool -> m (Bool, Int32, Text) -- | Parses marked-up text (see <link -- linkend="PangoMarkupFormat">markup format</link>) to create a -- plain-text string and an attribute list. -- -- If accelMarker is nonzero, the given character will -- mark the character following it as an accelerator. For example, -- accelMarker might be an ampersand or underscore. All -- characters marked as an accelerator will receive a UnderlineLow -- attribute, and the first character so marked will be returned in -- accelChar. Two accelMarker characters -- following each other produce a single literal -- accelMarker character. -- -- To parse a stream of pango markup incrementally, use -- markupParserNew. -- -- If any error happens, none of the output arguments are touched except -- for error. parseMarkup :: (HasCallStack, MonadIO m) => Text -> Int32 -> Char -> m (AttrList, Text, Char) -- | Quantizes the thickness and position of a line, typically an underline -- or strikethrough, to whole device pixels, that is integer multiples of -- SCALE. The purpose of this function is to avoid such lines -- looking blurry. -- -- Care is taken to make sure thickness is at least one -- pixel when this function returns, but returned -- position may become zero as a result of rounding. -- -- Since: 1.12 quantizeLineGeometry :: (HasCallStack, MonadIO m) => Int32 -> Int32 -> m (Int32, Int32) -- | Reads an entire line from a file into a buffer. Lines may be delimited -- with '\n', '\r', '\n\r', or '\r\n'. The delimiter is not written into -- the buffer. Text after a '#' character is treated as a comment and -- skipped. '\' can be used to escape a # character. '\' proceeding a -- line delimiter combines adjacent lines. A '\' proceeding any other -- character is ignored and written into the output buffer unmodified. -- | Deprecated: (Since version 1.38) readLine :: (HasCallStack, MonadIO m) => Ptr () -> m (Int32, String) -- | From a list of items in logical order and the associated directional -- levels, produce a list in visual order. The original list is -- unmodified. reorderItems :: (HasCallStack, MonadIO m) => [Item] -> m [Item] -- | Scans an integer. Leading white space is skipped. -- | Deprecated: (Since version 1.38) scanInt :: (HasCallStack, MonadIO m) => Text -> m (Bool, Text, Int32) -- | Scans a string into a String buffer. The string may either be a -- sequence of non-white-space characters, or a quoted string with '"'. -- Instead a quoted string, '\"' represents a literal quote. Leading -- white space outside of quotes is skipped. -- | Deprecated: (Since version 1.38) scanString :: (HasCallStack, MonadIO m) => Text -> m (Bool, Text, String) -- | Scans a word into a String buffer. A word consists of [A-Za-z_] -- followed by zero or more [A-Za-z_0-9] Leading white space is skipped. -- | Deprecated: (Since version 1.38) scanWord :: (HasCallStack, MonadIO m) => Text -> m (Bool, Text, String) -- | Given a segment of text and the corresponding Analysis -- structure returned from itemize, convert the characters into -- glyphs. You may also pass in only a substring of the item from -- itemize. -- -- It is recommended that you use shapeFull instead, since that -- API allows for shaping interaction happening across text item -- boundaries. shape :: (HasCallStack, MonadIO m) => Text -> Int32 -> Analysis -> GlyphString -> m () -- | Given a segment of text and the corresponding Analysis -- structure returned from itemize, convert the characters into -- glyphs. You may also pass in only a substring of the item from -- itemize. -- -- This is similar to shape, except it also can optionally take -- the full paragraph text as input, which will then be used to perform -- certain cross-item shaping interactions. If you have access to the -- broader text of which itemText is part of, provide the -- broader text as paragraphText. If -- paragraphText is Nothing, item text is used -- instead. -- -- Since: 1.32 shapeFull :: (HasCallStack, MonadIO m) => Text -> Int32 -> Maybe Text -> Int32 -> Analysis -> GlyphString -> m () -- | Skips 0 or more characters of white space. -- | Deprecated: (Since version 1.38) skipSpace :: (HasCallStack, MonadIO m) => Text -> m (Bool, Text) -- | Splits a SEARCHPATH_SEPARATOR-separated list of files, -- stripping white space and substituting ~/ with $HOME/. -- | Deprecated: (Since version 1.38) splitFileList :: (HasCallStack, MonadIO m) => Text -> m [Text] -- | Trims leading and trailing whitespace from a string. -- | Deprecated: (Since version 1.38) trimString :: (HasCallStack, MonadIO m) => Text -> m Text -- | Determines the inherent direction of a character; either -- DirectionLtr, DirectionRtl, or DirectionNeutral. -- -- This function is useful to categorize characters into left-to-right -- letters, right-to-left letters, and everything else. If full Unicode -- bidirectional type of a character is needed, bidiTypeForUnichar -- can be used instead. unicharDirection :: (HasCallStack, MonadIO m) => Char -> m Direction -- | Converts a floating-point number to Pango units: multiplies it by -- SCALE and rounds to nearest integer. -- -- Since: 1.16 unitsFromDouble :: (HasCallStack, MonadIO m) => Double -> m Int32 -- | Converts a number in Pango units to floating-point: divides it by -- SCALE. -- -- Since: 1.16 unitsToDouble :: (HasCallStack, MonadIO m) => Int32 -> m Double -- | This is similar to the macro PANGO_VERSION except that -- it returns the encoded version of Pango available at run-time, as -- opposed to the version available at compile-time. -- -- A version number can be encoded into an integer using -- PANGO_VERSION_ENCODE(). -- -- Since: 1.16 version :: (HasCallStack, MonadIO m) => m Int32 -- | Checks that the Pango library in use is compatible with the given -- version. Generally you would pass in the constants -- PANGO_VERSION_MAJOR, -- PANGO_VERSION_MINOR, -- PANGO_VERSION_MICRO as the three arguments to this -- function; that produces a check that the library in use at run-time is -- compatible with the version of Pango the application or module was -- compiled against. -- -- Compatibility is defined by two things: first the version of the -- running library is newer than the version -- requiredMajor.required_minor.requiredMicro. -- Second the running library must be binary compatible with the version -- requiredMajor.required_minor.requiredMicro -- (same major version.) -- -- For compile-time version checking use -- PANGO_VERSION_CHECK(). -- -- Since: 1.16 versionCheck :: (HasCallStack, MonadIO m) => Int32 -> Int32 -> Int32 -> m (Maybe Text) -- | This is similar to the macro PANGO_VERSION_STRING -- except that it returns the version of Pango available at run-time, as -- opposed to the version available at compile-time. -- -- Since: 1.16 versionString :: (HasCallStack, MonadIO m) => m Text -- | The Rectangle structure represents a rectangle. It is -- frequently used to represent the logical or ink extents of a single -- glyph or section of text. (See, for instance, -- fontGetGlyphExtents) module GI.Pango.Structs.Rectangle -- | Memory-managed wrapper type. newtype Rectangle Rectangle :: ManagedPtr Rectangle -> Rectangle -- | Construct a Rectangle struct initialized to zero. newZeroRectangle :: MonadIO m => m Rectangle -- | A convenience alias for Nothing :: Maybe -- Rectangle. noRectangle :: Maybe Rectangle -- | Get the value of the “height” field. When overloading -- is enabled, this is equivalent to -- --
--   get rectangle #height
--   
getRectangleHeight :: MonadIO m => Rectangle -> m Int32 -- | Set the value of the “height” field. When overloading -- is enabled, this is equivalent to -- --
--   set rectangle [ #height := value ]
--   
setRectangleHeight :: MonadIO m => Rectangle -> Int32 -> m () -- | Get the value of the “width” field. When overloading -- is enabled, this is equivalent to -- --
--   get rectangle #width
--   
getRectangleWidth :: MonadIO m => Rectangle -> m Int32 -- | Set the value of the “width” field. When overloading -- is enabled, this is equivalent to -- --
--   set rectangle [ #width := value ]
--   
setRectangleWidth :: MonadIO m => Rectangle -> Int32 -> m () -- | Get the value of the “x” field. When overloading is -- enabled, this is equivalent to -- --
--   get rectangle #x
--   
getRectangleX :: MonadIO m => Rectangle -> m Int32 -- | Set the value of the “x” field. When overloading is -- enabled, this is equivalent to -- --
--   set rectangle [ #x := value ]
--   
setRectangleX :: MonadIO m => Rectangle -> Int32 -> m () -- | Get the value of the “y” field. When overloading is -- enabled, this is equivalent to -- --
--   get rectangle #y
--   
getRectangleY :: MonadIO m => Rectangle -> m Int32 -- | Set the value of the “y” field. When overloading is -- enabled, this is equivalent to -- --
--   set rectangle [ #y := value ]
--   
setRectangleY :: MonadIO m => Rectangle -> Int32 -> m () instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.Rectangle.Rectangle instance (tag Data.Type.Equality.~ 'Data.GI.Base.Attributes.AttrSet) => Data.GI.Base.Constructible.Constructible GI.Pango.Structs.Rectangle.Rectangle tag -- | A ScriptIter is used to iterate through a string and identify -- ranges in different scripts. module GI.Pango.Structs.ScriptIter -- | Memory-managed wrapper type. newtype ScriptIter ScriptIter :: ManagedPtr ScriptIter -> ScriptIter -- | A convenience alias for Nothing :: Maybe -- ScriptIter. noScriptIter :: Maybe ScriptIter -- | Frees a ScriptIter created with -- pango_script_iter_new(). -- -- Since: 1.4 scriptIterFree :: (HasCallStack, MonadIO m) => ScriptIter -> m () -- | Gets information about the range to which iter -- currently points. The range is the set of locations p where *start -- <= p < *end. (That is, it doesn't include the character stored -- at *end) -- -- Since: 1.4 scriptIterGetRange :: (HasCallStack, MonadIO m) => ScriptIter -> m (Text, Text, Script) -- | Advances a ScriptIter to the next range. If -- iter is already at the end, it is left unchanged and -- False is returned. -- -- Since: 1.4 scriptIterNext :: (HasCallStack, MonadIO m) => ScriptIter -> m Bool instance Data.GI.Base.BasicTypes.WrappedPtr GI.Pango.Structs.ScriptIter.ScriptIter -- | The Layout structure represents an entire paragraph of text. It -- is initialized with a Context, UTF-8 string and set of -- attributes for that string. Once that is done, the set of formatted -- lines can be extracted from the object, the layout can be rendered, -- and conversion between logical character positions within the layout's -- text, and the physical position of the resulting glyphs can be made. -- -- There are also a number of parameters to adjust the formatting of a -- Layout, which are illustrated in <xref -- linkend="parameters"/>. It is possible, as well, to ignore the 2-D -- setup, and simply treat the results of a Layout as a list of -- lines. -- -- <figure id="parameters"> <title>Adjustable parameters for -- a PangoLayout</title> <graphic fileref="layout.gif" -- format="GIF"></graphic> </figure> -- -- The Layout structure is opaque, and has no user-visible fields. module GI.Pango.Objects.Layout -- | Memory-managed wrapper type. newtype Layout Layout :: ManagedPtr Layout -> Layout -- | Type class for types which can be safely cast to Layout, for -- instance with toLayout. class (GObject o, IsDescendantOf Layout o) => IsLayout o -- | Cast to Layout, for types for which this is known to be safe. -- For general casts, use castTo. toLayout :: (MonadIO m, IsLayout o) => o -> m Layout -- | A convenience alias for Nothing :: Maybe Layout. noLayout :: Maybe Layout -- | Forces recomputation of any state in the Layout that might -- depend on the layout's context. This function should be called if you -- make changes to the context subsequent to creating the layout. layoutContextChanged :: (HasCallStack, MonadIO m, IsLayout a) => a -> m () -- | Does a deep copy-by-value of the src layout. The -- attribute list, tab array, and text from the original layout are all -- copied by value. layoutCopy :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Layout -- | Gets the alignment for the layout: how partial lines are positioned -- within the horizontal space available. layoutGetAlignment :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Alignment -- | Gets the attribute list for the layout, if any. layoutGetAttributes :: (HasCallStack, MonadIO m, IsLayout a) => a -> m AttrList -- | Gets whether to calculate the bidirectional base direction for the -- layout according to the contents of the layout. See -- layoutSetAutoDir. -- -- Since: 1.4 layoutGetAutoDir :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Bool -- | Gets the Y position of baseline of the first line in -- layout. -- -- Since: 1.22 layoutGetBaseline :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Int32 -- | Returns the number of Unicode characters in the the text of -- layout. -- -- Since: 1.30 layoutGetCharacterCount :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Int32 -- | Retrieves the Context used for this layout. layoutGetContext :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Context -- | Given an index within a layout, determines the positions that of the -- strong and weak cursors if the insertion point is at that index. The -- position of each cursor is stored as a zero-width rectangle. The -- strong cursor location is the location where characters of the -- directionality equal to the base direction of the layout are inserted. -- The weak cursor location is the location where characters of the -- directionality opposite to the base direction of the layout are -- inserted. layoutGetCursorPos :: (HasCallStack, MonadIO m, IsLayout a) => a -> Int32 -> m (Rectangle, Rectangle) -- | Gets the type of ellipsization being performed for -- layout. See layoutSetEllipsize -- -- Since: 1.6 layoutGetEllipsize :: (HasCallStack, MonadIO m, IsLayout a) => a -> m EllipsizeMode -- | Computes the logical and ink extents of layout. -- Logical extents are usually what you want for positioning things. Note -- that both extents may have non-zero x and y. You may want to use those -- to offset where you render the layout. Not doing that is a very -- typical bug that shows up as right-to-left layouts not being correctly -- positioned in a layout with a set width. -- -- The extents are given in layout coordinates and in Pango units; layout -- coordinates begin at the top left corner of the layout. layoutGetExtents :: (HasCallStack, MonadIO m, IsLayout a) => a -> m (Rectangle, Rectangle) -- | Gets the font description for the layout, if any. -- -- Since: 1.8 layoutGetFontDescription :: (HasCallStack, MonadIO m, IsLayout a) => a -> m (Maybe FontDescription) -- | Gets the height of layout used for ellipsization. See -- layoutSetHeight for details. -- -- Since: 1.20 layoutGetHeight :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Int32 -- | Gets the paragraph indent width in Pango units. A negative value -- indicates a hanging indentation. layoutGetIndent :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Int32 -- | Returns an iterator to iterate over the visual extents of the layout. layoutGetIter :: (HasCallStack, MonadIO m, IsLayout a) => a -> m LayoutIter -- | Gets whether each complete line should be stretched to fill the entire -- width of the layout. layoutGetJustify :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Bool -- | Retrieves a particular line from a Layout. -- -- Use the faster layoutGetLineReadonly if you do not plan to -- modify the contents of the line (glyphs, glyph widths, etc.). layoutGetLine :: (HasCallStack, MonadIO m, IsLayout a) => a -> Int32 -> m (Maybe LayoutLine) -- | Retrieves the count of lines for the layout. layoutGetLineCount :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Int32 -- | Retrieves a particular line from a Layout. -- -- This is a faster alternative to layoutGetLine, but the user is -- not expected to modify the contents of the line (glyphs, glyph widths, -- etc.). -- -- Since: 1.16 layoutGetLineReadonly :: (HasCallStack, MonadIO m, IsLayout a) => a -> Int32 -> m (Maybe LayoutLine) -- | Returns the lines of the layout as a list. -- -- Use the faster layoutGetLinesReadonly if you do not plan to -- modify the contents of the lines (glyphs, glyph widths, etc.). layoutGetLines :: (HasCallStack, MonadIO m, IsLayout a) => a -> m [LayoutLine] -- | Returns the lines of the layout as a list. -- -- This is a faster alternative to layoutGetLines, but the user is -- not expected to modify the contents of the lines (glyphs, glyph -- widths, etc.). -- -- Since: 1.16 layoutGetLinesReadonly :: (HasCallStack, MonadIO m, IsLayout a) => a -> m [LayoutLine] -- | Retrieves an array of logical attributes for each character in the -- layout. layoutGetLogAttrs :: (HasCallStack, MonadIO m, IsLayout a) => a -> m [LogAttr] -- | Retrieves an array of logical attributes for each character in the -- layout. -- -- This is a faster alternative to layoutGetLogAttrs. The returned -- array is part of layout and must not be modified. -- Modifying the layout will invalidate the returned array. -- -- The number of attributes returned in nAttrs will be -- one more than the total number of characters in the layout, since -- there need to be attributes corresponding to both the position before -- the first character and the position after the last character. -- -- Since: 1.30 layoutGetLogAttrsReadonly :: (HasCallStack, MonadIO m, IsLayout a) => a -> m [LogAttr] -- | Computes the logical and ink extents of layout in -- device units. This function just calls layoutGetExtents -- followed by two extentsToPixels calls, rounding -- inkRect and logicalRect such that the -- rounded rectangles fully contain the unrounded one (that is, passes -- them as first argument to extentsToPixels). layoutGetPixelExtents :: (HasCallStack, MonadIO m, IsLayout a) => a -> m (Rectangle, Rectangle) -- | Determines the logical width and height of a Layout in device -- units. (layoutGetSize returns the width and height scaled by -- SCALE.) This is simply a convenience function around -- layoutGetPixelExtents. layoutGetPixelSize :: (HasCallStack, MonadIO m, IsLayout a) => a -> m (Int32, Int32) -- | Returns the current serial number of layout. The -- serial number is initialized to an small number larger than zero when -- a new layout is created and is increased whenever the layout is -- changed using any of the setter functions, or the Context it -- uses has changed. The serial may wrap, but will never have the value -- 0. Since it can wrap, never compare it with "less than", always use -- "not equals". -- -- This can be used to automatically detect changes to a Layout, -- and is useful for example to decide whether a layout needs redrawing. -- To force the serial to be increased, use layoutContextChanged. -- -- Since: 1.32.4 layoutGetSerial :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Word32 -- | Obtains the value set by layoutSetSingleParagraphMode. layoutGetSingleParagraphMode :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Bool -- | Determines the logical width and height of a Layout in Pango -- units (device units scaled by SCALE). This is simply a -- convenience function around layoutGetExtents. layoutGetSize :: (HasCallStack, MonadIO m, IsLayout a) => a -> m (Int32, Int32) -- | Gets the amount of spacing between the lines of the layout. layoutGetSpacing :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Int32 -- | Gets the current TabArray used by this layout. If no -- TabArray has been set, then the default tabs are in use and -- Nothing is returned. Default tabs are every 8 spaces. The -- return value should be freed with tabArrayFree. layoutGetTabs :: (HasCallStack, MonadIO m, IsLayout a) => a -> m (Maybe TabArray) -- | Gets the text in the layout. The returned text should not be freed or -- modified. layoutGetText :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Text -- | Counts the number unknown glyphs in layout. That is, -- zero if glyphs for all characters in the layout text were found, or -- more than zero otherwise. -- -- This function can be used to determine if there are any fonts -- available to render all characters in a certain string, or when used -- in combination with AttrTypeFallback, to check if a certain -- font supports all the characters in the string. -- -- Since: 1.16 layoutGetUnknownGlyphsCount :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Int32 -- | Gets the width to which the lines of the Layout should wrap. layoutGetWidth :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Int32 -- | Gets the wrap mode for the layout. -- -- Use layoutIsWrapped to query whether any paragraphs were -- actually wrapped. layoutGetWrap :: (HasCallStack, MonadIO m, IsLayout a) => a -> m WrapMode -- | Converts from byte index_ within the -- layout to line and X position. (X position is measured -- from the left edge of the line) layoutIndexToLineX :: (HasCallStack, MonadIO m, IsLayout a) => a -> Int32 -> Bool -> m (Int32, Int32) -- | Converts from an index within a Layout to the onscreen position -- corresponding to the grapheme at that index, which is represented as -- rectangle. Note that <literal>pos->x</literal> is -- always the leading edge of the grapheme and <literal>pos->x + -- pos->width</literal> the trailing edge of the grapheme. If -- the directionality of the grapheme is right-to-left, then -- <literal>pos->width</literal> will be negative. layoutIndexToPos :: (HasCallStack, MonadIO m, IsLayout a) => a -> Int32 -> m Rectangle -- | Queries whether the layout had to ellipsize any paragraphs. -- -- This returns True if the ellipsization mode for -- layout is not EllipsizeModeNone, a positive -- width is set on layout, and there are paragraphs -- exceeding that width that have to be ellipsized. -- -- Since: 1.16 layoutIsEllipsized :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Bool -- | Queries whether the layout had to wrap any paragraphs. -- -- This returns True if a positive width is set on -- layout, ellipsization mode of layout -- is set to EllipsizeModeNone, and there are paragraphs exceeding -- the layout width that have to be wrapped. -- -- Since: 1.16 layoutIsWrapped :: (HasCallStack, MonadIO m, IsLayout a) => a -> m Bool -- | Computes a new cursor position from an old position and a count of -- positions to move visually. If direction is positive, -- then the new strong cursor position will be one position to the right -- of the old cursor position. If direction is negative, -- then the new strong cursor position will be one position to the left -- of the old cursor position. -- -- In the presence of bidirectional text, the correspondence between -- logical and visual order will depend on the direction of the current -- run, and there may be jumps when the cursor is moved off of the end of -- a run. -- -- Motion here is in cursor positions, not in characters, so a single -- call to layoutMoveCursorVisually may move the cursor over -- multiple characters when multiple characters combine to form a single -- grapheme. layoutMoveCursorVisually :: (HasCallStack, MonadIO m, IsLayout a) => a -> Bool -> Int32 -> Int32 -> Int32 -> m (Int32, Int32) -- | Create a new Layout object with attributes initialized to -- default values for a particular Context. layoutNew :: (HasCallStack, MonadIO m, IsContext a) => a -> m Layout -- | Sets the alignment for the layout: how partial lines are positioned -- within the horizontal space available. layoutSetAlignment :: (HasCallStack, MonadIO m, IsLayout a) => a -> Alignment -> m () -- | Sets the text attributes for a layout object. References -- attrs, so the caller can unref its reference. layoutSetAttributes :: (HasCallStack, MonadIO m, IsLayout a) => a -> Maybe AttrList -> m () -- | Sets whether to calculate the bidirectional base direction for the -- layout according to the contents of the layout; when this flag is on -- (the default), then paragraphs in layout that begin -- with strong right-to-left characters (Arabic and Hebrew principally), -- will have right-to-left layout, paragraphs with letters from other -- scripts will have left-to-right layout. Paragraphs with only neutral -- characters get their direction from the surrounding paragraphs. -- -- When False, the choice between left-to-right and right-to-left -- layout is done according to the base direction of the layout's -- Context. (See contextSetBaseDir). -- -- When the auto-computed direction of a paragraph differs from the base -- direction of the context, the interpretation of AlignmentLeft -- and AlignmentRight are swapped. -- -- Since: 1.4 layoutSetAutoDir :: (HasCallStack, MonadIO m, IsLayout a) => a -> Bool -> m () -- | Sets the type of ellipsization being performed for -- layout. Depending on the ellipsization mode -- ellipsize text is removed from the start, middle, or -- end of text so they fit within the width and height of layout set with -- layoutSetWidth and layoutSetHeight. -- -- If the layout contains characters such as newlines that force it to be -- layed out in multiple paragraphs, then whether each paragraph is -- ellipsized separately or the entire layout is ellipsized as a whole -- depends on the set height of the layout. See layoutSetHeight -- for details. -- -- Since: 1.6 layoutSetEllipsize :: (HasCallStack, MonadIO m, IsLayout a) => a -> EllipsizeMode -> m () -- | Sets the default font description for the layout. If no font -- description is set on the layout, the font description from the -- layout's context is used. layoutSetFontDescription :: (HasCallStack, MonadIO m, IsLayout a) => a -> Maybe FontDescription -> m () -- | Sets the height to which the Layout should be ellipsized at. -- There are two different behaviors, based on whether -- height is positive or negative. -- -- If height is positive, it will be the maximum height -- of the layout. Only lines would be shown that would fit, and if there -- is any text omitted, an ellipsis added. At least one line is included -- in each paragraph regardless of how small the height value is. A value -- of zero will render exactly one line for the entire layout. -- -- If height is negative, it will be the (negative of) -- maximum number of lines per paragraph. That is, the total number of -- lines shown may well be more than this value if the layout contains -- multiple paragraphs of text. The default value of -1 means that first -- line of each paragraph is ellipsized. This behvaior may be changed in -- the future to act per layout instead of per paragraph. File a bug -- against pango at <ulink -- url="http://bugzilla.gnome.org/">http://bugzilla.gnome.org/</ulink> -- if your code relies on this behavior. -- -- Height setting only has effect if a positive width is set on -- layout and ellipsization mode of -- layout is not EllipsizeModeNone. The behavior -- is undefined if a height other than -1 is set and ellipsization mode -- is set to EllipsizeModeNone, and may change in the future. -- -- Since: 1.20 layoutSetHeight :: (HasCallStack, MonadIO m, IsLayout a) => a -> Int32 -> m () -- | Sets the width in Pango units to indent each paragraph. A negative -- value of indent will produce a hanging indentation. -- That is, the first line will have the full width, and subsequent lines -- will be indented by the absolute value of indent. -- -- The indent setting is ignored if layout alignment is set to -- AlignmentCenter. layoutSetIndent :: (HasCallStack, MonadIO m, IsLayout a) => a -> Int32 -> m () -- | Sets whether each complete line should be stretched to fill the entire -- width of the layout. This stretching is typically done by adding -- whitespace, but for some scripts (such as Arabic), the justification -- may be done in more complex ways, like extending the characters. -- -- Note that this setting is not implemented and so is ignored in Pango -- older than 1.18. layoutSetJustify :: (HasCallStack, MonadIO m, IsLayout a) => a -> Bool -> m () -- | Same as layoutSetMarkupWithAccel, but the markup text isn't -- scanned for accelerators. layoutSetMarkup :: (HasCallStack, MonadIO m, IsLayout a) => a -> Text -> Int32 -> m () -- | If setting is True, do not treat newlines and -- similar characters as paragraph separators; instead, keep all text in -- a single paragraph, and display a glyph for paragraph separator -- characters. Used when you want to allow editing of newlines on a -- single text line. layoutSetSingleParagraphMode :: (HasCallStack, MonadIO m, IsLayout a) => a -> Bool -> m () -- | Sets the amount of spacing in Pango unit between the lines of the -- layout. layoutSetSpacing :: (HasCallStack, MonadIO m, IsLayout a) => a -> Int32 -> m () -- | Sets the tabs to use for layout, overriding the -- default tabs (by default, tabs are every 8 spaces). If -- tabs is Nothing, the default tabs are -- reinstated. tabs is copied into the layout; you must -- free your copy of tabs yourself. layoutSetTabs :: (HasCallStack, MonadIO m, IsLayout a) => a -> Maybe TabArray -> m () -- | Sets the text of the layout. -- -- Note that if you have used layoutSetMarkup or -- layoutSetMarkupWithAccel on layout before, you -- may want to call layoutSetAttributes to clear the attributes -- set on the layout from the markup as this function does not clear -- attributes. layoutSetText :: (HasCallStack, MonadIO m, IsLayout a) => a -> Text -> Int32 -> m () -- | Sets the width to which the lines of the Layout should wrap or -- ellipsized. The default value is -1: no width set. layoutSetWidth :: (HasCallStack, MonadIO m, IsLayout a) => a -> Int32 -> m () -- | Sets the wrap mode; the wrap mode only has effect if a width is set on -- the layout with layoutSetWidth. To turn off wrapping, set the -- width to -1. layoutSetWrap :: (HasCallStack, MonadIO m, IsLayout a) => a -> WrapMode -> m () -- | Converts from X and Y position within a layout to the byte index to -- the character at that logical position. If the Y position is not -- inside the layout, the closest position is chosen (the position will -- be clamped inside the layout). If the X position is not within the -- layout, then the start or the end of the line is chosen as described -- for layoutLineXToIndex. If either the X or Y positions were not -- inside the layout, then the function returns False; on an exact -- hit, it returns True. layoutXyToIndex :: (HasCallStack, MonadIO m, IsLayout a) => a -> Int32 -> Int32 -> m (Bool, Int32, Int32) instance (Data.GI.Base.BasicTypes.GObject o, Data.GI.Base.Overloading.IsDescendantOf GI.Pango.Objects.Layout.Layout o) => GI.Pango.Objects.Layout.IsLayout o instance Data.GI.Base.BasicTypes.GObject GI.Pango.Objects.Layout.Layout instance Data.GI.Base.Overloading.HasParentTypes GI.Pango.Objects.Layout.Layout module GI.Pango.Objects -- | A TabArray struct contains an array of tab stops. Each tab stop -- has an alignment and a position. module GI.Pango.Structs.TabArray -- | Memory-managed wrapper type. newtype TabArray TabArray :: ManagedPtr TabArray -> TabArray -- | A convenience alias for Nothing :: Maybe -- TabArray. noTabArray :: Maybe TabArray -- | Copies a TabArray tabArrayCopy :: (HasCallStack, MonadIO m) => TabArray -> m TabArray -- | Frees a tab array and associated resources. tabArrayFree :: (HasCallStack, MonadIO m) => TabArray -> m () -- | Returns True if the tab positions are in pixels, False -- if they are in Pango units. tabArrayGetPositionsInPixels :: (HasCallStack, MonadIO m) => TabArray -> m Bool -- | Gets the number of tab stops in tabArray. tabArrayGetSize :: (HasCallStack, MonadIO m) => TabArray -> m Int32 -- | Gets the alignment and position of a tab stop. tabArrayGetTab :: (HasCallStack, MonadIO m) => TabArray -> Int32 -> m (TabAlign, Int32) -- | Creates an array of initialSize tab stops. Tab stops -- are specified in pixel units if positionsInPixels is -- True, otherwise in Pango units. All stops are initially at -- position 0. tabArrayNew :: (HasCallStack, MonadIO m) => Int32 -> Bool -> m TabArray -- | Resizes a tab array. You must subsequently initialize any tabs that -- were added as a result of growing the array. tabArrayResize :: (HasCallStack, MonadIO m) => TabArray -> Int32 -> m () -- | Sets the alignment and location of a tab stop. -- alignment must always be -- PANGO_TAB_LEFT in the current implementation. tabArraySetTab :: (HasCallStack, MonadIO m) => TabArray -> Int32 -> TabAlign -> Int32 -> m () instance Data.GI.Base.BasicTypes.BoxedObject GI.Pango.Structs.TabArray.TabArray module GI.Pango.Structs module GI.Pango