HyperlinkImpl

open class HyperlinkImpl : HyperlinkImplProtocol

AtkHyperlinkImpl allows AtkObjects to refer to their associated AtkHyperlink instance, if one exists. AtkHyperlinkImpl differs from AtkHyperlink in that AtkHyperlinkImpl is an interface, whereas AtkHyperlink is a object type. The AtkHyperlinkImpl interface allows a client to query an AtkObject for the availability of an associated AtkHyperlink instance, and obtain that instance. It is thus particularly useful in cases where embedded content or inline content within a text object is present, since the embedding text object implements AtkHypertext and the inline/embedded objects are exposed as children which implement AtkHyperlinkImpl, in addition to their being obtainable via AtkHypertext:getLink followed by AtkHyperlink:getObject.

The AtkHyperlinkImpl interface should be supported by objects exposed within the hierarchy as children of an AtkHypertext container which correspond to “links” or embedded content within the text. HTML anchors are not, for instance, normally exposed this way, but embedded images and components which appear inline in the content of a text object are. The AtkHyperlinkIface interface allows a means of determining which children are hyperlinks in this sense of the word, and for obtaining their corresponding AtkHyperlink object, from which the embedding range, URI, etc. can be obtained.

To some extent this interface exists because, for historical reasons, AtkHyperlink was defined as an object type, not an interface. Thus, in order to interact with AtkObjects via AtkHyperlink semantics, a new interface was required.

The HyperlinkImpl type acts as an owner of an underlying AtkHyperlinkImpl instance. It provides the methods that can operate on this data type through HyperlinkImplProtocol conformance. Use HyperlinkImpl as a strong reference or owner of a AtkHyperlinkImpl instance.

  • ptr
    Untyped pointer to the underlying `AtkHyperlinkImpl` instance.
    

    For type-safe access, use the generated, typed pointer hyperlink_impl_ptr property instead.

    Declaration

    Swift

    public let ptr: UnsafeMutableRawPointer!
  • Designated initialiser from the underlying C data type. This creates an instance without performing an unbalanced retain i.e., ownership is transferred to the HyperlinkImpl instance.

    Declaration

    Swift

    @inlinable
    public init(_ op: UnsafeMutablePointer<AtkHyperlinkImpl>)

    Parameters

    op

    pointer to the underlying object

  • Designated initialiser from a constant pointer to the underlying C data type. This creates an instance without performing an unbalanced retain i.e., ownership is transferred to the HyperlinkImpl instance.

    Declaration

    Swift

    @inlinable
    public init(_ op: UnsafePointer<AtkHyperlinkImpl>)

    Parameters

    op

    pointer to the underlying object

  • Optional initialiser from a non-mutating gpointer to the underlying C data type. This creates an instance without performing an unbalanced retain i.e., ownership is transferred to the HyperlinkImpl instance.

    Declaration

    Swift

    @inlinable
    public init!(gpointer op: gpointer?)

    Parameters

    op

    gpointer to the underlying object

  • Optional initialiser from a non-mutating gconstpointer to the underlying C data type. This creates an instance without performing an unbalanced retain i.e., ownership is transferred to the HyperlinkImpl instance.

    Declaration

    Swift

    @inlinable
    public init!(gconstpointer op: gconstpointer?)

    Parameters

    op

    pointer to the underlying object

  • Optional initialiser from a constant pointer to the underlying C data type. This creates an instance without performing an unbalanced retain i.e., ownership is transferred to the HyperlinkImpl instance.

    Declaration

    Swift

    @inlinable
    public init!(_ op: UnsafePointer<AtkHyperlinkImpl>?)

    Parameters

    op

    pointer to the underlying object

  • Optional initialiser from the underlying C data type. This creates an instance without performing an unbalanced retain i.e., ownership is transferred to the HyperlinkImpl instance.

    Declaration

    Swift

    @inlinable
    public init!(_ op: UnsafeMutablePointer<AtkHyperlinkImpl>?)

    Parameters

    op

    pointer to the underlying object

  • Designated initialiser from the underlying C data type. AtkHyperlinkImpl does not allow reference counting, so despite the name no actual retaining will occur. i.e., ownership is transferred to the HyperlinkImpl instance.

    Declaration

    Swift

    @inlinable
    public init(retaining op: UnsafeMutablePointer<AtkHyperlinkImpl>)

    Parameters

    op

    pointer to the underlying object

  • Reference intialiser for a related type that implements HyperlinkImplProtocol AtkHyperlinkImpl does not allow reference counting.

    Declaration

    Swift

    @inlinable
    public init<T>(_ other: T) where T : HyperlinkImplProtocol

    Parameters

    other

    an instance of a related type that implements HyperlinkImplProtocol

  • Unsafe typed initialiser. Do not use unless you know the underlying data type the pointer points to conforms to HyperlinkImplProtocol.

    Declaration

    Swift

    @inlinable
    public init<T>(cPointer p: UnsafeMutablePointer<T>)

    Parameters

    cPointer

    pointer to the underlying object

  • Unsafe typed, retaining initialiser. Do not use unless you know the underlying data type the pointer points to conforms to HyperlinkImplProtocol.

    Declaration

    Swift

    @inlinable
    public init<T>(retainingCPointer cPointer: UnsafeMutablePointer<T>)

    Parameters

    cPointer

    pointer to the underlying object

  • Unsafe untyped initialiser. Do not use unless you know the underlying data type the pointer points to conforms to HyperlinkImplProtocol.

    Declaration

    Swift

    @inlinable
    public init(raw p: UnsafeRawPointer)

    Parameters

    p

    raw pointer to the underlying object

  • Unsafe untyped, retaining initialiser. Do not use unless you know the underlying data type the pointer points to conforms to HyperlinkImplProtocol.

    Declaration

    Swift

    @inlinable
    public init(retainingRaw raw: UnsafeRawPointer)
  • Unsafe untyped initialiser. Do not use unless you know the underlying data type the pointer points to conforms to HyperlinkImplProtocol.

    Declaration

    Swift

    @inlinable
    public required init(raw p: UnsafeMutableRawPointer)

    Parameters

    p

    mutable raw pointer to the underlying object

  • Unsafe untyped, retaining initialiser. Do not use unless you know the underlying data type the pointer points to conforms to HyperlinkImplProtocol.

    Declaration

    Swift

    @inlinable
    public init(retainingRaw raw: UnsafeMutableRawPointer)

    Parameters

    raw

    mutable raw pointer to the underlying object

  • Unsafe untyped initialiser. Do not use unless you know the underlying data type the pointer points to conforms to HyperlinkImplProtocol.

    Declaration

    Swift

    @inlinable
    public init(opaquePointer p: OpaquePointer)

    Parameters

    p

    opaque pointer to the underlying object

  • Unsafe untyped, retaining initialiser. Do not use unless you know the underlying data type the pointer points to conforms to HyperlinkImplProtocol.

    Declaration

    Swift

    @inlinable
    public init(retainingOpaquePointer p: OpaquePointer)

    Parameters

    p

    opaque pointer to the underlying object