mirror of
https://github.com/ZetaKebab/MpcNET.git
synced 2025-01-14 22:18:43 +00:00
Consume command
This commit is contained in:
parent
7a0a28dbe9
commit
133571023e
64
Sources/MpcNET/Commands/Playback/ConsumeCommand.cs
Normal file
64
Sources/MpcNET/Commands/Playback/ConsumeCommand.cs
Normal file
@ -0,0 +1,64 @@
|
||||
// --------------------------------------------------------------------------------------------------------------------
|
||||
// <copyright file="ConsumeCommand.cs" company="MpcNET">
|
||||
// Copyright (c) MpcNET. All rights reserved.
|
||||
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
||||
// </copyright>
|
||||
// --------------------------------------------------------------------------------------------------------------------
|
||||
namespace MpcNET.Commands.Playback
|
||||
{
|
||||
using System.Collections.Generic;
|
||||
|
||||
/// <summary>
|
||||
/// Command to set consume state.
|
||||
/// Sets consume state to STATE, STATE should be 0 or 1. When consume is activated, each song played is removed from playlist.
|
||||
/// https://mpd.readthedocs.io/en/stable/protocol.html#playback-options
|
||||
/// </summary>
|
||||
public class ConsumeCommand : IMpcCommand<string>
|
||||
{
|
||||
private readonly string single;
|
||||
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="ConsumeCommand" /> class.
|
||||
/// </summary>
|
||||
/// <param name="single">if set to <c>true</c> [consume].</param>
|
||||
public ConsumeCommand(bool single)
|
||||
{
|
||||
this.single = single ? "1" : "0";
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Initializes a new instance of the <see cref="ConsumeCommand"/> class.
|
||||
/// </summary>
|
||||
public ConsumeCommand()
|
||||
{
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Serializes the command.
|
||||
/// </summary>
|
||||
/// <returns>
|
||||
/// The serialize command.
|
||||
/// </returns>
|
||||
public string Serialize()
|
||||
{
|
||||
if (this.single == null)
|
||||
{
|
||||
return string.Join(" ", "consume");
|
||||
}
|
||||
|
||||
return string.Join(" ", "consume", this.single);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Deserializes the specified response text pairs.
|
||||
/// </summary>
|
||||
/// <param name="response">The response.</param>
|
||||
/// <returns>
|
||||
/// The deserialized response.
|
||||
/// </returns>
|
||||
public string Deserialize(SerializedResponse response)
|
||||
{
|
||||
return string.Join(", ", response.ResponseValues);
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user