diff --git a/README.md b/README.md
index dca0a20..27627c0 100644
--- a/README.md
+++ b/README.md
@@ -17,13 +17,13 @@ classes.
 
 The library sets up a `QLocalServer` and a `QSharedMemory` block. The first
 instance of your Application is your Primary Instance. It would check if the
-shared memory block exists and if not it will start a `QLocalServer` and then
-listen for connections. Each subsequent instance of your application would
-check if the shared memory block exists and if it does, it will connect to the
-QLocalServer to notify it that a new instance had been started, after which it
-would terminate with status code `0`. The Primary Instance, `SingleApplication`
-would emit the `instanceStarted()` signal upon detecting that a new instance
-had been started.
+shared memory block exists and if not it will start a `QLocalServer` and listen
+for connections. Each subsequent instance of your application would check if the
+shared memory block exists and if it does, it will connect to the QLocalServer
+to notify the primary instance that a new instance had been started, after which
+it would terminate with status code `0`. In the Primary Instance
+`SingleApplication` would emit the `instanceStarted()` signal upon detecting
+that a new instance had been started.
 
 The library uses `stdlib` to terminate the program with the `exit()` function.
 
@@ -63,11 +63,16 @@ The `Instance Started` signal
 
 The SingleApplication class implements a `instanceStarted()` signal. You can
 bind to that signal to raise your application's window when a new instance had
-been started.
+been started, for example.
 
 ```cpp
 // window is a QWindow instance
-QObject::connect( &app, &SingleApplication::instanceStarted, window, &QWindow::raise );
+QObject::connect(
+    &app,
+    &SingleApplication::instanceStarted,
+    &window,
+    &QWindow::raise
+);
 ```
 
 Using `SingleApplication::instance()` is a neat way to get the
@@ -113,6 +118,92 @@ app.isSecondary();
 __*Note:*__ If your Primary Instance is terminated a newly launched instance
 will replace the Primary one even if the Secondary flag has been set.
 
+API
+---
+
+### Members
+
+```cpp
+SingleApplication::SingleApplication( int &argc, char *argv[], bool allowSecondary = false, Options options = Mode::User, int timeout = 100 )
+```
+
+Depending on whether `allowSecondary` is set, this constructor may terminate
+your app if there is already a primary instance running. Additional `Options`
+can be specified to set whether the SingleApplication block should work
+user-wide or system-wide. Additionally the `Mode::SecondaryNotification` may be
+used to notify the primary instance whenever a secondary instance had been
+started (disabled by default). `timeout` specifies the maximum time in
+milliseconds to wait for blocking operations.
+
+*__Note:__ `argc` and `argv` may be changed as Qt removes arguments that it
+recognizes.*
+
+*__Note:__ `Mode::SecondaryNotification` only works if set on both the primary
+and the secondary instance.*
+
+*__Note:__ Operating system can restrict the shared memory blocks to the same
+user, in which case the User/System modes will have no effect and the block will
+be user wide.*
+
+```cpp
+bool SingleApplication::sendMessage( QByteArray message, int timeout = 100 )
+```
+
+Sends `message` to the Primary Instance. Uses `timeout` as a the maximum timeout
+in milliseconds for blocking functions
+
+```cpp
+bool SingleApplication::isPrimary()
+```
+
+Returns if the instance is the primary instance.
+
+```cpp
+bool SingleApplication::isSecondary()
+```
+Returns if the instance is a secondary instance.
+
+```cpp
+quint32 SingleApplication::instanceId()
+```
+
+Returns a unique identifier for the current instance
+
+### Signals
+
+```cpp
+void SingleApplication::instanceStarted()
+```
+
+Triggered whenever a new instance had been started, except for secondary
+instances if the `Mode::SecondaryNotification` flag is not specified.
+
+```cpp
+void SingleApplication::receivedMessage( quint32 instanceId, QByteArray message )
+```
+
+Triggered whenever there is a message received from a secondary instance.
+
+### Flags
+
+```cpp
+enum SingleApplication::Mode
+```
+
+*   `Mode::User` - The SingleApplication block should apply user wide. This adds
+    user specific data to the key used for the shared memory and server name.
+    This is the default functionality.
+*   `Mode::System` – The SingleApplication block applies system-wide.
+*   `SecondaryNotification` – Whether to trigger `instanceStarted()` even
+    whenever secondary instances are started.
+
+*__Note:__ `Mode::SecondaryNotification` only works if set on both the primary
+and the secondary instance.*
+
+*__Note:__ Operating system can restrict the shared memory blocks to the same
+user, in which case the User/System modes will have no effect and the block will
+be user wide.*
+
 Versioning
 ----------
 
@@ -154,9 +245,11 @@ results in process termination.
 *   `SIGXCPU` - `24`, CPU time limit exceeded.
 *   `SIGXFSZ` - `25`, File size limit exceeded.
 
+Additionally the library can recover from being killed with uncatchable signals
+and will reset the memory block given that there are no other instances running.
 
 License
 -------
 This library and it's supporting documentation are released under
-`The MIT License (MIT)` with exception to some of the examples distributed under
-the terms of the BSD license.
+`The MIT License (MIT)` with the exception of some of the examples distributed
+under the BSD license.