mirror of
https://review.haiku-os.org/haiku
synced 2025-01-22 06:16:03 +01:00
76889670db
* When the user isn't requesting a custom notification, it will be a BMediaRoster job to do it. * Reintroduce BMediaRoster::SyncToServices, this time based on local message passing rather than a global semaphore. * SyncToServices is used in launch_media_server to make the process more launch_daemon safe and faster in the average case. * It was an error to add notifications in the media_server. * Fixes #12717.
121 lines
3.1 KiB
C++
121 lines
3.1 KiB
C++
/*
|
|
* Copyright (c) 2003 Marcus Overhagen.
|
|
* All Rights Reserved.
|
|
*
|
|
* This file may be used under the terms of the MIT License.
|
|
*/
|
|
#ifndef _MEDIA_ROSTER_EX_H_
|
|
#define _MEDIA_ROSTER_EX_H_
|
|
|
|
|
|
#ifndef _MEDIA_T_LIST_H
|
|
#include "TList.h"
|
|
#endif
|
|
#ifndef _DATA_EXCHANGE_H
|
|
#include "DataExchange.h"
|
|
#endif
|
|
#ifndef _MEDIA_NODE_H
|
|
#include <MediaNode.h>
|
|
#endif
|
|
#ifndef _MEDIA_ADD_ON_H
|
|
#include <MediaAddOn.h>
|
|
#endif
|
|
|
|
|
|
namespace BPrivate { namespace media {
|
|
|
|
|
|
/* The BMediaRosterEx class is an extension to the BMediaRoster.
|
|
* It provides functionality that can be used by the implementation
|
|
* of media_server, media_addon_server and libmedia.so.
|
|
* To access it, convert any BMediaRoster pointer in a BMediaRosterEx
|
|
* pointer using the inline function provided below.
|
|
*/
|
|
class BMediaRosterEx : public BMediaRoster
|
|
{
|
|
public:
|
|
BMediaRosterEx(status_t* out_error);
|
|
virtual ~BMediaRosterEx();
|
|
|
|
virtual void Quit();
|
|
|
|
status_t SaveNodeConfiguration(BMediaNode* node);
|
|
status_t LoadNodeConfiguration(media_addon_id addonid,
|
|
int32 flavorid, BMessage* out_msg);
|
|
|
|
status_t IncrementAddonFlavorInstancesCount(
|
|
media_addon_id addonid, int32 flavorid);
|
|
|
|
status_t DecrementAddonFlavorInstancesCount(
|
|
media_addon_id addonid, int32 flavorid);
|
|
|
|
status_t ReleaseNodeAll(const media_node& node);
|
|
|
|
status_t SetNodeCreator(media_node_id node, team_id creator);
|
|
|
|
status_t RegisterNode(BMediaNode* node, media_addon_id addonid,
|
|
int32 flavorid);
|
|
|
|
status_t InstantiateDormantNode(media_addon_id addonid,
|
|
int32 flavorid, team_id creator, media_node* out_node);
|
|
|
|
status_t GetDormantFlavorInfo(media_addon_id addonid,
|
|
int32 flavorid, dormant_flavor_info* out_flavor);
|
|
|
|
status_t GetNode(node_type type, media_node* out_node,
|
|
int32* out_input_id = NULL,
|
|
BString* out_input_name = NULL);
|
|
|
|
status_t SetNode(node_type type, const media_node* node,
|
|
const dormant_node_info* info = NULL,
|
|
const media_input *input = NULL);
|
|
|
|
status_t GetAllOutputs(const media_node& node,
|
|
List<media_output>* list);
|
|
|
|
status_t GetAllOutputs(BBufferProducer* node,
|
|
List<media_output>* list);
|
|
|
|
status_t GetAllInputs(const media_node& node,
|
|
List<media_input>* list);
|
|
|
|
status_t GetAllInputs(BBufferConsumer* node,
|
|
List<media_input>* list);
|
|
|
|
status_t PublishOutputs(const media_node& node,
|
|
List<media_output>* list);
|
|
|
|
status_t PublishInputs(const media_node& node,
|
|
List<media_input>* list);
|
|
|
|
BTimeSource* MakeTimeSourceObject(media_node_id timesource_id);
|
|
|
|
status_t BuildConnections();
|
|
|
|
void RegisterLocalNode(BMediaNode* node);
|
|
void UnregisterLocalNode(BMediaNode* node);
|
|
|
|
void EnableLaunchNotification(bool enable,
|
|
bool autoExit);
|
|
|
|
private:
|
|
bool fLaunchNotification;
|
|
bool fAutoExit;
|
|
|
|
friend class BMediaRoster;
|
|
};
|
|
|
|
/* The pointer returned by BMediaRoster::Roster() is always a
|
|
* BMediaRosterEx object pointer. Use this to convert it.
|
|
*/
|
|
inline BMediaRosterEx* MediaRosterEx(BMediaRoster* mediaroster)
|
|
{
|
|
return static_cast<BMediaRosterEx*>(mediaroster);
|
|
}
|
|
|
|
|
|
} } // BPrivate::media
|
|
using namespace BPrivate::media;
|
|
|
|
#endif
|