cpp: Use portable off_t size_t
* configure.ac: Configure cpp data.h.in * lang/cpp/src/Makefile.am: Generate data.h * lang/cpp/src/data.cpp, lang/cpp/src/data.h: Use portable types. * lang/qt/src/Makefile.am: Include build dir. * lang/qt/tests/makefile.am: Include build dir. -- These kind of patches have been around for a while, IMO this should not create an ABI incompatbility for cases where it already works because the types should be the same so I think this is not an interface break. GnuPG-Bug-Id: T3996
This commit is contained in:
parent
3c185c2159
commit
88294023c1
@ -902,7 +902,8 @@ AC_CONFIG_FILES(Makefile src/Makefile
|
|||||||
src/versioninfo.rc
|
src/versioninfo.rc
|
||||||
src/gpgme.pc
|
src/gpgme.pc
|
||||||
src/gpgme-glib.pc
|
src/gpgme-glib.pc
|
||||||
src/gpgme.h)
|
src/gpgme.h
|
||||||
|
lang/cpp/src/data.h)
|
||||||
AC_CONFIG_FILES(src/gpgme-config, chmod +x src/gpgme-config)
|
AC_CONFIG_FILES(src/gpgme-config, chmod +x src/gpgme-config)
|
||||||
AC_CONFIG_FILES(lang/cpp/Makefile lang/cpp/src/Makefile)
|
AC_CONFIG_FILES(lang/cpp/Makefile lang/cpp/src/Makefile)
|
||||||
AC_CONFIG_FILES(lang/cpp/tests/Makefile)
|
AC_CONFIG_FILES(lang/cpp/tests/Makefile)
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
# 02111-1307, USA
|
# 02111-1307, USA
|
||||||
|
|
||||||
EXTRA_DIST = GpgmeppConfig.cmake.in.in GpgmeppConfigVersion.cmake.in \
|
EXTRA_DIST = GpgmeppConfig.cmake.in.in GpgmeppConfigVersion.cmake.in \
|
||||||
gpgmepp_version.h.in GpgmeppConfig-w32.cmake.in.in
|
gpgmepp_version.h.in data.h.in GpgmeppConfig-w32.cmake.in.in
|
||||||
|
|
||||||
lib_LTLIBRARIES = libgpgmepp.la
|
lib_LTLIBRARIES = libgpgmepp.la
|
||||||
|
|
||||||
@ -39,7 +39,7 @@ main_sources = \
|
|||||||
vfsmountresult.cpp configuration.cpp tofuinfo.cpp swdbresult.cpp
|
vfsmountresult.cpp configuration.cpp tofuinfo.cpp swdbresult.cpp
|
||||||
|
|
||||||
gpgmepp_headers = \
|
gpgmepp_headers = \
|
||||||
configuration.h context.h data.h decryptionresult.h \
|
configuration.h context.h decryptionresult.h \
|
||||||
defaultassuantransaction.h editinteractor.h encryptionresult.h \
|
defaultassuantransaction.h editinteractor.h encryptionresult.h \
|
||||||
engineinfo.h error.h eventloopinteractor.h exception.h global.h \
|
engineinfo.h error.h eventloopinteractor.h exception.h global.h \
|
||||||
gpgadduserideditinteractor.h gpgagentgetinfoassuantransaction.h \
|
gpgadduserideditinteractor.h gpgagentgetinfoassuantransaction.h \
|
||||||
@ -63,7 +63,7 @@ interface_headers= \
|
|||||||
gpgmeppincludedir = $(includedir)/gpgme++
|
gpgmeppincludedir = $(includedir)/gpgme++
|
||||||
gpgmeppinclude_HEADERS = $(gpgmepp_headers)
|
gpgmeppinclude_HEADERS = $(gpgmepp_headers)
|
||||||
nobase_gpgmeppinclude_HEADERS = $(interface_headers)
|
nobase_gpgmeppinclude_HEADERS = $(interface_headers)
|
||||||
nodist_gpgmeppinclude_HEADERS = gpgmepp_version.h
|
nodist_gpgmeppinclude_HEADERS = gpgmepp_version.h data.h
|
||||||
|
|
||||||
libgpgmepp_la_SOURCES = $(main_sources) $(gpgmepp_headers) context_vanilla.cpp \
|
libgpgmepp_la_SOURCES = $(main_sources) $(gpgmepp_headers) context_vanilla.cpp \
|
||||||
$(interface_headers) $(private_gpgmepp_headers)
|
$(interface_headers) $(private_gpgmepp_headers)
|
||||||
@ -110,4 +110,4 @@ install-data-local: install-cmake-files
|
|||||||
uninstall-local: uninstall-cmake-files
|
uninstall-local: uninstall-cmake-files
|
||||||
|
|
||||||
CLEANFILES = GpgmeppConfig.cmake GpgmeppConfigVersion.cmake \
|
CLEANFILES = GpgmeppConfig.cmake GpgmeppConfigVersion.cmake \
|
||||||
gpgmepp_version.h GpgmeppConfig.cmake.in
|
gpgmepp_version.h data.h GpgmeppConfig.cmake.in
|
||||||
|
@ -217,17 +217,17 @@ GpgME::Error GpgME::Data::setFileName(const char *name)
|
|||||||
return Error(gpgme_data_set_file_name(d->data, name));
|
return Error(gpgme_data_set_file_name(d->data, name));
|
||||||
}
|
}
|
||||||
|
|
||||||
ssize_t GpgME::Data::read(void *buffer, size_t length)
|
gpgme_ssize_t GpgME::Data::read(void *buffer, size_t length)
|
||||||
{
|
{
|
||||||
return gpgme_data_read(d->data, buffer, length);
|
return gpgme_data_read(d->data, buffer, length);
|
||||||
}
|
}
|
||||||
|
|
||||||
ssize_t GpgME::Data::write(const void *buffer, size_t length)
|
gpgme_ssize_t GpgME::Data::write(const void *buffer, size_t length)
|
||||||
{
|
{
|
||||||
return gpgme_data_write(d->data, buffer, length);
|
return gpgme_data_write(d->data, buffer, length);
|
||||||
}
|
}
|
||||||
|
|
||||||
off_t GpgME::Data::seek(off_t offset, int whence)
|
gpgme_off_t GpgME::Data::seek(gpgme_off_t offset, int whence)
|
||||||
{
|
{
|
||||||
return gpgme_data_seek(d->data, offset, whence);
|
return gpgme_data_seek(d->data, offset, whence);
|
||||||
}
|
}
|
||||||
|
@ -1,140 +0,0 @@
|
|||||||
/*
|
|
||||||
data.h - wraps a gpgme data object
|
|
||||||
Copyright (C) 2003,2004 Klarälvdalens Datakonsult AB
|
|
||||||
|
|
||||||
This file is part of GPGME++.
|
|
||||||
|
|
||||||
GPGME++ is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Library General Public
|
|
||||||
License as published by the Free Software Foundation; either
|
|
||||||
version 2 of the License, or (at your option) any later version.
|
|
||||||
|
|
||||||
GPGME++ is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
GNU Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public License
|
|
||||||
along with GPGME++; see the file COPYING.LIB. If not, write to the
|
|
||||||
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
||||||
Boston, MA 02110-1301, USA.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef __GPGMEPP_DATA_H__
|
|
||||||
#define __GPGMEPP_DATA_H__
|
|
||||||
|
|
||||||
#include "global.h"
|
|
||||||
#include "key.h"
|
|
||||||
|
|
||||||
#include <sys/types.h> // for size_t, off_t
|
|
||||||
#include <cstdio> // FILE
|
|
||||||
#include <algorithm>
|
|
||||||
#include <memory>
|
|
||||||
|
|
||||||
namespace GpgME
|
|
||||||
{
|
|
||||||
|
|
||||||
class DataProvider;
|
|
||||||
class Error;
|
|
||||||
|
|
||||||
class GPGMEPP_EXPORT Data
|
|
||||||
{
|
|
||||||
struct Null {
|
|
||||||
Null() {}
|
|
||||||
};
|
|
||||||
public:
|
|
||||||
/* implicit */ Data(const Null &);
|
|
||||||
Data();
|
|
||||||
explicit Data(gpgme_data_t data);
|
|
||||||
|
|
||||||
// Memory-Based Data Buffers:
|
|
||||||
Data(const char *buffer, size_t size, bool copy = true);
|
|
||||||
explicit Data(const char *filename);
|
|
||||||
Data(const char *filename, off_t offset, size_t length);
|
|
||||||
Data(std::FILE *fp, off_t offset, size_t length);
|
|
||||||
// File-Based Data Buffers:
|
|
||||||
explicit Data(std::FILE *fp);
|
|
||||||
explicit Data(int fd);
|
|
||||||
// Callback-Based Data Buffers:
|
|
||||||
explicit Data(DataProvider *provider);
|
|
||||||
|
|
||||||
static const Null null;
|
|
||||||
|
|
||||||
const Data &operator=(Data other)
|
|
||||||
{
|
|
||||||
swap(other);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
void swap(Data &other)
|
|
||||||
{
|
|
||||||
using std::swap;
|
|
||||||
swap(this->d, other.d);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool isNull() const;
|
|
||||||
|
|
||||||
enum Encoding {
|
|
||||||
AutoEncoding,
|
|
||||||
BinaryEncoding,
|
|
||||||
Base64Encoding,
|
|
||||||
ArmorEncoding,
|
|
||||||
MimeEncoding,
|
|
||||||
UrlEncoding,
|
|
||||||
UrlEscEncoding,
|
|
||||||
Url0Encoding,
|
|
||||||
};
|
|
||||||
Encoding encoding() const;
|
|
||||||
Error setEncoding(Encoding encoding);
|
|
||||||
|
|
||||||
enum Type {
|
|
||||||
Invalid,
|
|
||||||
Unknown,
|
|
||||||
PGPSigned,
|
|
||||||
PGPOther,
|
|
||||||
PGPKey,
|
|
||||||
CMSSigned,
|
|
||||||
CMSEncrypted,
|
|
||||||
CMSOther,
|
|
||||||
X509Cert,
|
|
||||||
PKCS12,
|
|
||||||
PGPEncrypted,
|
|
||||||
PGPSignature,
|
|
||||||
};
|
|
||||||
Type type() const;
|
|
||||||
|
|
||||||
char *fileName() const;
|
|
||||||
Error setFileName(const char *name);
|
|
||||||
|
|
||||||
ssize_t read(void *buffer, size_t length);
|
|
||||||
ssize_t write(const void *buffer, size_t length);
|
|
||||||
off_t seek(off_t offset, int whence);
|
|
||||||
|
|
||||||
/* Convenience function to do a seek (0, SEEK_SET). */
|
|
||||||
Error rewind();
|
|
||||||
|
|
||||||
/** Try to parse the data to a key object using the
|
|
||||||
* Protocol proto. Returns an empty list on error.*/
|
|
||||||
std::vector<Key> toKeys(const Protocol proto = Protocol::OpenPGP) const;
|
|
||||||
|
|
||||||
/** Return a copy of the data as std::string. Sets seek pos to 0 */
|
|
||||||
std::string toString();
|
|
||||||
|
|
||||||
class Private;
|
|
||||||
Private *impl()
|
|
||||||
{
|
|
||||||
return d.get();
|
|
||||||
}
|
|
||||||
const Private *impl() const
|
|
||||||
{
|
|
||||||
return d.get();
|
|
||||||
}
|
|
||||||
private:
|
|
||||||
std::shared_ptr<Private> d;
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
GPGMEPP_MAKE_STD_SWAP_SPECIALIZATION(Data)
|
|
||||||
|
|
||||||
#endif // __GPGMEPP_DATA_H__
|
|
@ -227,7 +227,7 @@ nodist_qgpgmeinclude_HEADERS = qgpgme_version.h
|
|||||||
|
|
||||||
libqgpgme_la_SOURCES = $(qgpgme_sources) $(qgpgme_headers) $(private_qgpgme_headers)
|
libqgpgme_la_SOURCES = $(qgpgme_sources) $(qgpgme_headers) $(private_qgpgme_headers)
|
||||||
|
|
||||||
AM_CPPFLAGS = -I$(top_srcdir)/lang/cpp/src -I$(top_builddir)/src \
|
AM_CPPFLAGS = -I$(top_srcdir)/lang/cpp/src -I$(top_builddir)/lang/cpp/src -I$(top_builddir)/src \
|
||||||
@GPGME_QT_CFLAGS@ @GPG_ERROR_CFLAGS@ @LIBASSUAN_CFLAGS@ \
|
@GPGME_QT_CFLAGS@ @GPG_ERROR_CFLAGS@ @LIBASSUAN_CFLAGS@ \
|
||||||
-DBUILDING_QGPGME -Wsuggest-override \
|
-DBUILDING_QGPGME -Wsuggest-override \
|
||||||
-Wzero-as-null-pointer-constant
|
-Wzero-as-null-pointer-constant
|
||||||
|
@ -39,7 +39,7 @@ LDADD = ../../cpp/src/libgpgmepp.la ../src/libqgpgme.la \
|
|||||||
../../../src/libgpgme.la @GPGME_QT_LIBS@ @GPG_ERROR_LIBS@ \
|
../../../src/libgpgme.la @GPGME_QT_LIBS@ @GPG_ERROR_LIBS@ \
|
||||||
@GPGME_QTTEST_LIBS@ @LDADD_FOR_TESTS_KLUDGE@ -lstdc++
|
@GPGME_QTTEST_LIBS@ @LDADD_FOR_TESTS_KLUDGE@ -lstdc++
|
||||||
|
|
||||||
AM_CPPFLAGS = -I$(top_srcdir)/lang/cpp/src -I$(top_builddir)/src \
|
AM_CPPFLAGS = -I$(top_srcdir)/lang/cpp/src -I$(top_builddir)/lang/cpp/src -I$(top_builddir)/src \
|
||||||
@GPG_ERROR_CFLAGS@ @GPGME_QT_CFLAGS@ @GPG_ERROR_CFLAGS@ \
|
@GPG_ERROR_CFLAGS@ @GPGME_QT_CFLAGS@ @GPG_ERROR_CFLAGS@ \
|
||||||
@LIBASSUAN_CFLAGS@ @GPGME_QTTEST_CFLAGS@ -DBUILDING_QGPGME \
|
@LIBASSUAN_CFLAGS@ @GPGME_QTTEST_CFLAGS@ -DBUILDING_QGPGME \
|
||||||
-I$(top_srcdir)/lang/qt/src \
|
-I$(top_srcdir)/lang/qt/src \
|
||||||
|
Loading…
Reference in New Issue
Block a user