X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;ds=sidebyside;f=Usermode%2FApplications%2Faxwin2_src%2FWM%2Fwm.h;h=d91626ba8f9dcb5eb87427b06d4b9a2772159853;hb=117854336280cdf3d07143820e4d82d92c570239;hp=9ce35443b0b6523fdb8f9b8a533a71389aaffba7;hpb=43992cf707ec82f8ffd3a1500ad5952640335a6d;p=tpg%2Facess2.git diff --git a/Usermode/Applications/axwin2_src/WM/wm.h b/Usermode/Applications/axwin2_src/WM/wm.h index 9ce35443..d91626ba 100644 --- a/Usermode/Applications/axwin2_src/WM/wm.h +++ b/Usermode/Applications/axwin2_src/WM/wm.h @@ -1,36 +1,53 @@ - +/* + * Acess2 Window Manager (AxWin2) + */ #ifndef _WM_H_ #define _WM_H_ #include +#include "common.h" + +/** + * \brief Number of elements that can be owned by each application) + */ +// TODO: Fine tune these values +#define MAX_ELEMENTS_PER_APP 1024 +#define DEFAULT_ELEMENTS_PER_APP 128 typedef struct sAxWin_Element tElement; +typedef struct sApplication tApplication; struct sAxWin_Element { - int Type; + enum eElementTypes Type; + // Element Tree tElement *Parent; tElement *FirstChild; tElement *LastChild; tElement *NextSibling; + // Application + tApplication *Owner; //!< Owning application + uint16_t ApplicationID; //!< Index into sApplication::EleIndex + + // User modifiable attributes short PaddingL, PaddingR; short PaddingT, PaddingB; short GapSize; - short FixedWith; // Fixed Long Size attribute (height) - short FixedCross; // Fixed Cross Size attribute (width) + uint32_t Flags; + + short FixedWith; //!< Fixed Long Size attribute (height) + short FixedCross; //!< Fixed Cross Size attribute (width) char *Text; // -- Attributes maitained by the element code // Not touched by the user - short MinWith; // Minimum long size - short MinCross; // Minimum cross size - void *Data; - - uint32_t Flags; + short MinWith; //!< Minimum long size + short MinCross; //!< Minimum cross size + void *Data; //!< Per-type data // -- Render Cache short CachedX, CachedY; @@ -39,28 +56,28 @@ struct sAxWin_Element char DebugName[]; }; -typedef struct sTab +struct sApplication { - int Type; // Should be zero, allows a tab to be the parent of an element + tApplication *Next; + + void *Ident; //!< Client Identifier + tMessages_Handle_Callback *SendMessage; - tElement *Parent; - tElement *FirstChild; - tElement *LastChild; - struct sTab *NextTab; + char *Name; //!< Application name - char *Name; + int MaxElementIndex; //!< Number of entries in \a EleIndex + tElement **EleIndex; //!< Array of pointers to elements owned by this application - tElement *RootElement; -} tTab; + tElement MetaElement; //!< Windows child off this +}; -typedef struct sApplication -{ - pid_t PID; - - int nTabs; - tTab *Tabs; - - char Name[]; -} tApplication; +// === FUNCTIONS === + +// --- Render +extern void WM_UpdateMinDims(tElement *Element); +extern void WM_UpdateDimensions(tElement *Element, int Pass); +extern void WM_UpdatePosition(tElement *Element); +extern void WM_RenderWidget(tElement *Element); +extern void WM_Update(void); #endif