diff foosdk/sdk/foobar2000/helpers/track_property_callback_impl.h @ 1:20d02a178406 default tip

*: check in everything else yay
author Paper <paper@tflc.us>
date Mon, 05 Jan 2026 02:15:46 -0500
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/foosdk/sdk/foobar2000/helpers/track_property_callback_impl.h	Mon Jan 05 02:15:46 2026 -0500
@@ -0,0 +1,53 @@
+#pragma once
+
+#include <functional>
+#include <SDK/track_property.h>
+
+class groupname_comparator {
+public:
+	static int compare(pfc::stringp p_name1,pfc::stringp p_name2) {
+		int temp = uStringCompare(p_name1,p_name2);
+		if (temp != 0) return temp;
+		return strcmp(p_name1,p_name2);
+	}
+};
+
+struct propertyname_container {
+	pfc::string m_name;
+	double m_priority;
+};
+
+class propertyname_comparator {
+public:
+	static int compare(const propertyname_container & p_item1,const propertyname_container & p_item2) {
+		int state = pfc::compare_t(p_item1.m_priority,p_item2.m_priority);
+		if (state != 0) return state;
+		return uStringCompare(p_item1.m_name.ptr(),p_item2.m_name.ptr());
+	}
+};
+
+typedef pfc::map_t<propertyname_container,pfc::string,propertyname_comparator> property_group;
+
+typedef pfc::map_t<pfc::string,property_group,groupname_comparator> t_property_group_list;
+
+class track_property_callback_impl : public track_property_callback_v2 {
+public:
+	void set_property(const char * p_group,double p_sortpriority,const char * p_name,const char * p_value) override;
+	bool is_group_wanted(const char * p_group) override;
+
+	void merge( track_property_callback_impl const & other );
+
+	t_property_group_list m_entries;
+
+	bool m_cutMultiLine = false;
+	typedef std::function<bool ( const char * ) > groupFilter_t;
+	groupFilter_t m_groupFilter;
+};
+
+// Helper function to walk all track property providers in an optimized multithread manner
+// Various *source arguments have been std::function'd so you can reference your own data structures gracefully
+// If the function is aborted, it returns immediately - while actual worker threads may not yet have completed, and may still reference *source arguments. 
+// You must ensure - by means of std::shared_ptr<> or such - that all of the *source arguments remain accessible even after enumerateTrackProperties() returns, until the std::functions are released.
+// Legacy track property providers that do not support off main thread operation will be invoked via main_thread_callback in main thread, and the function will stall until they have returned (unless aborted).
+void enumerateTrackProperties(track_property_callback_impl & callback, std::function< metadb_handle_list_cref() > itemsSource, std::function<track_property_provider_v3_info_source*()> infoSource, std::function<abort_callback& () > abortSource);
+void enumerateTrackProperties_v5(track_property_callback_impl& callback, std::function< metadb_handle_list_cref() > itemsSource, std::function<track_property_provider_v5_info_source* ()> infoSource, std::function<abort_callback& () > abortSource);