// Copyright 2009 Dolphin Emulator Project
// Licensed under GPLv2+
// Refer to the license.txt file included.

#pragma once

#include <memory>

#include "AudioCommon/Mixer.h"
#include "AudioCommon/WaveFile.h"
#include "Common/CommonTypes.h"
#include "Common/Logging/Log.h"

class SoundStream
{
protected:
	std::unique_ptr<CMixer> m_mixer;
	bool m_logAudio;
	WaveFileWriter g_wave_writer;
	bool m_muted;

public:
	SoundStream() : m_mixer(new CMixer(48000)), m_logAudio(false), m_muted(false) {}
	virtual ~SoundStream() { }

	static  bool isValid() { return false; }
	CMixer* GetMixer() const { return m_mixer.get(); }
	virtual bool Start() { return false; }
	virtual void SetVolume(int) {}
	virtual void SoundLoop() {}
	virtual void Stop() {}
	virtual void Update() {}
	virtual void Clear(bool mute) { m_muted = mute; }
	bool IsMuted() const { return m_muted; }

	void StartLogAudio(const std::string& filename)
	{
		if (!m_logAudio)
		{
			m_logAudio = true;
			g_wave_writer.Start(filename, m_mixer->GetSampleRate());
			g_wave_writer.SetSkipSilence(false);
			NOTICE_LOG(AUDIO, "Starting Audio logging");
		}
		else
		{
			WARN_LOG(AUDIO, "Audio logging already started");
		}
	}

	void StopLogAudio()
	{
		if (m_logAudio)
		{
			m_logAudio = false;
			g_wave_writer.Stop();
			NOTICE_LOG(AUDIO, "Stopping Audio logging");
		}
		else
		{
			WARN_LOG(AUDIO, "Audio logging already stopped");
		}
	}
};