Mostly Harmless

Cpptext

From Unreal Wiki, The Unreal Engine Documentation Site
Jump to: navigation, search

Starting with Unreal Engine 2 UnrealScript classes/structs support cpptext(prefix for C++text) block declarations. The cpptext is a block declaration where programmers can implement C++ functions it also can only be declared in native classes, any text within this block will then be exported to the corresponding native class prefixClasses.h file when compiled.

Note: structs use cppstruct instead and starting with Unreal Engine 3 it was renamed to structcpptext.

Example

Taken from Canvas.uc.

cpptext
{
    //...
    void DrawTile(UTexture* Tex, FLOAT X, FLOAT Y, FLOAT XL, FLOAT YL, FLOAT U, FLOAT V, FLOAT UL, FLOAT VL, const FLinearColor& Color);
    //...
}

This exports DrawTile into class UCanvas in file EngineClasses.h e.g.

class UCanvas : public UObject
{
    //...
    void DrawTile(UTexture* Tex, FLOAT X, FLOAT Y, FLOAT XL, FLOAT YL, FLOAT U, FLOAT V, FLOAT UL, FLOAT VL, const FLinearColor& Color);
    //...
};

Why use cpptext over native functions

Even though you can just make a native UnrealScript function that will also get exported the same way but then translated to C++, it doesn't support all formats thus in that case the native coder can implement functions that cannot be declared in UnrealScript but also because the native coder might not want you to be able to call a function from within UnrealScript.

See also