diff options
Diffstat (limited to 'kde-base/kleopatra/files/kleopatra-4.4.3-assuan2.patch')
-rw-r--r-- | kde-base/kleopatra/files/kleopatra-4.4.3-assuan2.patch | 1083 |
1 files changed, 0 insertions, 1083 deletions
diff --git a/kde-base/kleopatra/files/kleopatra-4.4.3-assuan2.patch b/kde-base/kleopatra/files/kleopatra-4.4.3-assuan2.patch deleted file mode 100644 index cb716bcbf7de..000000000000 --- a/kde-base/kleopatra/files/kleopatra-4.4.3-assuan2.patch +++ /dev/null @@ -1,1083 +0,0 @@ -Index: cmake/modules/FindAssuan2.cmake -=================================================================== ---- cmake/modules/FindAssuan2.cmake (revision 0) -+++ cmake/modules/FindAssuan2.cmake (revision 1078528) -@@ -0,0 +1,251 @@ -+# - Try to find the assuan v2 library -+ -+# Variables set: -+# ASSUAN2_{INCLUDES,FOUND,LIBRARIES} will be set for each of the above -+ -+# do away with crappy condition repetition on else/endfoo -+set( CMAKE_ALLOW_LOOSE_LOOP_CONSTRUCTS_assuan2_saved ${CMAKE_ALLOW_LOOSE_LOOP_CONSTRUCTS} ) -+set( CMAKE_ALLOW_LOOSE_LOOP_CONSTRUCTS true ) -+ -+#if this is built-in, please replace, if it isn't, export into a MacroToBool.cmake of it's own -+macro( macro_bool_to_bool FOUND_VAR ) -+ foreach( _current_VAR ${ARGN} ) -+ if ( ${FOUND_VAR} ) -+ set( ${_current_VAR} TRUE ) -+ else() -+ set( ${_current_VAR} FALSE ) -+ endif() -+ endforeach() -+endmacro() -+ -+include (MacroEnsureVersion) -+ -+message( STATUS "In FindAssuan2.cmake" ) -+ -+if ( WIN32 ) -+ -+ # On Windows, we don't have a libassuan-config script, so we need to -+ # look for the stuff ourselves: -+ -+ # in cmake, AND and OR have the same precedence, there's no -+ # subexpressions, and expressions are evaluated short-circuit'ed -+ # IOW: CMake if() suxx. -+ set( _seem_to_have_cached_assuan2 false ) -+ if ( ASSUAN2_INCLUDES ) -+ if ( ASSUAN2_VANILLA_LIBRARIES )#OR ASSUAN2_QT_LIBRARIES OR ASSUAN2_GLIB_LIBRARIES ) -+ set( _seem_to_have_cached_assuan2 true ) -+ endif() -+ endif() -+ -+ if ( _seem_to_have_cached_assuan2 ) -+ -+ macro_bool_to_bool( ASSUAN2_VANILLA_LIBRARIES ASSUAN2_VANILLA_FOUND ) -+ # this would have been preferred: -+ #set( ASSUAN2_*_FOUND macro_bool_to_bool(ASSUAN2_*_LIBRARIES) ) -+ -+ if ( ASSUAN2_VANILLA_FOUND ) #OR ASSUAN2_GLIB_FOUND OR ASSUAN2_QT_FOUND ) -+ set( ASSUAN2_FOUND true ) -+ else() -+ set( ASSUAN2_FOUND false ) -+ endif() -+ -+ else() -+ -+ set( ASSUAN2_FOUND false ) -+ set( ASSUAN2_VANILLA_FOUND false ) -+ #set( ASSUAN2_GLIB_FOUND false ) -+ #set( ASSUAN2_QT_FOUND false ) -+ -+ find_path( ASSUAN2_INCLUDES assuan.h -+ ${CMAKE_INCLUDE_PATH} -+ ${CMAKE_INSTALL_PREFIX}/include -+ ) -+ -+ find_library( _assuan2_library NAMES assuan assuan0 assuan2 libassuan libassuan0 libassuan2 -+ PATHS -+ ${CMAKE_LIBRARY_PATH} -+ ${CMAKE_INSTALL_PREFIX}/lib -+ ) -+ -+ find_library( _gpg_error_library NAMES gpg-error libgpg-error gpg-error-0 libgpg-error-0 -+ PATHS -+ ${CMAKE_LIBRARY_PATH} -+ ${CMAKE_INSTALL_PREFIX}/lib -+ ) -+ -+ set( ASSUAN2_INCLUDES ${ASSUAN2_INCLUDES} ) -+ -+ if ( _assuan2_library AND _gpg_error_library ) -+ set( ASSUAN2_LIBRARIES ${_assuan2_library} ${_gpg_error_library} ws2_32 ) -+ set( ASSUAN2_FOUND true ) -+ endif() -+ -+ endif() -+ -+ macro_bool_to_01( ASSUAN2_FOUND HAVE_ASSUAN2 ) -+ -+else() # not WIN32 -+ -+ # On *nix, we have the libassuan-config script which can tell us all we -+ # need to know: -+ -+ # see WIN32 case for an explanation of what this does: -+ set( _seem_to_have_cached_assuan2 false ) -+ if ( ASSUAN2_INCLUDES AND ASSUAN2_LIBRARIES ) -+ set( _seem_to_have_cached_assuan2 true ) -+ endif() -+ -+ if ( _seem_to_have_cached_assuan2 ) -+ -+ set( ASSUAN2_FOUND true ) -+ -+ else() -+ -+ set( ASSUAN2_FOUND false ) -+ -+ find_program( _ASSUAN2CONFIG_EXECUTABLE NAMES libassuan-config ) -+ -+ # if libassuan-config has been found -+ if ( _ASSUAN2CONFIG_EXECUTABLE ) -+ -+ message( STATUS "Found libassuan-config at ${_ASSUAN2CONFIG_EXECUTABLE}" ) -+ -+ exec_program( ${_ASSUAN2CONFIG_EXECUTABLE} ARGS --version OUTPUT_VARIABLE ASSUAN2_VERSION ) -+ -+ set( _ASSUAN2_MIN_VERSION "2.0.0" ) -+ macro_ensure_version( ${_ASSUAN2_MIN_VERSION} ${ASSUAN2_VERSION} _ASSUAN2_INSTALLED_VERSION_OK ) -+ -+ if ( NOT _ASSUAN2_INSTALLED_VERSION_OK ) -+ -+ message( STATUS "The installed version of assuan is too old: ${ASSUAN2_VERSION} (required: >= ${_ASSUAN2_MIN_VERSION})" ) -+ -+ else() -+ -+ message( STATUS "Found assuan v${ASSUAN2_VERSION}" ) -+ -+ exec_program( ${_ASSUAN2CONFIG_EXECUTABLE} ARGS --libs OUTPUT_VARIABLE _assuan2_config_libs RETURN_VALUE _ret ) -+ if ( _ret ) -+ set( _assuan2_config_libs ) -+ endif() -+ -+ # append -lgpg-error to the list of libraries, if necessary -+ if ( _assuan2_config_libs AND NOT _assuan2_config_libs MATCHES "lgpg-error" ) -+ set( _assuan2_config_libs "${_assuan2_config_libs} -lgpg-error" ) -+ endif() -+ -+ if ( _assuan2_config_libs ) -+ -+ exec_program( ${_ASSUAN2CONFIG_EXECUTABLE} ARGS --cflags OUTPUT_VARIABLE _ASSUAN2_CFLAGS ) -+ -+ if ( _ASSUAN2_CFLAGS ) -+ string( REGEX REPLACE "(\r?\n)+$" " " _ASSUAN2_CFLAGS "${_ASSUAN2_CFLAGS}" ) -+ string( REGEX REPLACE " *-I" ";" ASSUAN2_INCLUDES "${_ASSUAN2_CFLAGS}" ) -+ endif() -+ -+ if ( _assuan2_config_libs ) -+ -+ set( _assuan2_library_dirs ) -+ set( _assuan2_library_names ) -+ -+ string( REGEX REPLACE " +" ";" _assuan2_config_libs "${_assuan2_config_libs}" ) -+ -+ foreach( _flag ${_assuan2_config_libs} ) -+ if ( "${_flag}" MATCHES "^-L" ) -+ string( REGEX REPLACE "^-L" "" _dir "${_flag}" ) -+ file( TO_CMAKE_PATH "${_dir}" _dir ) -+ set( _assuan2_library_dirs ${_assuan2_library_dirs} "${_dir}" ) -+ elseif( "${_flag}" MATCHES "^-l" ) -+ string( REGEX REPLACE "^-l" "" _name "${_flag}" ) -+ set( _assuan2_library_names ${_assuan2_library_names} "${_name}" ) -+ endif() -+ endforeach() -+ -+ set( ASSUAN2_FOUND true ) -+ -+ foreach( _name ${_assuan2_library_names} ) -+ set( _assuan2_${_name}_lib ) -+ -+ # if -L options were given, look only there -+ if ( _assuan2_library_dirs ) -+ find_library( _assuan2_${_name}_lib NAMES ${_name} PATHS ${_assuan2_library_dirs} NO_DEFAULT_PATH ) -+ endif() -+ -+ # if not found there, look in system directories -+ if ( NOT _assuan2_${_name}_lib ) -+ find_library( _assuan2_${_name}_lib NAMES ${_name} ) -+ endif() -+ -+ # if still not found, then the whole flavour isn't found -+ if ( NOT _assuan2_${_name}_lib ) -+ if ( ASSUAN2_FOUND ) -+ set( ASSUAN2_FOUND false ) -+ set( _not_found_reason "dependant library ${_name} wasn't found" ) -+ endif() -+ endif() -+ -+ set( ASSUAN2_LIBRARIES ${ASSUAN2_LIBRARIES} "${_assuan2_${_name}_lib}" ) -+ endforeach() -+ -+ #check_c_library_exists_explicit( assuan assuan_check_version "${_ASSUAN2_CFLAGS}" "${ASSUAN2_LIBRARIES}" ASSUAN2_FOUND ) -+ if ( ASSUAN2_FOUND ) -+ message( STATUS " Checking whether assuan is usable...yes" ) -+ else() -+ message( STATUS " Checking whether assuan is usable...no" ) -+ message( STATUS " (${_not_found_reason})" ) -+ endif() -+ endif() -+ -+ # ensure that they are cached -+ set( ASSUAN2_INCLUDES ${ASSUAN2_INCLUDES} ) -+ set( ASSUAN2_LIBRARIES ${ASSUAN2_LIBRARIES} ) -+ -+ endif() -+ -+ endif() -+ -+ endif() -+ -+ endif() -+ -+ macro_bool_to_01( ASSUAN2_FOUND HAVE_ASSUAN2 ) -+ -+endif() # WIN32 | Unix -+ -+ -+if ( NOT Assuan2_FIND_QUIETLY ) -+ -+ if ( ASSUAN2_FOUND ) -+ message( STATUS "Usable assuan found." ) -+ message( STATUS " Includes: ${ASSUAN2_INCLUDES}" ) -+ message( STATUS " Libraries: ${ASSUAN2_LIBRARIES}" ) -+ else() -+ message( STATUS "No usable assuan found." ) -+ endif() -+ -+ macro_bool_to_bool( Assuan2_FIND_REQUIRED _req ) -+ -+ if ( WIN32 ) -+ set( _assuan2_homepage "http://www.gpg4win.org" ) -+ else() -+ set( _assuan2_homepage "http://www.gnupg.org/related_software/libassuan" ) -+ endif() -+ -+ macro_log_feature( -+ ASSUAN2_FOUND -+ "assuan2" -+ "Assuan v2 IPC library" -+ ${_assuan2_homepage} -+ ${_req} -+ "${_ASSUAN2_MIN_VERSION} or greater" -+ "Needed for Kleopatra to act as the GnuPG UI Server" -+ ) -+ -+else() -+ -+ if ( Assuan2_FIND_REQUIRED AND NOT ASSUAN2_FOUND ) -+ message( FATAL_ERROR "" ) -+ endif() -+ -+endif() -+ -+set( CMAKE_ALLOW_LOOSE_LOOP_CONSTRUCTS CMAKE_ALLOW_LOOSE_LOOP_CONSTRUCTS_assuan2_saved ) -Index: kleopatra/ConfigureChecks.cmake -=================================================================== ---- kleopatra/ConfigureChecks.cmake (revision 1078527) -+++ kleopatra/ConfigureChecks.cmake (revision 1078528) -@@ -1,21 +1,18 @@ - # assuan configure checks - include(CheckFunctionExists) - --macro_optional_find_package(Assuan) -+macro_optional_find_package(Assuan2) - - set( USABLE_ASSUAN_FOUND false ) - --if ( ASSUAN_FOUND ) -+if ( ASSUAN2_FOUND ) - -- set( CMAKE_REQUIRED_INCLUDES ${ASSUAN_INCLUDES} ) -+ set( CMAKE_REQUIRED_INCLUDES ${ASSUAN2_INCLUDES} ) - -- if ( WIN32 AND ASSUAN_VANILLA_FOUND ) -- set( CMAKE_REQUIRED_LIBRARIES ${ASSUAN_VANILLA_LIBRARIES} ) -+ if ( ASSUAN2_FOUND ) -+ set( CMAKE_REQUIRED_LIBRARIES ${ASSUAN2_LIBRARIES} ) - set( USABLE_ASSUAN_FOUND true ) -- elseif( NOT WIN32 AND ASSUAN_PTHREAD_FOUND ) -- set( CMAKE_REQUIRED_LIBRARIES ${ASSUAN_PTHREAD_LIBRARIES} ) -- set( USABLE_ASSUAN_FOUND true ) -- endif( WIN32 AND ASSUAN_VANILLA_FOUND ) -+ endif( ASSUAN2_FOUND ) - - # TODO: this workaround will be removed as soon as we find better solution - if(MINGW) -@@ -24,7 +21,7 @@ - set(CMAKE_REQUIRED_INCLUDES ${CMAKE_REQUIRED_INCLUDES} ${KDEWIN32_INCLUDE_DIR}/msvc) - endif(MINGW) - --endif( ASSUAN_FOUND ) -+endif( ASSUAN2_FOUND ) - - if ( USABLE_ASSUAN_FOUND ) - # check if assuan.h can be compiled standalone (it couldn't, on -@@ -48,40 +45,6 @@ - - if ( USABLE_ASSUAN_FOUND ) - -- # check if assuan has assuan_fd_t -- check_cxx_source_compiles(" -- #include <assuan.h> -- int main() { -- assuan_fd_t fd = ASSUAN_INVALID_FD; -- return fd ? 1 : 0 ; -- } -- " -- HAVE_ASSUAN_FD_T ) -- -- if ( WIN32 AND NOT HAVE_ASSUAN_FD_T ) -- set( USABLE_ASSUAN_FOUND false ) -- endif ( WIN32 AND NOT HAVE_ASSUAN_FD_T ) -- -- # check if assuan has assuan_inquire_ext, old style -- check_function_exists( "assuan_inquire_ext" HAVE_ASSUAN_INQUIRE_EXT ) -- -- if ( NOT HAVE_ASSUAN_INQUIRE_EXT ) -- set( USABLE_ASSUAN_FOUND false ) -- endif( NOT HAVE_ASSUAN_INQUIRE_EXT ) -- -- # check if assuan has new-style assuan_inquire_ext: -- check_cxx_source_compiles(" -- #include <assuan.h> -- static int handler( void *, int, unsigned char*, size_t ) { return 0; } -- int main() { -- assuan_context_t ctx = 0; -- const size_t maxSize = 0U; -- assuan_error_t err = assuan_inquire_ext( ctx, \"FOO\", maxSize, handler, (void*)0 ); -- return err ? 1 : 0 ; -- } -- " -- HAVE_NEW_STYLE_ASSUAN_INQUIRE_EXT ) -- - # check if gpg-error already has GPG_ERR_SOURCE_KLEO - check_cxx_source_compiles(" - #include <gpg-error.h> -@@ -90,21 +53,6 @@ - " - HAVE_GPG_ERR_SOURCE_KLEO ) - -- # check if assuan has assuan_sock_get_nonce (via assuan_sock_nonce_t) -- # function_exists runs into linking errors - libassuan is static, -- # and assuan_sock_get_nonce drags in stuff that needs linking -- # against winsock2. -- check_cxx_source_compiles(" -- #include <assuan.h> -- static assuan_sock_nonce_t nonce; -- int main() { return 0; } -- " -- HAVE_ASSUAN_SOCK_GET_NONCE ) -- -- if ( WIN32 AND NOT HAVE_ASSUAN_SOCK_GET_NONCE ) -- set( USABLE_ASSUAN_FOUND false ) -- endif ( WIN32 AND NOT HAVE_ASSUAN_SOCK_GET_NONCE ) -- - endif ( USABLE_ASSUAN_FOUND ) - - if ( USABLE_ASSUAN_FOUND ) -@@ -113,45 +61,14 @@ - message( STATUS "NO usable assuan found for Kleopatra" ) - endif ( USABLE_ASSUAN_FOUND ) - --# --# Check that libassuan (which is built statically) can be linked into a DSO --# (e.g. on amd64, this requires it to be compiled with -fPIC). --# -- --set ( ASSUAN_LINKABLE_TO_DSO false ) -- - OPTION( BUILD_libkleopatraclient "Build directory kleopatra/libkleopatraclient" ${USABLE_ASSUAN_FOUND} ) - - if ( NOT USABLE_ASSUAN_FOUND ) - set( BUILD_libkleopatraclient false ) - endif ( NOT USABLE_ASSUAN_FOUND ) - --if ( BUILD_libkleopatraclient ) -- -- message( STATUS "Checking whether libassuan can be linked against from DSO's" ) -- -- set ( YUP TRUE ) -- if ( YUP ) -- set ( ASSUAN_LINKABLE_TO_DSO true ) -- message( STATUS "--> Assuming that it can. If compilation of libkleopatraclient fails on AMD64, check that libassuan is compiled with -fPIC and try again. Otherwise, pass -DBUILD_libkleopatraclient=OFF." ) -- else ( YUP ) -- # TODO: make this one executed at configure time, so the check below works: -- add_library( dso_with_assuan_check SHARED ${CMAKE_SOURCE_DIR}/kleopatra/dso_with_assuan_check.c ) -- -- set( CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES} dso_with_assuan_check ) -- check_cxx_source_compiles( "int main() { return 0; }" ASSUAN_LINKABLE_TO_DSO ) -- -- if ( ASSUAN_LINKABLE_TO_DSO ) -- message( STATUS "Usable assuan found for libkleopatraclient" ) -- else ( ASSUAN_LINKABLE_TO_DSO ) -- message( STATUS "NO usable assuan found for libkleopatraclient - if this is AMD64, check that libassuan is compiled with -fPIC" ) -- endif ( ASSUAN_LINKABLE_TO_DSO ) -- endif ( YUP ) -- --endif ( BUILD_libkleopatraclient ) -- - macro_bool_to_01( USABLE_ASSUAN_FOUND HAVE_USABLE_ASSUAN ) --macro_bool_to_01( ASSUAN_LINKABLE_TO_DSO HAVE_KLEOPATRACLIENT_LIBRARY ) -+macro_bool_to_01( USABLE_ASSUAN_FOUND HAVE_KLEOPATRACLIENT_LIBRARY ) - - set(CMAKE_REQUIRED_INCLUDES) - set(CMAKE_REQUIRED_LIBRARIES) -Index: kleopatra/config-kleopatra.h.cmake -=================================================================== ---- kleopatra/config-kleopatra.h.cmake (revision 1078527) -+++ kleopatra/config-kleopatra.h.cmake (revision 1078528) -@@ -1,18 +1,6 @@ - /* Define to 1 if you have a recent enough libassuan */ - #cmakedefine HAVE_USABLE_ASSUAN 1 - --/* Define to 1 if your libassuan has the assuan_fd_t type */ --#cmakedefine HAVE_ASSUAN_FD_T 1 -- --/* Define to 1 if your libassuan has the assuan_inquire_ext function */ --#cmakedefine HAVE_ASSUAN_INQUIRE_EXT 1 -- --/* Define to 1 if your assuan_inquire_ext puts the buffer arguments into the callback signature */ --#cmakedefine HAVE_NEW_STYLE_ASSUAN_INQUIRE_EXT 1 -- --/* Define to 1 if your libassuan has the assuan_sock_get_nonce function */ --#cmakedefine HAVE_ASSUAN_SOCK_GET_NONCE 1 -- - /* Define to 1 if you build libkleopatraclient */ - #cmakedefine HAVE_KLEOPATRACLIENT_LIBRARY 1 - -Index: kleopatra/tests/test_uiserver.cpp -=================================================================== ---- kleopatra/tests/test_uiserver.cpp (revision 1078527) -+++ kleopatra/tests/test_uiserver.cpp (revision 1078528) -@@ -89,17 +89,17 @@ - exit( 1 ); - } - --static assuan_error_t data( void * void_ctx, const void * buffer, size_t len ) { -+static gpg_error_t data( void * void_ctx, const void * buffer, size_t len ) { - (void)void_ctx; (void)buffer; (void)len; - return 0; // ### implement me - } - --static assuan_error_t status( void * void_ctx, const char * line ) { -+static gpg_error_t status( void * void_ctx, const char * line ) { - (void)void_ctx; (void)line; - return 0; - } - --static assuan_error_t inquire( void * void_ctx, const char * keyword ) { -+static gpg_error_t inquire( void * void_ctx, const char * keyword ) { - assuan_context_t ctx = (assuan_context_t)void_ctx; - assert( ctx ); - const std::map<std::string,std::string>::const_iterator it = inquireData.find( keyword ); -@@ -121,7 +121,7 @@ - - const Kleo::WSAStarter _wsastarter; - -- assuan_set_assuan_err_source( GPG_ERR_SOURCE_DEFAULT ); -+ assuan_set_gpg_err_source( GPG_ERR_SOURCE_DEFAULT ); - - if ( argc < 3 ) - usage(); // need socket and command, at least -@@ -185,7 +185,12 @@ - - assuan_context_t ctx = 0; - -- if ( const gpg_error_t err = assuan_socket_connect_ext( &ctx, socket, -1, ASSUAN_CONNECT_FLAGS ) ) { -+ if ( const gpg_error_t err = assuan_new( &ctx ) ) { -+ qDebug( "%s", Exception( err, "assuan_new" ).what() ); -+ return 1; -+ } -+ -+ if ( const gpg_error_t err = assuan_socket_connect( ctx, socket, -1, ASSUAN_CONNECT_FLAGS ) ) { - qDebug( "%s", Exception( err, "assuan_socket_connect_ext" ).what() ); - return 1; - } -@@ -279,7 +284,7 @@ - return 1; - } - -- assuan_disconnect( ctx ); -+ assuan_release( ctx ); - - return 0; - } -Index: kleopatra/uiserver/assuancommand.h -=================================================================== ---- kleopatra/uiserver/assuancommand.h (revision 1078527) -+++ kleopatra/uiserver/assuancommand.h (revision 1078528) -@@ -39,6 +39,8 @@ - #include <gpgme++/global.h> - #include <gpgme++/error.h> - -+#include <gpg-error.h> -+ - #include <kmime/kmime_header_parsing.h> - - #include <qwindowdefs.h> // for WId -@@ -329,16 +331,16 @@ - virtual boost::shared_ptr<AssuanCommand> create() const = 0; - virtual const char * name() const = 0; - -- typedef int(*_Handler)( assuan_context_s*, char *); -+ typedef gpg_error_t(*_Handler)( assuan_context_s*, char *); - virtual _Handler _handler() const = 0; - protected: -- static int _handle( assuan_context_s*, char *, const char * ); -+ static gpg_error_t _handle( assuan_context_s*, char *, const char * ); - }; - - template <typename Command> - class GenericAssuanCommandFactory : public AssuanCommandFactory { - /* reimp */ AssuanCommandFactory::_Handler _handler() const { return &GenericAssuanCommandFactory::_handle; } -- static int _handle( assuan_context_s* _ctx, char * _line ) { -+ static gpg_error_t _handle( assuan_context_s* _ctx, char * _line ) { - return AssuanCommandFactory::_handle( _ctx, _line, Command::staticName() ); - } - /* reimp */ boost::shared_ptr<AssuanCommand> create() const { return make(); } -Index: kleopatra/uiserver/assuanserverconnection.cpp -=================================================================== ---- kleopatra/uiserver/assuanserverconnection.cpp (revision 1078527) -+++ kleopatra/uiserver/assuanserverconnection.cpp (revision 1078528) -@@ -116,13 +116,18 @@ - static const int FOR_READING = 0; - static const unsigned int MAX_ACTIVE_FDS = 32; - -+static void my_assuan_release( assuan_context_t ctx ) { -+ if ( ctx ) -+ assuan_release( ctx ); -+} -+ - // shared_ptr for assuan_context_t w/ deleter enforced to assuan_deinit_server: - typedef shared_ptr< remove_pointer<assuan_context_t>::type > AssuanContextBase; - struct AssuanContext : AssuanContextBase { - AssuanContext() : AssuanContextBase() {} -- explicit AssuanContext( assuan_context_t ctx ) : AssuanContextBase( ctx, &assuan_deinit_server ) {} -+ explicit AssuanContext( assuan_context_t ctx ) : AssuanContextBase( ctx, &my_assuan_release ) {} - -- void reset( assuan_context_t ctx=0 ) { AssuanContextBase::reset( ctx, &assuan_deinit_server ); } -+ void reset( assuan_context_t ctx=0 ) { AssuanContextBase::reset( ctx, &my_assuan_release ); } - }; - - static inline gpg_error_t assuan_process_done_msg( assuan_context_t ctx, gpg_error_t err, const char * err_msg ) { -@@ -240,7 +245,8 @@ - public Q_SLOTS: - void slotReadActivity( int ) { - assert( ctx ); -- if ( const int err = assuan_process_next( ctx.get() ) ) { -+ int done = false; -+ if ( const int err = assuan_process_next( ctx.get(), &done ) || done ) { - //if ( err == -1 || gpg_err_code(err) == GPG_ERR_EOF ) { - topHalfDeletion(); - if ( nohupedCommands.empty() ) -@@ -296,15 +302,17 @@ - } - - private: -- static void reset_handler( assuan_context_t ctx_ ) { -+ static gpg_error_t reset_handler( assuan_context_t ctx_, char * ) { - assert( assuan_get_pointer( ctx_ ) ); - - AssuanServerConnection::Private & conn = *static_cast<AssuanServerConnection::Private*>( assuan_get_pointer( ctx_ ) ); - - conn.reset(); -+ -+ return 0; - } - -- static int option_handler( assuan_context_t ctx_, const char * key, const char * value ) { -+ static gpg_error_t option_handler( assuan_context_t ctx_, const char * key, const char * value ) { - assert( assuan_get_pointer( ctx_ ) ); - - AssuanServerConnection::Private & conn = *static_cast<AssuanServerConnection::Private*>( assuan_get_pointer( ctx_ ) ); -@@ -317,7 +325,7 @@ - //return gpg_error( GPG_ERR_UNKNOWN_OPTION ); - } - -- static int session_handler( assuan_context_t ctx_, char * line ) { -+ static gpg_error_t session_handler( assuan_context_t ctx_, char * line ) { - assert( assuan_get_pointer( ctx_ ) ); - AssuanServerConnection::Private & conn = *static_cast<AssuanServerConnection::Private*>( assuan_get_pointer( ctx_ ) ); - -@@ -344,7 +352,7 @@ - return assuan_process_done( ctx_, 0 ); - } - -- static int capabilities_handler( assuan_context_t ctx_, char * line ) { -+ static gpg_error_t capabilities_handler( assuan_context_t ctx_, char * line ) { - if ( !QByteArray( line ).trimmed().isEmpty() ) { - static const QString errorString = i18n("CAPABILITIES does not take arguments"); - return assuan_process_done_msg( ctx_, gpg_error( GPG_ERR_ASS_PARAMETER ), errorString ); -@@ -357,7 +365,7 @@ - return assuan_process_done( ctx_, assuan_send_data( ctx_, capabilities, sizeof capabilities - 1 ) ); - } - -- static int getinfo_handler( assuan_context_t ctx_, char * line ) { -+ static gpg_error_t getinfo_handler( assuan_context_t ctx_, char * line ) { - assert( assuan_get_pointer( ctx_ ) ); - AssuanServerConnection::Private & conn = *static_cast<AssuanServerConnection::Private*>( assuan_get_pointer( ctx_ ) ); - -@@ -386,7 +394,7 @@ - return assuan_process_done( ctx_, assuan_send_data( ctx_, ba.constData(), ba.size() ) ); - } - -- static int start_keymanager_handler( assuan_context_t ctx_, char * line ) { -+ static gpg_error_t start_keymanager_handler( assuan_context_t ctx_, char * line ) { - assert( assuan_get_pointer( ctx_ ) ); - AssuanServerConnection::Private & conn = *static_cast<AssuanServerConnection::Private*>( assuan_get_pointer( ctx_ ) ); - -@@ -400,7 +408,7 @@ - return assuan_process_done( ctx_, 0 ); - } - -- static int start_confdialog_handler( assuan_context_t ctx_, char * line ) { -+ static gpg_error_t start_confdialog_handler( assuan_context_t ctx_, char * line ) { - assert( assuan_get_pointer( ctx_ ) ); - AssuanServerConnection::Private & conn = *static_cast<AssuanServerConnection::Private*>( assuan_get_pointer( ctx_ ) ); - -@@ -418,7 +426,7 @@ - - // format: TAG (FD|FD=\d+|FILE=...) - template <bool in, typename T_memptr> -- static int IO_handler( assuan_context_t ctx_, char * line_, T_memptr which ) { -+ static gpg_error_t IO_handler( assuan_context_t ctx_, char * line_, T_memptr which ) { - assert( assuan_get_pointer( ctx_ ) ); - AssuanServerConnection::Private & conn = *static_cast<AssuanServerConnection::Private*>( assuan_get_pointer( ctx_ ) ); - -@@ -498,19 +506,19 @@ - - } - -- static int input_handler( assuan_context_t ctx, char * line ) { -+ static gpg_error_t input_handler( assuan_context_t ctx, char * line ) { - return IO_handler<true>( ctx, line, &Private::inputs ); - } - -- static int output_handler( assuan_context_t ctx, char * line ) { -+ static gpg_error_t output_handler( assuan_context_t ctx, char * line ) { - return IO_handler<false>( ctx, line, &Private::outputs ); - } - -- static int message_handler( assuan_context_t ctx, char * line ) { -+ static gpg_error_t message_handler( assuan_context_t ctx, char * line ) { - return IO_handler<true>( ctx, line, &Private::messages ); - } - -- static int file_handler( assuan_context_t ctx_, char * line ) { -+ static gpg_error_t file_handler( assuan_context_t ctx_, char * line ) { - assert( assuan_get_pointer( ctx_ ) ); - AssuanServerConnection::Private & conn = *static_cast<AssuanServerConnection::Private*>( assuan_get_pointer( ctx_ ) ); - -@@ -572,7 +580,7 @@ - } - - template <typename T_memptr, typename T_memptr2> -- static int recipient_sender_handler( T_memptr mp, T_memptr2 info, assuan_context_t ctx, char * line, bool sender=false ) { -+ static gpg_error_t recipient_sender_handler( T_memptr mp, T_memptr2 info, assuan_context_t ctx, char * line, bool sender=false ) { - assert( assuan_get_pointer( ctx ) ); - AssuanServerConnection::Private & conn = *static_cast<AssuanServerConnection::Private*>( assuan_get_pointer( ctx ) ); - -@@ -656,11 +664,11 @@ - return assuan_process_done( ctx, 0 ); - } - -- static int recipient_handler( assuan_context_t ctx, char * line ) { -+ static gpg_error_t recipient_handler( assuan_context_t ctx, char * line ) { - return recipient_sender_handler( &Private::recipients, &Private::informativeRecipients, ctx, line ); - } - -- static int sender_handler( assuan_context_t ctx, char * line ) { -+ static gpg_error_t sender_handler( assuan_context_t ctx, char * line ) { - return recipient_sender_handler( &Private::senders, &Private::informativeSenders, ctx, line, true ); - } - -@@ -792,11 +800,15 @@ - if ( fd == ASSUAN_INVALID_FD ) - throw Exception( gpg_error( GPG_ERR_INV_ARG ), "pre-assuan_init_socket_server_ext" ); - -- assuan_context_t naked_ctx = 0; -- if ( const gpg_error_t err = assuan_init_socket_server_ext( &naked_ctx, fd, INIT_SOCKET_FLAGS ) ) -+ { -+ assuan_context_t naked_ctx = 0; -+ if ( const gpg_error_t err = assuan_new( &naked_ctx ) ) -+ throw Exception( err, "assuan_new" ); -+ ctx.reset( naked_ctx ); -+ } -+ if ( const gpg_error_t err = assuan_init_socket_server( ctx.get(), fd, INIT_SOCKET_FLAGS ) ) - throw Exception( err, "assuan_init_socket_server_ext" ); - -- ctx.reset( naked_ctx ); naked_ctx = 0; - - // for callbacks, associate the context with this connection: - assuan_set_pointer( ctx.get(), this ); -@@ -824,34 +836,34 @@ - - - // register our INPUT/OUTPUT/MESSGAE/FILE handlers: -- if ( const gpg_error_t err = assuan_register_command( ctx.get(), "INPUT", input_handler ) ) -+ if ( const gpg_error_t err = assuan_register_command( ctx.get(), "INPUT", input_handler, "" ) ) - throw Exception( err, "register \"INPUT\" handler" ); -- if ( const gpg_error_t err = assuan_register_command( ctx.get(), "MESSAGE", message_handler ) ) -+ if ( const gpg_error_t err = assuan_register_command( ctx.get(), "MESSAGE", message_handler, "" ) ) - throw Exception( err, "register \"MESSAGE\" handler" ); -- if ( const gpg_error_t err = assuan_register_command( ctx.get(), "OUTPUT", output_handler ) ) -+ if ( const gpg_error_t err = assuan_register_command( ctx.get(), "OUTPUT", output_handler, "" ) ) - throw Exception( err, "register \"OUTPUT\" handler" ); -- if ( const gpg_error_t err = assuan_register_command( ctx.get(), "FILE", file_handler ) ) -+ if ( const gpg_error_t err = assuan_register_command( ctx.get(), "FILE", file_handler, "" ) ) - throw Exception( err, "register \"FILE\" handler" ); - - - // register user-defined commands: - Q_FOREACH( shared_ptr<AssuanCommandFactory> fac, factories ) -- if ( const gpg_error_t err = assuan_register_command( ctx.get(), fac->name(), fac->_handler() ) ) -+ if ( const gpg_error_t err = assuan_register_command( ctx.get(), fac->name(), fac->_handler(), "" ) ) - throw Exception( err, std::string( "register \"" ) + fac->name() + "\" handler" ); - -- if ( const gpg_error_t err = assuan_register_command( ctx.get(), "GETINFO", getinfo_handler ) ) -+ if ( const gpg_error_t err = assuan_register_command( ctx.get(), "GETINFO", getinfo_handler, "" ) ) - throw Exception( err, "register \"GETINFO\" handler" ); -- if ( const gpg_error_t err = assuan_register_command( ctx.get(), "START_KEYMANAGER", start_keymanager_handler ) ) -+ if ( const gpg_error_t err = assuan_register_command( ctx.get(), "START_KEYMANAGER", start_keymanager_handler, "" ) ) - throw Exception( err, "register \"START_KEYMANAGER\" handler" ); -- if ( const gpg_error_t err = assuan_register_command( ctx.get(), "START_CONFDIALOG", start_confdialog_handler ) ) -+ if ( const gpg_error_t err = assuan_register_command( ctx.get(), "START_CONFDIALOG", start_confdialog_handler, "" ) ) - throw Exception( err, "register \"START_CONFDIALOG\" handler" ); -- if ( const gpg_error_t err = assuan_register_command( ctx.get(), "RECIPIENT", recipient_handler ) ) -+ if ( const gpg_error_t err = assuan_register_command( ctx.get(), "RECIPIENT", recipient_handler, "" ) ) - throw Exception( err, "register \"RECIPIENT\" handler" ); -- if ( const gpg_error_t err = assuan_register_command( ctx.get(), "SENDER", sender_handler ) ) -+ if ( const gpg_error_t err = assuan_register_command( ctx.get(), "SENDER", sender_handler, "" ) ) - throw Exception( err, "register \"SENDER\" handler" ); -- if ( const gpg_error_t err = assuan_register_command( ctx.get(), "SESSION", session_handler ) ) -+ if ( const gpg_error_t err = assuan_register_command( ctx.get(), "SESSION", session_handler, "" ) ) - throw Exception( err, "register \"SESSION\" handler" ); -- if ( const gpg_error_t err = assuan_register_command( ctx.get(), "CAPABILITIES", capabilities_handler ) ) -+ if ( const gpg_error_t err = assuan_register_command( ctx.get(), "CAPABILITIES", capabilities_handler, "" ) ) - throw Exception( err, "register \"CAPABILITIES\" handler" ); - - assuan_set_hello_line( ctx.get(), "GPG UI server (Kleopatra/" KLEOPATRA_VERSION_STRING ") ready to serve" ); -@@ -904,20 +916,14 @@ - Q_OBJECT - public: - --#ifdef HAVE_ASSUAN_INQUIRE_EXT - explicit InquiryHandler( const char * keyword_, QObject * p=0 ) - : QObject( p ), --# ifndef HAVE_NEW_STYLE_ASSUAN_INQUIRE_EXT -- buffer( 0 ), -- buflen( 0 ), --# endif - keyword( keyword_ ) - { - - } - --# ifdef HAVE_NEW_STYLE_ASSUAN_INQUIRE_EXT -- static int handler( void * cb_data, int rc, unsigned char * buffer, size_t buflen ) -+ static gpg_error_t handler( void * cb_data, gpg_error_t rc, unsigned char * buffer, size_t buflen ) - { - assert( cb_data ); - InquiryHandler * this_ = static_cast<InquiryHandler*>(cb_data); -@@ -926,26 +932,9 @@ - delete this_; - return 0; - } --# else -- static int handler( void * cb_data, int rc ) -- { -- assert( cb_data ); -- InquiryHandler * this_ = static_cast<InquiryHandler*>(cb_data); -- emit this_->signal( rc, QByteArray::fromRawData( reinterpret_cast<const char*>(this_->buffer), this_->buflen ), this_->keyword ); -- std::free( this_->buffer ); -- delete this_; -- return 0; -- } --# endif - - private: --# ifndef HAVE_NEW_STYLE_ASSUAN_INQUIRE_EXT -- friend class ::Kleo::AssuanCommand; -- unsigned char * buffer; -- size_t buflen; --# endif - const char * keyword; --#endif // HAVE_ASSUAN_INQUIRE_EXT - - Q_SIGNALS: - void signal( int rc, const QByteArray & data, const QByteArray & keyword ); -@@ -1157,20 +1146,13 @@ - if ( d->nohup ) - return makeError( GPG_ERR_INV_OP ); - --#ifdef HAVE_ASSUAN_INQUIRE_EXT - std::auto_ptr<InquiryHandler> ih( new InquiryHandler( keyword, receiver ) ); - receiver->connect( ih.get(), SIGNAL(signal(int,QByteArray,QByteArray)), slot ); - if ( const gpg_error_t err = assuan_inquire_ext( d->ctx.get(), keyword, --# ifndef HAVE_NEW_STYLE_ASSUAN_INQUIRE_EXT -- &ih->buffer, &ih->buflen, --# endif - maxSize, InquiryHandler::handler, ih.get() ) ) - return err; - ih.release(); - return 0; --#else -- return makeError( GPG_ERR_NOT_SUPPORTED ); // libassuan too old --#endif // HAVE_ASSUAN_INQUIRE_EXT - } - - void AssuanCommand::done( const GpgME::Error& err, const QString & details ) { -@@ -1262,7 +1244,7 @@ - return d->senders; - } - --int AssuanCommandFactory::_handle( assuan_context_t ctx, char * line, const char * commandName ) { -+gpg_error_t AssuanCommandFactory::_handle( assuan_context_t ctx, char * line, const char * commandName ) { - assert( assuan_get_pointer( ctx ) ); - AssuanServerConnection::Private & conn = *static_cast<AssuanServerConnection::Private*>( assuan_get_pointer( ctx ) ); - -Index: kleopatra/uiserver/uiserver.cpp -=================================================================== ---- kleopatra/uiserver/uiserver.cpp (revision 1078527) -+++ kleopatra/uiserver/uiserver.cpp (revision 1078528) -@@ -73,15 +73,15 @@ - actualSocketName(), - cryptoCommandsEnabled( false ) - { -- assuan_set_assuan_err_source( GPG_ERR_SOURCE_DEFAULT ); -+ assuan_set_gpg_err_source( GPG_ERR_SOURCE_DEFAULT ); - } - - bool UiServer::Private::isStaleAssuanSocket( const QString& fileName ) - { - assuan_context_t ctx = 0; -- const bool error = assuan_socket_connect_ext( &ctx, QFile::encodeName( fileName ).constData(), -1, 0 ); -+ const bool error = assuan_new( &ctx ) || assuan_socket_connect( ctx, QFile::encodeName( fileName ).constData(), -1, 0 ); - if ( !error ) -- assuan_disconnect( ctx ); -+ assuan_release( ctx ); - return error; - } - -@@ -166,13 +166,11 @@ - void UiServer::Private::incomingConnection( int fd ) { - try { - qDebug( "UiServer: client connect on fd %d", fd ); --#ifdef HAVE_ASSUAN_SOCK_GET_NONCE - if ( assuan_sock_check_nonce( (assuan_fd_t)fd, &nonce ) ) { - qDebug( "UiServer: nonce check failed" ); - assuan_sock_close( (assuan_fd_t)fd ); - return; - } --#endif - const shared_ptr<AssuanServerConnection> c( new AssuanServerConnection( (assuan_fd_t)fd, factories ) ); - connect( c.get(), SIGNAL(closed(Kleo::AssuanServerConnection*)), - this, SLOT(slotConnectionClosed(Kleo::AssuanServerConnection*)) ); -Index: kleopatra/uiserver/uiserver_unix.cpp -=================================================================== ---- kleopatra/uiserver/uiserver_unix.cpp (revision 1078527) -+++ kleopatra/uiserver/uiserver_unix.cpp (revision 1078528) -@@ -61,11 +61,7 @@ - - void UiServer::Private::doMakeListeningSocket( const QByteArray & encodedFileName ) { - // Create a Unix Domain Socket: --#ifdef HAVE_ASSUAN_SOCK_GET_NONCE - const assuan_fd_t sock = assuan_sock_new( AF_UNIX, SOCK_STREAM, 0 ); --#else -- const assuan_fd_t sock = ::socket( AF_UNIX, SOCK_STREAM, 0 ); --#endif - if ( sock == ASSUAN_INVALID_FD ) - throw_<std::runtime_error>( i18n( "Could not create socket: %1", systemErrorString() ) ); - -@@ -75,19 +71,13 @@ - std::memset( &sa, 0, sizeof(sa) ); - sa.sun_family = AF_UNIX; - std::strncpy( sa.sun_path, encodedFileName.constData(), sizeof( sa.sun_path ) - 1 ); --#ifdef HAVE_ASSUAN_SOCK_GET_NONCE - if ( assuan_sock_bind( sock, (struct sockaddr*)&sa, sizeof( sa ) ) ) --#else -- if ( ::bind( sock, (struct sockaddr*)&sa, sizeof( sa ) ) ) --#endif - throw_<std::runtime_error>( i18n( "Could not bind to socket: %1", systemErrorString() ) ); - - // ### TODO: permissions? - --#ifdef HAVE_ASSUAN_SOCK_GET_NONCE - if ( assuan_sock_get_nonce( (struct sockaddr*)&sa, sizeof( sa ), &nonce ) ) - throw_<std::runtime_error>( i18n("Could not get socket nonce: %1", systemErrorString() ) ); --#endif - - // Listen - if ( ::listen( sock, SOMAXCONN ) ) -Index: kleopatra/CMakeLists.txt -=================================================================== ---- kleopatra/CMakeLists.txt (revision 1078527) -+++ kleopatra/CMakeLists.txt (revision 1078528) -@@ -2,7 +2,7 @@ - - include(MacroOptionalAddSubdirectory) - --set( kleopatra_version 2.0.12 ) -+set( kleopatra_version 2.1.0 ) - set( kleopatra_release FALSE ) - - if (NOT kleopatra_release) -@@ -28,7 +28,7 @@ - ${QGPGME_INCLUDES} - ${GPGME_INCLUDES} ) - if (USABLE_ASSUAN_FOUND) -- include_directories(${ASSUAN_INCLUDES}) -+ include_directories(${ASSUAN2_INCLUDES}) - endif(USABLE_ASSUAN_FOUND) - add_definitions ( -DQT3_SUPPORT -DQT3_SUPPORT_WARNINGS -D_ASSUAN_ONLY_GPG_ERRORS -DQT_STL ) - remove_definitions ( -DQT_NO_STL ) -@@ -84,11 +84,7 @@ - selftest/uiservercheck.cpp - ) - -- if ( WIN32 ) -- set( _kleopatra_uiserver_extra_libs ${ASSUAN_VANILLA_LIBRARIES} ) -- else ( WIN32 ) -- set( _kleopatra_uiserver_extra_libs ${ASSUAN_PTHREAD_LIBRARIES} ) -- endif( WIN32 ) -+ set( _kleopatra_uiserver_extra_libs ${ASSUAN2_LIBRARIES} ) - - if ( HAVE_GPG_ERR_SOURCE_KLEO ) - add_definitions( -DGPG_ERR_SOURCE_DEFAULT=GPG_ERR_SOURCE_KLEO ) -Index: kleopatra/libkleopatraclient/core/command.cpp -=================================================================== ---- kleopatra/libkleopatraclient/core/command.cpp (revision 1078527) -+++ kleopatra/libkleopatraclient/core/command.cpp (revision 1078528) -@@ -283,19 +283,19 @@ - namespace { - struct AssuanClientContext : AssuanContextBase { - AssuanClientContext() : AssuanContextBase() {} -- explicit AssuanClientContext( assuan_context_t ctx ) : AssuanContextBase( ctx, &assuan_disconnect ) {} -- void reset( assuan_context_t ctx=0 ) { AssuanContextBase::reset( ctx, &assuan_disconnect ); } -+ explicit AssuanClientContext( assuan_context_t ctx ) : AssuanContextBase( ctx, &assuan_release ) {} -+ void reset( assuan_context_t ctx=0 ) { AssuanContextBase::reset( ctx, &assuan_release ); } - }; - } - --static assuan_error_t -+static gpg_error_t - my_assuan_transact( const AssuanClientContext & ctx, - const char *command, -- assuan_error_t (*data_cb)( void *, const void *, size_t )=0, -+ gpg_error_t (*data_cb)( void *, const void *, size_t )=0, - void * data_cb_arg=0, -- assuan_error_t (*inquire_cb)( void *, const char * )=0, -+ gpg_error_t (*inquire_cb)( void *, const char * )=0, - void * inquire_cb_arg=0, -- assuan_error_t (*status_cb)( void *, const char * )=0, -+ gpg_error_t (*status_cb)( void *, const char * )=0, - void * status_cb_arg=0) - { - return assuan_transact( ctx.get(), command, data_cb, data_cb_arg, inquire_cb, inquire_cb_arg, status_cb, status_cb_arg ); -@@ -337,26 +337,26 @@ - return Command::tr("start_uiserver: not yet implemented"); - } - --static assuan_error_t getinfo_pid_cb( void * opaque, const void * buffer, size_t length ) { -+static gpg_error_t getinfo_pid_cb( void * opaque, const void * buffer, size_t length ) { - qint64 & pid = *static_cast<qint64*>( opaque ); - pid = QByteArray( static_cast<const char*>( buffer ), length ).toLongLong(); - return 0; - } - --static assuan_error_t command_data_cb( void * opaque, const void * buffer, size_t length ) { -+static gpg_error_t command_data_cb( void * opaque, const void * buffer, size_t length ) { - QByteArray & ba = *static_cast<QByteArray*>( opaque ); - ba.append( QByteArray( static_cast<const char*>(buffer), length ) ); - return 0; - } - --static assuan_error_t send_option( const AssuanClientContext & ctx, const char * name, const QVariant & value ) { -+static gpg_error_t send_option( const AssuanClientContext & ctx, const char * name, const QVariant & value ) { - if ( value.isValid() ) - return my_assuan_transact( ctx, QString().sprintf( "OPTION %s=%s", name, value.toString().toUtf8().constData() ).toUtf8().constData() ); - else - return my_assuan_transact( ctx, QString().sprintf( "OPTION %s", name ).toUtf8().constData() ); - } - --static assuan_error_t send_file( const AssuanClientContext & ctx, const QString & file ) { -+static gpg_error_t send_file( const AssuanClientContext & ctx, const QString & file ) { - return my_assuan_transact( ctx, QString().sprintf( "FILE %s", hexencode( QFile::encodeName( file ) ).constData() ).toUtf8().constData() ); - } - -@@ -373,21 +373,32 @@ - - out.canceled = false; - -- assuan_error_t err = 0; -+ if ( out.serverLocation.isEmpty() ) -+ out.serverLocation = default_socket_name(); - -- assuan_context_t naked_ctx = 0; - AssuanClientContext ctx; -+ gpg_error_t err = 0; - -- if ( out.serverLocation.isEmpty() ) -- out.serverLocation = default_socket_name(); -- - const QString socketName = out.serverLocation; - if ( socketName.isEmpty() ) { - out.errorString = tr("Invalid socket name!"); - goto leave; - } - -- err = assuan_socket_connect( &naked_ctx, QFile::encodeName( socketName ).constData(), -1 ); -+ { -+ assuan_context_t naked_ctx = 0; -+ err = assuan_new( &naked_ctx ); -+ if ( err ) { -+ out.errorString = tr( "Could not allocate resources to connect to Kleopatra UI server at %1: %2" ) -+ .arg( socketName, to_error_string( err ) ); -+ goto leave; -+ } -+ -+ ctx.reset( naked_ctx ); -+ } -+ -+ -+ err = assuan_socket_connect( ctx.get(), QFile::encodeName( socketName ).constData(), -1, 0 ); - if ( err ) { - qDebug( "UI server not running, starting it" ); - -@@ -400,7 +411,7 @@ - // give it a bit of time to start up and try a couple of times - for ( int i = 0 ; err && i < 20 ; ++i ) { - msleep( 500 ); -- err = assuan_socket_connect( &naked_ctx, QFile::encodeName( socketName ).constData(), -1 ); -+ err = assuan_socket_connect( ctx.get(), QFile::encodeName( socketName ).constData(), -1, 0 ); - } - } - -@@ -410,9 +421,6 @@ - goto leave; - } - -- ctx.reset( naked_ctx ); -- naked_ctx = 0; -- - out.serverPid = -1; - err = my_assuan_transact( ctx, "GETINFO pid", &getinfo_pid_cb, &out.serverPid ); - if ( err || out.serverPid <= 0 ) { -Index: kleopatra/libkleopatraclient/core/initialization.cpp -=================================================================== ---- kleopatra/libkleopatraclient/core/initialization.cpp (revision 1078527) -+++ kleopatra/libkleopatraclient/core/initialization.cpp (revision 1078528) -@@ -29,7 +29,7 @@ - using namespace KLEOPATRACLIENT_NAMESPACE; - - Initialization::Initialization() { -- assuan_set_assuan_err_source( GPG_ERR_SOURCE_DEFAULT ); -+ assuan_set_gpg_err_source( GPG_ERR_SOURCE_DEFAULT ); - } - - Initialization::~Initialization() { -Index: kleopatra/libkleopatraclient/core/CMakeLists.txt -=================================================================== ---- kleopatra/libkleopatraclient/core/CMakeLists.txt (revision 1078527) -+++ kleopatra/libkleopatraclient/core/CMakeLists.txt (revision 1078528) -@@ -1,4 +1,4 @@ --include_directories( ${ASSUAN_INCLUDES} ${CMAKE_SOURCE_DIR}/kleopatra ) -+include_directories( ${ASSUAN2_INCLUDES} ${CMAKE_SOURCE_DIR}/kleopatra ) - - add_definitions( -D_ASSUAN_ONLY_GPG_ERRORS -DQT_NO_CAST_FROM_ASCII -DQT_NO_KEYWORDS -DQT_NO_CAST_TO_ASCII ) - -@@ -27,9 +27,9 @@ - - - if ( WIN32 ) -- target_link_libraries( kleopatraclientcore ${QT_QTCORE_LIBRARY} ${ASSUAN_VANILLA_LIBRARIES} ws2_32 ) -+ target_link_libraries( kleopatraclientcore ${QT_QTCORE_LIBRARY} ${ASSUAN2_LIBRARIES} ws2_32 ) - else ( WIN32 ) -- target_link_libraries( kleopatraclientcore ${QT_QTCORE_LIBRARY} ${ASSUAN_PTHREAD_LIBRARIES} ) -+ target_link_libraries( kleopatraclientcore ${QT_QTCORE_LIBRARY} ${ASSUAN2_LIBRARIES} ) - endif ( WIN32 ) - - install( |