Skip to content

Commit

Permalink
added time tracking via time played method
Browse files Browse the repository at this point in the history
  • Loading branch information
aminoa committed Jan 26, 2023
1 parent 09a8d95 commit cdb6376
Show file tree
Hide file tree
Showing 41 changed files with 18,202 additions and 23,476 deletions.
1,409 changes: 615 additions & 794 deletions Languages/po/ar.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/ca.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/cs.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/da.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/de.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/dolphin-emu.pot

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/el.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/en.po

Large diffs are not rendered by default.

1,405 changes: 615 additions & 790 deletions Languages/po/es.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/fa.po

Large diffs are not rendered by default.

1,457 changes: 631 additions & 826 deletions Languages/po/fr.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/hr.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/hu.po

Large diffs are not rendered by default.

1,456 changes: 631 additions & 825 deletions Languages/po/it.po

Large diffs are not rendered by default.

1,878 changes: 808 additions & 1,070 deletions Languages/po/ja.po

Large diffs are not rendered by default.

1,459 changes: 633 additions & 826 deletions Languages/po/ko.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/ms.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/nb.po

Large diffs are not rendered by default.

1,553 changes: 666 additions & 887 deletions Languages/po/nl.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/pl.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/pt.po

Large diffs are not rendered by default.

1,472 changes: 639 additions & 833 deletions Languages/po/pt_BR.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/ro.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/ru.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/sr.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/sv.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/tr.po

Large diffs are not rendered by default.

1,448 changes: 630 additions & 818 deletions Languages/po/zh_CN.po

Large diffs are not rendered by default.

1,401 changes: 611 additions & 790 deletions Languages/po/zh_TW.po

Large diffs are not rendered by default.

2 changes: 2 additions & 0 deletions Source/Core/Core/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -505,6 +505,8 @@ add_library(core
SysConf.h
System.cpp
System.h
TimePlayed.cpp
TimePlayed.h
TitleDatabase.cpp
TitleDatabase.h
WiiRoot.cpp
Expand Down
2 changes: 2 additions & 0 deletions Source/Core/Core/Config/MainSettings.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -445,6 +445,8 @@ const Info<bool> MAIN_GAMELIST_COLUMN_BLOCK_SIZE{{System::Main, "GameList", "Col
false};
const Info<bool> MAIN_GAMELIST_COLUMN_COMPRESSION{{System::Main, "GameList", "ColumnCompression"},
false};
const Info<bool> MAIN_GAMELIST_COLUMN_TIME_PLAYED{{System::Main, "GameList", "ColumnTimePlayed"},
true};
const Info<bool> MAIN_GAMELIST_COLUMN_TAGS{{System::Main, "GameList", "ColumnTags"}, false};

// Main.FifoPlayer
Expand Down
1 change: 1 addition & 0 deletions Source/Core/Core/Config/MainSettings.h
Original file line number Diff line number Diff line change
Expand Up @@ -286,6 +286,7 @@ extern const Info<bool> MAIN_GAMELIST_COLUMN_FILE_SIZE;
extern const Info<bool> MAIN_GAMELIST_COLUMN_FILE_FORMAT;
extern const Info<bool> MAIN_GAMELIST_COLUMN_BLOCK_SIZE;
extern const Info<bool> MAIN_GAMELIST_COLUMN_COMPRESSION;
extern const Info<bool> MAIN_GAMELIST_COLUMN_TIME_PLAYED;
extern const Info<bool> MAIN_GAMELIST_COLUMN_TAGS;

// Main.FifoPlayer
Expand Down
29 changes: 28 additions & 1 deletion Source/Core/Core/HW/CPU.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -10,11 +10,14 @@
#include "AudioCommon/AudioCommon.h"
#include "Common/CommonTypes.h"
#include "Common/Event.h"
#include "Common/Timer.h"
#include "Core/ConfigManager.h"
#include "Core/Core.h"
#include "Core/Host.h"
#include "Core/PowerPC/GDBStub.h"
#include "Core/PowerPC/PowerPC.h"
#include "Core/System.h"
#include "Core/TimePlayed.h"
#include "VideoCommon/Fifo.h"

namespace CPU
Expand Down Expand Up @@ -86,12 +89,34 @@ static void ExecutePendingJobs(std::unique_lock<std::mutex>& state_lock)
}
}

static void RunTimer()
{
const std::string game_id = SConfig::GetInstance().GetGameID();
TimePlayed time_played(game_id);
Common::Timer time_tracker;
time_tracker.Start();

while (s_state != State::PowerDown)
{
if (time_tracker.ElapsedMs() > 60000)
{
auto emulated_milliseconds = time_tracker.ElapsedMs();
time_tracker.Stop();
time_played.AddTime(emulated_milliseconds);
time_tracker.Start();
}
}
}

