Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
* | | fs/FileInfo: use GetFileAttributesEx() on WIN32 | Max Kellermann | 2015-02-28 | 1 | -1/+49 | |
| | | ||||||
* | | fs/FileSystem: remove unused WIN32 port of StatFile() | Max Kellermann | 2015-02-28 | 1 | -5/+4 | |
| | | ||||||
* | | fs/FileInfo: new library providing GetFileInfo() | Max Kellermann | 2015-02-28 | 10 | -70/+170 | |
| | | | | | | | | Replaces StatFile(), with a portable data object. | |||||
* | | FileCommands: skip special files completely | Max Kellermann | 2015-02-28 | 1 | -0/+2 | |
| | | | | | | | | | | Previously, MPD printed the time stamp without printing the file name. That made no sense. | |||||
* | | storage/FileInfo: rename to StorageFileInfo | Max Kellermann | 2015-02-28 | 18 | -82/+91 | |
| | | ||||||
* | | fs/Path: make IsAbsolute() const | Max Kellermann | 2015-02-28 | 2 | -2/+2 | |
| | | ||||||
* | | fs/FileSystem: use GetFileAttributes() on WIN32 if possible | Max Kellermann | 2015-02-27 | 1 | -2/+20 | |
| | | ||||||
* | | fs/FileSystem: merge CheckAccess() into PathExists() | Max Kellermann | 2015-02-27 | 2 | -17/+7 | |
| | | | | | | | | | | PathExists() should better do what CheckAccess() does, and CheckAccess() doesn't do what its name implies. | |||||
* | | fs/DirectoryReader: use FindFirstFile(), FindNextFile() on WIN32 | Max Kellermann | 2015-02-26 | 1 | -0/+85 | |
| | | ||||||
* | | fs/Traits: add constant CURRENT_DIRECTORY | Max Kellermann | 2015-02-25 | 3 | -2/+7 | |
| | | ||||||
* | | fs/AllocatedPath: add nullptr_t constructor | Max Kellermann | 2015-02-25 | 1 | -1/+3 | |
| | | ||||||
* | | fs/{Allocated,}Path,Charset: use PathTraitsFS typedefs | Max Kellermann | 2015-02-25 | 6 | -21/+19 | |
| | | ||||||
* | | fs/FileSystem: remove unused FOpenModes | Max Kellermann | 2015-02-25 | 1 | -20/+0 | |
| | | ||||||
* | | fs/io/File{Reader,OutputStream}: convert path to UTF-8 for error message | Max Kellermann | 2015-02-25 | 2 | -7/+18 | |
| | | ||||||
* | | db/ExcludeList: use the TextFile class instead of stdio.h | Max Kellermann | 2015-02-25 | 1 | -17/+24 | |
| | | ||||||
* | | util/DynamicFifoBuffer: adjust include guard | Max Kellermann | 2015-02-16 | 1 | -3/+3 | |
| | | ||||||
* | | net/StaticSocketAdress: new class wrapping struct sockaddr_storage | Max Kellermann | 2015-02-13 | 3 | -7/+203 | |
| | | ||||||
* | | system/ByteOrder: use GCC built-ins if available | Max Kellermann | 2015-02-12 | 1 | -6/+38 | |
| | | ||||||
* | | net/Resolver: relax size check in LocalAddressToString() | Max Kellermann | 2015-02-10 | 1 | -2/+20 | |
| | | | | | | | | Handles abstract sockets on Linux. | |||||
* | | net/Resolver: move code to LocalAddressToString() | Max Kellermann | 2015-02-10 | 1 | -8/+16 | |
| | | ||||||
* | | net/SocketAddress: light wrapper for struct sockaddr | Max Kellermann | 2015-02-10 | 13 | -66/+198 | |
| | | ||||||
* | | system/{Resolver,Socket{Error,Util}}: move to new library libnet.a | Max Kellermann | 2015-02-10 | 12 | -9/+9 | |
| | | ||||||
* | | Listen: add "override" | Max Kellermann | 2015-02-10 | 1 | -2/+2 | |
| | | ||||||
* | | event/ServerSocket: remove obsolete macro DEFAULT_PORT | Max Kellermann | 2015-02-10 | 1 | -2/+0 | |
| | | ||||||
* | | event/ServerSocket: remove obsolete typedef | Max Kellermann | 2015-02-10 | 1 | -6/+0 | |
| | | ||||||
* | | fs/io/FileOutputStream: use CREATE_ALWAYS instead of TRUNCATE_EXISTING | Max Kellermann | 2015-02-10 | 1 | -1/+1 | |
| | | | | | | | | | | Fixes yet another breakage of creating the database+state file on Windows. | |||||
* | | command/{Queue,File}Commands: drop "file:///" prefix for absolute paths | Max Kellermann | 2015-02-09 | 2 | -13/+15 | |
| | | | | | | | | | | | | | | | | | | | | | | | | Requiring this prefix makes the client's intention very clear, but it was too hard to understand why this prefix was needed. Initially, my intention was to differentiate from broken clients which prefix relate URIs with a slash; once MPD allowed that. In the past few years however, MPD has disallowed that, and there was no significant breakage (except for the "add /" special case which some clients apparently still do). So I figure it's about time to define that an URI that begins with a slash points to an arbitrary file on the file system. | |||||
* | | fs/Charset: convert #ifdef to regular "if" | Max Kellermann | 2015-02-09 | 1 | -3/+5 | |
| | | ||||||
* | | fs/Charset: change FixSeparators() API to use std::string&& | Max Kellermann | 2015-02-08 | 1 | -11/+6 | |
| | | ||||||
* | | Listen: remove C-style "void" | Max Kellermann | 2015-02-07 | 1 | -1/+2 | |
| | | ||||||
* | | Merge tag 'v0.19.9' | Max Kellermann | 2015-02-06 | 2 | -1/+12 | |
|\| | ||||||
| * | fs/io/FileOutputStream: don't auto-delete file on WIN32 | Max Kellermann | 2015-02-06 | 1 | -0/+2 | |
| | | | | | | | | | | | | | | | | | | The file handle is never reset to INVALID_HANDLE_VALUE, and thus the destructor will assume the operation shall be cancelled and will delete the temporary file. This was a major breakage for saving the database file and the state file. | |||||
| * | TagBuilder: allow adding duplicate tag types in Complement() | Max Kellermann | 2015-02-06 | 1 | -1/+10 | |
| | | | | | | | | | | | | | | | | | | | | Build a table of pre-existing tag types before adding new items. The old way would check HasType() each time, which would return true after the first instance of that tag type had been added, preventing duplicate tag types to be merged. This broke duplicate tag types loaded from the state file, because this code path uses TagBuilder::Complement(). | |||||
* | | SongPrint: let CPP concatenate string literals | Max Kellermann | 2015-02-06 | 1 | -2/+2 | |
| | | ||||||
* | | tag/Rva2: convert pointers to references | Max Kellermann | 2015-02-04 | 1 | -9/+9 | |
| | | ||||||
* | | tag/Rva2: rename struct rva2_data to CamelCase | Max Kellermann | 2015-02-04 | 1 | -6/+6 | |
| | | ||||||
* | | tag/Rva2: make enum rva2_channel strictly-typed | Max Kellermann | 2015-02-04 | 1 | -12/+12 | |
| | | ||||||
* | | lib/upnp/Discovery: remove locking from ExpireDevices() | Max Kellermann | 2015-02-03 | 2 | -7/+6 | |
| | | ||||||
* | | lib/upnp/Discovery: apply naming convention | Max Kellermann | 2015-02-02 | 5 | -42/+42 | |
| | | ||||||
* | | output/sles: use AudioOutputWrapper::Create() | Max Kellermann | 2015-02-01 | 1 | -4/+6 | |
| | | ||||||
* | | DecoderThread: make variables more local | Max Kellermann | 2015-01-31 | 1 | -6/+3 | |
| | | ||||||
* | | decoder/sndfile, ...: update API documentation | Max Kellermann | 2015-01-31 | 9 | -13/+13 | |
| | | ||||||
* | | decoder/DsdLib: fix integer overflow in ID3 size calculation | Max Kellermann | 2015-01-30 | 1 | -2/+4 | |
| | | ||||||
* | | decoder/DsdLib: check size before seeking | Max Kellermann | 2015-01-30 | 1 | -4/+3 | |
| | | ||||||
* | | decoder/DsdLib: don't use InputStream::GetOffset() after seeking | Max Kellermann | 2015-01-30 | 1 | -3/+2 | |
| | | | | | | | | We already know the offset. | |||||
* | | decoder/DsdLib: pass offset_type t dsdlib_tag_id3() | Max Kellermann | 2015-01-30 | 2 | -4/+2 | |
| | | ||||||
* | | Merge branch 'v0.19.x' | Max Kellermann | 2015-01-29 | 3 | -15/+14 | |
|\| | ||||||
| * | db/update/Walk: use std::unique_ptr instead of std::auto_ptr | Max Kellermann | 2015-01-29 | 1 | -1/+1 | |
| | | | | | | | | | | std::auto_ptr is deprecated, and std::unique_ptr is much better anyway. | |||||
| * | Avoid integer overflow in MonotonicClock{S,MS,US} | PHO | 2015-01-29 | 1 | -6/+6 | |
| | | | | | | | | | | This is Darwin specific: the previous implementation was causing an integer overflow when base.numer is very large. On PPC Darwin, the timebase info is 1000000000/33330116 and this is too large for integer arithmetic. | |||||
| * | decoder/DsdLib: use new[] to allocate the ID3 buffer | Max Kellermann | 2015-01-29 | 1 | -3/+5 | |
| | | | | | | | | | | Don't abort the process if there's not enough memory. This buffer is not important and can be large. |