Fix eepp windows build not exporting all symbols required for ecode.

This commit is contained in:
Martín Lucas Golini
2023-02-05 20:04:45 -03:00
parent 7ca5866932
commit 3aeb6f6bfe
28 changed files with 61 additions and 45 deletions

View File

@@ -8,7 +8,7 @@ namespace EE { namespace Graphics {
class EE_API BlendMode {
public:
enum class Factor {
enum class EE_API Factor {
Zero, /// (0, 0, 0, 0)
One, /// (1, 1, 1, 1)
SrcColor, /// (src.r, src.g, src.b, src.a)
@@ -21,7 +21,7 @@ class EE_API BlendMode {
OneMinusDstAlpha /// (1, 1, 1, 1) - (dst.a, dst.a, dst.a, dst.a)
};
enum class Equation {
enum class EE_API Equation {
Add, /// Pixel = Src * SrcFactor + Dst * DstFactor
Subtract, /// Pixel = Src * SrcFactor - Dst * DstFactor
ReverseSubtract /// Pixel = Dst * DstFactor - Src * SrcFactor

View File

@@ -17,7 +17,7 @@ class EE_API Glyph {
int rsbDelta{ 0 }; //!< Right offset after forced autohint. Internally used by getKerning()
};
enum class FontType { TTF, BMF, Sprite };
enum class EE_API FontType { TTF, BMF, Sprite };
enum FontHorizontalAlign {
TEXT_ALIGN_LEFT = ( 0 << 0 ),

View File

@@ -14,7 +14,7 @@ class EE_API GlyphDrawable : public DrawableResource {
static GlyphDrawable* New( Texture* texture, const Rect& srcRect,
const std::string& resourceName = "" );
enum class DrawMode {
enum class EE_API DrawMode {
Image, ///< It will be treated as a simple image, no special offset is applied.
Text, ///< Will add the glyph offset corresponding to that character
TextItalic ///< Will add the glyph offset corresponding to that character and simulate

View File

@@ -14,7 +14,7 @@ class Texture;
/** @enum EE::Graphics::ParticleEffect Predefined effects for the particle system. Use Callback when
* wan't to create a new effect, o set the parameters using NoFx, but it's much more limited. */
enum class ParticleEffect : Uint32 {
enum class EE_API ParticleEffect : Uint32 {
Nofx = 0, //!< User defined effect
BlueBall,
Fire,

View File

@@ -12,7 +12,7 @@ using namespace EE::Math;
namespace EE { namespace Graphics {
enum class PixelDensitySize : Uint32 {
enum class EE_API PixelDensitySize : Uint32 {
MDPI = 1, //!< 1dp = 1px
HDPI = 2, //!< 1dp = 1.5px
XHDPI = 3, //!< 1dp = 2px

View File

@@ -13,15 +13,15 @@ namespace EE { namespace Graphics {
class EE_API Texture : public DrawableResource, public Image, private NonCopyable {
public:
/** @enum TextureFilter Defines the texture filter used. */
enum class Filter : Uint32 {
enum class EE_API Filter : Uint32 {
Linear, //!< Linear filtering (Smoothed Zoom)
Nearest //!< No filtering (Pixeled Zoom)
};
/** @enum ClampMode Set the clamp mode of the texture. */
enum class ClampMode : Uint32 { ClampToEdge, ClampRepeat };
enum class EE_API ClampMode : Uint32 { ClampToEdge, ClampRepeat };
enum class CoordinateType : Uint32 {
enum class EE_API CoordinateType : Uint32 {
Normalized, ///< Texture coordinates in range [0 .. 1]
Pixels ///< Texture coordinates in range [0 .. size]
};

View File

@@ -4,7 +4,7 @@
namespace EE { namespace Graphics {
/// VBO default usage type
enum class VertexBufferUsageType : int {
enum class EE_API VertexBufferUsageType : int {
Static,
Dynamic,
Stream,

View File

@@ -17,7 +17,7 @@ class LogReaderInterface {
virtual void writeLog( const std::string& Text ) = 0;
};
enum class LogLevel : int {
enum class EE_API LogLevel : int {
Debug, ///< Detailed debug information.
Info, ///< Interesting events in your application.
Notice, ///< Normal, but significant events in your application.

View File

@@ -11,7 +11,7 @@ using namespace EE::UI::Models;
namespace EE { namespace UI { namespace Abstract {
enum class ModelEventType { Open, OpenTree, CloseTree, OpenMenu };
enum class EE_API ModelEventType { Open, OpenTree, CloseTree, OpenMenu };
class EE_API ModelEvent : public Event {
public:

View File

@@ -15,7 +15,7 @@ using namespace EE::Math;
namespace EE { namespace UI {
class UINode;
enum class BorderType : Uint32 { Inside, Outside, Outline };
enum class EE_API BorderType : Uint32 { Inside, Outside, Outline };
struct EE_API Border {
int width = 0;

View File

@@ -6,7 +6,7 @@
namespace EE { namespace UI { namespace CSS {
enum class PropertyId : Uint32 {
enum class EE_API PropertyId : Uint32 {
Id = String::hash( "id" ),
Class = String::hash( "class" ),
X = String::hash( "x" ),
@@ -209,7 +209,7 @@ enum class PropertyId : Uint32 {
GravityOwner = String::hash( "gravity-owner" ),
};
enum class PropertyType : Uint32 {
enum class EE_API PropertyType : Uint32 {
Undefined,
String,
Bool,
@@ -227,7 +227,7 @@ enum class PropertyType : Uint32 {
Time
};
enum class PropertyRelativeTarget : Uint32 {
enum class EE_API PropertyRelativeTarget : Uint32 {
None,
ContainingBlockWidth,
ContainingBlockHeight,

View File

@@ -8,7 +8,7 @@
namespace EE { namespace UI { namespace CSS {
enum class ShorthandId : Uint32 {
enum class EE_API ShorthandId : Uint32 {
Margin = String::hash( "margin" ),
Padding = String::hash( "padding" ),
Transition = String::hash( "transition" ),

View File

@@ -16,7 +16,7 @@ class UIWidget;
namespace EE { namespace UI { namespace CSS {
enum class AnimationOrigin : uint8_t { User, Animation, Transition };
enum class EE_API AnimationOrigin : uint8_t { User, Animation, Transition };
class EE_API StyleSheetPropertyAnimation : public Action {
public:

View File

@@ -9,7 +9,7 @@
namespace EE { namespace UI { namespace CSS {
enum class AtRuleType : Uint32 { None, FontFace };
enum class EE_API AtRuleType : Uint32 { None, FontFace };
class EE_API StyleSheetStyle {
public:

View File

@@ -35,15 +35,15 @@ class EE_API TextDocument {
public:
typedef std::function<void()> DocumentCommand;
enum class UndoRedo { Undo, Redo };
enum class EE_API UndoRedo { Undo, Redo };
enum class IndentType { IndentSpaces, IndentTabs };
enum class EE_API IndentType { IndentSpaces, IndentTabs };
enum class LineEnding { LF, CRLF, CR };
enum class EE_API LineEnding { LF, CRLF, CR };
enum class FindReplaceType { Normal, LuaPattern };
enum class EE_API FindReplaceType { Normal, LuaPattern };
enum class LoadStatus { Loaded, Interrupted, Failed };
enum class EE_API LoadStatus { Loaded, Interrupted, Failed };
static std::string lineEndingToString( const LineEnding& le ) {
switch ( le ) {

View File

@@ -14,7 +14,7 @@ namespace EE { namespace UI { namespace Doc {
class TextDocument;
enum class TextUndoCommandType { Insert, Remove, Selection };
enum class EE_API TextUndoCommandType { Insert, Remove, Selection };
class EE_API TextUndoCommand {
public:

View File

@@ -33,7 +33,7 @@ struct FileEvent {
class EE_API FileSystemModel : public Model {
public:
enum class Mode { DirectoriesOnly, FilesAndDirectories };
enum class EE_API Mode { DirectoriesOnly, FilesAndDirectories };
struct DisplayConfig {
DisplayConfig() {}

View File

@@ -25,7 +25,7 @@ namespace EE { namespace UI { namespace Models {
class PersistentHandle;
enum class SortOrder { None, Ascending, Descending };
enum class EE_API SortOrder { None, Ascending, Descending };
class EE_API Model {
public:
@@ -152,8 +152,8 @@ class EE_API Model {
ModelIndex createIndex( int row, int column, const void* data = nullptr,
const Int64& internalId = 0 ) const;
enum class OperationType { Invalid = 0, Insert, Move, Delete, Reset };
enum class Direction { Row, Column };
enum class EE_API OperationType { Invalid = 0, Insert, Move, Delete, Reset };
enum class EE_API Direction { Row, Column };
struct Operation {
OperationType type{ OperationType::Invalid };

View File

@@ -3,7 +3,7 @@
namespace EE { namespace UI { namespace Models {
enum class ModelRole { Display, Icon, Sort, Custom };
enum class EE_API ModelRole { Display, Icon, Sort, Custom };
}}} // namespace EE::UI::Models

View File

@@ -17,7 +17,7 @@ class EE_API UICodeEditorSplitter {
static const std::map<KeyBindings::Shortcut, std::string> getLocalDefaultKeybindings();
enum class SplitDirection { Left, Right, Top, Bottom };
enum class EE_API SplitDirection { Left, Right, Top, Bottom };
class EE_API Client {
public:

View File

@@ -6,7 +6,7 @@
namespace EE { namespace UI {
enum class ClipType : Uint32 { None, ContentBox, PaddingBox, BorderBox };
enum class EE_API ClipType : Uint32 { None, ContentBox, PaddingBox, BorderBox };
class UIClip {
public:

View File

@@ -105,15 +105,15 @@ enum UINodeType {
UI_TYPE_USER = 100000
};
enum class ScrollBarMode : Uint32 { Auto, AlwaysOn, AlwaysOff };
enum class EE_API ScrollBarMode : Uint32 { Auto, AlwaysOn, AlwaysOff };
enum class UIOrientation : Uint32 { Vertical, Horizontal };
enum class EE_API UIOrientation : Uint32 { Vertical, Horizontal };
enum class SizePolicy : Uint32 { Fixed, MatchParent, WrapContent };
enum class EE_API SizePolicy : Uint32 { Fixed, MatchParent, WrapContent };
enum class PositionPolicy : Uint32 { None, LeftOf, RightOf, TopOf, BottomOf };
enum class EE_API PositionPolicy : Uint32 { None, LeftOf, RightOf, TopOf, BottomOf };
enum class UIScaleType : Uint32 { None, Expand, FitInside };
enum class EE_API UIScaleType : Uint32 { None, Expand, FitInside };
static const Uint32 UI_NODE_DEFAULT_ALIGN = UI_HALIGN_LEFT | UI_VALIGN_CENTER;

View File

@@ -7,7 +7,7 @@
namespace EE { namespace UI {
enum class InnerWidgetOrientation { Left, Right, Center };
enum class EE_API InnerWidgetOrientation { Left, Right, Center };
class EE_API UIPushButton : public UIWidget {
public:

View File

@@ -22,7 +22,7 @@ class UIWidget;
class UILayout;
class UIIcon;
enum class ColorSchemePreference { Light, Dark };
enum class EE_API ColorSchemePreference { Light, Dark };
class EE_API UISceneNode : public SceneNode {
public:

View File

@@ -145,7 +145,7 @@ class EE_API UITreeView : public UIAbstractTableView {
void updateContentSize();
protected:
enum class IterationDecision {
enum class EE_API IterationDecision {
Continue,
Break,
Stop,

View File

@@ -29,7 +29,7 @@ enum WindowStyle {
#endif
};
enum class WindowBackend : Uint32 { SDL2, Default };
enum class EE_API WindowBackend : Uint32 { SDL2, Default };
#ifndef EE_SCREEN_KEYBOARD_ENABLED
#if EE_PLATFORM == EE_PLATFORM_ANDROID || EE_PLATFORM == EE_PLATFORM_IOS

View File

@@ -232,9 +232,17 @@ function postsymlinklib(src_path, dst_path, lib)
return
end
configuration { "release", "windows" }
postbuildcommands { "mklink \"" .. dst_path .. lib .. ".dll\"" .. " \"" .. src_path .. lib .. ".dll\" || ver>nul" }
if os.is("windows") then
postbuildcommands { "mklink \"" .. dst_path .. lib .. ".dll\"" .. " \"" .. src_path .. lib .. ".dll\" || ver>nul" }
else
postbuildcommands { "ln -sf \"" .. src_path .. "lib" .. lib .. "." .. get_dll_extension() .. "\" \"" .. dst_path .. "\"" }
end
configuration { "debug", "windows" }
postbuildcommands { "mklink \"" .. dst_path .. lib .. "-debug.dll\"" .. " \"" .. src_path .. lib .. "-debug.dll\" || ver>nul" }
if os.is("windows") then
postbuildcommands { "mklink \"" .. dst_path .. lib .. "-debug.dll\"" .. " \"" .. src_path .. lib .. "-debug.dll\" || ver>nul" }
else
postbuildcommands { "ln -sf \"" .. src_path .. "lib" .. lib .. "-debug." .. get_dll_extension() .. "\" \"" .. dst_path .. "\"" }
end
configuration { "release", "not windows" }
postbuildcommands { "ln -sf \"" .. src_path .. "lib" .. lib .. "." .. get_dll_extension() .. "\" \"" .. dst_path .. "\"" }
configuration { "debug", "not windows" }

View File

@@ -32,9 +32,17 @@ end
function postsymlinklib(src_path, dst_path, lib)
filter { "configurations:release*", "system:windows" }
postbuildcommands { "mklink \"" .. dst_path .. lib .. ".dll\"" .. " \"" .. src_path .. lib .. ".dll\" || ver>nul" }
if os.ishost("windows") then
postbuildcommands { "mklink \"" .. dst_path .. lib .. ".dll\"" .. " \"" .. src_path .. lib .. ".dll\" || ver>nul" }
else
postbuildcommands { "ln -sf \"" .. src_path .. "lib" .. lib .. "." .. get_dll_extension() .. "\" \"" .. dst_path .. "\"" }
end
filter { "configurations:debug*", "system:windows" }
postbuildcommands { "mklink \"" .. dst_path .. lib .. "-debug.dll\"" .. " \"" .. src_path .. lib .. "-debug.dll\" || ver>nul" }
if os.ishost("windows") then
postbuildcommands { "mklink \"" .. dst_path .. lib .. "-debug.dll\"" .. " \"" .. src_path .. lib .. "-debug.dll\" || ver>nul" }
else
postbuildcommands { "ln -sf \"" .. src_path .. "lib" .. lib .. "-debug." .. get_dll_extension() .. "\" \"" .. dst_path .. "\"" }
end
filter { "configurations:release*", "not system:windows" }
postbuildcommands { "ln -sf \"" .. src_path .. "lib" .. lib .. "." .. get_dll_extension() .. "\" \"" .. dst_path .. "\"" }
filter { "configurations:debug*", "not system:windows" }