From f2caac595a775b4314c69057eb48c14b7627a72a Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Mon, 20 Aug 2018 10:50:57 +0200 Subject: [PATCH 1/6] configure.ac: specify minimum libnfs version 1.9.5 This is the version in Debian Jessie (oldstable), a reasonable "old enough" version to keep support for. --- configure.ac | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/configure.ac b/configure.ac index c14f1a7c0..4e9f8b460 100644 --- a/configure.ac +++ b/configure.ac @@ -707,7 +707,7 @@ MPD_ENABLE_AUTO_PKG_LIB(smbclient, SMBCLIENT, [smbclient >= 0.2], [smbclient input plugin], [libsmbclient not found]) dnl ----------------------------------- NFS ----------------------------- -MPD_ENABLE_AUTO_PKG(nfs, NFS, [libnfs], +MPD_ENABLE_AUTO_PKG(nfs, NFS, [libnfs >= 1.9.5], [NFS input plugin], [libnfs not found]) dnl --------------------------------- Soundcloud ------------------------------ From 9127afbf3ff69584410a513d8155f698d478758a Mon Sep 17 00:00:00 2001 From: Thomas Guillem Date: Fri, 13 Nov 2015 20:33:56 +0100 Subject: [PATCH 2/6] lib/nfs/Connection: use nfs_stat64_async Since nfs_stat_async is deprecated. --- src/lib/nfs/Connection.cxx | 4 ++-- src/storage/plugins/NfsStorage.cxx | 16 ++++++++-------- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/src/lib/nfs/Connection.cxx b/src/lib/nfs/Connection.cxx index cad2da530..33980de3f 100644 --- a/src/lib/nfs/Connection.cxx +++ b/src/lib/nfs/Connection.cxx @@ -47,9 +47,9 @@ NfsConnection::CancellableCallback::Stat(nfs_context *ctx, { assert(connection.GetEventLoop().IsInside()); - int result = nfs_stat_async(ctx, path, Callback, this); + int result = nfs_stat64_async(ctx, path, Callback, this); if (result < 0) - throw FormatRuntimeError("nfs_stat_async() failed: %s", + throw FormatRuntimeError("nfs_stat64_async() failed: %s", nfs_get_error(ctx)); } diff --git a/src/storage/plugins/NfsStorage.cxx b/src/storage/plugins/NfsStorage.cxx index b2eec24ff..4d82c0415 100644 --- a/src/storage/plugins/NfsStorage.cxx +++ b/src/storage/plugins/NfsStorage.cxx @@ -246,19 +246,19 @@ NfsStorage::MapToRelativeUTF8(const char *uri_utf8) const noexcept } static void -Copy(StorageFileInfo &info, const struct stat &st) +Copy(StorageFileInfo &info, const struct nfs_stat_64 &st) { - if (S_ISREG(st.st_mode)) + if (S_ISREG(st.nfs_mode)) info.type = StorageFileInfo::Type::REGULAR; - else if (S_ISDIR(st.st_mode)) + else if (S_ISDIR(st.nfs_mode)) info.type = StorageFileInfo::Type::DIRECTORY; else info.type = StorageFileInfo::Type::OTHER; - info.size = st.st_size; - info.mtime = st.st_mtime; - info.device = st.st_dev; - info.inode = st.st_ino; + info.size = st.nfs_size; + info.mtime = st.nfs_mtime; + info.device = st.nfs_dev; + info.inode = st.nfs_ino; } class NfsGetInfoOperation final : public BlockingNfsOperation { @@ -279,7 +279,7 @@ protected: } void HandleResult(gcc_unused unsigned status, void *data) override { - Copy(info, *(const struct stat *)data); + Copy(info, *(const struct nfs_stat_64 *)data); } }; From 49372a222f13828be867c552dd54f7245c90cf58 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Mon, 20 Aug 2018 11:04:35 +0200 Subject: [PATCH 3/6] Makefile.am: use $(@D)/$(@F) instead of $(dir/notdir ...) --- Makefile.am | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Makefile.am b/Makefile.am index 6e2d96cae..320b779cc 100644 --- a/Makefile.am +++ b/Makefile.am @@ -325,7 +325,7 @@ $(AIDL_JAVA_FILES): android/build/src/org/musicpd/%.java: $(srcdir)/android/src/ $(AIDL) -Iandroid/build/src -oandroid/build/src $(patsubst %.java,%.aidl,$@) $(ANDROID_XML_RES_COPIES): $(ANDROID_XML_RES) - @$(MKDIR_P) $(dir $@) + @$(MKDIR_P) $(@D) cp $(patsubst android/build/%,$(srcdir)/android/%,$@) $@ android/build/resources.apk: $(ANDROID_XML_RES_COPIES) android/build/res/drawable/icon.png android/build/res/drawable/notification_icon.png @@ -368,7 +368,7 @@ android/build/res/drawable/notification_icon.png: android/build/res/drawable/ico .DELETE_ON_ERROR: android/build/unsigned.apk android/build/unsigned.apk: android/build/classes.dex android/build/resources.apk android/build/lib/$(ANDROID_ABI)/libmpd.so cp android/build/resources.apk $@ - cd $(dir $@) && zip -q -r $(notdir $@) classes.dex lib + cd $(@D) && zip -q -r $(@F) classes.dex lib android/build/$(APK_NAME)-debug.apk: android/build/unsigned.apk jarsigner -keystore $(HOME)/.android/debug.keystore -storepass android -signedjar $@ $< androiddebugkey From 2bc42c6445d0dcb5e25fdf4ecb1bedad3baa4662 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Mon, 20 Aug 2018 11:13:25 +0200 Subject: [PATCH 4/6] Makefile.am: use $(MKDIR_P) instead of "mkdir -p" --- Makefile.am | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Makefile.am b/Makefile.am index 320b779cc..4bb9c3a14 100644 --- a/Makefile.am +++ b/Makefile.am @@ -354,12 +354,12 @@ android/build/include/org_musicpd_Bridge.h: android/build/classes.dex BUILT_SOURCES = android/build/include/org_musicpd_Bridge.h android/build/lib/$(ANDROID_ABI)/libmpd.so: libmpd.so - mkdir -p $(@D) + $(MKDIR_P) $(@D) rm -f $@ $(STRIP) -o $@ $< android/build/res/drawable/icon.png: mpd.svg - mkdir -p $(@D) + $(MKDIR_P) $(@D) rsvg-convert --width=48 --height=48 $< -o $@ android/build/res/drawable/notification_icon.png: android/build/res/drawable/icon.png From 1ff97783ea237c3bd76d0ab2c5c612b98320dee8 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Mon, 20 Aug 2018 11:22:56 +0200 Subject: [PATCH 5/6] Makefile.am: use $(AM_V_GEN) and $(AM_V_at) --- Makefile.am | 53 ++++++++++++++++++++++++++++++++--------------------- 1 file changed, 32 insertions(+), 21 deletions(-) diff --git a/Makefile.am b/Makefile.am index 4bb9c3a14..ca800617a 100644 --- a/Makefile.am +++ b/Makefile.am @@ -292,6 +292,7 @@ clean-local: rm -rf android/build libmpd.so: $(filter %.a,$(src_mpd_LDADD)) libmain.a + $(AM_V_GEN) $(AM_V_CXXLD)$(CXXLD) -shared -Wl,--no-undefined,-shared,-Bsymbolic -llog -lz -o $@ $(AM_CXXFLAGS) $(CXXFLAGS) $(LDFLAGS) src/libmain_a-Main.o $(src_mpd_LDADD) $(LIBS) ANDROID_SDK_BUILD_TOOLS_VERSION = 27.0.0 @@ -320,17 +321,19 @@ AIDL_JAVA_FILES = $(patsubst $(srcdir)/android/src/%.aidl,android/build/src/org/ android/build/src/org/musicpd/IMain.java: android/build/src/org/musicpd/IMainCallback.java $(AIDL_JAVA_FILES): android/build/src/org/musicpd/%.java: $(srcdir)/android/src/%.aidl - @$(MKDIR_P) $(@D) - @cp $< $(@D)/ - $(AIDL) -Iandroid/build/src -oandroid/build/src $(patsubst %.java,%.aidl,$@) + $(AM_V_GEN) + $(AM_V_at)$(MKDIR_P) $(@D) + $(AM_V_at)cp $< $(@D)/ + $(AM_V_at)$(AIDL) -Iandroid/build/src -oandroid/build/src $(patsubst %.java,%.aidl,$@) $(ANDROID_XML_RES_COPIES): $(ANDROID_XML_RES) - @$(MKDIR_P) $(@D) - cp $(patsubst android/build/%,$(srcdir)/android/%,$@) $@ + $(AM_V_at)$(MKDIR_P) $(@D) + $(AM_V_at)cp $(patsubst android/build/%,$(srcdir)/android/%,$@) $@ android/build/resources.apk: $(ANDROID_XML_RES_COPIES) android/build/res/drawable/icon.png android/build/res/drawable/notification_icon.png - @$(MKDIR_P) android/build/gen - $(AAPT) package -f -m --auto-add-overlay \ + $(AM_V_GEN) + $(AM_V_at)$(MKDIR_P) android/build/gen + $(AM_V_at)$(AAPT) package -f -m --auto-add-overlay \ --custom-package org.musicpd \ -M $(srcdir)/android/AndroidManifest.xml \ -S android/build/res \ @@ -342,42 +345,50 @@ android/build/resources.apk: $(ANDROID_XML_RES_COPIES) android/build/res/drawabl android/build/gen/org/musicpd/R.java: android/build/resources.apk android/build/classes.dex: $(JAVA_SOURCE_PATHS) $(AIDL_JAVA_FILES) android/build/gen/org/musicpd/R.java - @$(MKDIR_P) $(JAVA_CLASSFILES_DIR) - $(JAVAC) -source 1.6 -target 1.6 -Xlint:-options \ + $(AM_V_GEN) + $(AM_V_at)$(MKDIR_P) $(JAVA_CLASSFILES_DIR) + $(AM_V_at)$(JAVAC) -source 1.6 -target 1.6 -Xlint:-options \ -cp $(ANDROID_SDK_PLATFORM_DIR)/android.jar:$(JAVA_CLASSFILES_DIR) \ -h android/build/include \ -d $(JAVA_CLASSFILES_DIR) $^ - $(DX) --dex --output $@ $(JAVA_CLASSFILES_DIR) + $(AM_V_at)$(DX) --dex --output $@ $(JAVA_CLASSFILES_DIR) android/build/include/org_musicpd_Bridge.h: android/build/classes.dex BUILT_SOURCES = android/build/include/org_musicpd_Bridge.h android/build/lib/$(ANDROID_ABI)/libmpd.so: libmpd.so - $(MKDIR_P) $(@D) - rm -f $@ - $(STRIP) -o $@ $< + $(AM_V_GEN) + $(AM_V_at)$(MKDIR_P) $(@D) + $(AM_V_at)rm -f $@ + $(AM_V_at)$(STRIP) -o $@ $< android/build/res/drawable/icon.png: mpd.svg - $(MKDIR_P) $(@D) - rsvg-convert --width=48 --height=48 $< -o $@ + $(AM_V_GEN) + $(AM_V_at)$(MKDIR_P) $(@D) + $(AM_V_at)rsvg-convert --width=48 --height=48 $< -o $@ android/build/res/drawable/notification_icon.png: android/build/res/drawable/icon.png - convert $< -colorspace Gray -gamma 2.2 $@ + $(AM_V_GEN) + $(AM_V_at)convert $< -colorspace Gray -gamma 2.2 $@ .DELETE_ON_ERROR: android/build/unsigned.apk android/build/unsigned.apk: android/build/classes.dex android/build/resources.apk android/build/lib/$(ANDROID_ABI)/libmpd.so - cp android/build/resources.apk $@ - cd $(@D) && zip -q -r $(@F) classes.dex lib + $(AM_V_GEN) + $(AM_V_at)cp android/build/resources.apk $@ + $(AM_V_at)cd $(@D) && zip -q -r $(@F) classes.dex lib android/build/$(APK_NAME)-debug.apk: android/build/unsigned.apk - jarsigner -keystore $(HOME)/.android/debug.keystore -storepass android -signedjar $@ $< androiddebugkey + $(AM_V_GEN) + $(AM_V_at)jarsigner -keystore $(HOME)/.android/debug.keystore -storepass android -signedjar $@ $< androiddebugkey android/build/$(APK_NAME)-release-unaligned.apk: android/build/unsigned.apk - jarsigner -digestalg SHA1 -sigalg MD5withRSA -storepass:env ANDROID_KEYSTORE_PASS -keystore $(ANDROID_KEYSTORE) -signedjar $@ $< $(ANDROID_KEY_ALIAS) + $(AM_V_GEN) + $(AM_V_at)jarsigner -digestalg SHA1 -sigalg MD5withRSA -storepass:env ANDROID_KEYSTORE_PASS -keystore $(ANDROID_KEYSTORE) -signedjar $@ $< $(ANDROID_KEY_ALIAS) android/build/$(APK_NAME).apk: android/build/$(APK_NAME)-release-unaligned.apk - $(ZIPALIGN) -f 4 $< $@ + $(AM_V_GEN) + $(AM_V_at)$(ZIPALIGN) -f 4 $< $@ endif From cf9613512515956bfca699ee23529ec9e459551a Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Mon, 20 Aug 2018 11:25:47 +0200 Subject: [PATCH 6/6] android/Main: remove SDK_INT diversion MPD has minSdkVersion=21 which is above all the checks here. --- android/src/Main.java | 58 +++++-------------------------------------- 1 file changed, 6 insertions(+), 52 deletions(-) diff --git a/android/src/Main.java b/android/src/Main.java index 5a5d9d048..82eebe89c 100644 --- a/android/src/Main.java +++ b/android/src/Main.java @@ -156,38 +156,6 @@ public class Main extends Service implements Runnable { sendMessage(MSG_SEND_STATUS, mStatus, 0, mError); } - @TargetApi(Build.VERSION_CODES.GINGERBREAD) - private Notification buildNotificationGB(int title, int text, int icon, PendingIntent contentIntent) { - final Notification notification = new Notification(); - notification.icon = R.drawable.icon; - notification.contentView = new RemoteViews(getPackageName(), R.layout.custom_notification_gb); - notification.contentView.setImageViewResource(R.id.image, icon); - notification.contentView.setTextViewText(R.id.title, getText(title)); - notification.contentView.setTextViewText(R.id.text, getText(text)); - notification.contentIntent = contentIntent; - return notification; - } - - @TargetApi(Build.VERSION_CODES.HONEYCOMB) - private Notification buildNotificationHC(int title, int text, int icon, PendingIntent contentIntent) { - return new Notification.Builder(this) - .setContentTitle(getText(title)) - .setContentText(getText(text)) - .setSmallIcon(icon) - .setContentIntent(contentIntent) - .getNotification(); - } - - @TargetApi(Build.VERSION_CODES.JELLY_BEAN) - private Notification buildNotificationJB(int title, int text, int icon, PendingIntent contentIntent) { - return new Notification.Builder(this) - .setContentTitle(getText(title)) - .setContentText(getText(text)) - .setSmallIcon(icon) - .setContentIntent(contentIntent) - .build(); - } - private void start() { if (mThread != null) return; @@ -200,26 +168,12 @@ public class Main extends Service implements Runnable { final PendingIntent contentIntent = PendingIntent.getActivity(this, 0, mainIntent, PendingIntent.FLAG_CANCEL_CURRENT); - Notification notification; - - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) - notification = buildNotificationJB( - R.string.notification_title_mpd_running, - R.string.notification_text_mpd_running, - R.drawable.notification_icon, - contentIntent); - else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) - notification = buildNotificationHC( - R.string.notification_title_mpd_running, - R.string.notification_text_mpd_running, - R.drawable.notification_icon, - contentIntent); - else - notification = buildNotificationGB( - R.string.notification_title_mpd_running, - R.string.notification_text_mpd_running, - R.drawable.notification_icon, - contentIntent); + Notification notification = new Notification.Builder(this) + .setContentTitle(getText(R.string.notification_title_mpd_running)) + .setContentText(getText(R.string.notification_text_mpd_running)) + .setSmallIcon(R.drawable.notification_icon) + .setContentIntent(contentIntent) + .build(); startForeground(R.string.notification_title_mpd_running, notification); startService(new Intent(this, Main.class));