[gvfs/wip/inigomartinez/meson: 1/2] build: Port to meson build system
- From: Iñigo Martínez <inigomartinez src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gvfs/wip/inigomartinez/meson: 1/2] build: Port to meson build system
- Date: Thu, 14 Sep 2017 14:51:20 +0000 (UTC)
commit 1d74202dbbb7fe1a5c33c4e80874907881a5276e
Author: Iñigo Martínez <inigomartinez gmail com>
Date: Fri Aug 11 11:45:48 2017 +0200
build: Port to meson build system
meson is a build system focused on speed an ease of use, which
helps speeding up the software development. This patch adds meson
support along autotools.
https://bugzilla.gnome.org/show_bug.cgi?id=786149
Makefile.am | 4 +
client/Makefile.am | 2 +
client/meson.build | 90 ++++++
client/symbol.map | 9 +
common/Makefile.am | 5 +-
common/meson.build | 104 +++++++
daemon/Makefile.am | 1 +
daemon/meson.build | 464 ++++++++++++++++++++++++++++++
daemon/trashlib/Makefile.am | 2 +
daemon/trashlib/meson.build | 19 ++
man/Makefile.am | 1 +
man/meson.build | 68 +++++
meson.build | 656 +++++++++++++++++++++++++++++++++++++++++++
meson_options.txt | 27 ++
meson_post_install.py | 14 +
metadata/Makefile.am | 1 +
metadata/meson.build | 99 +++++++
monitor/Makefile.am | 2 +
monitor/afc/Makefile.am | 1 +
monitor/afc/meson.build | 57 ++++
monitor/gdu/Makefile.am | 1 +
monitor/gdu/meson.build | 59 ++++
monitor/goa/Makefile.am | 1 +
monitor/goa/meson.build | 54 ++++
monitor/gphoto2/Makefile.am | 1 +
monitor/gphoto2/meson.build | 58 ++++
monitor/meson.build | 25 ++
monitor/mtp/Makefile.am | 1 +
monitor/mtp/meson.build | 55 ++++
monitor/proxy/Makefile.am | 2 +
monitor/proxy/meson.build | 64 +++++
monitor/proxy/symbol.map | 8 +
monitor/udisks2/Makefile.am | 1 +
monitor/udisks2/meson.build | 71 +++++
po/meson.build | 1 +
programs/Makefile.am | 1 +
programs/meson.build | 37 +++
test/Makefile.am | 2 +
test/gvfs-all-tests.in | 4 +
test/meson.build | 94 ++++++
40 files changed, 2165 insertions(+), 1 deletions(-)
---
diff --git a/Makefile.am b/Makefile.am
index 1bea404..bc6410e 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -27,6 +27,10 @@ EXTRA_DIST = \
m4 \
gettext/its/polkit.loc \
gettext/its/polkit.its \
+ meson.build \
+ meson_options.txt \
+ meson_post_install.py \
+ po/meson.build \
$(NULL)
distclean-local:
diff --git a/client/Makefile.am b/client/Makefile.am
index c0ac599..bfa5871 100644
--- a/client/Makefile.am
+++ b/client/Makefile.am
@@ -96,4 +96,6 @@ endif
EXTRA_DIST = \
gvfsd-fuse-tmpfiles.conf \
+ meson.build \
+ symbol.map \
$(NULL)
diff --git a/client/meson.build b/client/meson.build
new file mode 100644
index 0000000..26cee97
--- /dev/null
+++ b/client/meson.build
@@ -0,0 +1,90 @@
+headers = files(
+ 'gvfsurimapper.h',
+ 'gvfsuriutils.h'
+)
+
+install_headers(
+ headers,
+ subdir: join_paths('gvfs-client', 'gvfs')
+)
+
+## Dynamic client lib
+uri_parser_sources = files(
+ 'afpuri.c',
+ 'httpuri.c',
+ 'smburi.c'
+)
+
+uri_utils = files('gvfsuriutils.c')
+
+sources = uri_parser_sources + uri_utils + files(
+ 'gdaemonmount.c',
+ 'gdaemonfile.c',
+ 'gdaemonfileenumerator.c',
+ 'gdaemonfileinputstream.c',
+ 'gdaemonfilemonitor.c',
+ 'gdaemonfileoutputstream.c',
+ 'gdaemonvfs.c',
+ 'gdaemonvolumemonitor.c',
+ 'gvfsdaemondbus.c',
+ 'gvfsiconloadable.c',
+ 'gvfsurimapper.c'
+)
+
+deps = glib_deps + [libgvfscommon_dep]
+
+cflags = [
+ '-DG_LOG_DOMAIN="@0@"'.format(meson.project_name().to_upper()),
+ '-DGVFS_LOCALEDIR="@0@"'.format(gvfs_localedir),
+ '-DGVFS_MODULE_DIR="@0@"'.format(join_paths(gvfs_libdir, 'gvfs', 'modules'))
+]
+
+symbol_map = 'symbol.map'
+
+ldflags = []
+if have_version_script
+ ldflags += '-Wl,--version-script,@0@/@1@'.format(meson.current_source_dir(), symbol_map)
+endif
+
+libgvfsdbus = shared_module(
+ 'gvfsdbus',
+ sources: sources + [metadata_dbus],
+ include_directories: top_inc,
+ dependencies: deps + [libmetadata_dep],
+ c_args: cflags,
+ link_args: ldflags,
+ link_depends: symbol_map,
+ install: true,
+ install_dir: gio_module_dir
+)
+
+test_name = 'test-uri-utils'
+
+executable(
+ test_name,
+ [test_name + '.c'] + uri_utils,
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: cflags
+)
+
+## FUSE daemon
+if have_fuse
+ # FIXME: reusing USE_LIBSYSTEMD_LOGIN as systemd has no universal header or pkg-config file
+ if have_libsystemd_login
+ install_data(
+ 'gvfsd-fuse-tmpfiles.conf',
+ install_dir: join_paths(gvfs_libdir, 'tmpfiles.d')
+ )
+ endif
+
+ executable(
+ 'gvfsd-fuse',
+ 'gvfsfusedaemon.c',
+ include_directories: top_inc,
+ dependencies: deps + [fuse_dep],
+ c_args: cflags + ['-UG_LOG_DOMAIN'],
+ install: true,
+ install_dir: gvfs_libexecdir
+ )
+endif
diff --git a/client/symbol.map b/client/symbol.map
new file mode 100644
index 0000000..73699b0
--- /dev/null
+++ b/client/symbol.map
@@ -0,0 +1,9 @@
+{
+global:
+ g_vfs_*;
+ g_io_module_load;
+ g_io_module_unload;
+ g_io_module_query;
+local:
+ *;
+};
diff --git a/common/Makefile.am b/common/Makefile.am
index 9fff709..67ba37f 100644
--- a/common/Makefile.am
+++ b/common/Makefile.am
@@ -87,6 +87,9 @@ libgvfscommon_gphoto2_la_LIBADD = \
endif
-EXTRA_DIST = org.gtk.vfs.xml
+EXTRA_DIST = \
+ org.gtk.vfs.xml \
+ meson.build \
+ $(NULL)
CLEANFILES = $(dbus_built_sources)
diff --git a/common/meson.build b/common/meson.build
new file mode 100644
index 0000000..8374cf8
--- /dev/null
+++ b/common/meson.build
@@ -0,0 +1,104 @@
+common_inc = include_directories('.')
+
+common_cflags = ['-DG_LOG_DOMAIN="@0@"'.format(meson.project_name().to_upper())]
+
+sources = files(
+ 'gmountoperationdbus.c',
+ 'gmountsource.c',
+ 'gmountspec.c',
+ 'gmounttracker.c',
+ 'gvfsdaemonprotocol.c',
+ 'gvfsfileinfo.c',
+ 'gvfsicon.c',
+ 'gvfsmonitorimpl.c',
+ 'gvfsutils.c'
+)
+
+sources += gnome.gdbus_codegen(
+ 'gvfsdbus',
+ gvfs_namespace + '.xml',
+ interface_prefix: gvfs_namespace + '.',
+ namespace: 'GVfsDBus'
+)
+
+cflags = common_cflags + [
+ '-DREMOTE_VOLUME_MONITORS_DIR="@0@"'.format(gvfs_datadir, 'gvfs', 'remote-volume-monitors')
+]
+
+libgvfscommon = shared_library(
+ 'gvfscommon',
+ sources: sources,
+ include_directories: top_inc,
+ dependencies: glib_deps,
+ c_args: cflags,
+ install: true,
+ install_dir: gvfs_pkglibdir
+)
+
+libgvfscommon_dep = declare_dependency(
+ link_with: libgvfscommon,
+ include_directories: common_inc
+)
+
+deps = glib_deps
+
+if have_bluray
+ deps += libbluray_dep
+endif
+
+libgvfscommon_monitor = static_library(
+ 'gvfscommon-monitor',
+ sources: 'gvfsmountinfo.c',
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: common_cflags,
+ link_with: libgvfscommon,
+ pic: true
+)
+
+libgvfscommon_monitor_dep = declare_dependency(
+ link_with: libgvfscommon_monitor,
+ include_directories: common_inc
+)
+
+if have_avahi
+ sources = files(
+ 'gvfsdnssdresolver.c',
+ 'gvfsdnssdutils.c'
+ )
+
+ deps = glib_deps + [
+ avahi_client_dep,
+ avahi_glib_dep
+ ]
+
+ libgvfscommon_dnssd = static_library(
+ 'gvfscommon-dnssd',
+ sources: sources,
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: common_cflags,
+ link_with: libgvfscommon,
+ pic: true
+ )
+
+ libgvfscommon_dnssd_dep = declare_dependency(
+ link_with: libgvfscommon_dnssd,
+ include_directories: common_inc
+ )
+endif
+
+if have_libmtp or (have_gudev and have_gphoto2)
+ libgvfscommon_gphoto2 = static_library(
+ 'gvfscommon-gphoto2',
+ sources: 'gvfsgphoto2utils.c',
+ include_directories: top_inc,
+ dependencies: gudev_dep,
+ pic: true
+ )
+
+ libgvfscommon_gphoto2_dep = declare_dependency(
+ link_with: libgvfscommon_gphoto2,
+ include_directories: common_inc
+ )
+endif
diff --git a/daemon/Makefile.am b/daemon/Makefile.am
index a8b2958..0bdafae 100644
--- a/daemon/Makefile.am
+++ b/daemon/Makefile.am
@@ -149,6 +149,7 @@ EXTRA_DIST = \
$(gsettings_ENUM_FILES) \
org.gtk.vfs.file-operations.policy.in.in \
org.gtk.vfs.file-operations.rules \
+ meson.build \
$(NULL)
DISTCLEANFILES = $(mount_DATA) $(noinst_DATA)
diff --git a/daemon/meson.build b/daemon/meson.build
new file mode 100644
index 0000000..0453a10
--- /dev/null
+++ b/daemon/meson.build
@@ -0,0 +1,464 @@
+subdir('trashlib')
+
+# D-Bus and systemd service files
+service = 'org.gtk.vfs.Daemon.service'
+
+daemon_service = configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: gvfs_dbus_service_dir,
+ configuration: service_conf
+)
+
+if have_systemd_user_unit
+ service = 'gvfs-daemon.service'
+
+ configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: systemd_user_dir,
+ configuration: service_conf
+ )
+endif
+
+gnome.mkenums(
+ 'org.gnome.system.gvfs.enums.xml',
+ sources: 'gvfs-enums.h',
+ comments: '<!-- @comment@ -->',
+ fhead: '<schemalist>',
+ vhead: ' <@type@ id="org.gnome.system.gvfs.@EnumName@">',
+ vprod: ' <value nick="@valuenick@" value="@valuenum@"/>',
+ vtail: ' </@type@>',
+ ftail: '</schemalist>',
+ install_header: true,
+ install_dir: gvfs_schema_dir
+)
+
+sources = files(
+ 'gvfsbackend.c',
+ 'gvfschannel.c',
+ 'gvfsdaemon.c',
+ 'gvfsdaemonutils.c',
+ 'gvfsjob.c',
+ 'gvfsjobcloseread.c',
+ 'gvfsjobclosewrite.c',
+ 'gvfsjobcopy.c',
+ 'gvfsjobcreatemonitor.c',
+ 'gvfsjobdbus.c',
+ 'gvfsjobdelete.c',
+ 'gvfsjobenumerate.c',
+ 'gvfsjoberror.c',
+ 'gvfsjobmakedirectory.c',
+ 'gvfsjobmakesymlink.c',
+ 'gvfsjobmount.c',
+ 'gvfsjobmountmountable.c',
+ 'gvfsjobmove.c',
+ 'gvfsjobopenforread.c',
+ 'gvfsjobopenforwrite.c',
+ 'gvfsjobopeniconforread.c',
+ 'gvfsjobpollmountable.c',
+ 'gvfsjobprogress.c',
+ 'gvfsjobpull.c',
+ 'gvfsjobpush.c',
+ 'gvfsjobqueryattributes.c',
+ 'gvfsjobqueryfsinfo.c',
+ 'gvfsjobqueryinfo.c',
+ 'gvfsjobqueryinforead.c',
+ 'gvfsjobqueryinfowrite.c',
+ 'gvfsjobread.c',
+ 'gvfsjobseekread.c',
+ 'gvfsjobseekwrite.c',
+ 'gvfsjobsetattribute.c',
+ 'gvfsjobsetdisplayname.c',
+ 'gvfsjobsource.c',
+ 'gvfsjobstartmountable.c',
+ 'gvfsjobstopmountable.c',
+ 'gvfsjobtrash.c',
+ 'gvfsjobtruncate.c',
+ 'gvfsjobunmount.c',
+ 'gvfsjobunmountmountable.c',
+ 'gvfsjobwrite.c',
+ 'gvfskeyring.c',
+ 'gvfsmonitor.c',
+ 'gvfsreadchannel.c',
+ 'gvfswritechannel.c'
+)
+
+deps = glib_deps + [libgvfscommon_dep]
+
+if have_gcr
+ deps += gcr_dep
+endif
+
+if have_keyring
+ deps += libsecret_dep
+endif
+
+gvfs_mountdir = join_paths(gvfs_datadir, 'gvfs', 'mounts')
+
+cflags = [
+ '-DLIBEXEC_DIR="@0@"'.format(gvfs_libexecdir),
+ '-DMOUNTABLE_DIR="@0@"'.format(gvfs_mountdir),
+ '-DGVFS_LOCALEDIR="@0@"'.format(gvfs_localedir)
+]
+
+libgvfsdaemon = shared_library(
+ 'gvfsdaemon',
+ sources: sources,
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: cflags,
+ install: true,
+ install_dir: gvfs_pkglibdir
+)
+
+sources = files(
+ 'main.c',
+ 'mount.c'
+)
+
+executable(
+ 'gvfsd',
+ sources,
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: cflags,
+ link_with: libgvfsdaemon,
+ install: true,
+ install_dir: gvfs_libexecdir
+)
+
+daemon_main_sources = files(
+ 'daemon-main.c',
+ 'daemon-main-generic.c'
+)
+
+ftp_sources = files(
+ 'gvfsftpconnection.c',
+ 'gvfsftpdircache.c',
+ 'gvfsftpfile.c',
+ 'gvfsftptask.c',
+ 'ParseFTPList.c'
+)
+
+ftp_flags = ['-DMAX_JOB_THREADS=10']
+
+trash_deps = [libtrash_dep]
+
+trash_flags = ['-DMAX_JOB_THREADS=10']
+
+recent_flags = [
+ '-DBACKEND_USES_GVFS=1',
+ '-DMAX_JOB_THREADS=10'
+]
+
+computer_flags = [
+ '-DBACKEND_USES_GVFS=1',
+ '-DMAX_JOB_THREADS=1'
+]
+
+network_flags = [
+ '-DBACKEND_USES_GVFS=1',
+ '-DMAX_JOB_THREADS=1'
+]
+
+burn_flags = ['-DMAX_JOB_THREADS=1']
+
+'''
+name: gvfsd-{v},
+backend source: 'gvfsbackend{v}.c gvfsbackend{v}.h'
+extra sources: source files - {backend source + daemon main sources}
+g_vfs_type_backend: G_VFS_TYPE_BACKEND_{v}
+default backend: default backend name
+extra backends: backend names - {default backend name}
+dependencies: backend dependencies - {dependencies}
+c_args:
+ -DBACKEND_HEADER=gvfsbackend{backend source}.h,
+ -DDEFAULT_BACKEND_TYPE={default backend},
+ -DBACKEND_TYPES={"{backend}", G_VFS_TYPE_BACKEND_{g_vfs_type_backend},
+ - c_flags
+install exe: boolean
+mount names: names for .mount files
+'''
+programs = [
+ ['test', 'test', [], 'TEST', 'test', [], [], [], false, []],
+ ['localtest', 'localtest', [], 'LOCALTEST', 'localtest', [], [], [], true, ['localtest']],
+ ['ftp', 'ftp', ftp_sources, 'FTP', 'ftp', ['ftps'], [], ftp_flags, true, ['ftp', 'ftps']],
+ ['trash', 'trash', [], 'TRASH', 'trash', [], trash_deps, trash_flags, true, ['trash']],
+ ['recent', 'recent', [], 'RECENT', 'recent', [], [], recent_flags, true, ['recent']],
+ ['computer', 'computer', [], 'COMPUTER', 'computer', [], [], computer_flags, true, ['computer']],
+ ['network', 'network', [], 'NETWORK', 'network', [], [], network_flags, true, ['network']],
+ ['burn', 'burn', [], 'BURN', 'burn', [], [], burn_flags, true, ['burn']]
+]
+
+schema_data = []
+convert_data = []
+
+if have_openpty
+ sftp_sources = files('pty_open.c')
+
+ sftp_deps = [util_dep]
+
+ sftp_flags = [
+ '-DMAX_JOB_THREADS=1',
+ '-DSSH_PROGRAM="@0@"'.format(find_program('ssh').path())
+ ]
+
+ programs += [['sftp', 'sftp', sftp_sources, 'SFTP', 'sftp', [], sftp_deps, sftp_flags, true, ['sftp']]]
+endif
+
+if have_samba
+ smb_deps = [smbclient_dep]
+
+ smb_flags = ['-DMAX_JOB_THREADS=1']
+
+ smb_browse_sources = files('gvfsbackendsmb.c')
+
+ smb_browse_flags = smb_flags + ['-DMOUNTABLE_DBUS_NAME=org.gtk.vfs.mountpoint_smb_browse']
+
+ programs += [
+ ['smb', 'smb', [], 'SMB', 'smb-share', [], smb_deps, smb_flags, true, ['smb']],
+ ['smb-browse', 'smbbrowse', smb_browse_sources, 'SMB_BROWSE', 'smb-network', ['smb-server'], smb_deps,
smb_flags, true, ['smb-browse']]
+ ]
+
+ schema_data += files('org.gnome.system.smb.gschema.xml')
+ convert_data += files('gvfs-smb.convert')
+endif
+
+if have_avahi
+ dnssd_deps = [
+ avahi_client_dep,
+ avahi_glib_dep,
+ libgvfscommon_dnssd_dep
+ ]
+
+ dnssd_flags = [
+ '-DMAX_JOB_THREADS=1',
+ '-DMOUNTABLE_DBUS_NAME=org.gtk.vfs.mountpoint_dnssd'
+ ]
+
+ programs += [['dnssd', 'dnssd', [], 'DNS_SD', 'dns-sd', [], dnssd_deps, dnssd_flags, true, ['dns-sd']]]
+
+ schema_data += files('org.gnome.system.dns_sd.gschema.xml')
+ convert_data += files('gvfs-dns-sd.convert')
+endif
+
+if have_archive
+ archive_deps = [libarchive_dep]
+
+ archive_flags = [
+ '-DBACKEND_USES_GVFS=1',
+ '-DMAX_JOB_THREADS=1'
+ ]
+
+ programs += [['archive', 'archive', [], 'ARCHIVE', 'archive', [], archive_deps, archive_flags, true,
['archive']]]
+endif
+
+if have_cdda
+ cdda_deps = [
+ gudev_dep,
+ libcdio_paranoia_dep
+ ]
+
+ cdda_flags = ['-DMAX_JOB_THREADS=1']
+
+ programs += [['cdda', 'cdda', [], 'CDDA', 'cdda', [], cdda_deps, cdda_flags, true, ['cdda']]]
+endif
+
+if have_admin
+ admin_deps = [
+ libcap_dep,
+ polkit_gobject_dep
+ ]
+
+ programs += [['admin', 'admin', [], 'ADMIN', 'admin', [], admin_deps, [], true, ['admin']]]
+
+ policy = 'org.gtk.vfs.file-operations.policy'
+
+ policy_in = configure_file(
+ input: policy + '.in.in',
+ output: policy + '.in',
+ configuration: service_conf
+ )
+
+ i18n.merge_file(
+ policy,
+ input: policy_in,
+ output: policy,
+ po_dir: po_dir,
+ install: true,
+ install_dir: join_paths(gvfs_datadir, 'polkit-1', 'actions')
+ )
+
+ install_data(
+ 'org.gtk.vfs.file-operations.rules',
+ install_dir: join_paths(gvfs_datadir, 'polkit-1', 'rules.d')
+ )
+endif
+
+if have_google
+ google_deps = [
+ goa_dep,
+ libgdata_dep
+ ]
+
+ programs += [['google', 'google', [], 'GOOGLE', 'google-drive', [], google_deps, [], true, ['google']]]
+endif
+
+if have_gudev and have_gphoto2
+ gphoto2_deps = [
+ gudev_dep,
+ libgphoto2_dep,
+ libgvfscommon_gphoto2_dep
+ ]
+
+ gphoto2_flags = ['-DMAX_JOB_THREADS=1']
+
+ programs += [['gphoto2', 'gphoto2', [], 'GPHOTO2', 'gphoto2', [], gphoto2_deps, [], true, ['gphoto2']]]
+endif
+
+if have_libmtp
+ mtp_deps = [
+ gudev_dep,
+ libgvfscommon_gphoto2_dep,
+ libmtp_dep
+ ]
+
+ if have_libusb
+ mtp_deps += [libusb_dep]
+ endif
+
+ mtp_flags = ['-DMAX_JOB_THREADS=1']
+
+ programs += [['mtp', 'mtp', [], 'MTP', 'mtp', [], mtp_deps, [], true, ['mtp']]]
+endif
+
+if have_http
+ http_sources = files('gvfshttpinputstream.c')
+
+ http_deps = [
+ libsoup_dep,
+ libxml_dep
+ ]
+
+ http_flags = [
+ '-DMOUNTABLE_DBUS_NAME=org.gtk.vfs.mountpoint_http',
+ '-DMAX_JOB_THREADS=1'
+ ]
+
+ dav_sources = http_sources + files('gvfsbackendhttp.c')
+
+ dav_deps = http_deps
+
+ dav_flags = ['-DMAX_JOB_THREADS=1']
+
+ dav_backends = []
+ dav_mounts = ['dav']
+
+ if have_avahi
+ dav_deps += [libgvfscommon_dnssd_dep]
+ dav_backends += ['dav+sd', 'davs+sd']
+ dav_mounts += ['dav+sd']
+ endif
+
+ programs += [
+ ['http', 'http', http_sources, 'HTTP', 'http', [], http_deps, [], true, ['http']],
+ ['dav', 'dav', dav_sources, 'DAV', 'dav', dav_backends, dav_deps, dav_flags, true, dav_mounts]
+ ]
+endif
+
+if have_afc
+ afc_deps = [
+ libimobiledevice_dep,
+ libplist_dep
+ ]
+
+ afc_flags = [
+ '-DBACKEND_USES_GVFS=1',
+ '-DMAX_JOB_THREADS=1'
+ ]
+
+ programs += [['afc', 'afc', [], 'AFC', 'afc', [], afc_deps, afc_flags, true, ['afc']]]
+endif
+
+if have_afp
+ afp_sources = files(
+ 'gvfsafptypes.h',
+ 'gvfsafputils.c',
+ 'gvfsafpconnection.c',
+ 'gvfsafpserver.c',
+ 'gvfsafpvolume.c'
+ )
+
+ afp_deps = []
+ if have_gcrypt
+ afp_deps += libgcrypt_dep
+ endif
+
+ afp_flags = ['-DMAX_JOB_THREADS=1']
+
+ programs += [
+ ['afp', 'afp', afp_sources, 'AFP', 'afp-volume', [], afp_deps, afp_flags, true, ['afp']],
+ ['afp-browse', 'afpbrowse', afp_sources, 'AFP_BROWSE', 'afp-server', [], afp_deps, afp_flags, true,
['afp-browse']]
+ ]
+endif
+
+if have_nfs
+ nfs_deps = [libnfs_dep]
+
+ nfs_flags = ['-DMAX_JOB_THREADS=1']
+
+ programs += [['nfs', 'nfs', [], 'NFS', 'nfs', [], nfs_deps, nfs_flags, true, ['nfs']]]
+endif
+
+localmount_conf = configuration_data()
+localmount_conf.set('libexecdir', meson.current_build_dir())
+
+foreach program: programs
+ program_cflags = cflags + program[7] + [
+ '-DBACKEND_HEADER=gvfsbackend' + program[1] + '.h',
+ '-DDEFAULT_BACKEND_TYPE=' + program[4],
+ ]
+
+ g_vfs_type_backend = 'G_VFS_TYPE_BACKEND_' + program[3]
+
+ backend_cflags = '-DBACKEND_TYPES="@0@", @1@,'.format(program[4], g_vfs_type_backend)
+ foreach backend: program[5]
+ backend_cflags += ' "@0@", @1@,'.format(backend, g_vfs_type_backend)
+ endforeach
+
+ executable(
+ 'gvfsd-' + program[0],
+ ['gvfsbackend' + program[1] + '.c'] + program[2] + daemon_main_sources,
+ include_directories: top_inc,
+ dependencies: deps + program[6],
+ c_args: program_cflags + [backend_cflags],
+ link_with: libgvfsdaemon,
+ install: program[8],
+ install_dir: gvfs_libexecdir
+ )
+
+ foreach name: program[9]
+ mount = name + '.mount'
+
+ configure_file(
+ input: mount + '.in',
+ output: mount,
+ install: true,
+ install_dir: gvfs_mountdir,
+ configuration: service_conf
+ )
+ endforeach
+endforeach
+
+install_data(
+ schema_data,
+ install_dir: gvfs_schema_dir
+)
+
+install_data(
+ convert_data,
+ install_dir: join_paths(gvfs_datadir, 'GConf', 'gsettings')
+)
diff --git a/daemon/trashlib/Makefile.am b/daemon/trashlib/Makefile.am
index 323c942..e92a321 100644
--- a/daemon/trashlib/Makefile.am
+++ b/daemon/trashlib/Makefile.am
@@ -13,3 +13,5 @@ libtrash_a_SOURCES = \
trashwatcher.c \
trashexpunge.h \
trashexpunge.c
+
+EXTRA_DIST = meson.build
diff --git a/daemon/trashlib/meson.build b/daemon/trashlib/meson.build
new file mode 100644
index 0000000..610bb62
--- /dev/null
+++ b/daemon/trashlib/meson.build
@@ -0,0 +1,19 @@
+sources = files(
+ 'dirwatch.c',
+ 'trashdir.c',
+ 'trashitem.c',
+ 'trashwatcher.c',
+ 'trashexpunge.c'
+)
+
+libtrash = static_library(
+ 'trash',
+ sources: sources,
+ include_directories: top_inc,
+ dependencies: glib_deps
+)
+
+libtrash_dep = declare_dependency(
+ link_with: libtrash,
+ include_directories: include_directories('.')
+)
diff --git a/man/Makefile.am b/man/Makefile.am
index 2488925..086ecb6 100644
--- a/man/Makefile.am
+++ b/man/Makefile.am
@@ -94,6 +94,7 @@ EXTRA_DIST = \
gvfsd.xml \
gvfs-less.xml \
gvfs.xml \
+ meson.build \
$(NULL)
CLEANFILES = \
diff --git a/man/meson.build b/man/meson.build
new file mode 100644
index 0000000..1b754e4
--- /dev/null
+++ b/man/meson.build
@@ -0,0 +1,68 @@
+xsltproc = find_program('xsltproc', required: false)
+assert(xsltproc.found(), 'xsltproc is required for enable-man')
+
+xsltproc_cmd = [
+ xsltproc,
+ '--output', '@OUTPUT@',
+ '--nonet',
+ '--stringparam', 'man.output.quietly', '1',
+ '--stringparam', 'funcsynopsis.style', 'ansi',
+ '--stringparam', 'man.th.extra1.suppress', '1',
+ '--stringparam', 'man.authors.section.enabled', '0',
+ '--stringparam', 'man.copyright.section.enabled', '0',
+ 'http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl',
+ '@INPUT@'
+]
+
+mans = [
+ ['gvfs-cat', 'gio cat', 1],
+ ['gvfs-copy', 'gio copy', 1],
+ ['gvfs-info', 'gio info', 1],
+ ['gvfs-less', '', 1],
+ ['gvfs-ls', 'gio list', 1],
+ ['gvfs-mime', 'gio mime', 1],
+ ['gvfs-mkdir', 'gio mkdir', 1],
+ ['gvfs-monitor-dir', 'gio monitor', 1],
+ ['gvfs-monitor-file', 'gio monitor', 1],
+ ['gvfs-mount', 'gio mount', 1],
+ ['gvfs-move', 'gio move', 1],
+ ['gvfs-open', 'gio open', 1],
+ ['gvfs-rename', 'gio rename', 1],
+ ['gvfs-rm', 'gio remove', 1],
+ ['gvfs-save', 'gio save', 1],
+ ['gvfs-set-attribute', 'gio set', 1],
+ ['gvfs-trash', 'gio trash', 1],
+ ['gvfs-tree', 'gio tree', 1],
+ ['gvfs', '', 7],
+ ['gvfsd', '', 1],
+ ['gvfsd-fuse', '', 1],
+ ['gvfsd-metadata', '', 1]
+]
+
+foreach man: mans
+ if man[1].strip() == ''
+ xml = man[0] + '.xml'
+ else
+ conf = configuration_data()
+ conf.set('original', man[0])
+ conf.set('replacement', man[1])
+
+ xml = configure_file(
+ input: 'deprecated.xml.in',
+ output: man[0] + '.xml',
+ configuration: conf
+ )
+ endif
+
+ output = '@0@.@1@'.format(man[0], man[2])
+ man_dir = 'man@0@'.format(man[2])
+
+ custom_target(
+ output,
+ input: xml,
+ output: output,
+ command: xsltproc_cmd,
+ install: true,
+ install_dir: join_paths(gvfs_mandir, man_dir)
+ )
+endforeach
diff --git a/meson.build b/meson.build
new file mode 100644
index 0000000..d629755
--- /dev/null
+++ b/meson.build
@@ -0,0 +1,656 @@
+project(
+ 'gvfs', 'c',
+ version: '1.34.1',
+ license: 'LGPL2.1',
+ default_options: [
+ 'buildtype=debugoptimized',
+ 'warning_level=1',
+ 'b_lundef=true'
+ ],
+ meson_version: '>= 0.41.0'
+)
+
+gvfs_version = meson.project_version()
+
+gvfs_namespace = 'org.gtk.vfs'
+
+gvfs_prefix = get_option('prefix')
+gvfs_bindir = join_paths(gvfs_prefix, get_option('bindir'))
+gvfs_datadir = join_paths(gvfs_prefix, get_option('datadir'))
+gvfs_includedir = join_paths(gvfs_prefix, get_option('includedir'))
+gvfs_libdir = join_paths(gvfs_prefix, get_option('libdir'))
+gvfs_libexecdir = join_paths(gvfs_prefix, get_option('libexecdir'))
+gvfs_localedir = join_paths(gvfs_prefix, get_option('localedir'))
+gvfs_mandir = join_paths(gvfs_prefix, get_option('mandir'))
+
+gvfs_pkgdatadir = join_paths(gvfs_datadir, meson.project_name())
+gvfs_pkglibdir = join_paths(gvfs_libdir, meson.project_name())
+
+gvfs_dbus_service_dir = join_paths(gvfs_datadir, 'dbus-1', 'services')
+gvfs_remote_volume_monitors_dir = join_paths(gvfs_pkgdatadir, 'remote-volume-monitors')
+gvfs_schema_dir = join_paths(gvfs_datadir, 'glib-2.0', 'schemas')
+
+gio_module_dir = join_paths(gvfs_libdir, 'gio', 'modules')
+
+gvfs_debug = get_option('buildtype').contains('debug')
+
+cc = meson.get_compiler('c')
+
+config_h = configuration_data()
+
+# defines
+set_defines = [
+ # package
+ ['PACKAGE', meson.project_name()],
+ ['PACKAGE_BUGREPORT', 'http://bugzilla.gnome.org/enter_bug.cgi?product=' + meson.project_name()],
+ ['PACKAGE_NAME', meson.project_name()],
+ ['PACKAGE_STRING', '@0@ @1@'.format(meson.project_name(), gvfs_version)],
+ ['PACKAGE_TARNAME', meson.project_name()],
+ ['PACKAGE_URL', ''],
+ ['PACKAGE_VERSION', gvfs_version],
+ ['VERSION', gvfs_version],
+ # i18n
+ ['GETTEXT_PACKAGE', meson.project_name()]
+]
+
+foreach define: set_defines
+ config_h.set_quoted(define[0], define[1])
+endforeach
+
+# Globally define_GNU_SOURCE and therefore enable the GNU extensions
+config_h.set('_GNU_SOURCE', true)
+config_h.set('_FILE_OFFSET_BITS', 64)
+
+# Pull in the right libraries for various functions which might not be
+# bundled into an exploded libc.
+have_socketpair = cc.has_function('socketpair')
+if not have_socketpair
+ socket_dep = cc.find_library('socket', required: false)
+ have_socketpair = socket_dep.found() and cc.has_function('socketpair', dependencies: socket_dep)
+endif
+
+config_h.set('HAVE_SOCKETPAIR', have_socketpair,
+ description: 'Define if you have the socketpair function.')
+
+util_dep = cc.find_library('util', required: false)
+config_h.set('HAVE_UTIL_H', cc.has_header('util.h', dependendencies: util_dep))
+
+have_openpty = cc.has_function('openpty')
+if not have_openpty
+ have_openpty = util_dep.found() and cc.has_function('openpty', dependencies: util_dep)
+endif
+
+config_h.set('HAVE_OPENPTY', have_openpty,
+ description: 'Define if you have the openpty function.')
+
+config_h.set('HAVE_LOGIN_TTY', util_dep.found() and cc.has_function('login_tty', dependencies: util_dep),
+ description: 'Whether login_tty is available')
+
+# if statfs() takes 2 arguments (Posix) or 4 (Solaris)
+statfs_code = '''
+ #include <sys/statfs.h>
+ #include <sys/vfs.h>
+ int main() {
+ struct statfs st;
+ @0@;
+ };
+'''
+
+if cc.compiles(statfs_code.format('statfs("/", &st)'))
+ config_h.set('STATFS_ARGS', 2)
+elif cc.compiles(statfs_code.format('statfs("/", &st, sizeof (st), 0)'))
+ config_h.set('STATFS_ARGS', 4)
+else
+ error('unable to determine number of arguments to statfs()')
+endif
+
+# headers
+check_headers = [
+ ['HAVE_DLFCN_H', 'dlfcn.h'],
+ ['HAVE_INTTYPES_H', 'inttypes.h'],
+ ['HAVE_MEMORY_H', 'memory.h'],
+ ['HAVE_STDINT_H', 'stdint.h'],
+ ['HAVE_STDLIB_H', 'stdlib.h'],
+ ['HAVE_STRINGS_H', 'strings.h'],
+ ['HAVE_STRING_H', 'string.h'],
+ ['HAVE_SYS_STAT_H', 'sys/stat.h'],
+ ['HAVE_SYS_TYPES_H', 'sys/types.h'],
+ ['HAVE_UNISTD_H', 'unistd.h'],
+ # fs + pty
+ ['HAVE_SYS_PARAM_H', 'sys/param.h'],
+ # fs
+ ['HAVE_SYS_MOUNT_H', 'sys/mount.h'],
+ ['HAVE_SYS_STATFS_H', 'sys/statfs.h'],
+ ['HAVE_SYS_STATVFS_H', 'sys/statvfs.h'],
+ ['HAVE_SYS_VFS_H', 'sys/vfs.h']
+]
+
+foreach header: check_headers
+ config_h.set10(header[0], cc.has_header(header[1]))
+endforeach
+
+# pty
+check_headers = [
+ ['HAVE_STROPTS_H', 'stropts.h'],
+ ['HAVE_SYS_UIO_H', 'sys/uio.h'],
+ ['HAVE_SYS_UN_H', 'sys/un.h'],
+ ['HAVE_TERMIOS_H', 'termios.h'],
+ ['HAVE_UTMP_H', 'utmp.h']
+]
+
+foreach header: check_headers
+ config_h.set(header[0], cc.has_header(header[1]))
+endforeach
+
+# functions
+check_functions = [
+ # i18n
+ ['HAVE_DCGETTEXT', 'dcgettext'],
+ ['HAVE_GETTEXT', 'gettext'],
+ ['HAVE_ICONV', 'iconv'],
+ # pty
+ ['HAVE_GETPT', 'getpt'],
+ ['HAVE_GRANTPT', 'grantpt'],
+ ['HAVE_POSIX_OPENPT', 'posix_openpt'],
+ ['HAVE_PTSNAME', 'ptsname'],
+ ['HAVE_PTSNAME_R', 'ptsname_r'],
+ ['HAVE_UNLOCKPT', 'unlockpt'],
+ # fs
+ ['HAVE_STATFS', 'statfs'],
+ ['HAVE_STATVFS', 'statvfs']
+]
+
+if host_machine.system().contains('darwin')
+ check_functions += [
+ ['HAVE_CFLOCALECOPYCURRENT', 'CFLocaleCopyCurrent'],
+ ['HAVE_CFPREFERENCESCOPYAPPVALUE', 'CFPreferencesCopyAppValue']
+ ]
+endif
+
+foreach func: check_functions
+ config_h.set(func[0], cc.has_function(func[1]))
+endforeach
+
+# symbols
+check_symbols = [
+ # i18n
+ ['HAVE_NL_ADDRESS_LANG_TERM', 'langinfo.h', '_NL_ADDRESS_LANG_TERM'],
+ ['HAVE_NL_ADDRESS_COUNTRY_AB3', 'langinfo.h', '_NL_ADDRESS_COUNTRY_AB3']
+]
+
+foreach symbol: check_symbols
+ config_h.set(symbol[0], cc.has_header_symbol(symbol[1], symbol[2]))
+endforeach
+
+# fs, check major, minor and makedev functions
+check_major_functions = ['major', 'minor', 'makedev']
+
+check_major_headers = [
+ ['MAJOR_IN_MKDEV', 'sys/mkdev.h'],
+ ['MAJOR_IN_SYSMACROS', 'sys/sysmacros.h']
+]
+
+foreach header: check_major_headers
+ have_major = true
+ foreach function: check_major_functions
+ have_major = have_major and cc.has_header_symbol(header[1], function)
+ endforeach
+
+ config_h.set10(header[0], have_major)
+endforeach
+
+# types
+check_types = [
+ # type, header, fallback type
+ ['gid_t', 'sys/types.h', 'int'],
+ ['pid_t', 'sys/types.h', 'int'],
+ ['size_t', 'sys/types.h', 'unsigned int'],
+ ['uid_t', 'sys/types.h', 'int']
+]
+
+foreach type: check_types
+ if not cc.has_type(type[0], prefix: '#include<@0@>'.format(type[1]))
+ config_h.set(type[0], type[2])
+ endif
+endforeach
+
+# members
+check_members = [
+ # define, typename, membername, prefix
+ ['HAVE_STRUCT_STATFS_F_BAVAIL', 'struct statfs', 'f_bavail', '#include<sys/statfs.h>'],
+ ['HAVE_STRUCT_STATFS_F_FSTYPENAME', 'struct statfs', 'f_fstypename', '#include<sys/statfs.h>'],
+ ['HAVE_STRUCT_STATVFS_F_BASETYPE', 'struct statvfs', 'f_basetype', '#include<sys/statvfs.h>'],
+ ['HAVE_STRUCT_STAT_ST_ATIMENSEC', 'struct stat', 'st_atimensec', '#include<sys/stat.h>'],
+ ['HAVE_STRUCT_STAT_ST_ATIM_TV_NSEC', 'struct stat', 'st_atim.tv_nsec', '#include<sys/stat.h>'],
+ ['HAVE_STRUCT_STAT_ST_CTIMENSEC', 'struct stat', 'st_ctimensec', '#include<sys/stat.h>'],
+ ['HAVE_STRUCT_STAT_ST_CTIM_TV_NSEC', 'struct stat', 'st_ctim.tv_nsec', '#include<sys/stat.h>'],
+ ['HAVE_STRUCT_STAT_ST_MTIMENSEC', 'struct stat', 'st_mtimensec', '#include<sys/stat.h>'],
+ ['HAVE_STRUCT_STAT_ST_MTIM_TV_NSEC', 'struct stat', 'st_mtim.tv_nsec', '#include<sys/stat.h>']
+]
+
+foreach member: check_members
+ config_h.set(member[0], cc.has_members(member[1], member[2], prefix: member[3]))
+endforeach
+
+# compiler flags
+common_flags = ['-DHAVE_CONFIG_H']
+
+if gvfs_debug
+ test_flags = [
+ '-Wcast-align',
+ '-Wmissing-declarations',
+ '-Wmissing-prototypes',
+ '-Wnested-externs',
+ '-Wno-sign-compare',
+ '-Wno-strict-aliasing'
+ ]
+
+ foreach flag: test_flags
+ if cc.has_argument(flag)
+ common_flags += [flag]
+ endif
+ endforeach
+endif
+
+add_project_arguments(common_flags, language: 'c')
+
+ldflag = '-Wl,--version-script'
+have_version_script = host_machine.system().contains('linux') and cc.has_argument(ldflag)
+
+glib_deps = [
+ dependency('gio-2.0'),
+ dependency('gio-unix-2.0'),
+ dependency('glib-2.0', version: '>= 2.51.0'),
+ dependency('gmodule-no-export-2.0'),
+ dependency('gobject-2.0')
+]
+
+# *** Check for libXML ***
+libxml_dep = dependency('libxml-2.0', required: false)
+have_libxml = libxml_dep.found()
+
+config_h.set('HAVE_LIBXML', have_libxml)
+
+# *** Check for libgcrypt ***
+libgcrypt_config = find_program('libgcrypt-config')
+libgcrypt_version = run_command(libgcrypt_config, '--version').stdout().strip()
+
+libgcrypt_cflags = run_command(libgcrypt_config, '--cflags').stdout().strip().split()
+libgcrypt_libs = run_command(libgcrypt_config, '--libs').stdout().strip().split()
+
+libgcrypt_dep = declare_dependency(
+ compile_args: libgcrypt_cflags,
+ link_args: libgcrypt_libs,
+ version: libgcrypt_version
+)
+
+have_gcrypt = libgcrypt_version.version_compare('>= 1.2.2')
+
+config_h.set('HAVE_GCRYPT', have_gcrypt)
+
+# *** Check for dbus service dir ***
+dbus_service_dir = get_option('with-dbus-service-dir').strip()
+if dbus_service_dir == ''
+ dbus_service_dir = join_paths(gvfs_datadir, 'dbus-1', 'services')
+endif
+
+# *** Check for systemd user units ***
+systemd_user_dir = get_option('with-systemduserunitdir').strip()
+have_systemd_user_unit = systemd_user_dir != 'no'
+
+if have_systemd_user_unit
+ systemd_dep = dependency('systemd', version: '>= 206')
+
+ if systemd_user_dir == ''
+ systemd_user_dir = join_paths(gvfs_libdir, 'systemd', 'user')
+ endif
+endif
+
+# *** Check for gcr ***
+enable_gcr = get_option('enable-gcr')
+have_gcr = false
+
+if enable_gcr != 'no'
+ gcr_dep = dependency('gcr-base-3', required: (enable_gcr == 'yes'))
+ have_gcr = gcr_dep.found()
+endif
+
+config_h.set('HAVE_GCR', have_gcr)
+
+# *** Check if we should build with admin backend ***
+enable_admin = get_option('enable-admin')
+have_admin = false
+
+if enable_admin != 'no'
+ required = (enable_admin == 'yes')
+
+ libcap_dep = dependency('libcap', required: required)
+ polkit_gobject_dep = dependency('polkit-gobject-1', required: required)
+
+ have_admin = libcap_dep.found() and polkit_gobject_dep.found()
+endif
+
+config_h.set('HAVE_ADMIN', have_admin)
+
+# *** Check if we should build with http backend ***
+enable_http = get_option('enable-http')
+have_http = false
+
+if enable_http != 'no'
+ required = (enable_http == 'yes')
+
+ assert(not required and libxml_dep.found(), 'http required but libxml-2.0 not found')
+
+ libsoup_dep = dependency('libsoup-2.4', version: '>= 2.42.0', required: required)
+
+ have_http = libxml_dep.found() and libsoup_dep.found()
+endif
+
+config_h.set('HAVE_HTTP', have_http)
+
+# *** Check if we should build with DNS-SD backend ***
+enable_avahi = get_option('enable-avahi')
+have_avahi = false
+
+if enable_avahi != 'no'
+ required = (enable_avahi == 'yes')
+
+ avahi_client_dep = dependency('avahi-client', version: '>= 0.6', required: required)
+ avahi_glib_dep = dependency('avahi-glib', version: '>= 0.6', required: required)
+
+ have_avahi = avahi_client_dep.found() and avahi_glib_dep.found()
+endif
+
+config_h.set('HAVE_AVAHI', have_avahi)
+
+# *** Check for libudev ***
+enable_udev = get_option('enable-udev')
+have_udev = false
+
+if enable_udev != 'no'
+ libudev_dep = dependency('libudev', version: '>= 138', required: (enable_udev == 'yes'))
+ have_udev = libudev_dep.found()
+endif
+
+config_h.set('HAVE_LIBUDEV', have_udev)
+
+# *** Check for gudev ***
+enable_gudev = get_option('enable-gudev')
+have_gudev = false
+
+if enable_gudev != 'no'
+ gudev_dep = dependency('gudev-1.0', version: '>= 147', required: (enable_gudev == 'yes'))
+ have_gudev = gudev_dep.found()
+endif
+
+config_h.set('HAVE_GUDEV', have_gudev)
+
+# *** Check for FUSE ***
+enable_fuse = get_option('enable-fuse')
+have_fuse = false
+
+if enable_fuse != 'no'
+ fuse_dep = dependency('fuse', version: '>= 2.8.0', required: (enable_fuse == 'yes'))
+ have_fuse = fuse_dep.found()
+endif
+
+config_h.set('HAVE_FUSE', have_fuse)
+
+# *** Check for gnome-disk-utility ***
+enable_gdu = get_option('enable-gdu')
+have_gdu = false
+
+if enable_gdu != 'no'
+ gdu_dep = dependency('gdu', version: '>= 3.0.2', required: (enable_gdu == 'yes'))
+ have_gdu = gdu_dep.found()
+endif
+
+config_h.set('HAVE_GDU', have_gdu)
+
+# *** Check for udisks2 ***
+enable_udisks2 = get_option('enable-udisks2')
+have_udisks2 = false
+
+if enable_udisks2 != 'no'
+ udisks2_dep = dependency('udisks2', version: '>= 1.97', required: (enable_udisks2 == 'yes'))
+ have_udisks2 = udisks2_dep.found()
+endif
+
+config_h.set('HAVE_UDISKS2', have_udisks2)
+
+# *** Check for libsystemd-login ***
+enable_libsystemd_login = get_option('enable-libsystemd-login')
+have_libsystemd_login = false
+
+if enable_libsystemd_login != 'no'
+ libsystemd_login_dep = dependency('libsystemd', required: false)
+ if not libsystemd_login_dep.found()
+ libsystemd_login_dep = dependency('libsystemd-login', version: '>= 44', required:
(enable_libsystemd_login == 'yes'))
+ endif
+ have_libsystemd_login = libsystemd_login_dep.found()
+endif
+
+config_h.set('HAVE_LIBSYSTEMD_LOGIN', have_libsystemd_login)
+
+# *** Check if we should build with AFC backend ***
+enable_afc = get_option('enable-afc')
+have_afc = false
+
+if enable_afc != 'no'
+ required = (enable_afc == 'yes')
+
+ libimobiledevice_dep = dependency('libimobiledevice-1.0', version: '>= 1.2', required: required)
+ libplist_dep = dependency('libplist', version: '>= 0.15', required: required)
+
+ have_afc = libimobiledevice_dep.found() and libplist_dep.found()
+endif
+
+config_h.set('HAVE_AFC', have_afc)
+
+# *** Check if we should build with GOA volume monitor ***
+enable_goa = get_option('enable-goa')
+have_goa = false
+
+if enable_goa != 'no'
+ goa_dep = dependency('goa-1.0', version: '>= 3.17.1', required: (enable_goa == 'yes'))
+ have_goa = goa_dep.found()
+endif
+
+config_h.set('HAVE_GOA', have_goa)
+
+# *** Check for GNOME Keyring ***
+enable_keyring = get_option('enable-keyring')
+have_keyring = false
+
+if enable_keyring != 'no'
+ libsecret_dep = dependency('libsecret-unstable', required: (enable_keyring == 'yes'))
+ have_keyring = libsecret_dep.found()
+endif
+
+config_h.set('HAVE_KEYRING', have_keyring)
+
+# *** Check if we should build with libbluray ***
+enable_bluray = get_option('enable-bluray')
+have_bluray = false
+
+if enable_bluray != 'no'
+ libbluray_dep = dependency('libbluray', required: (enable_bluray == 'yes'))
+ have_bluray = libbluray_dep.found()
+endif
+
+config_h.set('HAVE_BLURAY', have_bluray)
+
+# *** Check if we should build with libusb-1.0 ***
+enable_libusb = get_option('enable-libusb')
+have_libusb = false
+
+if enable_libusb != 'no'
+ libusb_dep = dependency('libusb-1.0', version: '>= 1.0.21', required: (enable_libusb == 'yes'))
+ have_libusb = libusb_dep.found()
+endif
+
+config_h.set10('HAVE_LIBUSB', have_libusb)
+
+# *** Check for samba ***
+enable_samba = get_option('enable-samba')
+have_samba = false
+
+if enable_samba != 'no'
+ smbclient_dep = dependency('smbclient', required: (enable_samba == 'yes'))
+ have_samba = smbclient_dep.found()
+endif
+
+config_h.set('HAVE_SAMBA', have_samba)
+
+# *** Check for libarchive ***
+enable_archive = get_option('enable-archive')
+have_archive = false
+
+if enable_archive != 'no'
+ libarchive_dep = dependency('libarchive', required: (enable_archive == 'yes'))
+ have_archive = libarchive_dep.found()
+endif
+
+config_h.set('HAVE_ARCHIVE', have_archive)
+
+# *** Check if we should build with CDDA backend ***
+enable_cdda = get_option('enable-cdda')
+have_cdda = false
+
+if have_gudev and enable_cdda != 'no'
+ libcdio_paranoia_dep = dependency('libcdio_paranoia', version: '>= 0.78.2', required: (enable_cdda ==
'yes'))
+
+ have_cdda = libcdio_paranoia_dep.found()
+ config_h.set('HAVE_PARANOIA_NEW_INCLUDES', cc.has_header('cdio/paranoia/paranoia.h', dependencies:
libcdio_paranoia_dep))
+endif
+
+config_h.set('HAVE_CDDA', have_cdda)
+
+# *** Check if we should build with Google backend ***
+enable_google = get_option('enable-google')
+have_google = false
+
+if have_goa and enable_google != 'no'
+ libgdata_dep = dependency('libgdata', version: '>= 0.17.3', required: (enable_google == 'yes'))
+ have_google = libgdata_dep.found()
+ config_h.set10('HAVE_LIBGDATA_0_17_7', libgdata_dep.version().version_compare('>= 0.17.7'))
+ config_h.set10('HAVE_LIBGDATA_0_17_9', libgdata_dep.version().version_compare('>= 0.17.9'))
+endif
+
+config_h.set('HAVE_GOOGLE', have_google)
+
+# *** Check for gphoto2 ***
+enable_gphoto2 = get_option('enable-gphoto2')
+have_gphoto2 = false
+
+if enable_gphoto2 != 'no'
+ libgphoto2_dep = dependency('libgphoto2', version: '>= 2.4.0', required: (enable_gphoto2 == 'yes'))
+ have_gphoto2 = libgphoto2_dep.found()
+ config_h.set('HAVE_GPHOTO25', libgphoto2_dep.version().version_compare('>= 2.5.0'))
+
+ use_gphoto2 = host_machine.system().contains('linux') or host_machine.system().contains('bsd')
+endif
+
+config_h.set('HAVE_GPHOTO2', have_gphoto2)
+
+# *** Check for libmtp ***
+enable_libmtp = get_option('enable-libmtp')
+have_libmtp = false
+
+if have_gudev and enable_libmtp != 'no'
+ libmtp_dep = dependency('libmtp', version: '>= 1.1.0', required: (enable_libmtp == 'yes'))
+ have_libmtp = libmtp_dep.found()
+
+ config_h.set10('HAVE_LIBMTP_1_1_5', libmtp_dep.version().version_compare('>= 1.1.5'))
+ config_h.set10('HAVE_LIBMTP_1_1_6', libmtp_dep.version().version_compare('>= 1.1.6'))
+ config_h.set10('HAVE_LIBMTP_1_1_9', libmtp_dep.version().version_compare('>= 1.1.9'))
+ config_h.set10('HAVE_LIBMTP_1_1_12', libmtp_dep.version().version_compare('>= 1.1.12'))
+endif
+
+config_h.set('HAVE_LIBMTP', have_libmtp)
+
+# *** AFP backend ***
+have_afp = get_option('enable-afp')
+msg_afp = 'false'
+
+if have_afp
+ msg_afp = (have_gcrypt ? 'true' : 'partial (crypt support missing! Only anonymous logins)')
+endif
+
+# *** NFS backend ***
+enable_nfs = get_option('enable-nfs')
+have_nfs = false
+
+if enable_nfs != 'no'
+ libnfs_dep = dependency('libnfs', version: '>= 1.9.8', required: (enable_nfs == 'yes'))
+ have_nfs = libnfs_dep.found()
+endif
+
+config_h.set('HAVE_NFS', have_nfs)
+
+configure_file(
+ output: 'config.h',
+ configuration: config_h
+)
+
+gnome = import('gnome')
+i18n = import('i18n')
+pkg = import('pkgconfig')
+
+service_conf = configuration_data()
+service_conf.set('libexecdir', gvfs_libexecdir)
+
+po_dir = join_paths(meson.source_root(), 'po')
+
+top_inc = include_directories('.')
+
+subdir('common')
+subdir('metadata')
+subdir('client')
+subdir('daemon')
+subdir('monitor')
+subdir('po')
+subdir('programs')
+
+if get_option('enable-man')
+ subdir('man')
+endif
+
+# installed tests
+enable_installed_tests = get_option('enable-installed-tests')
+if enable_installed_tests
+ subdir('test')
+endif
+
+meson.add_install_script(
+ 'meson_post_install.py',
+ gvfs_datadir,
+ gvfs_libdir
+)
+
+output = '\ngvfs configuration summary:\n\n'
+output += ' gio module directory: ' + gio_module_dir + '\n\n'
+output += ' Blu-ray metadata support: ' + have_bluray.to_string() + '\n'
+output += ' Google support: ' + have_google.to_string() + '\n'
+output += ' HTTP/WebDAV support: ' + have_http.to_string() + '\n'
+output += ' Samba support: ' + have_samba.to_string() + '\n'
+output += ' FUSE support: ' + have_fuse.to_string() + '\n'
+output += ' CDDA support: ' + have_cdda.to_string() + '\n'
+output += ' Gphoto2 support: ' + have_gphoto2.to_string() + '\n'
+output += ' MTP support: ' + have_libmtp.to_string() + '\n'
+output += ' Polkit support: ' + have_admin.to_string() + '\n'
+output += ' USB support: ' + have_libusb.to_string() + '\n'
+output += ' archive support: ' + have_archive.to_string() + '\n'
+output += ' AFC support: ' + have_afc.to_string() + '\n'
+output += ' AFP support: ' + msg_afp + '\n'
+output += ' NFS support: ' + have_nfs.to_string() + '\n'
+output += ' DNS-SD support: ' + have_avahi.to_string() + '\n'
+output += ' Build GDU volume monitor: ' + have_gdu.to_string() + '\n'
+output += ' Build udisks2 volume monitor: ' + have_udisks2.to_string() + '\n'
+output += ' Build GOA volume monitor: ' + have_goa.to_string() + '\n'
+output += ' Use systemd user unit: ' + have_systemd_user_unit.to_string() + '\n'
+output += ' Use libsystemd-login: ' + have_libsystemd_login.to_string() + '\n'
+output += ' Use GCR: ' + have_gcr.to_string() + '\n'
+output += ' GNOME Keyring support: ' + have_keyring.to_string() + '\n'
+output += ' Installed tests: ' + enable_installed_tests.to_string()
+message(output)
diff --git a/meson_options.txt b/meson_options.txt
new file mode 100644
index 0000000..32002e5
--- /dev/null
+++ b/meson_options.txt
@@ -0,0 +1,27 @@
+option('with-dbus-service-dir', type: 'string', value: '', description: 'choose directory for dbus service
files [default=PREFIX/share/dbus-1/services]')
+option('with-systemduserunitdir', type: 'string', value: '', description: 'choose directory for systemd user
units, or \'no\' to disable [default=PREFIX/lib/systemd/user]')
+option('enable-gcr', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build with
gcr')
+option('enable-admin', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build
with admin backend')
+option('enable-http', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build with
http/dav backend')
+option('enable-avahi', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build
with avahi backend')
+option('enable-udev', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build with
libudev')
+option('enable-gudev', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build
with gudev support')
+option('enable-fuse', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build with
FUSE support')
+option('enable-gdu', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build with
GDU volume monitor')
+option('enable-udisks2', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build
with libudisks2')
+option('enable-libsystemd-login', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description:
'build with libsystemd-login')
+option('enable-afc', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build with
AFC backend')
+option('enable-goa', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build with
GOA volume monitor')
+option('enable-keyring', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build
with GNOME Keyring support')
+option('enable-bluray', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build
with bluray metadata support')
+option('enable-libusb', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build
with libusb support')
+option('enable-samba', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build
with samba support')
+option('enable-archive', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build
with archive support')
+option('enable-nfs', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build with
NFS support')
+option('enable-cdda', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build with
CDDA backend')
+option('enable-google', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build
with Google backend')
+option('enable-gphoto2', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build
with gphoto2 support')
+option('enable-libmtp', type: 'combo', choices: ['yes', 'no', 'auto'], value: 'auto', description: 'build
with libmtp support')
+option('enable-afp', type: 'boolean', value: true, description: 'build with AFP support')
+option('enable-man', type: 'boolean', value: false, description: 'generate man pages')
+option('enable-installed-tests', type: 'boolean', value: false, description: 'enable installed unit tests')
diff --git a/meson_post_install.py b/meson_post_install.py
new file mode 100644
index 0000000..4232625
--- /dev/null
+++ b/meson_post_install.py
@@ -0,0 +1,14 @@
+#!/usr/bin/env python3
+
+import os
+import subprocess
+import sys
+
+if not os.environ.get('DESTDIR'):
+ schemadir = os.path.join(sys.argv[1], 'glib-2.0', 'schemas')
+ print('Compiling gsettings schemas...')
+ subprocess.call(['glib-compile-schemas', schemadir])
+
+ giomoduledir = os.path.join(sys.argv[2], 'gio', 'modules')
+ print('GIO module cache creation...')
+ subprocess.call(['gio-querymodules', giomoduledir])
diff --git a/metadata/Makefile.am b/metadata/Makefile.am
index b38d01b..9acc213 100644
--- a/metadata/Makefile.am
+++ b/metadata/Makefile.am
@@ -81,6 +81,7 @@ EXTRA_DIST = \
$(service_in_files) \
$(systemd_user_in_files) \
dbus-interface.xml \
+ meson.build \
$(NULL)
CLEANFILES = \
diff --git a/metadata/meson.build b/metadata/meson.build
new file mode 100644
index 0000000..3bca1c8
--- /dev/null
+++ b/metadata/meson.build
@@ -0,0 +1,99 @@
+service = 'org.gtk.vfs.Metadata.service'
+
+metadata_service = configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: gvfs_dbus_service_dir,
+ configuration: service_conf
+)
+
+if have_systemd_user_unit
+ service = 'gvfs-metadata.service'
+
+ configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: systemd_user_dir,
+ configuration: service_conf
+ )
+endif
+
+name = 'dbus-interface'
+
+metadata_dbus = gnome.gdbus_codegen(
+ 'metadata-dbus',
+ name + '.xml',
+ interface_prefix: gvfs_namespace + '.',
+ namespace: 'GVfs'
+)
+
+sources = files(
+ 'crc32.c',
+ 'metabuilder.c',
+ 'metatree.c'
+)
+
+cflags = [
+ '-DDBUS_API_SUBJECT_TO_CHANGE',
+ '-DG_LOG_DOMAIN="@0@"'.format(meson.project_name().to_upper()),
+ '-DGVFS_LOCALEDIR="@0@"'.format(gvfs_localedir)
+]
+
+libmetadata = static_library(
+ 'metadata',
+ sources: sources + [metadata_dbus],
+ include_directories: [top_inc, common_inc],
+ dependencies: glib_deps,
+ c_args: cflags,
+ pic: true
+)
+
+libmetadata_dep = declare_dependency(
+ link_with: libmetadata,
+ include_directories: include_directories('.')
+)
+
+apps = [
+ 'meta-ls',
+ 'meta-get',
+ 'meta-set',
+ 'meta-get-tree'
+]
+
+foreach app: apps
+ executable(
+ app,
+ app + '.c',
+ include_directories: top_inc,
+ dependencies: glib_deps + [libgvfscommon_dep],
+ c_args: cflags,
+ link_with: libmetadata
+ )
+endforeach
+
+if have_libxml
+ executable(
+ 'convert-nautilus-metadata',
+ 'metadata-nautilus.c',
+ include_directories: top_inc,
+ dependencies: glib_deps + [libxml_dep],
+ c_args: cflags,
+ link_with: libmetadata
+ )
+endif
+
+executable(
+ 'gvfsd-metadata',
+ 'meta-daemon.c',
+ include_directories: top_inc,
+ dependencies: glib_deps + [
+ libgvfscommon_dep,
+ libudev_dep
+ ],
+ c_args: cflags,
+ link_with: libmetadata,
+ install: true,
+ install_dir: gvfs_libexecdir
+)
diff --git a/monitor/Makefile.am b/monitor/Makefile.am
index 10df398..3a8481a 100644
--- a/monitor/Makefile.am
+++ b/monitor/Makefile.am
@@ -24,3 +24,5 @@ endif
if USE_GOA
SUBDIRS += goa
endif
+
+EXTRA_DIST = meson.build
diff --git a/monitor/afc/Makefile.am b/monitor/afc/Makefile.am
index 48c7978..2a1821d 100644
--- a/monitor/afc/Makefile.am
+++ b/monitor/afc/Makefile.am
@@ -55,6 +55,7 @@ CLEANFILES = \
$(NULL)
EXTRA_DIST = \
+ meson.build \
$(service_in_files) \
$(systemd_user_in_files) \
$(remote_volume_monitors_DATA) \
diff --git a/monitor/afc/meson.build b/monitor/afc/meson.build
new file mode 100644
index 0000000..cbc985c
--- /dev/null
+++ b/monitor/afc/meson.build
@@ -0,0 +1,57 @@
+afc_monitor = files('afc.monitor')
+
+install_data(
+ afc_monitor,
+ install_dir: gvfs_remote_volume_monitors_dir
+)
+
+service = 'org.gtk.vfs.AfcVolumeMonitor.service'
+
+afc_service = configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: gvfs_dbus_service_dir,
+ configuration: service_conf
+)
+
+if have_systemd_user_unit
+ service = 'gvfs-afc-volume-monitor.service'
+
+ configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: systemd_user_dir,
+ configuration: service_conf
+ )
+endif
+
+sources = files(
+ 'afcvolumemonitordaemon.c',
+ 'afcvolume.c',
+ 'afcvolumemonitor.c'
+)
+
+deps = glib_deps + [
+ libimobiledevice_dep,
+ libplist_dep,
+ libgvfscommon_dep,
+ libgvfsproxyvolumemonitordaemon_noin_dep
+]
+
+cflags = [
+ '-DG_LOG_DOMAIN="GVFS-AFC"',
+ '-DGIO_MODULE_DIR="@0@"'.format(gio_module_dir),
+ '-DGVFS_LOCALEDIR="@0@"'.format(gvfs_localedir)
+]
+
+executable(
+ 'gvfs-afc-volume-monitor',
+ sources,
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: cflags,
+ install: true,
+ install_dir: gvfs_libexecdir
+)
diff --git a/monitor/gdu/Makefile.am b/monitor/gdu/Makefile.am
index 175d739..4ba128f 100644
--- a/monitor/gdu/Makefile.am
+++ b/monitor/gdu/Makefile.am
@@ -63,6 +63,7 @@ CLEANFILES = \
$(NULL)
EXTRA_DIST = \
+ meson.build \
$(service_in_files) \
$(systemd_user_in_files) \
$(remote_volume_monitors_DATA) \
diff --git a/monitor/gdu/meson.build b/monitor/gdu/meson.build
new file mode 100644
index 0000000..516b27d
--- /dev/null
+++ b/monitor/gdu/meson.build
@@ -0,0 +1,59 @@
+gdu_monitor = files('gdu.monitor')
+
+install_data(
+ gdu_monitor,
+ install_dir: gvfs_remote_volume_monitors_dir
+)
+
+gdu_service = configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: gvfs_dbus_service_dir,
+ configuration: service_conf
+)
+
+if have_systemd_user_unit
+ service = 'gvfs-gdu-volume-monitor.service'
+
+ configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: systemd_user_dir,
+ configuration: service_conf
+ )
+endif
+
+sources = files(
+ 'gdu-volume-monitor-daemon.c',
+ 'ggdudrive.c',
+ 'ggdumount.c',
+ 'ggduvolume.c',
+ 'ggduvolumemonitor.c'
+)
+
+deps = glib_deps + [
+ gdu_dep,
+ gudev_dep,
+ libgvfscommon_dep,
+ libgvfscommon_monitor_dep,
+ libgvfsproxyvolumemonitordaemon_noin_dep
+]
+
+cflags = [
+ '-DG_LOG_DOMAIN="GVFS-Gdu"',
+ '-DGDU_API_IS_SUBJECT_TO_CHANGE',
+ '-DGIO_MODULE_DIR="@0@"'.format(gio_modules_dir),
+ '-DGVFS_LOCALEDIR="@0@"'.format(gvfs_localedir)
+]
+
+executable(
+ 'gvfs-gdu-volume-monitor',
+ sources,
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: cflags,
+ install: true,
+ install_dir: gvfs_libexecdir
+)
diff --git a/monitor/goa/Makefile.am b/monitor/goa/Makefile.am
index af7845e..9a85d04 100644
--- a/monitor/goa/Makefile.am
+++ b/monitor/goa/Makefile.am
@@ -55,6 +55,7 @@ CLEANFILES = \
$(NULL)
EXTRA_DIST = \
+ meson.build \
$(service_in_files) \
$(systemd_user_in_files) \
$(remote_volume_monitors_DATA) \
diff --git a/monitor/goa/meson.build b/monitor/goa/meson.build
new file mode 100644
index 0000000..e93d0a8
--- /dev/null
+++ b/monitor/goa/meson.build
@@ -0,0 +1,54 @@
+install_data(
+ 'goa.monitor',
+ install_dir: gvfs_remote_volume_monitors_dir
+)
+
+service = 'org.gtk.vfs.GoaVolumeMonitor.service'
+
+configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: gvfs_dbus_service_dir,
+ configuration: service_conf
+)
+
+if have_systemd_user_unit
+ service = 'gvfs-goa-volume-monitor.service'
+
+ configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: systemd_user_dir,
+ configuration: service_conf
+ )
+endif
+
+sources = files(
+ 'goavolumemonitordaemon.c',
+ 'goavolume.c',
+ 'goavolumemonitor.c'
+)
+
+deps = glib_deps + [
+ goa_dep,
+ libgvfscommon_dep,
+ libgvfsproxyvolumemonitordaemon_noin_dep
+]
+
+cflags = [
+ '-DG_LOG_DOMAIN="GVFS-GOA"',
+ '-DGIO_MODULE_DIR="@0@"'.format(gio_module_dir),
+ '-DGVFS_LOCALEDIR="@0@"'.format(gvfs_localedir)
+]
+
+executable(
+ 'gvfs-goa-volume-monitor',
+ sources,
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: cflags,
+ install: true,
+ install_dir: gvfs_libexecdir
+)
diff --git a/monitor/gphoto2/Makefile.am b/monitor/gphoto2/Makefile.am
index b13fd98..2beb08f 100644
--- a/monitor/gphoto2/Makefile.am
+++ b/monitor/gphoto2/Makefile.am
@@ -59,6 +59,7 @@ CLEANFILES = \
$(NULL)
EXTRA_DIST = \
+ meson.build \
$(service_in_files) \
$(systemd_user_in_files) \
$(remote_volume_monitors_DATA) \
diff --git a/monitor/gphoto2/meson.build b/monitor/gphoto2/meson.build
new file mode 100644
index 0000000..569b480
--- /dev/null
+++ b/monitor/gphoto2/meson.build
@@ -0,0 +1,58 @@
+gphoto2_monitor = files('gphoto2.monitor')
+
+install_data(
+ gphoto2_monitor,
+ install_dir: gvfs_remote_volume_monitors_dir
+)
+
+service = 'org.gtk.vfs.GPhoto2VolumeMonitor.service'
+
+gphoto2_service = configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: gvfs_dbus_service_dir,
+ configuration: service_conf
+)
+
+if have_systemd_user_unit
+ service = 'gvfs-gphoto2-volume-monitor.service'
+
+ configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: systemd_user_dir,
+ configuration: service_conf
+ )
+endif
+
+sources = files(
+ 'gphoto2-volume-monitor-daemon.c',
+ 'ggphoto2volume.c',
+ 'ggphoto2volumemonitor.c'
+)
+
+deps = glib_deps + [
+ libgphoto2_dep,
+ gudev_dep,
+ libgvfscommon_dep,
+ libgvfscommon_gphoto2_dep,
+ libgvfsproxyvolumemonitordaemon_noin_dep
+]
+
+cflags = [
+ '-DG_LOG_DOMAIN="GVFS-GPhoto2"',
+ '-DGIO_MODULE_DIR="@0@"'.format(gio_module_dir),
+ '-DGVFS_LOCALEDIR="@0@"'.format(gvfs_localedir)
+]
+
+executable(
+ 'gvfs-gphoto2-volume-monitor',
+ sources,
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: cflags,
+ install: true,
+ install_dir: gvfs_libexecdir
+)
diff --git a/monitor/meson.build b/monitor/meson.build
new file mode 100644
index 0000000..1674990
--- /dev/null
+++ b/monitor/meson.build
@@ -0,0 +1,25 @@
+subdir('proxy')
+
+if have_gdu
+ subdir('gdu')
+endif
+
+if have_udisks2
+ subdir('udisks2')
+endif
+
+if have_gphoto2
+ subdir('gphoto2')
+endif
+
+if have_afc
+ subdir('afc')
+endif
+
+if have_libmtp
+ subdir('mtp')
+endif
+
+if have_goa
+ subdir('goa')
+endif
diff --git a/monitor/mtp/Makefile.am b/monitor/mtp/Makefile.am
index 2a7e9de..af0d10e 100644
--- a/monitor/mtp/Makefile.am
+++ b/monitor/mtp/Makefile.am
@@ -63,4 +63,5 @@ EXTRA_DIST = \
$(service_in_files) \
$(systemd_user_in_files) \
$(remote_volume_monitors_DATA) \
+ meson.build \
$(NULL)
diff --git a/monitor/mtp/meson.build b/monitor/mtp/meson.build
new file mode 100644
index 0000000..eb2c3e4
--- /dev/null
+++ b/monitor/mtp/meson.build
@@ -0,0 +1,55 @@
+install_data(
+ 'mtp.monitor',
+ install_dir: gvfs_remote_volume_monitors_dir
+)
+
+service = 'org.gtk.vfs.MTPVolumeMonitor.service'
+
+configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: gvfs_dbus_service_dir,
+ configuration: service_conf
+)
+
+if have_systemd_user_unit
+ service = 'gvfs-mtp-volume-monitor.service'
+
+ configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: systemd_user_dir,
+ configuration: service_conf
+ )
+endif
+
+sources = files(
+ 'mtp-volume-monitor-daemon.c',
+ 'gmtpvolume.c',
+ 'gmtpvolumemonitor.c'
+)
+
+deps = glib_deps + [
+ gudev_dep,
+ libgvfscommon_dep,
+ libgvfscommon_gphoto2_dep,
+ libgvfsproxyvolumemonitordaemon_noin_dep
+]
+
+cflags = [
+ '-DG_LOG_DOMAIN="GVFS-MTP"',
+ '-DGIO_MODULE_DIR="@0@"'.format(gio_module_dir),
+ '-DGVFS_LOCALEDIR="@0@"'.format(gvfs_localedir)
+]
+
+executable(
+ 'gvfs-mtp-volume-monitor',
+ sources,
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: cflags,
+ install: true,
+ install_dir: gvfs_libexecdir
+)
diff --git a/monitor/proxy/Makefile.am b/monitor/proxy/Makefile.am
index 3b3c8db..cf449c4 100644
--- a/monitor/proxy/Makefile.am
+++ b/monitor/proxy/Makefile.am
@@ -81,6 +81,8 @@ install-data-local:
EXTRA_DIST = \
dbus-interfaces.xml \
+ meson.build \
+ symbol.map \
$(NULL)
CLEANFILES = \
diff --git a/monitor/proxy/meson.build b/monitor/proxy/meson.build
new file mode 100644
index 0000000..8856673
--- /dev/null
+++ b/monitor/proxy/meson.build
@@ -0,0 +1,64 @@
+dbus_sources = gnome.gdbus_codegen(
+ 'gvfsvolumemonitordbus',
+ 'dbus-interfaces.xml',
+ interface_prefix: 'org.gtk.Private.',
+ namespace: 'GVfs'
+)
+
+sources = files(
+ 'remote-volume-monitor-module.c',
+ 'gproxydrive.c',
+ 'gproxymount.c',
+ 'gproxymountoperation.c',
+ 'gproxyshadowmount.c',
+ 'gproxyvolume.c',
+ 'gproxyvolumemonitor.c'
+)
+
+deps = glib_deps + [libgvfscommon_dep]
+
+cflags = [
+ '-DG_LOG_DOMAIN="GVFS-RemoveVolumeMonitor"',
+ '-DGIO_MODULE_DIR="@0@"'.format(gio_module_dir),
+ '-DGVFS_LOCALEDIR="@0@"'.format(gvfs_localedir),
+ '-DREMOTE_VOLUME_MONITORS_DIR="@0@"'.format(gvfs_remote_volume_monitors_dir)
+]
+
+symbol_map = 'symbol.map'
+
+ldflags = []
+if have_version_script
+ ldflags += '-Wl,--version-script,@0@/@1@'.format(meson.current_source_dir(), symbol_map)
+endif
+
+libgioremove_volume_monitor = shared_module(
+ 'gioremote-volume-monitor',
+ sources: sources + [dbus_sources],
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: cflags,
+ link_args: ldflags,
+ link_depends: symbol_map,
+ install: true,
+ install_dir: gio_module_dir
+)
+
+sources = files('gvfsproxyvolumemonitordaemon.c')
+
+cflags = [
+ '-DG_LOG_DOMAIN="GVFS-RemoteVolumeMonitorDaemon"',
+ '-DGVFS_LOCALEDIR="@0@"'.format(gvfs_localedir)
+]
+
+libgvfsproxyvolumemonitordaemon_noin = static_library(
+ 'gvfsproxyvolumemonitordaemon-noin',
+ sources: sources + [dbus_sources],
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: cflags
+)
+
+libgvfsproxyvolumemonitordaemon_noin_dep = declare_dependency(
+ link_with: libgvfsproxyvolumemonitordaemon_noin,
+ include_directories: include_directories('.')
+)
diff --git a/monitor/proxy/symbol.map b/monitor/proxy/symbol.map
new file mode 100644
index 0000000..451e539
--- /dev/null
+++ b/monitor/proxy/symbol.map
@@ -0,0 +1,8 @@
+{
+global:
+ g_io_module_load;
+ g_io_module_unload;
+ g_io_module_query;
+local:
+ *;
+};
diff --git a/monitor/udisks2/Makefile.am b/monitor/udisks2/Makefile.am
index 052fac5..304b9c1 100644
--- a/monitor/udisks2/Makefile.am
+++ b/monitor/udisks2/Makefile.am
@@ -69,6 +69,7 @@ CLEANFILES = \
EXTRA_DIST = \
what-is-shown.txt \
+ meson.build \
$(service_in_files) \
$(systemd_user_in_files) \
$(remote_volume_monitors_DATA) \
diff --git a/monitor/udisks2/meson.build b/monitor/udisks2/meson.build
new file mode 100644
index 0000000..df30600
--- /dev/null
+++ b/monitor/udisks2/meson.build
@@ -0,0 +1,71 @@
+udisks2_monitor = files('udisks2.monitor')
+
+install_data(
+ udisks2_monitor,
+ install_dir: gvfs_remote_volume_monitors_dir
+)
+
+service = 'org.gtk.vfs.UDisks2VolumeMonitor.service'
+
+udisks2_service = configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: gvfs_dbus_service_dir,
+ configuration: service_conf
+)
+
+if have_systemd_user_unit
+ service = 'gvfs-udisks2-volume-monitor.service'
+
+ configure_file(
+ input: service + '.in',
+ output: service,
+ install: true,
+ install_dir: systemd_user_dir,
+ configuration: service_conf
+ )
+endif
+
+sources = files(
+ 'udisks2volumemonitordaemon.c',
+ 'gvfsudisks2drive.c',
+ 'gvfsudisks2mount.c',
+ 'gvfsudisks2utils.c',
+ 'gvfsudisks2volume.c',
+ 'gvfsudisks2volumemonitor.c'
+)
+
+deps = glib_deps + [
+ udisks2_dep,
+ gudev_dep,
+ libgvfscommon_dep,
+ libgvfscommon_monitor_dep,
+ libgvfsproxyvolumemonitordaemon_noin_dep
+]
+
+if have_libsystemd_login
+ deps += libsystemd_login_dep
+endif
+
+if have_keyring
+ deps += libsecret_dep
+endif
+
+cflags = [
+ '-DG_LOG_DOMAIN="GVFS-UDisks2"',
+ '-DG_DISABLE_DEPRECATED',
+ '-DGIO_MODULE_DIR="@0@"'.format(gio_module_dir),
+ '-DGVFS_LOCALEDIR="@0@"'.format(gvfs_localedir),
+ '-DUDISKS_API_IS_SUBJECT_TO_CHANGE'
+]
+
+executable(
+ 'gvfs-udisks2-volume-monitor',
+ sources,
+ include_directories: top_inc,
+ dependencies: deps,
+ c_args: cflags,
+ install: true,
+ install_dir: gvfs_libexecdir
+)
diff --git a/po/meson.build b/po/meson.build
new file mode 100644
index 0000000..e9b77d7
--- /dev/null
+++ b/po/meson.build
@@ -0,0 +1 @@
+i18n.gettext(meson.project_name(), preset: 'glib')
diff --git a/programs/Makefile.am b/programs/Makefile.am
index d7e22e2..0eb074b 100644
--- a/programs/Makefile.am
+++ b/programs/Makefile.am
@@ -75,6 +75,7 @@ gvfs-mime: deprecated.in Makefile
EXTRA_DIST = \
deprecated.in \
gvfs-less \
+ meson.build \
$(NULL)
CLEANFILES = \
diff --git a/programs/deprecated.in b/programs/deprecated.in
old mode 100644
new mode 100755
diff --git a/programs/meson.build b/programs/meson.build
new file mode 100644
index 0000000..1dea6b7
--- /dev/null
+++ b/programs/meson.build
@@ -0,0 +1,37 @@
+script_names = [
+ ['mount', 'mount'],
+ ['cat', 'cat'],
+ ['open', 'open'],
+ ['save', 'save'],
+ ['ls', 'list'],
+ ['tree', 'tree'],
+ ['info', 'info'],
+ ['set-attribute', 'set'],
+ ['trash', 'trash'],
+ ['rename', 'rename'],
+ ['rm', 'remove'],
+ ['copy', 'copy'],
+ ['move', 'move'],
+ ['monitor-file', 'monitor'],
+ ['monitor-dir', 'monitor'],
+ ['mkdir', 'mkdir'],
+ ['mime', 'mime']
+]
+
+foreach name: script_names
+ conf = configuration_data()
+ conf.set('command', name[1])
+
+ configure_file(
+ input: 'deprecated.in',
+ output: 'gvfs-' + name[0],
+ install: true,
+ install_dir: gvfs_bindir,
+ configuration: conf
+ )
+endforeach
+
+install_data(
+ 'gvfs-less',
+ install_dir: gvfs_bindir
+)
diff --git a/test/Makefile.am b/test/Makefile.am
index 3c169e6..3142ce1 100644
--- a/test/Makefile.am
+++ b/test/Makefile.am
@@ -119,4 +119,6 @@ EXTRA_DIST += \
files/testcert.pem \
files/powershot.ioctl \
files/powershot.umockdev \
+ meson.build \
+ gvfs-all-tests.in \
$(NULL)
diff --git a/test/gvfs-all-tests.in b/test/gvfs-all-tests.in
new file mode 100644
index 0000000..9bb619f
--- /dev/null
+++ b/test/gvfs-all-tests.in
@@ -0,0 +1,4 @@
+[Test]
+Type=session
+Exec=@installed_testdir@/gvfs-test
+Output=TAP
diff --git a/test/meson.build b/test/meson.build
new file mode 100644
index 0000000..93d163d
--- /dev/null
+++ b/test/meson.build
@@ -0,0 +1,94 @@
+installed_test_metadir = join_paths(gvfs_datadir, 'installed-tests', meson.project_name())
+installed_testdir = join_paths(gvfs_libexecdir, 'installed-tests', meson.project_name())
+
+session_conf = configuration_data()
+session_conf.set('testdir', installed_testdir)
+
+session = 'session.conf'
+
+configure_file(
+ input: session + '.in',
+ output: session,
+ install: true,
+ install_dir: installed_testdir,
+ configuration: session_conf
+)
+
+all_tests_conf = configuration_data()
+all_tests_conf.set('installed_testdir', installed_testdir)
+
+all_tests = 'gvfs-all-tests'
+
+configure_file(
+ input: all_tests + '.in',
+ output: all_tests + '.test',
+ install: true,
+ install_dir: installed_test_metadir,
+ configuration: all_tests_conf
+)
+
+install_subdir(
+ 'files',
+ install_dir: installed_testdir
+)
+
+test_data = [
+ 'gvfs-test',
+ daemon_service,
+ metadata_service
+]
+
+if have_afc
+ test_data += [afc_monitor, afc_service]
+endif
+
+if have_gdu
+ test_data += [gdu_monitor, gdu_service]
+endif
+
+if have_gphoto2
+ test_data += [gphoto2_monitor, gphoto2_service]
+endif
+
+if have_udisks2
+ test_data += [udisks2_monitor, udisks2_service]
+endif
+
+install_data(
+ test_data,
+ install_dir: installed_testdir
+)
+
+test_units = [
+ 'benchmark-gvfs-big-files',
+ 'benchmark-gvfs-small-files',
+ 'benchmark-posix-big-files',
+ 'benchmark-posix-small-files',
+ 'test-query-info-stream'
+]
+
+foreach unit: test_units
+ exe = executable(
+ unit,
+ unit + '.c',
+ include_directories: top_inc,
+ dependencies: glib_deps
+ )
+
+ test(unit, exe)
+endforeach
+
+'''
+# run tests against build tree
+check: $(CONFIG_FILES) gvfs-test
+ $(srcdir)/run-in-tree.sh $(srcdir)/gvfs-test $(TEST_NAMES)
+
+# run tests against the installed system packages
+# when running as root, use gvfs-testbed to enable all tests
+installcheck-local: gvfs-test
+ if [ `id -u` = 0 ]; then \
+ $(srcdir)/gvfs-testbed $(srcdir)/gvfs-test $(TEST_NAMES); \
+ else \
+ $(srcdir)/gvfs-test $(TEST_NAMES); \
+ fi
+'''
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]