diff --git a/OpenHome/Network.cpp b/OpenHome/Network.cpp index d6b1828..caeb252 100644 --- a/OpenHome/Network.cpp +++ b/OpenHome/Network.cpp @@ -22,7 +22,7 @@ Network::Network(TUint /*aMaxCacheEntries*/, ILog&/* aLog*/) { iWatchableThread = new WatchableThread(*this); //iCache = new IdCache(aMaxCacheEntries); - //iTagManager = new TagManager(); + iTagManager = new OpenHome::Av::TagManager(); //iEventSupervisor = new EventSupervisor(iWatchableThread); } @@ -35,7 +35,7 @@ Network::Network(IWatchableThread& aWatchableThread, TUint /*aMaxCacheEntries*/, ,iWatchableThread(&aWatchableThread) { //iCache = new IdCache(aMaxCacheEntries); - //iTagManager = new TagManager(); + iTagManager = new OpenHome::Av::TagManager(); //iEventSupervisor = new EventSupervisor(iWatchableThread); } diff --git a/OpenHome/Network.h b/OpenHome/Network.h index 08a53b4..ff488bd 100644 --- a/OpenHome/Network.h +++ b/OpenHome/Network.h @@ -22,8 +22,9 @@ namespace Av class IIdCache; -class ITagManager; +//class ITagManager; class IEventSupervisor; +//class TagManager; diff --git a/OpenHome/Tag.h b/OpenHome/Tag.h index 6a4ee4d..caab9b8 100644 --- a/OpenHome/Tag.h +++ b/OpenHome/Tag.h @@ -145,22 +145,6 @@ class ITagRealmAudio : public ITagRealm } */ -class ITagManager -{ -public: - virtual TUint MaxSystemTagId() = 0; - virtual ITag* Tag(TUint aId) = 0; - //ITagRealm this[TagRealm aRealm]) = 0; - virtual ITagRealm& Realm(ETagRealm aRealm) = 0; - - //virtual ITagRealmSystem System() = 0; - //virtual ITagRealmGlobal Global() = 0; - virtual ITagRealmAudio& Audio() = 0; - //virtual ITagRealmVideo Video() = 0; - //virtual ITagRealmImage Image() = 0; - //virtual ITagRealmPlaylist Playlist() = 0; - //virtual ITagRealmContainer Container() = 0; -}; /////////////////////////////////////////////// @@ -616,6 +600,7 @@ class TagRealmAudio : public TagRealmBase, public ITagRealmAudio Dictionary iRealms; ITagRealmSystem iSystem; + ITagRealmGlobal iGlobal; ITagRealmAudio iAudio; ITagRealmVideo iVideo; diff --git a/OpenHome/TagManager.cpp b/OpenHome/TagManager.cpp index 9a0f3f3..fc49f22 100644 --- a/OpenHome/TagManager.cpp +++ b/OpenHome/TagManager.cpp @@ -128,6 +128,32 @@ IMediaMetadata* TagManager::FromDidlLite(const Brx& aMetadata) } + +TUint TagManager::MaxSystemTagId() +{ + return(kMaxSystemTagId); +} + + +ITag* TagManager::Tag(TUint aId) +{ + return(iTags[aId]); +} + + +ITagRealm& TagManager::Realm(ETagRealm aRealm) +{ + return(*(iRealms[aRealm])); +} + + +ITagRealmAudio& TagManager::Audio() +{ + return (*iAudio); +} + + + //////////////////////////////////////////////////////// diff --git a/OpenHome/TagManager.h b/OpenHome/TagManager.h index 7457daa..4d90c42 100644 --- a/OpenHome/TagManager.h +++ b/OpenHome/TagManager.h @@ -6,6 +6,7 @@ #include #include #include +#include #include #include @@ -16,14 +17,55 @@ namespace OpenHome namespace Av { -///////////////////////////////////////////////// -class ITag + +class ITagManager +{ +public: + virtual TUint MaxSystemTagId() = 0; + virtual ITag* Tag(TUint aId) = 0; + //ITagRealm this[TagRealm aRealm]) = 0; + virtual ITagRealm& Realm(ETagRealm aRealm) = 0; + + //virtual ITagRealmSystem System() = 0; + //virtual ITagRealmGlobal Global() = 0; + virtual ITagRealmAudio& Audio() = 0; + //virtual ITagRealmVideo Video() = 0; + //virtual ITagRealmImage Image() = 0; + //virtual ITagRealmPlaylist Playlist() = 0; + //virtual ITagRealmContainer Container() = 0; + + virtual IMediaMetadata* FromDidlLite(const Brx& aMetadata) = 0; +}; + +////////////////////////////////////////////////////////////////////// + +class TagManager : public ITagManager//, public ITagManagerInitialiser { +private: + static const TUint kMaxSystemTagId = 49; + +public: + virtual IMediaMetadata* FromDidlLite(const Brx& aMetadata); + virtual TUint MaxSystemTagId(); + virtual ITag* Tag(TUint aId); + virtual ITagRealm& Realm(ETagRealm aRealm); + virtual ITagRealmAudio& Audio(); +private: + std::map iTags; + std::map iRealms; + + //ITagRealmSystem* iSystem; + ITagRealmGlobal* iGlobal; + ITagRealmAudio* iAudio; + //ITagRealmVideo* iVideo; + //ITagRealmImage* iImage; + //ITagRealmPlaylist* iPlaylist; + //ITagRealmContainer* iContainer; }; -///////////////////////////////////////// +///////////////////////////////////////////////// class IMediaValue { @@ -107,33 +149,6 @@ class MediaMetadata : public MediaDictionary//, public IMediaMetadata /////////////////////////////////////////////////// -class ITagManager -{ -public: -// TUint MaxSystemTagId() = 0; -// ITag* Tag(TUint aId) = 0; - //ITag this[uint aId]() = 0; - //ITagRealm this[TagRealm aRealm]() = 0; -// ITagRealm& TagRealm(ETagRealm aRealm) = 0; - //ITagRealmSystem System() = 0; -// ITagRealmGlobal& Global() = 0; -// ITagRealmAudio& Audio() = 0; - //ITagRealmVideo Video() = 0; - //ITagRealmImage Image() = 0; - //ITagRealmPlaylist Playlist() = 0; - //ITagRealmContainer Container() = 0; - - virtual IMediaMetadata* FromDidlLite(const Brx& aMetadata); -}; - - - -class TagManager : public ITagManager//, public ITagManagerInitialiser -{ -public: - virtual IMediaMetadata* FromDidlLite(const Brx& aMetadata); -}; - } // Av } // OpenHome diff --git a/OpenHome/Tests/TestTopologym.cpp b/OpenHome/Tests/TestTopologym.cpp index 9add697..2555a4d 100644 --- a/OpenHome/Tests/TestTopologym.cpp +++ b/OpenHome/Tests/TestTopologym.cpp @@ -156,7 +156,6 @@ void SuiteTopologym::Test1() InjectorMock* mockInjector = new InjectorMock(*network, Brx::Empty(), *log); mocker->Add(Brn("network"), *mockInjector); - Topology1* topology1 = new Topology1(network, *log); Topology2* topology2 = new Topology2(topology1, *log); iTopologym = new Topologym(topology2, *log); @@ -180,58 +179,6 @@ void SuiteTopologym::Test1() //topology1->Dispose(); //mockInjector->Dispose(); //network->Dispose(); - - -/* - Mockable mocker = new Mockable(); - Log log = new Log(new LogConsole()); - Network network = new Network(50, log); - DeviceInjectorMock mockInjector = new DeviceInjectorMock(network, Path.GetDirectoryName(System.Reflection.Assembly.GetEntryAssembly().Location), log); - mocker.Add("network", mockInjector); - - - - Topology1 topology1 = new Topology1(network, log); - Topology2 topology2 = new Topology2(topology1, log); - Topologym topologym = new Topologym(topology2, log); - - MockableScriptRunner runner = new MockableScriptRunner(); - - RoomWatcher watcher = new RoomWatcher(runner); - - network.Schedule(() => - { - topologym.Groups.AddWatcher(watcher); - }); - - try - { - runner.Run(network.Wait, new StreamReader(args[0]), mocker); - } - catch (MockableScriptRunner.AssertError) - { - return 1; - } - - network.Execute(() => - { - topologym.Groups.RemoveWatcher(watcher); - watcher.Dispose(); - }); - - topologym.Dispose(); - - topology2.Dispose(); - - topology1.Dispose(); - - mockInjector.Dispose(); - - network.Dispose(); - - -*/ - } @@ -254,7 +201,7 @@ void SuiteTopologym::ScheduleCallback(void* aObj) //////////////////////////////////////////// -void TestTopologym(Environment& aEnv, const std::vector& aArgss) +void TestTopologym(Environment& aEnv, const std::vector& aArgs) { TestScriptHttpReader reader(aEnv, aArgs); Runner runner("Topologym tests\n"); diff --git a/OpenHome/Topologym.cpp b/OpenHome/Topologym.cpp index f309076..9b54f3b 100644 --- a/OpenHome/Topologym.cpp +++ b/OpenHome/Topologym.cpp @@ -364,7 +364,7 @@ void SenderWatcher::Dispose() Brn SenderWatcher::Uri() { - DisposeLock lock(*iDisposeHandler); + DisposeLock lock(*waf tests); return iMetadata->Uri(); } diff --git a/oncommit.test b/oncommit.test index 5a8d137..469c1a7 100644 --- a/oncommit.test +++ b/oncommit.test @@ -5,11 +5,11 @@ suiteRunner = MakeSuiteRunner(context) # testharness honours a '#' within this string :) tests = ''' - TestWatchableThread - TestWatchable + #TestWatchableThread + #TestWatchable TestTopology1 -s {ws_hostname} -p {ws_port} --path Topology1TestScript.txt - TestTopology2 -s {ws_hostname} -p {ws_port} --path Topology2TestScript.txt - TestTopologym -s {ws_hostname} -p {ws_port} --path TopologymTestScript.txt + #TestTopology2 -s {ws_hostname} -p {ws_port} --path Topology2TestScript.txt + #TestTopologym -s {ws_hostname} -p {ws_port} --path TopologymTestScript.txt '''