void Run()
{
// Updating the host CPU's rounding mode must be done on the CPU thread.
// We can't rely on PowerPC::Init doing it, since it's called from EmuThread.
PowerPC::RoundingModeUpdated();

//start a separate timing thread here
auto timing = std::thread(RunTimer);

std::unique_lock state_lock(s_state_change_lock);
while (s_state != State::PowerDown)
{
Expand All @@ -101,7 +126,7 @@ void Run()
Common::Event gdb_step_sync_event;
switch (s_state)
{
case State::Running:
case State::Running:
s_state_cpu_thread_active = true;
state_lock.unlock();

Expand Down Expand Up @@ -183,6 +208,8 @@ void Run()
break;
}
}

timing.join();
state_lock.unlock();
Host_UpdateDisasmDialog();
}
Expand Down
8 changes: 2 additions & 6 deletions Source/Core/Core/State.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@

#include <atomic>
#include <condition_variable>
#include <filesystem>
#include <map>
#include <memory>
#include <mutex>
Expand Down Expand Up @@ -459,8 +458,7 @@ static void CompressAndDumpState(CompressAndDumpState_args& save_args)
File::Rename(temp_filename, filename);
}

std::filesystem::path tempfilename(filename);
Core::DisplayMessage(fmt::format("Saved State to {}", tempfilename.filename().string()), 2000);
Core::DisplayMessage(fmt::format("Saved State to {}", filename), 2000);
Host_UpdateMainFrame();
}

