Max Kellermann
|
71928b473e
|
db/upnp/Discovery: unlock mutex before deleting DiscoveredTask
|
2014-01-22 21:48:33 +01:00 |
|
Max Kellermann
|
a0bee9fa0a
|
db/upnp/Discovery: eliminate two strlen() calls
|
2014-01-22 21:47:34 +01:00 |
|
Max Kellermann
|
0defd927f3
|
db/upnp: use std::list instead of std::set for SearchCapabilities
Reduce bloat. We never used the set lookup.
|
2014-01-22 21:41:05 +01:00 |
|
Max Kellermann
|
6c41e8f63f
|
db/upnp: check offset<total at end of loop
|
2014-01-22 21:37:21 +01:00 |
|
Max Kellermann
|
fa67a4e956
|
db/upnp: break when zero objects have been returned
|
2014-01-22 21:37:19 +01:00 |
|
Max Kellermann
|
bf9352fb26
|
db/upnp: free responses manually
|
2014-01-22 21:33:54 +01:00 |
|
Max Kellermann
|
7573d4e1ba
|
db/upnp: break when count==0
Make this non-fatal. Just stop reading more objects.
|
2014-01-22 21:33:19 +01:00 |
|
Max Kellermann
|
bfb483898f
|
db/upnp: use ParseUnsigned() instead of atoi()
|
2014-01-22 21:11:04 +01:00 |
|
Max Kellermann
|
f363788d76
|
db/upnp: pass unsigned integers to readDirSlice()
|
2014-01-22 20:57:10 +01:00 |
|
Max Kellermann
|
714056f157
|
db/upnp: inline ContentDirectoryService::readDirSlice()
|
2014-01-22 20:42:36 +01:00 |
|
Max Kellermann
|
1abc96fa27
|
db/upnp: remove special case for "*"
Passing this to csvToStrings() will do the same.
|
2014-01-22 20:37:17 +01:00 |
|
Max Kellermann
|
0fa98479ad
|
db/upnp: obtain char* from ixmlwrap::getFirstElementValue()
Fixes crash when there's no SearchCaps element.
|
2014-01-22 20:26:33 +01:00 |
|
Max Kellermann
|
02f2171010
|
db/upnp/Util: pass char* to csvToStrings()
|
2014-01-22 20:24:55 +01:00 |
|
Max Kellermann
|
a5e7d0a90f
|
db/upnp: require an empty input capability set
|
2014-01-22 20:21:01 +01:00 |
|
Max Kellermann
|
9fb5134f64
|
db/upnp/Util: handle absolute URI paths properly in caturl()
Fixes problems with some UPnP servers.
|
2014-01-22 19:38:07 +01:00 |
|
Max Kellermann
|
9aeb23dfe9
|
db/upnp/Util: use string::back(), string::front()
|
2014-01-22 19:38:02 +01:00 |
|
Max Kellermann
|
e59d8c9378
|
db/upnp/Device: clear the "value" pointer on unknown element
Avoid appending to an obsolete string object.
|
2014-01-22 19:38:02 +01:00 |
|
Max Kellermann
|
0616667688
|
Main: glue_mapper_init() returns true if GetUserMusicDir() fails
Not a fatal error. Fixes assertion failure.
|
2014-01-22 16:28:19 +01:00 |
|
Max Kellermann
|
9747cc9e58
|
db/upnp/Device: replace std::vector with a std::string pointer
|
2014-01-22 09:55:51 +01:00 |
|
Max Kellermann
|
7b44dea4b1
|
db/upnp/Device: remove unused UPnPService attributes
|
2014-01-22 09:51:26 +01:00 |
|
Max Kellermann
|
18aea922e9
|
db/upnp/Directory: "emplace" items into the vector
|
2014-01-22 09:43:49 +01:00 |
|
Max Kellermann
|
7d194aceb6
|
db/upnp/Device: emplace/move the UPnPService into the vector
Reduce overhead.
|
2014-01-22 09:42:46 +01:00 |
|
Max Kellermann
|
2722b8a3df
|
db/upnp/Util: "emplace" items into the list
Reduce overhead.
|
2014-01-22 09:40:38 +01:00 |
|
Max Kellermann
|
fd754ff8f8
|
db/upnp/Directory: replace std::vector with a simple enum
Reduce bloat.
|
2014-01-22 09:32:11 +01:00 |
|
Max Kellermann
|
b7738e7af3
|
db/upnp/Directory: join all CDATA nodes for tag values
Expat can call CharacterData() multiple times if the CDATA contains
entity references. We need to collect all of them in one large
string.
|
2014-01-22 08:44:35 +01:00 |
|
Max Kellermann
|
99bebabac9
|
db/upnp/Directory: make "m_dir" private
|
2014-01-22 08:44:20 +01:00 |
|
Max Kellermann
|
0ed48b364a
|
db/upnp: merge duplicate branches in Namei()
|
2014-01-21 23:42:02 +01:00 |
|
Max Kellermann
|
b38b8b9c18
|
db/upnp: simplify Namei()
|
2014-01-21 23:37:27 +01:00 |
|
Max Kellermann
|
5434856136
|
db/upnp: use std::list instead of std::vector
Reduce overhead.
|
2014-01-21 23:33:28 +01:00 |
|
Max Kellermann
|
aa1eb2f40d
|
db/upnp: use iterator in Namei()
|
2014-01-21 23:32:42 +01:00 |
|
Max Kellermann
|
7260d7883c
|
db/upnp: move "objid" declaration down
Don't allocate the object when it's not needed.
|
2014-01-21 23:10:30 +01:00 |
|
Max Kellermann
|
154250f551
|
db/upnp: eliminate redundant Namei() parameter "oobjid"
The caller should better obtain the object id from the returned
UPnPDirObject instance.
|
2014-01-21 23:07:33 +01:00 |
|
Max Kellermann
|
3e4fb92cfb
|
db/upnp: remove redundant objid.empty() check from VisitServer()
If Namei() succeeds, the object id is guaranteed to be set.
|
2014-01-21 23:07:06 +01:00 |
|
Max Kellermann
|
0da713e278
|
db/upnp: use std::move() to extract server name
Reduce runtime overhead.
|
2014-01-21 22:57:54 +01:00 |
|
Max Kellermann
|
94cb1545b3
|
db/upnp: use vector::front() instead of [0]
|
2014-01-21 22:57:16 +01:00 |
|
Max Kellermann
|
411527a240
|
db/upnp: don't use stringToTokens() in ParseDuration()
Reduce bloat.
|
2014-01-21 22:52:12 +01:00 |
|
Max Kellermann
|
7777057d35
|
db/upnp: don't construct redundant empty vector<string> in Visit()
We know already that vpath is empty, let's use this instance.
|
2014-01-21 22:47:57 +01:00 |
|
Max Kellermann
|
dc5ef9ad01
|
db/upnp: simplify GetSong()
|
2014-01-21 22:43:04 +01:00 |
|
Max Kellermann
|
7471f65d95
|
LightSong: add attribute "real_uri"
The UPnP database plugin can now show relative song URIs for remote
songs.
|
2014-01-21 21:08:11 +01:00 |
|
Max Kellermann
|
5d4b450c52
|
DetachedSong: add attribute "real_uri"
Prepare for UPnP songs that retain there database identity.
|
2014-01-21 21:06:56 +01:00 |
|
Max Kellermann
|
483b1f51c9
|
DetachedSong: remove parameter names from "defaulted" constructors
Suppresses gcc warnings.
|
2014-01-21 21:06:56 +01:00 |
|
Max Kellermann
|
ecac7a629e
|
db/upnp: fix empty song URI
Fall back to UPnPDirObject::url if there is no override.
|
2014-01-21 21:02:21 +01:00 |
|
Max Kellermann
|
21209ff46b
|
DetachedSong: use "default" copy/move constructors
Remove unnecessary explicit code.
|
2014-01-21 20:38:13 +01:00 |
|
Chase Geigle
|
716bdc36fd
|
pcm/SoxrResampler: Add configurable quality levels
|
2014-01-21 20:35:26 +01:00 |
|
Max Kellermann
|
4f120f3714
|
PlaylistSong: modify the given song object in-place
Reduce bloat.
|
2014-01-21 00:28:37 +01:00 |
|
Max Kellermann
|
dd20a3ce7e
|
test: add unit test for playlist_check_translate_song()
|
2014-01-21 00:28:34 +01:00 |
|
Max Kellermann
|
c727c86245
|
PlaylistSong: remove redundant "secure" check
This has been verified already in the caller.
|
2014-01-21 00:28:32 +01:00 |
|
Max Kellermann
|
82b4ec22be
|
PlaylistSong: recurse after applying base_uri
Allows applying map_to_relative_path() with base_uri.
|
2014-01-20 23:47:43 +01:00 |
|
Max Kellermann
|
501f1e6de0
|
PlaylistSong: remove the IsInDatabase() check
No caller passes a database song to this function, but if he does,
this check doesn't make sense.
|
2014-01-20 23:32:03 +01:00 |
|
Max Kellermann
|
414d5b648c
|
PlaylistSong: don't map relative URI to absolute path
This didn't make sense.
|
2014-01-20 23:31:08 +01:00 |
|