mirror of
https://review.haiku-os.org/haiku
synced 2025-01-27 00:34:50 +01:00
0cc5ecb8ca
* It's very important to use a negative value to identify non valid or uninitialized connections. Additionally, it's preferred to don't interfere with media_kit types as long as the framework use it in the backend.
108 lines
2.1 KiB
C++
108 lines
2.1 KiB
C++
/*
|
|
* Copyright 2015, Haiku, Inc. All rights reserved.
|
|
* Distributed under the terms of the MIT License.
|
|
*/
|
|
|
|
#ifndef _MEDIA_CLIENT_DEFS_H
|
|
#define _MEDIA_CLIENT_DEFS_H
|
|
|
|
#include <MediaDefs.h>
|
|
#include <MediaNode.h>
|
|
|
|
|
|
namespace BPrivate { namespace media {
|
|
|
|
|
|
typedef int64 media_client_id;
|
|
typedef int64 media_connection_id;
|
|
|
|
typedef uint64 media_client_kinds;
|
|
typedef uint64 media_connection_kinds;
|
|
|
|
|
|
enum media_client_kind {
|
|
// The client can receive media data.
|
|
B_MEDIA_RECORDER = 0x000000001,
|
|
// The client can send media data to another client.
|
|
B_MEDIA_PLAYER = 0x000000002,
|
|
// The client specify a control GUI which can be used to configure it.
|
|
B_MEDIA_CONTROLLABLE = 0x000000004
|
|
};
|
|
|
|
enum media_connection_kind {
|
|
B_MEDIA_INPUT = 0,
|
|
B_MEDIA_OUTPUT = 1
|
|
};
|
|
|
|
|
|
typedef struct media_client {
|
|
media_client_id Id() const;
|
|
media_client_kinds Kinds() const;
|
|
|
|
BMessage* ToMessage();
|
|
|
|
private:
|
|
media_client_kinds kinds;
|
|
|
|
media_node node;
|
|
uint32 padding[16];
|
|
|
|
friend class BMediaClient;
|
|
friend class BMediaConnection;
|
|
friend class media_connection;
|
|
} media_client;
|
|
|
|
|
|
typedef struct media_connection {
|
|
media_connection_id Id() const;
|
|
media_connection_kinds Kinds() const;
|
|
|
|
const media_client& Client() const;
|
|
|
|
const char* Name() const;
|
|
|
|
bool IsInput() const;
|
|
bool IsOutput() const;
|
|
|
|
BMessage* ToMessage() const;
|
|
|
|
private:
|
|
media_input _MediaInput() const;
|
|
media_output _MediaOutput() const;
|
|
|
|
const media_source& _Source() const;
|
|
const media_destination& _Destination() const;
|
|
|
|
media_node _Node() const;
|
|
media_node _RemoteNode() const;
|
|
|
|
media_connection_id id;
|
|
|
|
media_client client;
|
|
|
|
media_node remote_node;
|
|
|
|
media_source source;
|
|
media_destination destination;
|
|
media_format format;
|
|
char name[B_MEDIA_NAME_LENGTH];
|
|
|
|
media_connection_kinds kinds;
|
|
uint32 padding[16];
|
|
|
|
friend class BMediaClient;
|
|
friend class BMediaClientNode;
|
|
friend class BMediaConnection;
|
|
friend class BMediaInput;
|
|
friend class BMediaOutput;
|
|
} media_connection;
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
using namespace BPrivate::media;
|
|
|
|
#endif
|