Update 'README.md'

This commit is contained in:
Reece Wilson 2021-10-28 21:03:01 +00:00
parent d9d83f00cd
commit d7cfbb6c7e

View File

@ -5,7 +5,7 @@ This library implements the macros required to define Aurora style interfaces. D
## Example usage:
#### In your common header:
```
```c
#if defined(MY_LIB_GEN_BINDINGS)
#define LIB_INTERFACE(name, list) AUI_INTERFACE_IMPL(name, list)
#define
@ -14,7 +14,7 @@ This library implements the macros required to define Aurora style interfaces. D
```
#### In your public API:
```
```c
LIB_INTERFACE(IInputMouseSubscriber,
AUI_METHOD(void, onButtonPress, (AuUInt8, mb)),
AUI_METHOD(void, onButtonTick, (AuUInt8, mb)),
@ -23,13 +23,32 @@ LIB_INTERFACE(IInputMouseSubscriber,
```
#### In a dedicated translation unit:
```
```c++
#define MY_LIB_GEN_BINDINGS
#include <...>
#include <AuroraForEach.hpp>
#include <AuroraInterfaces.hpp>
```
#### Usage Runtime Binding and Modern C++
#### Usage: C++ inheritance (covers SWIG and CppSharp)
```
#include <AuroraForEach.hpp>
#include <AuroraInterfaces.hpp>
struct MyEventHandler : public IInputMouseSubscriber
{
void onButtonPress(AuUInt8 mb) override;
void onButtonTick(AuUInt8 mb) override;
void onButtonUp(AuUInt8 mb) override;
};
static AuSPtr<IInputMouseSubscriber> MyMouseSubscriber()
{
return AuMakeShared<MyEventHandler>();
}
```
#### Usage: Runtime bindings and modern C++
``` c++
// My language binding
IInputMouseSubscriberFunctional test;
test.onButtonPress = [](AuUInt8 btn)
@ -41,17 +60,8 @@ AuSPtr<IInputMouseSubscriber> handle = AuUnsafeRaiiToShared(&test);
// use handle with an Aurora API
```
#### Usage C++ Native, SWIG, and CppSharp
```
struct MyEventHandler : public IInputMouseSubscriber
{
void onButtonPress(AuUInt8 mb) override;
void onButtonTick(AuUInt8 mb) override;
void onButtonUp(AuUInt8 mb) override;
};
auto handle = AuMakeShared<MyEventHandler>();
```
## Dependencies
* [AuroraForEach](https://git.reece.sx/AuroraSupport/AuroraForEach) [header only]
##### Not recommended for small projects and/or people with a shred of sanity left
##### Possibly useful for API developers