diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..023d1eb
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1 @@
+SOURCES/xmlrpc-c-1.51.0.tar.xz
diff --git a/.xmlrpc-c.metadata b/.xmlrpc-c.metadata
new file mode 100644
index 0000000..40e82bc
--- /dev/null
+++ b/.xmlrpc-c.metadata
@@ -0,0 +1 @@
+784a3e74971f3b7d992d768c732daa891ffd2412 SOURCES/xmlrpc-c-1.51.0.tar.xz
diff --git a/SOURCES/0001-Remove-trace-statements-accidentally-committed-with-.patch b/SOURCES/0001-Remove-trace-statements-accidentally-committed-with-.patch
new file mode 100644
index 0000000..6609b32
--- /dev/null
+++ b/SOURCES/0001-Remove-trace-statements-accidentally-committed-with-.patch
@@ -0,0 +1,83 @@
+From 78e995f9f2958fc54e2a559a52c81684dc3460cf Mon Sep 17 00:00:00 2001
+From: giraffedata <giraffedata@98333e67-4a24-44d7-a75c-e53540dd3050>
+Date: Sun, 21 Jan 2018 22:27:31 +0000
+Subject: [PATCH] Remove trace statements accidentally committed with 2977
+
+git-svn-id: https://svn.code.sf.net/p/xmlrpc-c/code/trunk@2981 98333e67-4a24-44d7-a75c-e53540dd3050
+---
+ src/cpp/value.cpp   | 8 --------
+ src/xmlrpc_string.c | 5 -----
+ 2 files changed, 13 deletions(-)
+
+diff --git a/src/cpp/value.cpp b/src/cpp/value.cpp
+index e2c12372..b319430e 100644
+--- a/src/cpp/value.cpp
++++ b/src/cpp/value.cpp
+@@ -1,4 +1,3 @@
+-#include <iostream>
+ /*****************************************************************************
+                                 value.cpp
+ ******************************************************************************
+@@ -622,13 +621,9 @@ public:
+ 
+         switch (nlCode) {
+         case value_string::nlCode_all:
+-            cerr << "Going to call xmlrpc_string_new_lp" << endl;
+-            cerr << "length = " << cppvalue.length() << ", value = "
+-                 << cppvalue.c_str() << endl;
+             this->valueP = xmlrpc_string_new_lp(&env.env_c,
+                                                 cppvalue.length(),
+                                                 cppvalue.c_str());
+-            cerr << "Back from xmlrpc_string_new_lp" << endl;
+             break;
+         case value_string::nlCode_lf:
+             this->valueP = xmlrpc_string_new_lp_cr(&env.env_c,
+@@ -661,12 +656,9 @@ value_string::value_string(std::string          const& cppvalue,
+ 
+ value_string::value_string(std::string const& cppvalue) {
+ 
+-    cerr << "value_string constructor entered" << endl;
+     cNewStringWrapper wrapper(cppvalue, nlCode_all);
+-    cerr << "wrapper constructed" << endl;
+ 
+     this->instantiate(wrapper.valueP);
+-    cerr << "value_string constructor exiting" << endl;
+ }
+ 
+ 
+diff --git a/src/xmlrpc_string.c b/src/xmlrpc_string.c
+index 2da61e4e..e6e00716 100644
+--- a/src/xmlrpc_string.c
++++ b/src/xmlrpc_string.c
+@@ -1,4 +1,3 @@
+-#include <stdio.h>
+ /*=============================================================================
+                               xmlrpc_string
+ ===============================================================================
+@@ -746,15 +745,12 @@ stringNew(xmlrpc_env *     const envP,
+           enum crTreatment const crTreatment,
+           xmlrpc_value **  const valPP) {
+ 
+-    fprintf(stderr, "stringNew entered\n");
+     xmlrpc_value * valP;
+ 
+     xmlrpc_validate_utf8(envP, value, length);
+ 
+     if (!envP->fault_occurred) {
+-        fprintf(stderr, "Going to xmlrpc_createXmlrpcValue\n");
+         xmlrpc_createXmlrpcValue(envP, &valP);
+-        fprintf(stderr, "Back from createXmlrpcValue\n");
+ 
+         if (!envP->fault_occurred) {
+             valP->_type = XMLRPC_TYPE_STRING;
+@@ -774,7 +770,6 @@ stringNew(xmlrpc_env *     const envP,
+                 *valPP = valP;
+         }
+     }
+-    fprintf(stderr, "stringNew exiting\n");
+ }
+ 
+ 
+-- 
+2.17.0
+
diff --git a/SOURCES/0001-add-meson-buildsystem-definitions.patch b/SOURCES/0001-add-meson-buildsystem-definitions.patch
new file mode 100644
index 0000000..ce1328f
--- /dev/null
+++ b/SOURCES/0001-add-meson-buildsystem-definitions.patch
@@ -0,0 +1,1668 @@
+From 0fa42d185e8770a49df5c0820159a25cb402a0b8 Mon Sep 17 00:00:00 2001
+From: Igor Gnatenko <i.gnatenko.brain@gmail.com>
+Date: Sun, 18 Dec 2016 10:24:31 +0100
+Subject: [PATCH 1/2] add meson buildsystem definitions
+
+Signed-off-by: Igor Gnatenko <i.gnatenko.brain@gmail.com>
+---
+ include/meson.build                 |   3 +
+ include/xmlrpc-c/config.h.in        |  41 +++++++
+ include/xmlrpc-c/lnsfr.sh           |   9 ++
+ include/xmlrpc-c/meson.build        |  87 ++++++++++++++
+ lib/abyss++/meson.build             |  43 +++++++
+ lib/abyss/meson.build               |   1 +
+ lib/abyss/src/meson.build           |  66 +++++++++++
+ lib/curl_transport/meson.build      |  16 +++
+ lib/expat/gennmtab/meson.build      |   4 +
+ lib/expat/meson.build               |  15 +++
+ lib/expat/xmlparse/meson.build      |  21 ++++
+ lib/expat/xmltok/meson.build        |  32 ++++++
+ lib/libutil++/meson.build           |  28 +++++
+ lib/libutil/meson.build             |  41 +++++++
+ lib/meson.build                     |  27 +++++
+ lib/openssl/meson.build             |  27 +++++
+ lib/util/meson.build                |  20 ++++
+ meson.build                         | 209 +++++++++++++++++++++++++++++++++
+ meson_options.txt                   |  13 +++
+ src/cpp/meson.build                 | 223 ++++++++++++++++++++++++++++++++++++
+ src/meson.build                     | 190 ++++++++++++++++++++++++++++++
+ tools/lib/meson.build               |   5 +
+ tools/meson.build                   |  17 +++
+ tools/xml-rpc-api2cpp/meson.build   |  21 ++++
+ tools/xml-rpc-api2txt/meson.build   |   2 +
+ tools/xml/meson.build               |  15 +++
+ tools/xmlrpc/meson.build            |  20 ++++
+ tools/xmlrpc_cpp_proxy/meson.build  |  19 +++
+ tools/xmlrpc_dumpserver/meson.build |  23 ++++
+ tools/xmlrpc_pstream/meson.build    |  21 ++++
+ tools/xmlrpc_transport/meson.build  |  18 +++
+ transport_config.h.in               |   4 +
+ xmlrpc-c-config                     | 114 ++++++++++++++++++
+ 33 files changed, 1395 insertions(+)
+ create mode 100644 include/meson.build
+ create mode 100644 include/xmlrpc-c/config.h.in
+ create mode 100755 include/xmlrpc-c/lnsfr.sh
+ create mode 100644 include/xmlrpc-c/meson.build
+ create mode 100644 lib/abyss++/meson.build
+ create mode 100644 lib/abyss/meson.build
+ create mode 100644 lib/abyss/src/meson.build
+ create mode 100644 lib/curl_transport/meson.build
+ create mode 100644 lib/expat/gennmtab/meson.build
+ create mode 100644 lib/expat/meson.build
+ create mode 100644 lib/expat/xmlparse/meson.build
+ create mode 100644 lib/expat/xmltok/meson.build
+ create mode 100644 lib/libutil++/meson.build
+ create mode 100644 lib/libutil/meson.build
+ create mode 100644 lib/meson.build
+ create mode 100644 lib/openssl/meson.build
+ create mode 100644 lib/util/meson.build
+ create mode 100644 meson.build
+ create mode 100644 meson_options.txt
+ create mode 100644 src/cpp/meson.build
+ create mode 100644 src/meson.build
+ create mode 100644 tools/lib/meson.build
+ create mode 100644 tools/meson.build
+ create mode 100644 tools/xml-rpc-api2cpp/meson.build
+ create mode 100644 tools/xml-rpc-api2txt/meson.build
+ create mode 100644 tools/xml/meson.build
+ create mode 100644 tools/xmlrpc/meson.build
+ create mode 100644 tools/xmlrpc_cpp_proxy/meson.build
+ create mode 100644 tools/xmlrpc_dumpserver/meson.build
+ create mode 100644 tools/xmlrpc_pstream/meson.build
+ create mode 100644 tools/xmlrpc_transport/meson.build
+ create mode 100644 transport_config.h.in
+ create mode 100755 xmlrpc-c-config
+
+diff --git a/include/meson.build b/include/meson.build
+new file mode 100644
+index 00000000..ec0964c0
+--- /dev/null
++++ b/include/meson.build
+@@ -0,0 +1,3 @@
++hdr_incdir = include_directories('.')
++
++subdir('xmlrpc-c')
+diff --git a/include/xmlrpc-c/config.h.in b/include/xmlrpc-c/config.h.in
+new file mode 100644
+index 00000000..e8a633e7
+--- /dev/null
++++ b/include/xmlrpc-c/config.h.in
+@@ -0,0 +1,41 @@
++#ifndef XMLRPC_C_CONFIG_H_INCULDED
++#define XMLRPC_C_CONFIG_H_INCLUDED
++
++/* This file, part of XML-RPC For C/C++, is meant to 
++   define characteristics of this particular installation 
++   that the other <xmlrpc-c/...> header files need in 
++   order to compile correctly when #included in Xmlrpc-c
++   user code.
++
++   Those header files #include this one.
++*/
++#define XMLRPC_HAVE_WCHAR @HAVE_WCHAR_H_DEFINE@
++#ifdef _WIN32
++  /* SOCKET is a type defined by <winsock.h>.  Anyone who
++     uses XMLRPC_SOCKET on a WIN32 system must #include
++     <winsock.h>
++  */
++  #define XMLRPC_SOCKET SOCKET
++  #define XMLRPC_HAVE_TIMEVAL 0
++  #define XMLRPC_HAVE_TIMESPEC 0
++  #define XMLRPC_HAVE_PTHREAD 0
++  #define XMLRPC_HAVE_WINTHREAD 1
++#else
++  #define XMLRPC_SOCKET int
++  #define XMLRPC_HAVE_TIMEVAL 1
++  #define XMLRPC_HAVE_TIMESPEC 1
++  #define XMLRPC_HAVE_PTHREAD 1
++  #define XMLRPC_HAVE_WINTHREAD 0
++#endif
++
++#if defined(_MSC_VER)
++  /* Newer MSVC has long long, but MSVC 6 does not */
++  #define XMLRPC_INT64 __int64
++  #define XMLRPC_PRId64 "I64"
++  #define XMLRPC_INT32 __int32
++#else
++  #define XMLRPC_INT64 long long
++  #define XMLRPC_PRId64 "lld"
++  #define XMLRPC_INT32 int
++#endif
++#endif
+diff --git a/include/xmlrpc-c/lnsfr.sh b/include/xmlrpc-c/lnsfr.sh
+new file mode 100755
+index 00000000..83f231b7
+--- /dev/null
++++ b/include/xmlrpc-c/lnsfr.sh
+@@ -0,0 +1,9 @@
++#!/bin/sh -efu
++
++if [ "$#" != 2 ]; then
++  exit 1
++fi
++
++tgt="$1"; shift
++src="$1"; shift
++ln -sfr "${DESTDIR}${tgt}" "${DESTDIR}${src}"
+diff --git a/include/xmlrpc-c/meson.build b/include/xmlrpc-c/meson.build
+new file mode 100644
+index 00000000..761acfd4
+--- /dev/null
++++ b/include/xmlrpc-c/meson.build
+@@ -0,0 +1,87 @@
++config_h = configure_file(input : 'config.h.in',
++                          output : 'config.h',
++                          configuration : conf)
++
++compat_links = [
++  [ 'oldxmlrpc.h',         'xmlrpc.h'                   ],
++  [ 'server.h',            'xmlrpc_server.h'            ],
++  [ 'server_abyss.h',      'xmlrpc_abyss.h'             ],
++  [ 'server_w32httpsys.h', 'xmlrpc_server_w32httpsys.h' ],
++]
++
++hdrs = [
++  join_paths(meson.current_build_dir(), 'config.h'), # config_h,
++  'inttypes.h',
++  'c_util.h',
++  'util.h',
++  'base.h',
++  'json.h',
++  'abyss.h',
++  'abyss_unixsock.h',
++  'abyss_winsock.h',
++  'server.h',
++  'server_abyss.h',
++  'server_w32httpsys.h',
++  'oldxmlrpc.h',
++]
++if get_option('cplusplus')
++  hdrs += [
++    'oldcppwrapper.hpp',
++    'girerr.hpp',
++    'girmem.hpp',
++    'base.hpp',
++    'base64.hpp',
++    'timeout.hpp',
++    'xml.hpp',
++    'registry.hpp',
++    'server_abyss.hpp',
++    'packetsocket.hpp',
++    'server_pstream.hpp',
++    'AbyssEnvironment.hpp',
++    'AbyssServer.hpp',
++    'abyss_reqhandler_xmlrpc.hpp',
++    'AbyssChanSwitch.hpp',
++    'AbyssChanSwitchUnix.hpp',
++  ]
++  compat_links += [
++    ['oldcppwrapper.hpp', 'XmlRpcCpp.h'],
++  ]
++endif
++if build_client
++  hdrs += [
++    'client.h',
++    'transport.h',
++    'client_global.h',
++  ]
++  compat_links += [
++    ['client.h', 'xmlrpc_client.h'],
++  ]
++  if get_option('cplusplus')
++    hdrs += [
++      'client.hpp',
++      'client_transport.hpp',
++      'client_simple.hpp',
++    ]
++  endif
++endif
++if get_option('cgi-server')
++  hdrs += [
++    'server_cgi.h',
++  ]
++  compat_links += [
++    ['server_cgi.h', 'xmlrpc_cgi.h'],
++  ]
++endif
++if get_option('abyss-openssl')
++  hdrs += [
++    'openssl_thread.h',
++  ]
++endif
++
++install_headers(hdrs, subdir : meson.project_name())
++# Install old names of header files for backward compatibility
++foreach compat_link : compat_links
++  tgt = join_paths(get_option('prefix'), get_option('includedir'), meson.project_name(), compat_link[0])
++  src = join_paths(get_option('prefix'), get_option('includedir'), compat_link[1])
++  meson.add_install_script('lnsfr.sh', tgt, src)
++endforeach
+diff --git a/lib/abyss++/meson.build b/lib/abyss++/meson.build
+new file mode 100644
+index 00000000..19f04cc3
+--- /dev/null
++++ b/lib/abyss++/meson.build
+@@ -0,0 +1,43 @@
++if host_machine.system() == 'windows'
++  abysspp_chan_switch = 'AbyssChanSwitchWin.cpp'
++else
++  abysspp_chan_switch = ['AbyssChanSwitchUnix.cpp']
++  if get_option('abyss-openssl')
++    abysspp_chan_switch += ['AbyssChanSwitchOpenSsl.cpp']
++  endif
++endif
++
++libxmlrpc_abysspp = library(
++  'xmlrpc_abyss++',
++  sources : [
++    'AbyssServer.cpp',
++    'AbyssChanSwitch.cpp',
++    'AbyssEnvironment.cpp',
++    abysspp_chan_switch,
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++  ],
++  link_with : [
++    libxmlrpc_abyss,
++    libxmlrpc_util,
++    libxmlrpc_utilpp,
++  ],
++  dependencies : [
++    socket,
++  ],
++  soversion : 8,
++  version : '8.@0@'.format(version_minor),
++  install : true,
++)
++
++pkgg.generate(
++  name : 'xmlrpc_abyss++',
++  description : 'Xmlrpc-c Abyss HTTP C++ library',
++  version : meson.project_version(),
++  requires_private : ['xmlrpc_abyss', 'xmlrpc_util', 'xmlrpc_util++'],
++  libraries : libxmlrpc_abysspp,
++  install : true,
++)
+diff --git a/lib/abyss/meson.build b/lib/abyss/meson.build
+new file mode 100644
+index 00000000..9537275d
+--- /dev/null
++++ b/lib/abyss/meson.build
+@@ -0,0 +1 @@
++subdir('src')
+diff --git a/lib/abyss/src/meson.build b/lib/abyss/src/meson.build
+new file mode 100644
+index 00000000..daa91fce
+--- /dev/null
++++ b/lib/abyss/src/meson.build
+@@ -0,0 +1,66 @@
++abyss_deps = [socket]
++if host_machine.system() == 'windows'
++  abyss_socket = 'socket_win.c'
++  abyss_thread = 'thread_windows.c'
++  abyss_deps += [threads]
++else
++  abyss_socket = ['socket_unix.c']
++  if get_option('abyss-openssl')
++    abyss_socket += ['socket_openssl.c']
++    abyss_deps += [openssl]
++  endif
++  abyss_socket += ['sockutil.c']
++
++  if get_option('abyss-threads')
++    abyss_thread = 'thread_pthread.c'
++    abyss_deps += [threads]
++  else
++    abyss_thread = 'thread_fork.c'
++  endif
++endif
++
++libxmlrpc_abyss = library(
++  'xmlrpc_abyss',
++  sources : [
++    'channel.c',
++    'chanswitch.c',
++    'conf.c',
++    'conn.c',
++    'data.c',
++    'date.c',
++    'file.c',
++    'handler.c',
++    'http.c',
++    'init.c',
++    'response.c',
++    'server.c',
++    'session.c',
++    'sessionReadRequest.c',
++    'socket.c',
++    abyss_socket,
++    'token.c',
++    abyss_thread,
++    'trace.c',
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++  ],
++  link_with : [
++    libxmlrpc_util,
++  ],
++  dependencies : abyss_deps,
++  soversion : 3,
++  version : '3.@0@'.format(version_minor),
++  install : true,
++)
++
++pkgg.generate(
++  name : 'xmlrpc_abyss',
++  description : 'Xmlrpc-c Abyss HTTP C library',
++  version : meson.project_version(),
++  libraries : libxmlrpc_abyss,
++  requires_private : 'xmlrpc_util',
++  install : true,
++)
+diff --git a/lib/curl_transport/meson.build b/lib/curl_transport/meson.build
+new file mode 100644
+index 00000000..f5ff3040
+--- /dev/null
++++ b/lib/curl_transport/meson.build
+@@ -0,0 +1,16 @@
++libcurl = dependency('libcurl')
++if libcurl.version().version_compare('<7.16.0')
++  xmlrpc_curl_cargs = ['-DNEED_CURL_TYPES_H']
++else
++  xmlrpc_curl_cargs = []
++endif
++xmlrpc_curl_transport = declare_dependency(
++  include_directories : include_directories('.'),
++  sources : [
++    'xmlrpc_curl_transport.c',
++    'curltransaction.c',
++    'curlmulti.c',
++  ],
++  compile_args : xmlrpc_curl_cargs,
++  dependencies : libcurl,
++)
+diff --git a/lib/expat/gennmtab/meson.build b/lib/expat/gennmtab/meson.build
+new file mode 100644
+index 00000000..94764c22
+--- /dev/null
++++ b/lib/expat/gennmtab/meson.build
+@@ -0,0 +1,4 @@
++gennmtab = executable(
++  'gennmtab', 'gennmtab.c',
++  include_directories : top_incdir,
++)
+diff --git a/lib/expat/meson.build b/lib/expat/meson.build
+new file mode 100644
+index 00000000..df9ca84c
+--- /dev/null
++++ b/lib/expat/meson.build
+@@ -0,0 +1,15 @@
++subdir('gennmtab')
++subdir('xmltok')
++subdir('xmlparse')
++
++pkgg.generate(
++  name : 'xmlrpc_expat',
++  description : 'Xmlrpc-c XML parsing library',
++  version : meson.project_version(),
++  requires_private: 'xmlrpc_util',
++  libraries : [
++    libxmlrpc_xmlparse,
++    libxmlrpc_xmltok,
++  ],
++  install : true,
++)
+diff --git a/lib/expat/xmlparse/meson.build b/lib/expat/xmlparse/meson.build
+new file mode 100644
+index 00000000..39c0bf26
+--- /dev/null
++++ b/lib/expat/xmlparse/meson.build
+@@ -0,0 +1,21 @@
++xmlparse_incdir = include_directories('.')
++
++libxmlrpc_xmlparse = library(
++  'xmlrpc_xmlparse',
++  sources : [
++    'xmlparse.c',
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++    xmltok_incdir,
++  ],
++  link_with : [
++    libxmlrpc_util,
++    libxmlrpc_xmltok,
++  ],
++  soversion : '3',
++  version : '3.@0@'.format(version_minor),
++  install : true,
++)
+diff --git a/lib/expat/xmltok/meson.build b/lib/expat/xmltok/meson.build
+new file mode 100644
+index 00000000..6629719c
+--- /dev/null
++++ b/lib/expat/xmltok/meson.build
+@@ -0,0 +1,32 @@
++nametab = custom_target(
++  'nametab.h',
++  output : 'nametab.h',
++  command : gennmtab,
++  capture : true,
++)
++
++if host_machine.endian() == 'big'
++  xmltok_endian_flag = '-DXML_BYTE_ORDER=21'
++else
++  xmltok_endian_flag = '-DXML_BYTE_ORDER=12'
++endif
++
++libxmlrpc_xmltok = library(
++  'xmlrpc_xmltok',
++  sources : [
++    'xmltok.c',
++    'xmlrole.c',
++    nametab,
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++  ],
++  c_args : [xmltok_endian_flag],
++  soversion : '3',
++  version : '3.@0@'.format(version_minor),
++  install : true,
++)
++
++xmltok_incdir = include_directories('.')
+diff --git a/lib/libutil++/meson.build b/lib/libutil++/meson.build
+new file mode 100644
+index 00000000..9764c08d
+--- /dev/null
++++ b/lib/libutil++/meson.build
+@@ -0,0 +1,28 @@
++libxmlrpc_utilpp = library(
++  'xmlrpc_util++',
++  sources : [
++    'Lock.cpp',
++    'base64.cpp',
++    'env_wrap.cpp',
++    'girerr.cpp',
++    'girmem.cpp',
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++  ],
++  link_with : libxmlrpc_util,
++  soversion : '8',
++  version : '8.@0@'.format(version_minor),
++  install : true,
++)
++
++pkgg.generate(
++  name : 'xmlrpc_util++',
++  description : 'Xmlrpc-c C++ utility functions library',
++  version : meson.project_version(),
++  requires_private : 'xmlrpc_util',
++  libraries : libxmlrpc_utilpp,
++  install : true,
++)
+diff --git a/lib/libutil/meson.build b/lib/libutil/meson.build
+new file mode 100644
+index 00000000..bb1cc67d
+--- /dev/null
++++ b/lib/libutil/meson.build
+@@ -0,0 +1,41 @@
++# FIXME: it's default already to 1 in xmlrpc_config.h
++util_lock_pthread = ['lock_pthread.c']
++# TODO: handle mscvrt.dll properly
++util_lock_windows = [] # lock_windows.c
++
++libxmlrpc_util = library(
++  'xmlrpc_util',
++  sources : [
++    'asprintf.c',
++    'base64.c',
++    'error.c',
++    'lock_platform.c',
++    util_lock_pthread,
++    util_lock_windows,
++    'lock_none.c',
++    'make_printable.c',
++    'memblock.c',
++    'mempool.c',
++    'select.c',
++    'sleep.c',
++    'string_number.c',
++    'time.c',
++    'utf8.c',
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++  ],
++  soversion : 4,
++  version : '4.@0@'.format(version_minor),
++  install : true,
++)
++
++pkgg.generate(
++  name : 'xmlrpc_util',
++  description : 'Xmlrpc-c utility functions library',
++  version : meson.project_version(),
++  libraries : libxmlrpc_util,
++  install : true,
++)
+diff --git a/lib/meson.build b/lib/meson.build
+new file mode 100644
+index 00000000..e78c1f83
+--- /dev/null
++++ b/lib/meson.build
+@@ -0,0 +1,27 @@
++subdir('util')
++subdir('libutil')
++if get_option('cplusplus')
++  subdir('libutil++')
++endif
++if get_option('abyss-server')
++  subdir('abyss')
++  if get_option('cplusplus')
++    subdir('abyss++')
++  endif
++endif
++if get_option('wininet-client')
++  subdir('wininet_transport')
++endif
++if get_option('curl-client')
++  subdir('curl_transport')
++endif
++if get_option('libwww-client')
++  subdir('libwww_transport')
++endif
++if not get_option('libxml2-backend')
++  subdir('expat')
++endif
++
++if openssl.found()
++  subdir('openssl')
++endif
+diff --git a/lib/openssl/meson.build b/lib/openssl/meson.build
+new file mode 100644
+index 00000000..f65a4dc1
+--- /dev/null
++++ b/lib/openssl/meson.build
+@@ -0,0 +1,27 @@
++libxmlrpc_openssl = library(
++  'xmlrpc_openssl',
++  sources : [
++    'xmlrpc_openssl_thread.c',
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++  ],
++  link_with : [
++    libxmlrpc_util,
++  ],
++  dependencies : openssl,
++  soversion : '1',
++  version : '1.@0@'.format(version_minor),
++  install : true,
++)
++
++pkgg.generate(
++  name : 'xmlrpc_openssl',
++  description : 'Openssl convenience function from Xmlrpc-c package',
++  version : meson.project_version(),
++  requires_private : 'xmlrpc_util',
++  libraries : libxmlrpc_openssl,
++  install : true,
++)
+diff --git a/lib/util/meson.build b/lib/util/meson.build
+new file mode 100644
+index 00000000..4cae4926
+--- /dev/null
++++ b/lib/util/meson.build
+@@ -0,0 +1,20 @@
++util_incdir = include_directories('include')
++util_casprintf_dep = declare_dependency(
++  include_directories : util_incdir,
++  sources : 'casprintf.c',
++)
++util_dep = declare_dependency(
++  dependencies : util_casprintf_dep,
++  sources : [
++    'cmdline_parser.c',
++    'getoptx.c',
++    'string_parser.c',
++    'stripcaseeq.c',
++  ],
++)
++if get_option('cplusplus')
++  util_cpp_dep = declare_dependency(
++    dependencies : util_dep,
++    sources : 'cmdline_parser_cpp.cpp',
++  )
++endif
+diff --git a/meson.build b/meson.build
+new file mode 100644
+index 00000000..52a0f0eb
+--- /dev/null
++++ b/meson.build
+@@ -0,0 +1,209 @@
++project('xmlrpc-c', 'c',
++        version : '1.51.0',
++        default_options : [
++          'b_asneeded=true',
++          'b_lundef=true',
++          'warning_level=1',
++        ],
++        meson_version : '>=0.36.0')
++
++version_array = meson.project_version().split('.')
++version_major = version_array[0].to_int()
++version_minor = version_array[1].to_int()
++version_point = version_array[2].to_int()
++
++# version.h
++version_conf = configuration_data()
++version_conf.set_quoted('XMLRPC_C_VERSION', meson.project_version())
++version_conf.set('XMLRPC_VERSION_MAJOR', version_major)
++version_conf.set('XMLRPC_VERSION_MINOR', version_minor)
++version_conf.set('XMLRPC_VERSION_POINT', version_point)
++configure_file(output : 'version.h', configuration : version_conf)
++
++if get_option('wininet-client') or get_option('libwww-client')
++  error('only curl-client is implemented yet')
++endif
++
++if get_option('cplusplus')
++  add_languages('cpp')
++endif
++
++cc = meson.get_compiler('c')
++cxx = meson.get_compiler('cpp')
++
++optflags = [
++  '-Wno-uninitialized',
++  '-Wundef',
++  '-Wno-unknown-pragmas',
++]
++cflags = [
++  '-Wmissing-declarations',
++  '-Wstrict-prototypes',
++  '-Wmissing-prototypes',
++  '-Wimplicit',
++] + optflags
++cxxflags = [
++  '-Wsynth',
++] + optflags
++foreach cflag : cflags
++  if cc.has_argument(cflag)
++    add_project_arguments(cflag, language : 'c')
++  endif
++endforeach
++foreach cxxflag : cxxflags
++  if cxx.has_argument(cxxflag)
++    add_project_arguments(cxxflag, language : 'cpp')
++  endif
++endforeach
++
++pkgg = import('pkgconfig')
++
++if not cc.has_function('vsnprintf')
++  error('your C library does not provide vsnprintf')
++endif
++if not cc.has_header('stdarg.h')
++  error('stdarg.h is required to build this library')
++endif
++
++conf = configuration_data()
++
++check_headers = [
++  'wchar.h',
++  'sys/filio.h',  # Needed by Abyss on Solaris
++  'sys/ioctl.h',  # Needed by Abyss on Solaris
++  'sys/select.h',
++]
++check_functions = [
++  'wcsncmp',      # Unicode function needed by test suites
++  'setgroups',    # CygWin doesn't provide setgroups
++  'asprintf',
++  'setenv',
++  'strtoll',
++  'strtoull',
++  'strtoq',
++  'strtouq',
++  '__strtoll',
++  '__strtoull',
++  '_strtoui64',
++  'pselect',      # uclib doesn't have pselect
++  'gettimeofday', # Windows doesn't have gettimeofday
++  'localtime_r',  # Windows doesn't have localtime_r
++  'gmtime_r',     # Windows doesn't have gmtime_r
++  'strcasecmp',   # Windows doesn't have strcasecmp
++  'stricmp',
++  '_stricmp',
++]
++
++foreach hdr : check_headers
++  if cc.has_header(hdr)
++    conf.set('HAVE_@0@_DEFINE'.format(hdr.to_upper().underscorify()), 1)
++  else
++    conf.set('HAVE_@0@_DEFINE'.format(hdr.to_upper().underscorify()), 0)
++  endif
++endforeach
++foreach func : check_functions
++  if cc.has_function(func)
++    conf.set('HAVE_@0@_DEFINE'.format(func.to_upper()), 1)
++  else
++    conf.set('HAVE_@0@_DEFINE'.format(func.to_upper()), 0)
++  endif
++endforeach
++
++if not cc.compiles('''
++#include <stdarg.h>
++
++int
++main ()
++{
++  va_list list1, list2;
++  list1 = list2;
++  return 0;
++}
++               ''')
++  conf.set('VA_LIST_IS_ARRAY_DEFINE', 1)
++else
++  conf.set('VA_LIST_IS_ARRAY_DEFINE', 0)
++endif
++
++if cc.compiles('int x __attribute__((__unused__));')
++  conf.set('ATTR_UNUSED', '__attribute__((__unused__))')
++else
++  conf.set('ATTR_UNUSED', '')
++endif
++
++if host_machine.system() == 'windows'
++  conf.set('DIRECTORY_SEPARATOR', '\\')
++else
++  conf.set('DIRECTORY_SEPARATOR', '/')
++endif
++
++openssl = dependency('openssl', required : get_option('abyss-openssl'))
++if get_option('abyss-openssl')
++  conf.set('HAVE_ABYSS_OPENSSL_DEFINE', 1)
++else
++  conf.set('HAVE_ABYSS_OPENSSL_DEFINE', 0)
++endif
++
++if get_option('libwww-ssl')
++  conf.set('HAVE_LIBWWW_SSL_DEFINE', 1)
++else
++  conf.set('HAVE_LIBWWW_SSL_DEFINE', 0)
++endif
++
++configure_file(input : 'xmlrpc_config.h.in', output : 'xmlrpc_config.h', configuration : conf)
++
++ncurses = cc.find_library('ncurses', required : false)
++readline = cc.find_library('readline', required : false)
++
++build_xmlrpc_pstream = false
++
++if not get_option('wininet-client') and not get_option('curl-client') and not get_option('libwww-client')
++  build_client = false
++  build_tools = false
++  message('We are not building any client XML transport, therefore WE WILL NOT BUILD THE CLIENT LIBRARY')
++else
++  build_client = true
++  if ncurses.found() and readline.found()
++    build_xmlrpc_pstream = true
++  endif
++  build_tools = true
++  # transport_config.h
++  transport_conf = configuration_data()
++  if get_option('wininet-client')
++    transport_conf.set('MUST_BUILD_WININET_CLIENT', 1)
++    transport_conf.set_quoted('XMLRPC_DEFAULT_TRANSPORT', 'wininet')
++  else
++    transport_conf.set('MUST_BUILD_WININET_CLIENT', 0)
++  endif
++  if get_option('curl-client')
++    transport_conf.set('MUST_BUILD_CURL_CLIENT', 1)
++    transport_conf.set_quoted('XMLRPC_DEFAULT_TRANSPORT', 'curl')
++  else
++    transport_conf.set('MUST_BUILD_CURL_CLIENT', 0)
++  endif
++  if get_option('libwww-client')
++    transport_conf.set('MUST_BUILD_LIBWWW_CLIENT', 1)
++    transport_conf.set_quoted('XMLRPC_DEFAULT_TRANSPORT', 'libwww')
++  else
++    transport_conf.set('MUST_BUILD_LIBWWW_CLIENT', 0)
++  endif
++  configure_file(input : 'transport_config.h.in', output : 'transport_config.h', configuration : transport_conf)
++endif
++
++threads = dependency('threads')
++socket = cc.find_library('socket', required : false)
++
++if get_option('libxml2-backend')
++  libxml2 = dependency('libxml-2.0')
++endif
++
++top_incdir = include_directories('.')
++
++subdir('include')
++subdir('lib')
++subdir('src')
++if build_tools
++  subdir('tools')
++endif
++
++install_data('xmlrpc-c-config', install_dir : get_option('bindir'))
+diff --git a/meson_options.txt b/meson_options.txt
+new file mode 100644
+index 00000000..4e2c1607
+--- /dev/null
++++ b/meson_options.txt
+@@ -0,0 +1,13 @@
++option('wininet-client',  type : 'boolean', value : false, description : 'Build the Wininet client XML transport')
++option('curl-client',     type : 'boolean', value : true,  description : 'Build the Curl client XML transport')
++option('libwww-client',   type : 'boolean', value : false, description : 'Build the Libwww client XML transport')
++
++option('abyss-server',    type : 'boolean', value : true,  description : 'Build the Abyss server module')
++option('abyss-threads',   type:  'boolean', value : true,  description : 'Use fork in Abyss instead of pthreads')
++option('abyss-openssl',   type:  'boolean', value : true,  description : 'Build Abyss Openssl channel function')
++option('cgi-server',      type : 'boolean', value : true,  description : 'Build the CGI server module')
++
++option('cplusplus',       type : 'boolean', value : true,  description : 'Build the C++ wrapper classes or tools')
++
++option('libwww-ssl',      type : 'boolean', value : false, description : 'Use SSL with libwww')
++option('libxml2-backend', type : 'boolean', value : false, description : 'Use libxml2 instead of built-in expat')
+diff --git a/src/cpp/meson.build b/src/cpp/meson.build
+new file mode 100644
+index 00000000..f0fd74f6
+--- /dev/null
++++ b/src/cpp/meson.build
+@@ -0,0 +1,223 @@
++libxmlrpc_cpp = library(
++  'xmlrpc_cpp',
++  sources : [
++    'XmlRpcCpp.cpp',
++  ],
++  include_directories : [
++    hdr_incdir,
++  ],
++  link_with : [
++    libxmlrpc,
++    libxmlrpc_util,
++    libxmlrpc_server,
++  ],
++  soversion : 8,
++  version : '8.@0@'.format(version_minor),
++  install : true,
++)
++
++libxmlrpcpp = library(
++  'xmlrpc++',
++  sources : [
++    'fault.cpp',
++    'global.cpp',
++    'outcome.cpp',
++    'param_list.cpp',
++    'value.cpp',
++    'xml.cpp',
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++  ],
++  link_with : [
++    libxmlrpc,
++    libxmlrpc_util,
++    libxmlrpc_utilpp,
++  ],
++  soversion : 8,
++  version : '8.@0@'.format(version_minor),
++  install : true,
++)
++pkgg.generate(
++  name : 'xmlrpc++',
++  description : 'Xmlrpc-c basic XML-RPC C++ library',
++  version : meson.project_version(),
++  requires_private : ['xmlrpc', 'xmlrpc_util', 'xmlrpc_util++'],
++  libraries : libxmlrpcpp,
++  install : true,
++)
++
++libxmlrpc_serverpp = library(
++  'xmlrpc_server++',
++  sources : [
++    'registry.cpp',
++  ],
++  include_directories : [
++    hdr_incdir,
++  ],
++  link_with : [
++    libxmlrpc,
++    libxmlrpcpp,
++    libxmlrpc_server,
++    libxmlrpc_util,
++    libxmlrpc_utilpp,
++  ],
++  soversion : 8,
++  version : '8.@0@'.format(version_minor),
++  install : true,
++)
++pkgg.generate(
++  name : 'xmlrpc_server++',
++  description : 'Xmlrpc-c XML-RPC server C++ library',
++  version : meson.project_version(),
++  requires_private : ['xmlrpc', 'xmlrpc++', 'xmlrpc_server', 'xmlrpc_util', 'xmlrpc_util++'],
++  libraries : libxmlrpc_serverpp,
++  install : true,
++)
++
++if get_option('abyss-server')
++  libxmlrpc_server_abysspp = library(
++    'xmlrpc_server_abyss++',
++    sources : [
++      'server_abyss.cpp',
++      'abyss_reqhandler_xmlrpc.cpp',
++    ],
++    include_directories : [
++      top_incdir,
++      hdr_incdir,
++      util_incdir,
++    ],
++    link_with : [
++      libxmlrpc_abyss,
++      libxmlrpc_abysspp,
++      libxmlrpc_serverpp,
++      libxmlrpc_server_abyss,
++      libxmlrpc_util,
++      libxmlrpc_utilpp,
++    ],
++    soversion : 8,
++    version : '8.@0@'.format(version_minor),
++    install : true,
++  )
++  pkgg.generate(
++    name : 'xmlrpc_server_abyss++',
++    description : 'Xmlrpc-c Abyss XML-RPC server C++ library',
++    version : meson.project_version(),
++    requires_private : ['xmlrpc_abyss', 'xmlrpc_abyss++', 'xmlrpc_server++', 'xmlrpc_server_abyss', 'xmlrpc_util', 'xmlrpc_util++'],
++    libraries : libxmlrpc_server_abysspp,
++    install : true,
++  )
++endif
++
++if get_option('cgi-server')
++  libxmlrpc_server_cgipp = library(
++    'xmlrpc_server_cgi++',
++    sources : [
++      'server_cgi.cpp',
++    ],
++    include_directories : [
++      top_incdir,
++      hdr_incdir,
++    ],
++    link_with : [
++      libxmlrpc,
++      libxmlrpcpp,
++      libxmlrpc_serverpp,
++      libxmlrpc_utilpp,
++    ],
++    soversion : 8,
++    version : '8.@0@'.format(version_minor),
++    install : true,
++  )
++endif
++
++libxmlrpc_packetsocket = library(
++  'xmlrpc_packetsocket',
++  sources : [
++    'packetsocket.cpp',
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++  ],
++  link_with : [
++    libxmlrpcpp,
++    libxmlrpc_utilpp,
++  ],
++  soversion : 8,
++  version : '8.@0@'.format(version_minor),
++  install : true,
++)
++
++if build_xmlrpc_pstream
++  libxmlrpc_server_pstreampp = library(
++    'xmlrpc_server_pstream++',
++    sources : [
++      'server_pstream_conn.cpp',
++      'server_pstream.cpp',
++    ],
++    include_directories : [
++      top_incdir,
++      hdr_incdir,
++    ],
++    link_with : [
++      libxmlrpcpp,
++      libxmlrpc_serverpp,
++      libxmlrpc_packetsocket,
++      libxmlrpc_utilpp,
++    ],
++    soversion : 8,
++    version : '8.@0@'.format(version_minor),
++    install : true,
++  )
++  pkgg.generate(
++    name : 'xmlrpc_server_pstream',
++    description : 'Xmlrpc-c packet-stream XML-RPC server library',
++    version : meson.project_version(),
++    requires_private : ['xmlrpc++', 'xmlrpc_server++', 'xmlrpc_util++'],
++    libraries : [libxmlrpc_server_pstreampp, libxmlrpc_packetsocket],
++    install : true,
++  )
++endif
++
++if build_client
++  libxmlrpc_clientpp = library(
++    'xmlrpc_client++',
++    sources : [
++      'client.cpp',
++      'client_simple.cpp',
++      'curl.cpp',
++      'libwww.cpp',
++      'wininet.cpp',
++      'pstream.cpp',
++    ],
++    include_directories : [
++      top_incdir,
++      hdr_incdir,
++      util_incdir,
++    ],
++    link_with : [
++      libxmlrpc,
++      libxmlrpcpp,
++      libxmlrpc_client,
++      libxmlrpc_packetsocket,
++      libxmlrpc_util,
++      libxmlrpc_utilpp,
++    ],
++    soversion : 8,
++    version : '8.@0@'.format(version_minor),
++    install : true,
++  )
++  pkgg.generate(
++    name : 'xmlrpc_client++',
++    description : 'Xmlrpc-c XML-RPC client C++ library',
++    version : meson.project_version(),
++    requires_private : ['xmlrpc', 'xmlrpc++', 'xmlrpc_client', 'xmlrpc_util', 'xmlrpc_util++'],
++    libraries : libxmlrpc_clientpp,
++    libraries_private : libxmlrpc_packetsocket,
++    install : true,
++  )
++endif
+diff --git a/src/meson.build b/src/meson.build
+new file mode 100644
+index 00000000..8dd22486
+--- /dev/null
++++ b/src/meson.build
+@@ -0,0 +1,190 @@
++xmlrpc_deps = []
++xmlrpc_incs = []
++xmlrpc_libs = [libxmlrpc_util]
++xmlrpc_pkgconfig_req = ['xmlrpc_util']
++# TODO: handle clients
++
++if get_option('libxml2-backend')
++  xmlrpc_xml_parser = 'xmlrpc_libxml2.c'
++  xmlrpc_deps += [libxml2]
++  xmlrpc_pkgconfig_req += ['libxml-2.0']
++else
++  xmlrpc_xml_parser = 'xmlrpc_expat.c'
++  xmlrpc_incs += [xmlparse_incdir]
++  xmlrpc_libs += [libxmlrpc_xmlparse]
++  xmlrpc_pkgconfig_req += ['xmlrpc_expat']
++endif
++
++libxmlrpc = library(
++  'xmlrpc',
++  sources : [
++    'base_global.c',
++    'double.c',
++    'json.c',
++    'parse_datetime.c',
++    'parse_value.c',
++    'resource.c',
++    'trace.c',
++    'version.c',
++    'xmlrpc_data.c',
++    'xmlrpc_datetime.c',
++    'xmlrpc_string.c',
++    'xmlrpc_array.c',
++    'xmlrpc_struct.c',
++    'xmlrpc_build.c',
++    'xmlrpc_decompose.c',
++    xmlrpc_xml_parser,
++    'xmlrpc_parse.c',
++    'xmlrpc_serialize.c',
++    'xmlrpc_authcookie.c',
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++  ] + xmlrpc_incs,
++  link_with : xmlrpc_libs,
++  dependencies : xmlrpc_deps,
++  soversion : 3,
++  version : '3.@0@'.format(version_minor),
++  install : true,
++)
++pkgg.generate(
++  name : 'xmlrpc',
++  description : 'Xmlrpc-c basic XML-RPC library',
++  version : meson.project_version(),
++  requires_private : xmlrpc_pkgconfig_req,
++  libraries : libxmlrpc,
++  install : true,
++)
++
++libxmlrpc_server = library(
++  'xmlrpc_server',
++  sources : [
++    'registry.c',
++    'method.c',
++    'system_method.c',
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++  ],
++  link_with : [
++    libxmlrpc,
++    libxmlrpc_util,
++  ],
++  soversion : 3,
++  version : '3.@0@'.format(version_minor),
++  install : true,
++)
++pkgg.generate(
++  name : 'xmlrpc_server',
++  description : 'Xmlrpc-c XML-RPC server library',
++  version : meson.project_version(),
++  requires_private : ['xmlrpc', 'xmlrpc_util'],
++  libraries : libxmlrpc_server,
++  install : true,
++)
++
++if get_option('abyss-server')
++  libxmlrpc_server_abyss = library(
++    'xmlrpc_server_abyss',
++    sources : [
++      'xmlrpc_server_abyss.c',
++      'abyss_handler.c',
++    ],
++    include_directories : [
++      top_incdir,
++      hdr_incdir,
++      util_incdir,
++    ],
++    link_with : [
++      libxmlrpc,
++      libxmlrpc_server,
++      libxmlrpc_abyss,
++      libxmlrpc_util,
++    ],
++    soversion : 3,
++    version : '3.@0@'.format(version_minor),
++    install : true,
++  )
++  pkgg.generate(
++    name : 'xmlrpc_server_abyss',
++    description : 'Xmlrpc-c Abyss XML-RPC server library',
++    version : meson.project_version(),
++    requires_private : ['xmlrpc', 'xmlrpc_server', 'xmlrpc_abyss', 'xmlrpc_util'],
++    libraries : libxmlrpc_server_abyss,
++    install : true,
++  )
++endif
++
++if get_option('cgi-server')
++  libxmlrpc_server_cgi = library(
++    'xmlrpc_server_cgi',
++    sources : [
++      'xmlrpc_server_cgi.c',
++    ],
++    include_directories : [
++      top_incdir,
++      hdr_incdir,
++      util_incdir,
++    ],
++    link_with : [
++      libxmlrpc,
++      libxmlrpc_server,
++      libxmlrpc_util,
++    ],
++    soversion : 3,
++    version : '3.@0@'.format(version_minor),
++    install : true,
++  )
++  pkgg.generate(
++    name : 'xmlrpc_server_cgi',
++    description : 'Xmlrpc-c CGI XML-RPC server library',
++    version : meson.project_version(),
++    requires_private : ['xmlrpc', 'xmlrpc_server', 'xmlrpc_util'],
++    libraries : libxmlrpc_server_cgi,
++    install : true,
++  )
++endif
++
++if build_client
++  xmlrpc_client_transports = []
++  if get_option('curl-client')
++    xmlrpc_client_transports += [xmlrpc_curl_transport]
++  endif
++  libxmlrpc_client = library(
++    'xmlrpc_client',
++    sources : [
++      'xmlrpc_client.c',
++      'xmlrpc_client_global.c',
++      'xmlrpc_server_info.c',
++    ],
++    include_directories : [
++      top_incdir,
++      hdr_incdir,
++      util_incdir,
++    ],
++    link_with : [
++      libxmlrpc,
++      libxmlrpc_util,
++    ],
++    dependencies : xmlrpc_client_transports,
++    soversion : 3,
++    version : '3.@0@'.format(version_minor),
++    install : true,
++  )
++  pkgg.generate(
++    name : 'xmlrpc_client',
++    description : 'Xmlrpc-c XML-RPC client library',
++    version : meson.project_version(),
++    requires_private : ['xmlrpc', 'xmlrpc_util'],
++    libraries : libxmlrpc_client,
++    install : true,
++  )
++endif
++
++if get_option('cplusplus')
++  subdir('cpp')
++endif
+diff --git a/tools/lib/meson.build b/tools/lib/meson.build
+new file mode 100644
+index 00000000..fc6929b8
+--- /dev/null
++++ b/tools/lib/meson.build
+@@ -0,0 +1,5 @@
++dumpvalue = declare_dependency(
++  include_directories : include_directories('include'),
++  sources : 'dumpvalue.c',
++  link_with : [libxmlrpc_util, libxmlrpc],
++)
+diff --git a/tools/meson.build b/tools/meson.build
+new file mode 100644
+index 00000000..f48a28f9
+--- /dev/null
++++ b/tools/meson.build
+@@ -0,0 +1,17 @@
++subdir('lib')
++subdir('xml')
++if build_client
++  subdir('xmlrpc')
++  subdir('xmlrpc_transport')
++  if get_option('cplusplus')
++    subdir('xml-rpc-api2cpp')
++    subdir('xml-rpc-api2txt')
++    subdir('xmlrpc_cpp_proxy')
++    if build_xmlrpc_pstream
++      subdir('xmlrpc_pstream')
++    endif
++  endif
++endif
++if get_option('cplusplus')
++  subdir('xmlrpc_dumpserver')
++endif
+diff --git a/tools/xml-rpc-api2cpp/meson.build b/tools/xml-rpc-api2cpp/meson.build
+new file mode 100644
+index 00000000..ec01212f
+--- /dev/null
++++ b/tools/xml-rpc-api2cpp/meson.build
+@@ -0,0 +1,21 @@
++executable(
++  'xml-rpc-api2cpp',
++  sources : [
++    'xml-rpc-api2cpp.cpp',
++    'DataType.cpp',
++    'XmlRpcFunction.cpp',
++    'XmlRpcClass.cpp',
++    'SystemProxy.cpp',
++  ],
++  include_directories : [
++    hdr_incdir,
++  ],
++  link_with : [
++    libxmlrpc,
++    libxmlrpc_client,
++    libxmlrpc_cpp,
++    libxmlrpc_util,
++  ],
++  install : true,
++)
++install_man('xml-rpc-api2cpp.1')
+diff --git a/tools/xml-rpc-api2txt/meson.build b/tools/xml-rpc-api2txt/meson.build
+new file mode 100644
+index 00000000..2a0a61e8
+--- /dev/null
++++ b/tools/xml-rpc-api2txt/meson.build
+@@ -0,0 +1,2 @@
++install_data('xml-rpc-api2txt', install_dir : get_option('bindir'))
++install_man('xml-rpc-api2txt.1')
+diff --git a/tools/xml/meson.build b/tools/xml/meson.build
+new file mode 100644
+index 00000000..2d856c60
+--- /dev/null
++++ b/tools/xml/meson.build
+@@ -0,0 +1,15 @@
++executable(
++  'xmlrpc_parsecall',
++  sources : [
++    'xmlrpc_parsecall.c',
++  ],
++  dependencies : [
++    util_casprintf_dep,
++    dumpvalue,
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++  ],
++  install : true,
++)
+diff --git a/tools/xmlrpc/meson.build b/tools/xmlrpc/meson.build
+new file mode 100644
+index 00000000..e1e8d552
+--- /dev/null
++++ b/tools/xmlrpc/meson.build
+@@ -0,0 +1,20 @@
++executable(
++  'xmlrpc',
++  sources : [
++    'xmlrpc.c',
++  ],
++  dependencies : [
++    dumpvalue,
++    util_dep,
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++  ],
++  link_with : [
++    libxmlrpc,
++    libxmlrpc_client,
++  ],
++  install : true,
++)
+diff --git a/tools/xmlrpc_cpp_proxy/meson.build b/tools/xmlrpc_cpp_proxy/meson.build
+new file mode 100644
+index 00000000..f3fc9988
+--- /dev/null
++++ b/tools/xmlrpc_cpp_proxy/meson.build
+@@ -0,0 +1,19 @@
++executable(
++  'xmlrpc_cpp_proxy',
++  sources : [
++    'xmlrpc_cpp_proxy.cpp',
++    'xmlrpcMethod.cpp',
++    'xmlrpcType.cpp',
++    'proxyClass.cpp',
++    'systemProxy.cpp',
++  ],
++  include_directories : [
++    hdr_incdir,
++  ],
++  link_with : [
++    libxmlrpcpp,
++    libxmlrpc_clientpp,
++    libxmlrpc_utilpp,
++  ],
++  install : true,
++)
+diff --git a/tools/xmlrpc_dumpserver/meson.build b/tools/xmlrpc_dumpserver/meson.build
+new file mode 100644
+index 00000000..b7aa7cfc
+--- /dev/null
++++ b/tools/xmlrpc_dumpserver/meson.build
+@@ -0,0 +1,23 @@
++executable(
++  'xmlrpc_dumpserver',
++  sources : [
++    'xmlrpc_dumpserver.c',
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++    util_incdir,
++  ],
++  link_with : [
++    libxmlrpc,
++    libxmlrpc_server,
++    libxmlrpc_server_abyss,
++    libxmlrpc_util,
++  ],
++  dependencies : [
++    util_dep,
++    util_casprintf_dep,
++    dumpvalue,
++  ],
++  install : true,
++)
+diff --git a/tools/xmlrpc_pstream/meson.build b/tools/xmlrpc_pstream/meson.build
+new file mode 100644
+index 00000000..9cd3eb85
+--- /dev/null
++++ b/tools/xmlrpc_pstream/meson.build
+@@ -0,0 +1,21 @@
++executable(
++  'xmlrpc_pstream',
++  sources : [
++    'xmlrpc_pstream.cpp',
++  ],
++  dependencies : [
++    dumpvalue,
++    util_cpp_dep,
++    readline,
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++  ],
++  link_with : [
++    libxmlrpcpp,
++    libxmlrpc_clientpp,
++    libxmlrpc_utilpp,
++  ],
++  install : true,
++)
+diff --git a/tools/xmlrpc_transport/meson.build b/tools/xmlrpc_transport/meson.build
+new file mode 100644
+index 00000000..cbb6f835
+--- /dev/null
++++ b/tools/xmlrpc_transport/meson.build
+@@ -0,0 +1,18 @@
++executable(
++  'xmlrpc_transport',
++  sources : [
++    'xmlrpc_transport.c',
++  ],
++  dependencies : [
++    util_dep,
++  ],
++  include_directories : [
++    top_incdir,
++    hdr_incdir,
++  ],
++  link_with : [
++    libxmlrpc_client,
++    libxmlrpc_util,
++  ],
++  install : true,
++)
+diff --git a/transport_config.h.in b/transport_config.h.in
+new file mode 100644
+index 00000000..687fdaf2
+--- /dev/null
++++ b/transport_config.h.in
+@@ -0,0 +1,4 @@
++#define MUST_BUILD_WININET_CLIENT @MUST_BUILD_WININET_CLIENT@
++#define MUST_BUILD_CURL_CLIENT @MUST_BUILD_CURL_CLIENT@
++#define MUST_BUILD_LIBWWW_CLIENT @MUST_BUILD_LIBWWW_CLIENT@
++static const char * const XMLRPC_DEFAULT_TRANSPORT = @XMLRPC_DEFAULT_TRANSPORT@;
+diff --git a/xmlrpc-c-config b/xmlrpc-c-config
+new file mode 100755
+index 00000000..25f95194
+--- /dev/null
++++ b/xmlrpc-c-config
+@@ -0,0 +1,114 @@
++#!/bin/sh
++
++comp=
++
++need_cxx=
++need_client=
++need_server=
++need_abyss_server=
++need_pstream=
++need_packetsocket=
++need_cgi=
++need_abyss=
++need_openssl=
++
++show_help() {
++    cat <<EOF
++Usage: xmlrpc-c-config <feature> ... <option> ...
++
++The features are:
++  c++            legacy C++ wrapper API
++  c++2           modern C++ API
++  client         client functions
++  cgi-server     CGI-based server functions
++  abyss-server   ABYSS-based server functions
++  pstream-server pstream-based server functions
++  server-util    basic server functions (implied by *-server)
++  abyss          Abyss HTTP server (not necessary with abyss-server)
++  openssl        Openssl convenience functions
++
++Options are:
++  --version      The version number of the package
++  --features     List all features (aka modules) currently installed
++  --cflags       C compiler flags to use when '#include'ing package headers
++  --libs         Libraries and flags to use when linking programs normally
++  --ldadd        Libraries to use with automake
++  --ldflags      Flags to use with automake & libtool
++  --prefix       The prefix under which the package was installed
++EOF
++    exit $1
++}
++
++test $# -ne 0 || show_help 1 >&2
++
++while test $# -gt 0; do
++    case $1 in
++      (c++)                  comp="$comp xmlrpc_cpp";;
++      (server-util)          need_server=1;;
++      (cgi-server)           need_cgi=1;;
++      (c++2)                 need_cxx=1;;
++      (abyss-server)         need_abyss_server=1;;
++      (pstream-server)       need_pstream=1;;
++      (packetsocket)         need_packetsocket=1;;
++      (client|libwww-client) need_client=1;;
++      (abyss)                need_abyss=1;;
++      (openssl)              need_openssl=1;;
++      (--help) show_help 0;;
++      (--) shift; break;;
++      (--*) break;;
++      (*)
++      echo "Unrecognized token '$1'"
++      exit 1
++      ;;
++    esac
++    shift
++done
++
++if test -z "$need_cxx"; then
++    test -z "$need_client"       || comp="$comp xmlrpc_client"
++    test -z "$need_abyss_server" || comp="$comp xmlrpc_server_abyss"
++    test -z "$need_abyss"        || comp="$comp xmlrpc_abyss"
++    test -z "$need_server"       || comp="$comp xmlrpc_server"
++    test -z "$need_cgi"          || comp="$comp xmlrpc_server_cgi"
++else
++    test -z "$need_client"       || comp="$comp xmlrpc_client++"
++    test -z "$need_abyss_server" || comp="$comp xmlrpc_server_abyss++"
++    test -z "$need_abyss"        || comp="$comp xmlrpc_abyss++"
++    test -z "$need_server"       || comp="$comp xmlrpc_server++"
++    test -z "$need_cgi"          || comp="$comp xmlrpc_server_cgi++"
++fi
++
++test -z "$need_packetsocket" || comp="$comp xmlrpc_packetsocket"
++test -z "$need_pstream"      || comp="$comp xmlrpc_server_pstream++"
++test -z "$need_openssl"      || comp="$comp xmlrpc_openssl"
++test -n "$comp"              || comp="xmlrpc xmlrpc_util"
++
++case $1 in
++  (--features|--modules)
++  echo "c++ abyss-server curl-client"
++  exit 0
++  ;;
++  (--version)
++  comp=xmlrpc
++  set -- --modversion
++  ;;
++  (--exec-prefix)
++  comp=xmlrpc
++  set -- --variable=prefix
++  ;;
++  (--*dir|--prefix)
++  comp=xmlrpc
++  set -- --variable=${1##--}
++  ;;
++  (--ldflags)
++  set -- --libs-only-L
++  ;;
++  (--ldadd)
++  set -- --libs-only-l
++  ;;
++  (--cflags)
++  set -- "$1"
++  ;;
++esac
++
++exec pkg-config "$@" $comp
diff --git a/SOURCES/0001-xmlrpc_server_abyss-use-va_args-properly.patch b/SOURCES/0001-xmlrpc_server_abyss-use-va_args-properly.patch
new file mode 100644
index 0000000..f519d95
--- /dev/null
+++ b/SOURCES/0001-xmlrpc_server_abyss-use-va_args-properly.patch
@@ -0,0 +1,34 @@
+From d31c2ffbf5181053330fa32e4f03c47283bd1448 Mon Sep 17 00:00:00 2001
+From: Igor Gnatenko <i.gnatenko.brain@gmail.com>
+Date: Sat, 17 Dec 2016 10:28:31 +0100
+Subject: [PATCH 1/3] xmlrpc_server_abyss: use va_args properly
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+../src/xmlrpc_server_abyss.c: In function ‘createServer’:
+../src/xmlrpc_server_abyss.c:783:13: error: format not a string literal and no format arguments [-Werror=format-security]
+             xmlrpc_faultf(envP, error);
+             ^~~~~~~~~~~~~
+
+Signed-off-by: Igor Gnatenko <i.gnatenko.brain@gmail.com>
+---
+ src/xmlrpc_server_abyss.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/src/xmlrpc_server_abyss.c b/src/xmlrpc_server_abyss.c
+index 8aacb4b..58f5ba0 100644
+--- a/src/xmlrpc_server_abyss.c
++++ b/src/xmlrpc_server_abyss.c
+@@ -780,7 +780,7 @@ createServer(xmlrpc_env *                      const envP,
+         ServerInit2(abyssServerP, &error);
+ 
+         if (error) {
+-            xmlrpc_faultf(envP, error);
++            xmlrpc_faultf(envP, "%s", error);
+             xmlrpc_strfree(error);
+         }
+     }
+-- 
+2.13.1
+
diff --git a/SOURCES/0002-Use-proper-datatypes-for-long-long.patch b/SOURCES/0002-Use-proper-datatypes-for-long-long.patch
new file mode 100644
index 0000000..25c7efe
--- /dev/null
+++ b/SOURCES/0002-Use-proper-datatypes-for-long-long.patch
@@ -0,0 +1,84 @@
+From aca713786debd68c81a823c5989afb3de82da45b Mon Sep 17 00:00:00 2001
+From: Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de>
+Date: Sat, 5 Apr 2008 11:41:34 +0200
+Subject: [PATCH 2/3] Use proper datatypes for 'long long'
+
+xmlrpc-c uses 'long long' at some places (e.g. in printf
+statements with PRId64) under the assumption that it has a
+width of exactly 64 bits.
+
+On 64 bit machines 'long long' has a width of 128 bit and
+will cause overhead both in memory and cpu usage there. As
+'long long' is used only to handle <i8> datatypes, the patch
+uses a plain 64 integer type there.
+
+It is arguable whether 'int_least64_t' (and 'int_least32_t')
+would be a better choice for 'int64_t' (and 'int32_t'), but
+for now, the patch uses datatypes with exact widths.
+---
+ include/xmlrpc-c/base.h     | 7 ++++---
+ lib/libutil/string_number.c | 1 +
+ src/cpp/param_list.cpp      | 2 +-
+ 3 files changed, 6 insertions(+), 4 deletions(-)
+
+diff --git a/include/xmlrpc-c/base.h b/include/xmlrpc-c/base.h
+index e74e2c5..90f2c91 100644
+--- a/include/xmlrpc-c/base.h
++++ b/include/xmlrpc-c/base.h
+@@ -5,6 +5,7 @@
+ 
+ #include <stddef.h>
+ #include <stdarg.h>
++#include <stdint.h>
+ #include <time.h>
+ #include <xmlrpc-c/c_util.h>  /* For XMLRPC_DLLEXPORT */
+ #include <xmlrpc-c/util.h>
+@@ -73,9 +74,9 @@ xmlrpc_version(unsigned int * const majorP,
+ 
+ typedef signed int xmlrpc_int;  
+     /* An integer of the type defined by XML-RPC <int>; i.e. 32 bit */
+-typedef XMLRPC_INT32 xmlrpc_int32;
++typedef int32_t xmlrpc_int32;
+     /* An integer of the type defined by XML-RPC <i4>; i.e. 32 bit */
+-typedef XMLRPC_INT64 xmlrpc_int64;
++typedef int64_t xmlrpc_int64;
+     /* An integer of the type defined by "XML-RPC" <i8>; i.e. 64 bit */
+ typedef int xmlrpc_bool;
+     /* A boolean (of the type defined by XML-RPC <boolean>, but there's
+@@ -112,7 +113,7 @@ typedef int xmlrpc_socket;
+ #define XMLRPC_INT32_MAX 0x7fffffff
+ #define XMLRPC_INT32_MIN (-XMLRPC_INT32_MAX - 1)
+ 
+-#define XMLRPC_INT64_MAX 0x7fffffffffffffffll
++#define XMLRPC_INT64_MAX ((xmlrpc_int64)0x7fffffffffffffffll)
+ #define XMLRPC_INT64_MIN (-XMLRPC_INT64_MAX - 1)
+ 
+ 
+diff --git a/lib/libutil/string_number.c b/lib/libutil/string_number.c
+index 1c284af..a7e78ad 100644
+--- a/lib/libutil/string_number.c
++++ b/lib/libutil/string_number.c
+@@ -6,6 +6,7 @@
+ ============================================================================*/
+ #include <stdlib.h>
+ #include <string.h>
++#include <inttypes.h>
+ #include <errno.h>
+ 
+ #include <xmlrpc-c/base.h>
+diff --git a/src/cpp/param_list.cpp b/src/cpp/param_list.cpp
+index 1f7ae41..60f7df9 100644
+--- a/src/cpp/param_list.cpp
++++ b/src/cpp/param_list.cpp
+@@ -277,7 +277,7 @@ paramList::getI8(unsigned int const paramNumber,
+         throw(fault("Parameter that is supposed to be 64-bit integer is not", 
+                     fault::CODE_TYPE));
+ 
+-    long long const longlongvalue(static_cast<long long>(
++    xmlrpc_int64 const longlongvalue(static_cast<xmlrpc_int64>(
+         value_i8(this->paramVector[paramNumber])));
+ 
+     if (longlongvalue < minimum)
+-- 
+2.13.1
+
diff --git a/SOURCES/0002-chmod-x-xml-rpc-api2txt.patch b/SOURCES/0002-chmod-x-xml-rpc-api2txt.patch
new file mode 100644
index 0000000..dd03ca8
--- /dev/null
+++ b/SOURCES/0002-chmod-x-xml-rpc-api2txt.patch
@@ -0,0 +1,16 @@
+From d97ec6e652690a321d7ce8c81aa30f87d9c0de8f Mon Sep 17 00:00:00 2001
+From: Igor Gnatenko <i.gnatenko.brain@gmail.com>
+Date: Mon, 19 Dec 2016 21:33:47 +0100
+Subject: [PATCH 2/2] chmod +x xml-rpc-api2txt
+
+It's script which is installing into $bindir, so it must be executable.
+
+Signed-off-by: Igor Gnatenko <i.gnatenko.brain@gmail.com>
+---
+ tools/xml-rpc-api2txt/xml-rpc-api2txt | 0
+ 1 file changed, 0 insertions(+), 0 deletions(-)
+ mode change 100644 => 100755 tools/xml-rpc-api2txt/xml-rpc-api2txt
+
+diff --git a/tools/xml-rpc-api2txt/xml-rpc-api2txt b/tools/xml-rpc-api2txt/xml-rpc-api2txt
+old mode 100644
+new mode 100755
diff --git a/SOURCES/0003-allow-30x-redirections.patch b/SOURCES/0003-allow-30x-redirections.patch
new file mode 100644
index 0000000..7446fa6
--- /dev/null
+++ b/SOURCES/0003-allow-30x-redirections.patch
@@ -0,0 +1,27 @@
+From 9bb040a9ae29e1b5afcb674c74f107114b316818 Mon Sep 17 00:00:00 2001
+From: Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de>
+Date: Thu, 29 Jul 2010 19:25:32 +0200
+Subject: [PATCH 3/3] allow 30x redirections
+
+---
+ lib/curl_transport/curltransaction.c | 4 ++++
+ 1 file changed, 4 insertions(+)
+
+diff --git a/lib/curl_transport/curltransaction.c b/lib/curl_transport/curltransaction.c
+index f0aafae..b5392a9 100644
+--- a/lib/curl_transport/curltransaction.c
++++ b/lib/curl_transport/curltransaction.c
+@@ -671,6 +671,10 @@ setupCurlSession(xmlrpc_env *               const envP,
+     curl_easy_setopt(curlSessionP, CURLOPT_POST, 1);
+     curl_easy_setopt(curlSessionP, CURLOPT_URL, transP->serverUrl);
+ 
++    curl_easy_setopt(curlSessionP, CURLOPT_FOLLOWLOCATION, 1);
++    curl_easy_setopt(curlSessionP, CURLOPT_MAXREDIRS, (long)10);
++    curl_easy_setopt(curlSessionP, CURLOPT_POSTREDIR, CURL_REDIR_POST_ALL);
++
+     XMLRPC_MEMBLOCK_APPEND(char, envP, transP->postDataP, "\0", 1);
+     if (!envP->fault_occurred) {
+         curl_easy_setopt(curlSessionP, CURLOPT_POSTFIELDS, 
+-- 
+2.13.1
+
diff --git a/SOURCES/0004-Add-missing-validation-of-encoding-CVE-2022-25235.patch b/SOURCES/0004-Add-missing-validation-of-encoding-CVE-2022-25235.patch
new file mode 100644
index 0000000..a11e792
--- /dev/null
+++ b/SOURCES/0004-Add-missing-validation-of-encoding-CVE-2022-25235.patch
@@ -0,0 +1,89 @@
+From 6aee99f381cc5bdfb6e514ac1e82f5e7b0fa7e2d Mon Sep 17 00:00:00 2001
+From: Rob Crittenden <rcritten@redhat.com>
+Date: Fri, 25 Feb 2022 16:42:35 -0500
+Subject: [PATCH 5/6] Add missing validation of encoding (CVE-2022-25235)
+
+Backported from upstream https://github.com/libexpat/libexpat/pull/562
+
+Resolves: #2058114
+---
+ lib/expat/xmltok/xmltok.c      | 21 +++++++++++++++------
+ lib/expat/xmltok/xmltok_impl.c |  8 ++++++--
+ 2 files changed, 21 insertions(+), 8 deletions(-)
+
+diff --git a/lib/expat/xmltok/xmltok.c b/lib/expat/xmltok/xmltok.c
+index 7b31fbb..3b0c950 100644
+--- a/lib/expat/xmltok/xmltok.c
++++ b/lib/expat/xmltok/xmltok.c
+@@ -61,12 +61,17 @@ We need 8 bits to index into pages, 3 bits to add to that index and
+      ? UTF8_GET_NAMING3(pages, (const unsigned char *)(p)) \
+      : 0))
+ 
++#define UTF8_INVALID2(p) \
++  ((*p) < 0xC2 || ((p)[1] & 0x80) == 0 || ((p)[1] & 0xC0) == 0xC0)
++
+ #define UTF8_INVALID3(p) \
+-  ((*p) == 0xED \
+-  ? (((p)[1] & 0x20) != 0) \
+-  : ((*p) == 0xEF \
+-     ? ((p)[1] == 0xBF && ((p)[2] == 0xBF || (p)[2] == 0xBE)) \
+-     : 0))
++  (((p)[2] & 0x80) == 0 \
++   || ((*p) == 0xEF && (p)[1] == 0xBF ? (p)[2] > 0xBD \
++                                      : ((p)[2] & 0xC0) == 0xC0) \
++   || ((*p) == 0xE0 \
++           ? (p)[1] < 0xA0 || ((p)[1] & 0xC0) == 0xC0 \
++           : ((p)[1] & 0x80) == 0 \
++                 || ((*p) == 0xED ? (p)[1] > 0x9F : ((p)[1] & 0xC0) == 0xC0)))
+ 
+ #define UTF8_INVALID4(p) ((*p) == 0xF4 && ((p)[1] & 0x30) != 0)
+ 
+@@ -104,7 +109,11 @@ int utf8_isNmstrt3(const ENCODING *enc ATTR_UNUSED, const char *p)
+ 
+ #define utf8_isNmstrt4 isNever
+ 
+-#define utf8_isInvalid2 isNever
++static
++int utf8_isInvalid2(const ENCODING *enc ATTR_UNUSED, const char *p)
++{ 
++  return UTF8_INVALID2((const unsigned char *)p);
++}
+ 
+ static
+ int utf8_isInvalid3(const ENCODING *enc ATTR_UNUSED, const char *p)
+diff --git a/lib/expat/xmltok/xmltok_impl.c b/lib/expat/xmltok/xmltok_impl.c
+index d035527..bae79b9 100644
+--- a/lib/expat/xmltok/xmltok_impl.c
++++ b/lib/expat/xmltok/xmltok_impl.c
+@@ -43,7 +43,7 @@ See the file copying.txt for copying permission.
+    case BT_LEAD ## n: \
+      if (end - ptr < n) \
+        return XML_TOK_PARTIAL_CHAR; \
+-     if (!IS_NAME_CHAR(enc, ptr, n)) { \
++     if (IS_INVALID_CHAR(enc, ptr, n) || !IS_NAME_CHAR(enc, ptr, n)) { \
+        *nextTokPtr = ptr; \
+        return XML_TOK_INVALID; \
+      } \
+@@ -71,7 +71,7 @@ See the file copying.txt for copying permission.
+    case BT_LEAD ## n: \
+      if (end - ptr < n) \
+        return XML_TOK_PARTIAL_CHAR; \
+-     if (!IS_NMSTRT_CHAR(enc, ptr, n)) { \
++     if (IS_INVALID_CHAR(enc, ptr, n) || !IS_NMSTRT_CHAR(enc, ptr, n)) { \
+        *nextTokPtr = ptr; \
+        return XML_TOK_INVALID; \
+      } \
+@@ -1168,6 +1168,10 @@ int PREFIX(prologTok)(const ENCODING *enc, const char *ptr, const char *end,
+   case BT_LEAD ## n: \
+     if (end - ptr < n) \
+       return XML_TOK_PARTIAL_CHAR; \
++    if (IS_INVALID_CHAR(enc, ptr, n)) { \
++      *nextTokPtr = ptr; \
++      return XML_TOK_INVALID; \
++    } \
+     if (IS_NMSTRT_CHAR(enc, ptr, n)) { \
+       ptr += n; \
+       tok = XML_TOK_NAME; \
+-- 
+2.31.1
+
diff --git a/SOURCES/0005-lib-Prevent-more-integer-overflows-CVE-2022-22822-to.patch b/SOURCES/0005-lib-Prevent-more-integer-overflows-CVE-2022-22822-to.patch
new file mode 100644
index 0000000..4c507ee
--- /dev/null
+++ b/SOURCES/0005-lib-Prevent-more-integer-overflows-CVE-2022-22822-to.patch
@@ -0,0 +1,92 @@
+From ce6eddc1a167dafaac17c7bad9fa6b013fada31b Mon Sep 17 00:00:00 2001
+From: Rob Crittenden <rcritten@redhat.com>
+Date: Fri, 25 Feb 2022 13:07:07 -0500
+Subject: [PATCH 5/6] lib: Prevent more integer overflows (CVE-2022-22822 to
+ CVE-2022-22827)
+
+Backport fixes from https://github.com/libexpat/libexpat/pull/539
+
+Resolves: #2058567, #2058576, #2058282, #2058589, #2058595, #2058602
+---
+ lib/expat/xmlparse/xmlparse.c | 40 +++++++++++++++++++++++++++++++++++
+ 1 file changed, 40 insertions(+)
+
+diff --git a/lib/expat/xmlparse/xmlparse.c b/lib/expat/xmlparse/xmlparse.c
+index 48adfb3..16ab82a 100644
+--- a/lib/expat/xmlparse/xmlparse.c
++++ b/lib/expat/xmlparse/xmlparse.c
+@@ -19,6 +19,7 @@ See the file copying.txt for copying permission.
+ #include <assert.h>
+ #include <limits.h>                     /* UINT_MAX */
+ #include <time.h>                       /* time() */
++#include <stdint.h>
+ 
+ #include "xmlrpc_config.h"
+ #include "c_util.h"
+@@ -1076,6 +1077,9 @@ int addBinding(XML_Parser parser,
+     ;
+   if (namespaceSeparator)
+     len++;
++  if (namespaceSeparator && (uri[len] == namespaceSeparator)) {
++    return XML_ERROR_SYNTAX;
++  }
+   if (freeBindingList) {
+     b = freeBindingList;
+     if (len > b->uriAlloc) {
+@@ -2116,10 +2120,32 @@ storeAtts(XML_Parser       const xmlParserP,
+   }
+   /* get the attributes from the tokenizer */
+   n = XmlGetAttributes(enc, attStr, attsSize, atts);
++
++
++  /* Detect and prevent integer overflow */
++  if (n > INT_MAX - nDefaultAtts) {
++    return XML_ERROR_NO_MEMORY;
++  }
++
+   if (n + nDefaultAtts > attsSize) {
+     int oldAttsSize = attsSize;
+     ATTRIBUTE *temp;
++    /* Detect and prevent integer overflow */
++    if ((nDefaultAtts > INT_MAX - INIT_ATTS_SIZE)
++        || (n > INT_MAX - (nDefaultAtts + INIT_ATTS_SIZE))) {
++      return XML_ERROR_NO_MEMORY;
++    }
+     attsSize = n + nDefaultAtts + INIT_ATTS_SIZE;
++    /* Detect and prevent integer overflow.
++     * The preprocessor guard addresses the "always false" warning
++     * from -Wtype-limits on platforms where
++     * sizeof(unsigned int) < sizeof(size_t), e.g. on x86_64. */
++#if UINT_MAX >= SIZE_MAX
++    if ((unsigned)parser->m_attsSize > (size_t)(-1) / sizeof(ATTRIBUTE)) {
++      attsSize = oldAttsSize;
++      return XML_ERROR_NO_MEMORY;
++    }
++#endif
+     temp = realloc((void *)atts, attsSize * sizeof(ATTRIBUTE));
+     if (!temp)
+       return XML_ERROR_NO_MEMORY;
+@@ -2297,6 +2323,20 @@ storeAtts(XML_Parser       const xmlParserP,
+   n = i + binding->uriLen;
+   if (n > binding->uriAlloc) {
+     TAG *p;
++
++    /* Detect and prevent integer overflow */
++    if (n > INT_MAX - EXPAND_SPARE) {
++      return XML_ERROR_NO_MEMORY;
++    }
++    /* Detect and prevent integer overflow.
++     * The preprocessor guard addresses the "always false" warning
++     * from -Wtype-limits on platforms where
++     * sizeof(unsigned int) < sizeof(size_t), e.g. on x86_64. */
++#if UINT_MAX >= SIZE_MAX
++    if ((unsigned)(n + EXPAND_SPARE) > (size_t)(-1) / sizeof(XML_Char)) {
++      return XML_ERROR_NO_MEMORY;
++    }
++#endif
+     XML_Char *uri = malloc((n + EXPAND_SPARE) * sizeof(XML_Char));
+     if (!uri)
+       return XML_ERROR_NO_MEMORY;
+-- 
+2.31.1
+
diff --git a/SOURCES/0006-Prevent-integer-overflow-on-m_groupSize-in-doProlog-.patch b/SOURCES/0006-Prevent-integer-overflow-on-m_groupSize-in-doProlog-.patch
new file mode 100644
index 0000000..9290060
--- /dev/null
+++ b/SOURCES/0006-Prevent-integer-overflow-on-m_groupSize-in-doProlog-.patch
@@ -0,0 +1,32 @@
+From 06d354807ac297374973631a6418edf7e3fcbf30 Mon Sep 17 00:00:00 2001
+From: Rob Crittenden <rcritten@redhat.com>
+Date: Mon, 28 Feb 2022 10:43:23 -0500
+Subject: [PATCH 6/6] Prevent integer overflow on m_groupSize in doProlog
+ (CVE-2021-46143)
+
+Backported from upstream https://github.com/libexpat/libexpat/pull/538
+
+Resolves: #2058560
+---
+ lib/expat/xmlparse/xmlparse.c | 5 +++++
+ 1 file changed, 5 insertions(+)
+
+diff --git a/lib/expat/xmlparse/xmlparse.c b/lib/expat/xmlparse/xmlparse.c
+index 16ab82a..b9aa927 100644
+--- a/lib/expat/xmlparse/xmlparse.c
++++ b/lib/expat/xmlparse/xmlparse.c
+@@ -3991,6 +3991,11 @@ doProlog(XML_Parser       const xmlParserP,
+     case XML_ROLE_GROUP_OPEN:
+       if (prologState.level >= groupSize) {
+         if (groupSize) {
++          /* Detect and prevent integer overflow */
++          if (groupSize > (unsigned int)(-1) / 2u) {
++            *errorCodeP = XML_ERROR_NO_MEMORY;
++            return;
++          }
+           char *temp = realloc(groupConnector, groupSize *= 2);
+           if (!temp) {
+             *errorCodeP = XML_ERROR_NO_MEMORY;
+-- 
+2.31.1
+
diff --git a/SPECS/xmlrpc-c.spec b/SPECS/xmlrpc-c.spec
new file mode 100644
index 0000000..9732d67
--- /dev/null
+++ b/SPECS/xmlrpc-c.spec
@@ -0,0 +1,515 @@
+%global advanced_branch 1
+
+# Upstream libxml2 backend is completely broken since 2015
+# https://sourceforge.net/p/xmlrpc-c/patches/49/
+%bcond_with libxml2
+
+Name:           xmlrpc-c
+Version:        1.51.0
+Release:        8%{?dist}
+Summary:        Lightweight RPC library based on XML and HTTP
+# See doc/COPYING for details.
+# The Python 1.5.2 license used by a few files is just BSD.
+License:        BSD and MIT
+URL:            http://xmlrpc-c.sourceforge.net/
+%{!?advanced_branch:Source0: http://dl.sourceforge.net/sourceforge/xmlrpc-c/xmlrpc-%version.tgz}
+# generated by 'make svn-sources [SVN_VER=%version SVN_REV=%svnrev]'. Unfortunately,
+# upstream does not tag versions so we must fetch from the branch and
+# check which version was used for it
+%{?advanced_branch:Source0: xmlrpc-c-%version.tar.xz}
+
+# Upstreamable patches
+Patch101:       0001-xmlrpc_server_abyss-use-va_args-properly.patch
+Patch102:       0002-Use-proper-datatypes-for-long-long.patch
+Patch103:       0003-allow-30x-redirections.patch
+#Patch104:       xmlrpc-c-printf-size_t.patch
+#Patch105:       xmlrpc-c-check-vasprintf-return-value.patch
+Patch104:       0004-Add-missing-validation-of-encoding-CVE-2022-25235.patch
+Patch105:       0005-lib-Prevent-more-integer-overflows-CVE-2022-22822-to.patch
+Patch106:       0006-Prevent-integer-overflow-on-m_groupSize-in-doProlog-.patch
+
+# Backported patches
+# https://sourceforge.net/p/xmlrpc-c/code/2981/
+# Fixes RHBZ #1541868
+Patch201:       0001-Remove-trace-statements-accidentally-committed-with-.patch
+
+# Meson buildsystem, see https://blogs.gnome.org/ignatenko/2016/12/17/meson-%E2%99%A5-xmlrpc-c/
+Patch1001:      0001-add-meson-buildsystem-definitions.patch
+Patch1002:      0002-chmod-x-xml-rpc-api2txt.patch
+
+BuildRequires:  git-core
+BuildRequires:  meson >= 0.36.0
+BuildRequires:  gcc
+BuildRequires:  gcc-c++
+%if %{with libxml2}
+BuildRequires:  pkgconfig(libxml-2.0)
+%else
+# upstream has its own fork of expat
+Provides:       bundled(expat)
+%endif
+BuildRequires:  pkgconfig(openssl)
+BuildRequires:  pkgconfig(libcurl)
+BuildRequires:  readline-devel
+BuildRequires:  ncurses-devel
+
+%package c++
+Summary:        C++ libraries for xmlrpc-c
+Requires:       %{name}%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+
+%package client
+Summary:        C client libraries for xmlrpc-c
+Requires:       %{name}%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+
+%package client++
+Summary:        C++ client libraries for xmlrpc-c
+Requires:       %{name}%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+Requires:       %{name}-c++%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+Requires:       %{name}-client%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+
+%package devel
+Summary:        Development files for xmlrpc-c based programs
+Requires:       %{name}%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+Requires:       %{name}-c++%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+Requires:       %{name}-client%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+Requires:       %{name}-client++%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+
+%package apps
+Summary:        Sample XML-RPC applications
+Requires:       %{name}%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+Requires:       %{name}-c++%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+Requires:       %{name}-client%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+Requires:       %{name}-client++%{?_isa} = %{?epoch:%{epoch}:}%{version}-%{release}
+
+
+%description
+XML-RPC is a quick-and-easy way to make procedure calls over the
+Internet. It converts the procedure call into XML document, sends it
+to a remote server using HTTP, and gets back the response as XML.
+
+This library provides a modular implementation of XML-RPC for C.
+
+
+%description c++
+XML-RPC is a quick-and-easy way to make procedure calls over the
+Internet. It converts the procedure call into XML document, sends it
+to a remote server using HTTP, and gets back the response as XML.
+
+This library provides a modular implementation of XML-RPC for C++.
+
+
+%description client
+XML-RPC is a quick-and-easy way to make procedure calls over the
+Internet. It converts the procedure call into XML document, sends it
+to a remote server using HTTP, and gets back the response as XML.
+
+This library provides a modular implementation of XML-RPC for C
+clients.
+
+%description client++
+XML-RPC is a quick-and-easy way to make procedure calls over the
+Internet. It converts the procedure call into XML document, sends it
+to a remote server using HTTP, and gets back the response as XML.
+
+This library provides a modular implementation of XML-RPC for C++
+clients.
+
+
+%description devel
+Static libraries and header files for writing XML-RPC applications in
+C and C++.
+
+
+%description apps
+XML-RPC is a quick-and-easy way to make procedure calls over the
+Internet. It converts the procedure call into XML document, sends it
+to a remote server using HTTP, and gets back the response as XML.
+
+This package contains some handy XML-RPC demo applications.
+
+
+%prep
+%autosetup -Sgit
+
+%build
+%meson %{?with_libxml2:-Dlibxml2-backend=true}
+%meson_build
+
+%install
+%meson_install
+
+%ldconfig_scriptlets
+%ldconfig_scriptlets client
+%ldconfig_scriptlets c++
+%ldconfig_scriptlets client++
+
+%files
+%license doc/COPYING lib/abyss/license.txt
+%doc doc/CREDITS doc/HISTORY
+%if ! %{with libxml2}
+%{_libdir}/libxmlrpc_xml*.so.*
+%endif
+%{_libdir}/libxmlrpc_openssl.so.*
+%{_libdir}/libxmlrpc.so.*
+%{_libdir}/libxmlrpc_util.so.*
+%{_libdir}/libxmlrpc_abyss.so.*
+%{_libdir}/libxmlrpc_server.so.*
+%{_libdir}/libxmlrpc_server_abyss.so.*
+%{_libdir}/libxmlrpc_server_cgi.so.*
+
+%files client
+%{_libdir}/libxmlrpc_client.so.*
+
+%files c++
+%{_libdir}/libxmlrpc_cpp.so.*
+%{_libdir}/libxmlrpc++.so.*
+%{_libdir}/libxmlrpc_util++.so.*
+%{_libdir}/libxmlrpc_abyss++.so.*
+%{_libdir}/libxmlrpc_server++.so.*
+%{_libdir}/libxmlrpc_server_abyss++.so.*
+%{_libdir}/libxmlrpc_server_cgi++.so.*
+%{_libdir}/libxmlrpc_packetsocket.so.*
+%{_libdir}/libxmlrpc_server_pstream++.so.*
+
+%files client++
+%{_libdir}/libxmlrpc_client++.so.*
+
+%files devel
+%{_bindir}/xmlrpc-c-config
+%{_includedir}/xmlrpc-c/
+%{_includedir}/*.h
+%{_libdir}/pkgconfig/xmlrpc*.pc
+%{_libdir}/libxmlrpc*.so
+
+%files apps
+%{_bindir}/xmlrpc_parsecall
+%{_bindir}/xmlrpc
+%{_bindir}/xmlrpc_transport
+%doc tools/xmlrpc_transport/xmlrpc_transport.html
+%{_bindir}/xml-rpc-api2cpp
+%{_mandir}/man1/xml-rpc-api2cpp.1*
+%{_bindir}/xml-rpc-api2txt
+%{_mandir}/man1/xml-rpc-api2txt.1*
+%{_bindir}/xmlrpc_cpp_proxy
+%{_bindir}/xmlrpc_pstream
+%{_bindir}/xmlrpc_dumpserver
+
+%changelog
+* Thu Apr 14 2022 Rob Crittenden <rcritten@redhat.com> - 1.51.0-8
+- Address some Coverity issues in the patch set
+
+* Tue Apr 05 2022 Rob Crittenden <rcritten@redhat.com> - 1.51.0-7
+- lib: Prevent more integer overflows (CVE-2022-22822 to CVE-2022-22827)
+  (#2058567, #2058576, #2058582, #2058589, #2058595, #2058602)
+- Prevent integer overflow on m_groupSize in doProlog
+  (CVE-2021-46143) (#2058560)
+
+* Thu Mar 03 2022 Rob Crittenden <rcritten@redhat.com> - 1.51.0-6
+- Add missing validation of encoding (CVE-2022-25235) (#2070481)
+
+* Thu Apr 19 2018 Adam Williamson <awilliam@redhat.com> - 1.51.0-5
+- Backport upstream fix for console spam with debug messages (#1541868)
+
+* Fri Feb 09 2018 Fedora Release Engineering <releng@fedoraproject.org> - 1.51.0-4
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild
+
+* Wed Jan 31 2018 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 1.51.0-3
+- Switch to %%ldconfig_scriptlets
+
+* Wed Jan 17 2018 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 1.51.0-2
+- BuildRequire openssl by pkgconfig()
+
+* Mon Jan 01 2018 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 1.51.0-1
+- Update to 1.51.0
+
+* Sun Oct 01 2017 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 1.49.02-2
+- Fix Requires.private in xmlrpc_server++.pc
+
+* Fri Sep 29 2017 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 1.49.02-1
+- Update to 1.49.02
+
+* Fri Sep 29 2017 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 1.48.0-8
+- Add xmlrpc_client++.pc
+
+* Thu Aug 03 2017 Fedora Release Engineering <releng@fedoraproject.org> - 1.48.0-7
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Binutils_Mass_Rebuild
+
+* Thu Jul 27 2017 Fedora Release Engineering <releng@fedoraproject.org> - 1.48.0-6
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild
+
+* Fri Jun 30 2017 Igor Gnatenko <ignatenkobrain@fedoraproject.org> - 1.48.0-5
+- Fix underlinking issue causing FTBFS
+
+* Mon Mar 13 2017 Peter Robinson <pbrobinson@fedoraproject.org> 1.48.0-4
+- Build with openssl 1.1
+
+* Sat Feb 11 2017 Fedora Release Engineering <releng@fedoraproject.org> - 1.48.0-3
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_26_Mass_Rebuild
+
+* Sat Jan 21 2017 Igor Gnatenko <ignatenko@redhat.com> - 1.48.0-2
+- Apply patches via git to preserve permissions
+
+* Sun Dec 18 2016 Igor Gnatenko <i.gnatenko.brain@gmail.com> - 1.48.0-1
+- Update to 1.48.0
+
+* Tue Feb 16 2016 Mikolaj Izdebski <mizdebsk@redhat.com> - 1.32.5-1909.svn2451
+- Add patch for conversion from int to usnigned char
+- Resolves: rhbz#1308254
+
+* Fri Feb 05 2016 Fedora Release Engineering <releng@fedoraproject.org> - 1.32.5-1909.svn2451
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_24_Mass_Rebuild
+
+* Fri Jun 19 2015 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 1.32.5-1908.svn2451
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_23_Mass_Rebuild
+
+* Sat May 02 2015 Kalev Lember <kalevlember@gmail.com> - 1.32.5-1907.svn2451
+- Rebuilt for GCC 5 C++11 ABI change
+
+* Mon Aug 18 2014 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 1.32.5-1906.svn2451
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_21_22_Mass_Rebuild
+
+* Sun Jun 08 2014 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 1.32.5-1905.svn2451
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_21_Mass_Rebuild
+
+* Fri Mar 28 2014 Mikolaj Izdebski <mizdebsk@redhat.com> - 1.32.5-1904.svn2451
+- Add patch to silence format-security compiler warning
+- Resolves: rhbz#1037399
+
+* Sun Aug 04 2013 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 1.32.5-1903.svn2451
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_20_Mass_Rebuild
+
+* Thu Apr 25 2013 Mikolaj Izdebski <mizdebsk@redhat.com> - 1.32.5-1902.svn2451
+- Add missing inter-package dependencies
+- Rename fedora directory to build
+
+* Fri Feb 15 2013 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 1.32.5-1901.svn2451
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_19_Mass_Rebuild
+
+* Sun Dec  9 2012 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.32.5-1900.svn2451
+- updated to 1.32.5
+
+* Sun Oct 21 2012 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.32.2-1900.svn2434
+- updated to 1.32.2
+
+* Sat Oct  6 2012 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.32.1-1900.svn2413
+- updated to 1.32.1
+
+* Sun Aug 26 2012 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.31.4-1900.svn2386
+- updated to 1.31.4
+
+* Sun Jul 22 2012 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 1.31.0-1801.svn2365
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_18_Mass_Rebuild
+
+* Sun Jul  1 2012 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.31.0-1800.svn2365
+- updated to 1.31.0
+
+* Wed Jun  6 2012 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.30.6-1800.svn2328
+- updated to 1.30.6
+
+* Sat May 26 2012 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.30.5-1800.svn2324
+- updated to 1.30.5 (IPv6 server fixes)
+
+* Sat May 12 2012 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.30.4-1800.svn2318
+- updated to 1.30.4
+
+* Thu Apr  5 2012 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.30.1-1800.svn2298
+- updated to 1.30.1
+
+* Tue Feb 28 2012 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 1.29.0-1701.svn2233
+- Rebuilt for c++ ABI breakage
+
+* Wed Jan  4 2012 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.29.0-1700.svn2233
+- updated to 1.29.0
+
+* Mon Oct  3 2011 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.28.1-1700.svn2203
+- updated to 1.28.1
+
+* Mon Oct  3 2011 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.27.5-1701.svn2185
+- fixed error handling when transfering too large files (#741980)
+
+* Sat Aug 27 2011 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.27.5-1700.svn2185
+- updated to 1.27.5
+
+* Sun Aug  7 2011 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.27.4-1700.svn2171
+- updated to 1.27.4
+
+* Sun Aug  7 2011 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.27.3-1700.svn2145
+- updated to 1.27.3
+
+* Mon Jun 27 2011 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.27.0-1600.svn2145
+- updated to 1.27.0
+- made it build with recent curl
+
+* Mon Jun 13 2011 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.26.3-1600.svn2134
+- updated to 1.26.3
+- removed default-constructor patch; issue is solved upstream
+
+* Sat Apr  2 2011 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.26.0-1600.svn2188
+- updated to 1.26.0
+
+* Mon Feb 07 2011 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 1.25.1-1501.svn2077
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_15_Mass_Rebuild
+
+* Thu Jan  6 2011 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.25.1-1500.svn2077
+- updated to 1.25.1
+
+* Thu Dec 30 2010 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.25.0-1500.svn2074
+- updated to 1.25.0
+
+* Sun Nov  7 2010 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.24.4-1500.svn2042
+- updated to 1.24.4
+
+* Sat Oct  9 2010 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.24.1-1500.svn1987
+- updated to 1.24.1
+- set -Wno-uninitialized CFLAGS; code contains lot of constructs
+  triggering this warning and the 'int a=a' defeaters have been
+  removed in this version
+
+* Fri Aug 27 2010 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.23.02-1500.svn1968
+- updated to 1.23.02 (note: this breaks C++ ABI)
+- added vasprintf patch
+
+* Thu Jul 29 2010 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.23.01-1400.svn1958
+- updated to 1.23.01
+- added patch to make curl follow HTTP POST 301 redirects (#618504)
+
+* Sun Apr 18 2010 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.22.01-1400.svn1907
+- updated to 1.22.01 (svn 1907)
+
+* Tue Feb 23 2010 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.21.00-1401.1851
+- require the various subpackages explicitly for -devel; the ld linker
+  scripts broke rpm's autodetection (#567400)
+- removed -devel Requires: which are covered by pkgconfig autodeps
+- added %%{?_isa} annotations
+
+* Sun Feb 21 2010 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.21.00-1400.1851
+- made linker scripts more 'ldconfig' friendly
+
+* Mon Feb 15 2010 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.21.00-1301.1851
+- replaced .so symlinks by linker scripts which add all implicit
+  dependencies in AS_NEEDED() commands (#564607, #565577)
+
+* Thu Jan 14 2010 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.21.00-1300.1851
+- updated to 1.21.00 (rev 1851)
+- removed curl-trace patch as applied upstream
+- rediffed patches
+
+* Sat Nov 21 2009 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.20.3-1.1841
+- updated to rev1841
+- rediffed patches
+- added patch to fix handling of wrong certificates (Nikola Pajkovsky)
+- added support for $XMLRPC_TRACE_CURL env (John Dennis)
+
+* Mon Jul 27 2009 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 1.16.6-3.1582
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_12_Mass_Rebuild
+
+* Thu Feb 26 2009 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 1.16.6-2.1582
+- Rebuilt for https://fedoraproject.org/wiki/Fedora_11_Mass_Rebuild
+
+* Thu Dec 11 2008 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.16.6-1.1582
+- updated to 1.16.6; rediffed patches
+- fixed client headers (bug #475887)
+
+* Sat Nov 15 2008 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.16.4.1567-2
+- updated to 1.16.4
+- rediffed/updated patches
+- splitted some subpackages (c++, client) out of main package as they
+  introduce additional dependencies (c++, curl)
+
+* Sat Sep  6 2008 Tom "spot" Callaway <tcallawa@redhat.com> - 1.14.8-2
+- fix license tag
+
+* Sat Jun 21 2008 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.14.8-1
+- updated to 1.14.8
+
+* Sun May 25 2008 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.14.6-1
+- updated to 1.14.6
+
+* Sat Apr 12 2008 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.14.2-1
+- updated to 1.14.2
+- rediffed patches
+- added patch to fix broken usage of 'long long' datatype
+
+* Mon Mar 17 2008 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.13.8-2
+- fixed cmake quoting so that pkgconfig files get correct version number
+- fixed handling of 'server-util' and '--cflags' within xmlrpc-c-config
+
+* Sun Mar 16 2008 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.13.8-1
+- updated to 1.13.8
+- removed some patches which were applied upstream
+
+* Tue Feb 26 2008 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.13.07-2
+- moved to advanced branched; rediffed/updated existing cmake patch
+  and fixed other compilation issues (#369841)
+
+* Mon Feb 18 2008 Fedora Release Engineering <rel-eng@fedoraproject.org> - 1.06.23-2
+- Autorebuild for GCC 4.3
+
+* Wed Jan  2 2008 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.06.23-1
+- use correct pkg-config script for 'xmlrpc-config abyss-server'
+  output (#355411)
+- updated to 1.06.23 (#355411)
+
+* Tue Sep  4 2007 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.06.18-1
+- updated to 1.06.18
+
+* Thu Aug 16 2007 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.06.17-1
+- updated to 1.06.17
+
+* Sun Jul 22 2007 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.06.16-1
+- updated to 1.06.16
+
+* Thu Jun 14 2007 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.06.14-1
+- updated to 1.06.14
+
+* Sun Apr  1 2007 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.06.11-2
+- rediffed cmake patch against current version
+- made the xmlrpc-c-config compatible to the upstream version
+- added compatibility symlinks for some header files (thx to Robert de
+  Vries for reporting these two issues)
+
+* Sat Mar 17 2007 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.06.11-1
+- updated to 1.06.11
+
+* Sat Feb  3 2007 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.06.09-1
+- updated to 1.06.09
+- removed -typo patch since applied upstream
+
+* Mon Nov  6 2006 Jindrich Novy <jnovy@redhat.com> - 1.06.05-3
+- rebuild against the new curl
+
+* Mon Oct  2 2006 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.06.05-2
+- updated cmake patch
+- strip installed libraries
+
+* Wed Sep 20 2006 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.06.05-1
+- updated to 1.06.05
+- merged + updated patches
+
+* Sat Sep 16 2006 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.06.04-1
+- updated to 1.06.04
+- patched the broken buildsystem
+- disabled libwww backend explicitely
+
+* Sun Jun  4 2006 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.05-1
+- updated to 1.05
+- updated patches
+
+* Sat Feb 18 2006 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.04-2
+- rebuilt for FC5
+
+* Sun Dec 18 2005 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.04-1
+- added libxml2-devel and openssl-devel Requires: for the -devel
+  subpackage
+- ship doc/* instead of doc
+- initial Fedora Extras package (review 175840)
+
+* Thu Dec 15 2005 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.04-0.1
+- disabled w3c-libwww because it does not exist anymore in FC5 and
+  seems to be unmaintained upstream
+- added missing libxml2-devel
+- cleaned up list of %%doc files
+- fixed gcc4.1 build issues
+- removed static libraries when there exists a corresponding dynamic one
+
+* Tue Aug  2 2005 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> - 1.03.02-1
+- Initial build.