/*
-Copyright (c) 2005-2011, John Hurst
+Copyright (c) 2005-2018, John Hurst
All rights reserved.
Redistribution and use in source and binary forms, with or without
const char* EncodeString(char* str_buf, ui32_t buf_len) const;
bool operator==(const UL& rhs) const;
bool MatchIgnoreStream(const UL& rhs) const;
- bool ExactMatch(const UL& rhs) const;
+ bool MatchExact(const UL& rhs) const;
};
// UMID
//
class Dictionary
{
- std::map<ASDCP::UL, ui32_t> m_md_lookup;
- std::map<ui32_t, ASDCP::UL> m_md_rev_lookup;
- MDDEntry m_MDD_Table[(ui32_t)ASDCP::MDD_Max];
+ std::map<ASDCP::UL, ui32_t> m_md_lookup;
+ std::map<std::string, ui32_t> m_md_sym_lookup;
+ std::map<ui32_t, ASDCP::UL> m_md_rev_lookup;
ASDCP_NO_COPY_CONSTRUCT(Dictionary);
public:
+ MDDEntry m_MDD_Table[(ui32_t)ASDCP::MDD_Max];
+
Dictionary();
~Dictionary();
- // bool operator==(const Dictionary& rhs) const { return this == &rhs; }
-
void Init();
bool AddEntry(const MDDEntry& Entry, ui32_t index);
bool DeleteEntry(ui32_t index);
- const MDDEntry* FindUL(const byte_t*) const;
+ const MDDEntry* FindULAnyVersion(const byte_t*) const;
+ const MDDEntry* FindULExact(const byte_t*) const;
+ const MDDEntry* FindSymbol(const std::string&) const;
const MDDEntry& Type(MDD_t type_id) const;
+ MDDEntry& MutableType(MDD_t type_id);
inline const byte_t* ul(MDD_t type_id) const {
return Type(type_id).ul;
};
+ const Dictionary& AtmosSMPTEDict();
const Dictionary& DefaultSMPTEDict();
const Dictionary& DefaultInteropDict();
const Dictionary& DefaultCompositeDict();
+ void default_md_object_init();
//
class IPrimerLookup
const byte_t* m_KeyStart;
ui32_t m_KLLength;
const byte_t* m_ValueStart;
- ui32_t m_ValueLength;
+ ui64_t m_ValueLength;
UL m_UL;
public:
KLVPacket() : m_KeyStart(0), m_KLLength(0), m_ValueStart(0), m_ValueLength(0) {}
virtual ~KLVPacket() {}
- ui32_t PacketLength() {
+ inline ui64_t PacketLength() {
return m_KLLength + m_ValueLength;
}
- ui32_t ValueLength() {
+ inline ui64_t ValueLength() {
return m_ValueLength;
}
- ui32_t KLLength() {
+ inline ui32_t KLLength() {
return m_KLLength;
}
virtual Result_t InitFromBuffer(const byte_t*, ui32_t);
virtual Result_t InitFromBuffer(const byte_t*, ui32_t, const UL& label);
virtual Result_t WriteKLToBuffer(ASDCP::FrameBuffer&, const UL& label, ui32_t length);
- virtual Result_t WriteKLToBuffer(ASDCP::FrameBuffer& fb, ui32_t length) {
+
+ virtual Result_t WriteKLToBuffer(ASDCP::FrameBuffer& fb, ui32_t length)
+ {
if ( ! m_UL.HasValue() )
- return RESULT_STATE;
- return WriteKLToBuffer(fb, m_UL, length); }
+ {
+ return RESULT_STATE;
+ }
+
+ return WriteKLToBuffer(fb, m_UL, length);
+ }
virtual void Dump(FILE*, const Dictionary& Dict, bool show_value);
};
{
ASDCP_NO_COPY_CONSTRUCT(KLVFilePacket);
- protected:
+ public:
ASDCP::FrameBuffer m_Buffer;
- public:
KLVFilePacket() {}
virtual ~KLVFilePacket() {}