module Graphics.UI.Qtah.Generator.Interface.Core.QMetaClassInfo (
aModule,
c_QMetaClassInfo,
) where
import Foreign.Hoppy.Generator.Spec (
MethodApplicability (MConst),
Purity (Nonpure),
addReqIncludes,
classSetConversionToGc,
classSetEntityPrefix,
ident,
ident2,
includeLocal,
includeStd,
makeClass,
makeFnMethod,
)
import Foreign.Hoppy.Generator.Spec.ClassFeature (
ClassFeature (Copyable),
classAddFeatures,
)
import Foreign.Hoppy.Generator.Types (objT)
import Graphics.UI.Qtah.Generator.Interface.Core.QString (c_QString)
import Graphics.UI.Qtah.Generator.Module (AModule (AQtModule), makeQtModule)
import Graphics.UI.Qtah.Generator.Types
{-# ANN module "HLint: ignore Use camelCase" #-}
aModule :: AModule
aModule =
QtModule -> AModule
AQtModule (QtModule -> AModule) -> QtModule -> AModule
forall a b. (a -> b) -> a -> b
$
[String] -> [QtExport] -> QtModule
makeQtModule [String
"Core", String
"QMetaClassInfo"]
[ Class -> QtExport
forall a. Exportable a => a -> QtExport
qtExport Class
c_QMetaClassInfo ]
c_QMetaClassInfo :: Class
c_QMetaClassInfo =
[Include] -> Class -> Class
forall a. HasReqs a => [Include] -> a -> a
addReqIncludes [ String -> Include
includeStd String
"QMetaClassInfo"
, String -> Include
includeLocal String
"wrap_qmetaclassinfo.hpp"
] (Class -> Class) -> Class -> Class
forall a b. (a -> b) -> a -> b
$
Class -> Class
classSetConversionToGc (Class -> Class) -> Class -> Class
forall a b. (a -> b) -> a -> b
$
[ClassFeature] -> Class -> Class
classAddFeatures [ClassFeature
Copyable] (Class -> Class) -> Class -> Class
forall a b. (a -> b) -> a -> b
$
String -> Class -> Class
classSetEntityPrefix String
"" (Class -> Class) -> Class -> Class
forall a b. (a -> b) -> a -> b
$
Identifier -> Maybe ExtName -> [Class] -> [ClassEntity] -> Class
makeClass (String -> Identifier
ident String
"QMetaClassInfo") Maybe ExtName
forall a. Maybe a
Nothing []
[ Identifier
-> String
-> MethodApplicability
-> Purity
-> [Type]
-> Type
-> ClassEntity
forall name p.
(IsFnName Identifier name, IsParameter p) =>
name
-> String
-> MethodApplicability
-> Purity
-> [p]
-> Type
-> ClassEntity
makeFnMethod (String -> String -> String -> Identifier
ident2 String
"qtah" String
"qmetaclassinfo" String
"name") String
"name" MethodApplicability
MConst Purity
Nonpure
[Class -> Type
objT Class
c_QMetaClassInfo] (Type -> ClassEntity) -> Type -> ClassEntity
forall a b. (a -> b) -> a -> b
$ Class -> Type
objT Class
c_QString
, Identifier
-> String
-> MethodApplicability
-> Purity
-> [Type]
-> Type
-> ClassEntity
forall name p.
(IsFnName Identifier name, IsParameter p) =>
name
-> String
-> MethodApplicability
-> Purity
-> [p]
-> Type
-> ClassEntity
makeFnMethod (String -> String -> String -> Identifier
ident2 String
"qtah" String
"qmetaclassinfo" String
"value") String
"value" MethodApplicability
MConst Purity
Nonpure
[Class -> Type
objT Class
c_QMetaClassInfo] (Type -> ClassEntity) -> Type -> ClassEntity
forall a b. (a -> b) -> a -> b
$ Class -> Type
objT Class
c_QString
]