aboutsummaryrefslogblamecommitdiffstats
path: root/src/base/stats.hpp
blob: b3068024dab3d0ab4bf85f1c507f0c188ebe319a (plain) (tree)






































































                                                                                
                                                        








































                                                                                            
                                   

                                          

                                        




                                           
                                     

                                                  

                                          




                                     
                                                                          












                                                         
                                   



                                             
                                                                                  












                                                          

                                        



                                             
                                                                                                       












                                                           
                                        



                                             
                                                                                     










                                                           
/*
 * UltraStar Deluxe - Karaoke Game
 *
 * UltraStar Deluxe is the legal property of its developers, whose names
 * are too numerous to list here. Please refer to the COPYRIGHT
 * file distributed with this source distribution.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; see the file COPYING. If not, write to
 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
 * Boston, MA 02110-1301, USA.
 *
 * $URL$
 * $Id$
 */

#ifndef STATS_HPP
#define STATS_HPP

#include <string>
#include <log4cxx/logger.h>
#include "stats_database.hpp"

namespace usdx
{
	/**
	 * Virtual base class for all different statistics.
	 */
	class Stats
	{
	private:
		static log4cxx::LoggerPtr log;

		static StatDatabase *db;
		static std::string filename;

	protected:
		/**
		 * Get the current StatDatabase object for making sqlite
		 * operations. On first execution after setting a filename, the
		 * database is open and initialized. If no filename was set an
		 * exception will be thrown. This function tries to ensure, that
		 * there is only one instance of StatDatabase. (not thread safe)
		 *
		 * @see set_filename(std::string filename)
		 * @return pointer to the StatDatabase object
		 */
		static StatDatabase *get_database(void);

		Stats(void) {};

		/**
		 * Abstract virtual deconstructor. This is here to be able to
		 * delete all subclasses correctly even if there is only a Stats
		 * pointer.
		 */
		virtual ~Stats(void) {};

		/**
		 * TODO
		 */
		static int get_count(std::string query);

	public:
		/**
		 * Get the timestamp of the last reset of the database.
 		 *
		 * @return Timestamp
		 */
		time_t get_stat_reset(void);

		/**
		 * Set the filename of the file to use as statistic
		 * database. The filename has to be set before executing the
		 * get_database member function. If this function is called, the
		 * current statistic database is closed and a new with the given
		 * filename will be open on next access.
		 *
		 * @param filename Filename to use as statistic database.
		 */
		static void set_filename(std::string filename);

		/**
		 * Get the filename used as statistic database.
		 *
		 * @return Filename of the statistics database.
		 */
		static std::string get_filename();

		/**
		 * TODO
		 */
//		static void add_score(Song *song, int level, const char* player, int score);

		/**
		 * TODD
		 */
//		static void add_song(Song *song);
	};

	class StatResultBestScores : public Stats
	{
	private:
		std::string singer;
		unsigned short score;
		unsigned short difficulty;
		std::string song_artist;
		std::string song_title;
		time_t date;

		StatResultBestScores *next;

		StatResultBestScores(
			char *singer,
			unsigned short score,
			unsigned short difficulty,
			char* song_artist,
			char* song_title,
			time_t date);
	public:
		/**
		 * TODO
		 */
		StatResultBestScores(char* song_artist, char* song_title);

		~StatResultBestScores(void);

		static int get_count(void);
		static StatResultBestScores *get_stats();

		StatResultBestScores *get_next();
	};


	class StatResultBestSingers : public Stats
	{
	private:
		std::string singer;
		unsigned short average_score;

		StatResultBestSingers *next;

		StatResultBestSingers(char *singer, unsigned short average_score);
	public:
		~StatResultBestSingers(void);

		static int get_count(void);
		static StatResultBestSingers *get_stats();

		StatResultBestSingers *get_next();
	};


	class StatResultMostSungSong : public Stats
	{
	private:
		std::string song_artist;
		std::string song_title;
		unsigned short times_sung;

		StatResultMostSungSong *next;

		StatResultMostSungSong(char* song_artist, char* song_title, unsigned short times_sung);
	public:
		~StatResultMostSungSong(void);

		static int get_count(void);
		static StatResultMostSungSong *get_stats();

		StatResultMostSungSong *get_next();
	};


	class StatResultMostSungBand : public Stats
	{
	private:
		std::string song_artist;
		unsigned short times_sung;

		StatResultMostSungBand *next;

		StatResultMostSungBand(char* song_artist, unsigned short times_sung);
	public:
		~StatResultMostSungBand(void);

		static int get_count(void);
		static StatResultMostSungBand *get_stats();

		StatResultMostSungBand *get_next();
	};
};

#endif