Expand Down Expand Up @@ -690,9 +688,7 @@ void LoadAs(const std::string& filename)
{
if (loadedSuccessfully)
{
std::filesystem::path tempfilename(filename);
Core::DisplayMessage(
fmt::format("Loaded State from {}", tempfilename.filename().string()), 2000);
Core::DisplayMessage(fmt::format("Loaded state from {}", filename), 2000);
if (File::Exists(filename + ".dtm"))
Movie::LoadInput(filename + ".dtm");
else if (!Movie::IsJustStartingRecordingInputFromSaveState() &&
Expand Down
38 changes: 38 additions & 0 deletions Source/Core/Core/TimePlayed.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
#pragma once

#include <string>

#include "Common/IniFile.h"
#include "Common/FileUtil.h"
#include "TimePlayed.h"

TimePlayed::TimePlayed(std::string game_id)
{
m_game_id = game_id;
}

void TimePlayed::AddTime(u64 time_emulated)
{
IniFile ini;
std::string ini_path = File::GetUserPath(D_CONFIG_IDX) + "TimePlayed.ini";
ini.Load(ini_path);

auto time_list = ini.GetOrCreateSection("Time Played");
int previous_time = 0;

time_list->Get(m_game_id, &previous_time);
time_list->Set(m_game_id, previous_time + int(time_emulated)); //unlikely u64 to int conversion issue
ini.Save(ini_path);
}

int TimePlayed::GetTimePlayed()
{
IniFile ini;
std::string ini_path = File::GetUserPath(D_CONFIG_IDX) + "TimePlayed.ini";
ini.Load(ini_path);

auto time_list = ini.GetOrCreateSection("Time Played");
int previous_time;
time_list->Get(m_game_id, &previous_time);
return previous_time;
}
15 changes: 15 additions & 0 deletions Source/Core/Core/TimePlayed.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
#pragma once
#include "Common/CommonTypes.h"

class TimePlayed
{
public:
TimePlayed(std::string game_id);

void AddTime(u64 time_emulated);

int GetTimePlayed();

private:
std::string m_game_id;
};
2 changes: 2 additions & 0 deletions Source/Core/DolphinLib.props
Original file line number Diff line number Diff line change
Expand Up @@ -430,6 +430,7 @@
<ClInclude Include="Core\SyncIdentifier.h" />
<ClInclude Include="Core\SysConf.h" />
<ClInclude Include="Core\System.h" />
<ClInclude Include="Core\TimePlayed.h" />
<ClInclude Include="Core\TitleDatabase.h" />
<ClInclude Include="Core\WiiRoot.h" />
<ClInclude Include="Core\WiiUtils.h" />
Expand Down Expand Up @@ -1044,6 +1045,7 @@
<ClCompile Include="Core\State.cpp" />
<ClCompile Include="Core\SysConf.cpp" />
<ClCompile Include="Core\System.cpp" />
<ClCompile Include="Core\TimePlayed.cpp" />
<ClCompile Include="Core\TitleDatabase.cpp" />
<ClCompile Include="Core\WiiRoot.cpp" />
<ClCompile Include="Core\WiiUtils.cpp" />
Expand Down
3 changes: 3 additions & 0 deletions Source/Core/DolphinQt/GameList/GameList.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -204,6 +204,7 @@ void GameList::MakeListView()
SetResizeMode(Column::FileFormat, Mode::Fixed);
SetResizeMode(Column::BlockSize, Mode::Fixed);
SetResizeMode(Column::Compression, Mode::Fixed);
SetResizeMode(Column::TimePlayed, Mode::Interactive);
SetResizeMode(Column::Tags, Mode::Interactive);

// Cells have 3 pixels of padding, so the width of these needs to be image width + 6. Banners
Expand Down Expand Up @@ -269,6 +270,7 @@ void GameList::UpdateColumnVisibility()
SetVisiblity(Column::FileFormat, Config::Get(Config::MAIN_GAMELIST_COLUMN_FILE_FORMAT));
SetVisiblity(Column::BlockSize, Config::Get(Config::MAIN_GAMELIST_COLUMN_BLOCK_SIZE));
SetVisiblity(Column::Compression, Config::Get(Config::MAIN_GAMELIST_COLUMN_COMPRESSION));
SetVisiblity(Column::TimePlayed, Config::Get(Config::MAIN_GAMELIST_COLUMN_TIME_PLAYED));
SetVisiblity(Column::Tags, Config::Get(Config::MAIN_GAMELIST_COLUMN_TAGS));
}

Expand Down Expand Up @@ -981,6 +983,7 @@ void GameList::OnColumnVisibilityToggled(const QString& row, bool visible)
{tr("File Format"), Column::FileFormat},
{tr("Block Size"), Column::BlockSize},
{tr("Compression"), Column::Compression},
{tr("Time Played"), Column::TimePlayed},
{tr("Tags"), Column::Tags},
};

Expand Down
19 changes: 19 additions & 0 deletions Source/Core/DolphinQt/GameList/GameListModel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
#include <QRegularExpression>

#include "Core/Config/MainSettings.h"
#include "Core/TimePlayed.h"

#include "DiscIO/Enums.h"

Expand Down Expand Up @@ -187,6 +188,22 @@ QVariant GameListModel::data(const QModelIndex& index, int role) const
return compression.isEmpty() ? tr("No Compression") : compression;
}
break;
case Column::TimePlayed:
if (role == Qt::DisplayRole || role == SORT_ROLE)
{
TimePlayed timer(game.GetGameID());

//milliseconds to minutes conversion
int game_milliseconds = timer.GetTimePlayed();
int game_minutes = game_milliseconds / (60000);
int game_hours = game_minutes / 60;
int remaining_game_minutes = game_minutes % 60;

// i18n: A time displayed as hours and minutes
QString formatted_time = tr("%0h %1m").arg(game_hours, remaining_game_minutes);
return formatted_time;
}
break;
case Column::Tags:
if (role == Qt::DisplayRole || role == SORT_ROLE)
{
Expand Down Expand Up @@ -231,6 +248,8 @@ QVariant GameListModel::headerData(int section, Qt::Orientation orientation, int
return tr("Block Size");
case Column::Compression:
return tr("Compression");
case Column::TimePlayed:
return tr("Time Played");
case Column::Tags:
return tr("Tags");
default:
Expand Down
1 change: 1 addition & 0 deletions Source/Core/DolphinQt/GameList/GameListModel.h
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,7 @@ class GameListModel final : public QAbstractTableModel
FileFormat,
BlockSize,
Compression,
TimePlayed,
Tags,
Count,
};
Expand Down
1 change: 1 addition & 0 deletions Source/Core/DolphinQt/MenuBar.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -625,6 +625,7 @@ void MenuBar::AddListColumnsMenu(QMenu* view_menu)
{tr("File Format"), &Config::MAIN_GAMELIST_COLUMN_FILE_FORMAT},
{tr("Block Size"), &Config::MAIN_GAMELIST_COLUMN_BLOCK_SIZE},
{tr("Compression"), &Config::MAIN_GAMELIST_COLUMN_COMPRESSION},
{tr("Time Played"), &Config::MAIN_GAMELIST_COLUMN_TIME_PLAYED},
{tr("Tags"), &Config::MAIN_GAMELIST_COLUMN_TAGS}};

QActionGroup* column_group = new QActionGroup(this);
Expand Down

0 comments on commit cdb6376

Please sign in to comment.