- What I want to achieve with this is to bring the GDIplus.dll to AutoHotkey in the way it was intended to be wrapped around.
- I also want to make the API easier to use - safer and less prone to breaking.
- I want consistent syntax, naming and usage throughout the library.
- The final result should fully wrap around the gdiplus API.
- I also want to make it possible to debug it easier by using Throw Exception()...
- overloaded constructors: In the gdiplus.dll there are several Overloaded constructors for every type of Object.
All of these different Constructor functions should be wrapped around by each object types constructor (
__New
). With the exception of those that make no sense in AutoHotkeys context. - registerObject and unregisterObject In order to make sure that every object get's safely deleted when the API closes you need to register the object in it's constructor and unregister it in it's destructor.
- disconnect base Detatch the object from it's base in it's destructor by calling
This.base := ""
or similar. - class nesting all classes should either be nested within the class GDIp or any of it's subclasses.
- the ptr field and getpObjectType Any class that represents a GDIp Object should store it's objects pointer in
This.ptr
. It should also return this pointer upon callinggetpObjectType()
whereObjectType
get's replaced by the Objects type ( e.g.getpBitmap()
for Bitmaps ). - parameters The biggest issue is making parameters both consistent and easy to use. Parameters should represent attributes that can be set e.g. Size. If the parameter covers more than one value combine them to an array. Never split parameters. Never use byref or global.
- getters and setters Every attribute that needs to be set or get dynamically shouls be set and get by using setter and getter methods.