QEverCloud
4.0.0
Unofficial Evernote Cloud API for Qt
|
Unofficial Evernote Cloud API for Qt
This library presents the complete Evernote SDK for Qt. All the functionality that is described on Evernote site is implemented and ready to use. In particular OAuth authentication is implemented.
Read doxygen generated documentation for detailed info.
The documentation can also be generated in the form of a .qch file which you can register with your copy of Qt Creator to have context-sensitive help. See below for more details.
Please see the contribution guide for detailed info.
Prebuilt versions of the library can be downloaded from the following locations:
The project can be built and shipped as either static library or shared library. Dll export/import symbols necessary for Windows platform are supported.
Dependencies include the following Qt components:
Since QEverCloud 3.0.2 it is possible to choose Qt5WebKit over Qt5WebEngine using CMake option USE_QT5_WEBKIT
.
Since QEverCloud 4.0.0 it is possible to build the library without OAuth support and thus without QtWebKit or QtWebEngine dependencies, for this use CMake option BUILD_WITH_OAUTH_SUPPORT=NO
.
Also, if Qt4's QtTest or Qt5's Qt5Test modules are found during the pre-build configuration, the unit tests are enabled and can be run with make test
command.
The project uses CMake build system which can be used as simply as follows (on Unix platforms):
Please note that installing the library somewhere is mandatory because it puts the library's headers into the subfolder dependent on used Qt version: either qt4qevercloud or qt5qevercloud. The intended use of library's headers is something like this:
If you just need to use the only one Qt version, you can skip the check and just include the header file you need.
More CMake configurations options available:
BUILD_DOCUMENTATION - when ON, attempts to find Doxygen and in case of success adds doc target so the documentation can be built using make doc
command after the cmake ../
step. By default this option is on.
BUILD_QCH_DOCUMENTATION - when ON, passes instructions on to Doxygen to build the documentation in qch format. This option only has any meaning if BUILD_DOCUMENTATION option is on. By default this option is off.
BUILD_SHARED - when ON, CMake configures the build for the shared library. By default this option is on.
If BUILD_SHARED is ON, make install
would install the CMake module necessary for applications using CMake's find_package
command to find the installation of the library.
If MAJOR_VERSION_LIB_NAME_SUFFIX is on, make install
would add the major version as a suffix to the library's name.
If MAJOR_VERSION_DEV_HEADERS_FOLDER_NAME_SUFFIX is on, make install
would install the development headers into the folder which name would end with the major version of QEverCloud.
The two latter options are intended to allow for easier installation of multiple major versions of QEverCloud.
The library can be built with both Qt4 and Qt5 versions of the framework. By default Qt4 is used, if found. If you'd like to force finding the Qt5 version no matter whether Qt4 is found, pass -DUSE_QT5=1
option to CMake.
The API breaks only include the relocation of header files required in order to use the library: in 2.x one could simply do
while since 3.0 the intended way to use the installed shared library is the following:
Tha API breaks in 4.0 inlcude a few changes caused by migration from Evernote API 1.25 to Evernote API 1.28. The breaks are listed in a separate document.
The library uses Qt's web facilities for OAuth authentication. These can be based on either QtWebKit (for Qt4 and older versions of Qt5) or QWebEngine (for more recent versions of Qt5). With CMake build system the choice happens automatically during the pre-build configuration based on the used version of Qt. One can also choose to use QtWebKit even with newer versions of Qt via CMake option USE_QT5_WEBKIT
.
The library does not use any C++11/14/17 features directly but only through macros like Q_DECL_OVERRIDE
, Q_STATIC_ASSERT_X
, QStringLiteral
and others. Some of these macros are also "backported" to Qt4 version of the library i.e. they are defined by the library itself for Qt4 version. So the library should be buildable even with not C++11/14/17-compliant compiler.
Two "cumulative" headers - QEverCloud.h or QEverCloudOAuth.h - include everything needed for the general and OAuth functionality correspondingly. More "fine-grained" headers are available within the same subfolder if needed.