Some xb style cleanup.

This commit is contained in:
Ben Vanik 2015-08-05 22:06:20 -07:00
parent eaa1a8ee3a
commit e6461f326c
29 changed files with 87 additions and 83 deletions

View File

@ -83,8 +83,8 @@ size_t Arena::CalculateSize() {
void* Arena::CloneContents() { void* Arena::CloneContents() {
size_t total_length = CalculateSize(); size_t total_length = CalculateSize();
void* result = malloc(total_length); auto result = reinterpret_cast<uint8_t*>(malloc(total_length));
uint8_t* p = (uint8_t*)result; auto p = result;
Chunk* chunk = head_chunk_; Chunk* chunk = head_chunk_;
while (chunk) { while (chunk) {
std::memcpy(p, chunk->buffer, chunk->offset); std::memcpy(p, chunk->buffer, chunk->offset);
@ -98,7 +98,7 @@ void* Arena::CloneContents() {
} }
void Arena::CloneContents(void* buffer, size_t buffer_length) { void Arena::CloneContents(void* buffer, size_t buffer_length) {
uint8_t* p = (uint8_t*)buffer; uint8_t* p = reinterpret_cast<uint8_t*>(buffer);
Chunk* chunk = head_chunk_; Chunk* chunk = head_chunk_;
while (chunk) { while (chunk) {
std::memcpy(p, chunk->buffer, chunk->offset); std::memcpy(p, chunk->buffer, chunk->offset);

View File

@ -18,7 +18,7 @@ namespace xe {
class Arena { class Arena {
public: public:
Arena(size_t chunk_size = 4 * 1024 * 1024); explicit Arena(size_t chunk_size = 4 * 1024 * 1024);
~Arena(); ~Arena();
void Reset(); void Reset();
@ -33,15 +33,15 @@ class Arena {
void* CloneContents(); void* CloneContents();
template <typename T> template <typename T>
void CloneContents(std::vector<T>& buffer) { void CloneContents(std::vector<T>* buffer) {
buffer.resize(CalculateSize() / sizeof(T)); buffer->resize(CalculateSize() / sizeof(T));
CloneContents(buffer.data(), buffer.size() * sizeof(T)); CloneContents(buffer->data(), buffer->size() * sizeof(T));
} }
private: private:
class Chunk { class Chunk {
public: public:
Chunk(size_t chunk_size); explicit Chunk(size_t chunk_size);
~Chunk(); ~Chunk();
Chunk* next; Chunk* next;

View File

@ -15,10 +15,6 @@
#include "xenia/base/assert.h" #include "xenia/base/assert.h"
#include "xenia/base/platform.h" #include "xenia/base/platform.h"
#if XE_PLATFORM_MAC
#include <libkern/OSByteOrder.h>
#endif // XE_PLATFORM_MAC
namespace xe { namespace xe {
#if XE_PLATFORM_WIN32 #if XE_PLATFORM_WIN32

View File

@ -33,7 +33,7 @@ thread_local uint64_t last_host_tick_count_ = Clock::QueryHostTickCount();
void RecomputeGuestTickScalar() { void RecomputeGuestTickScalar() {
guest_tick_scalar_ = (guest_tick_frequency_ * guest_time_scalar_) / guest_tick_scalar_ = (guest_tick_frequency_ * guest_time_scalar_) /
double(Clock::host_tick_frequency()); static_cast<double>(Clock::host_tick_frequency());
} }
void UpdateGuestClock() { void UpdateGuestClock() {
@ -108,7 +108,7 @@ int64_t Clock::ScaleGuestDurationFileTime(int64_t guest_file_time) {
return scaled_file_time; return scaled_file_time;
} }
void Clock::ScaleGuestDurationTimeval(long* tv_sec, long* tv_usec) { void Clock::ScaleGuestDurationTimeval(int32_t* tv_sec, int32_t* tv_usec) {
uint64_t scaled_sec = uint64_t(uint64_t(*tv_sec) * guest_tick_scalar_); uint64_t scaled_sec = uint64_t(uint64_t(*tv_sec) * guest_tick_scalar_);
uint64_t scaled_usec = uint64_t(uint64_t(*tv_usec) * guest_time_scalar_); uint64_t scaled_usec = uint64_t(uint64_t(*tv_usec) * guest_time_scalar_);
if (scaled_usec > UINT_MAX) { if (scaled_usec > UINT_MAX) {
@ -116,8 +116,8 @@ void Clock::ScaleGuestDurationTimeval(long* tv_sec, long* tv_usec) {
scaled_usec -= overflow_sec * 1000000; scaled_usec -= overflow_sec * 1000000;
scaled_sec += overflow_sec; scaled_sec += overflow_sec;
} }
*tv_sec = long(scaled_sec); *tv_sec = int32_t(scaled_sec);
*tv_usec = long(scaled_usec); *tv_usec = int32_t(scaled_usec);
} }
} // namespace xe } // namespace xe

View File

@ -52,7 +52,7 @@ class Clock {
// Scales a time duration in 100ns ticks like FILETIME, from guest time. // Scales a time duration in 100ns ticks like FILETIME, from guest time.
static int64_t ScaleGuestDurationFileTime(int64_t guest_file_time); static int64_t ScaleGuestDurationFileTime(int64_t guest_file_time);
// Scales a time duration represented as a timeval, from guest time. // Scales a time duration represented as a timeval, from guest time.
static void ScaleGuestDurationTimeval(long* tv_sec, long* tv_usec); static void ScaleGuestDurationTimeval(int32_t* tv_sec, int32_t* tv_usec);
}; };
} // namespace xe } // namespace xe

View File

@ -15,7 +15,7 @@ namespace xe {
namespace filesystem { namespace filesystem {
std::string CanonicalizePath(const std::string& original_path) { std::string CanonicalizePath(const std::string& original_path) {
char path_sep(xe::path_separator); char path_sep(xe::kPathSeparator);
std::string path(xe::fix_path_separators(original_path, path_sep)); std::string path(xe::fix_path_separators(original_path, path_sep));
std::vector<std::string::size_type> path_breaks; std::vector<std::string::size_type> path_breaks;
@ -111,19 +111,19 @@ WildcardRule::WildcardRule(const std::string& str_match,
} }
bool WildcardRule::Check(const std::string& str_lower, bool WildcardRule::Check(const std::string& str_lower,
std::string::size_type& offset) const { std::string::size_type* offset) const {
if (match.empty()) { if (match.empty()) {
return true; return true;
} }
if ((str_lower.size() - offset) < match.size()) { if ((str_lower.size() - *offset) < match.size()) {
return false; return false;
} }
std::string::size_type result(str_lower.find(match, offset)); std::string::size_type result(str_lower.find(match, *offset));
if (result != std::string::npos) { if (result != std::string::npos) {
if (rules.FromStart && result != offset) { if (rules.FromStart && result != *offset) {
return false; return false;
} }
@ -131,7 +131,7 @@ bool WildcardRule::Check(const std::string& str_lower,
return false; return false;
} }
offset = (result + match.size()); *offset = (result + match.size());
return true; return true;
} }
@ -168,7 +168,7 @@ bool WildcardEngine::Match(const std::string& str) const {
std::string::size_type offset(0); std::string::size_type offset(0);
for (const auto& rule : rules) { for (const auto& rule : rules) {
if (!(rule.Check(str_lc, offset))) { if (!(rule.Check(str_lc, &offset))) {
return false; return false;
} }
} }

View File

@ -70,7 +70,7 @@ class FileHandle {
virtual void Flush() = 0; virtual void Flush() = 0;
protected: protected:
FileHandle(std::wstring path) : path_(std::move(path)) {} explicit FileHandle(std::wstring path) : path_(std::move(path)) {}
std::wstring path_; std::wstring path_;
}; };
@ -105,7 +105,7 @@ class WildcardRule {
public: public:
WildcardRule(const std::string& str_match, const WildcardFlags& flags); WildcardRule(const std::string& str_match, const WildcardFlags& flags);
bool Check(const std::string& str_lower, bool Check(const std::string& str_lower,
std::string::size_type& offset) const; std::string::size_type* offset) const;
private: private:
std::string match; std::string match;

View File

@ -22,12 +22,12 @@ bool PathExists(const std::wstring& path) {
} }
bool CreateFolder(const std::wstring& path) { bool CreateFolder(const std::wstring& path) {
wchar_t folder[MAX_PATH] = {0}; wchar_t folder[kMaxPath] = {0};
auto end = std::wcschr(path.c_str(), xe::wpath_separator); auto end = std::wcschr(path.c_str(), xe::kWPathSeparator);
while (end) { while (end) {
wcsncpy(folder, path.c_str(), end - path.c_str() + 1); wcsncpy(folder, path.c_str(), end - path.c_str() + 1);
CreateDirectory(folder, NULL); CreateDirectory(folder, NULL);
end = wcschr(++end, xe::wpath_separator); end = wcschr(++end, xe::kWPathSeparator);
} }
return PathExists(path); return PathExists(path);
} }

View File

@ -13,6 +13,7 @@
#include <cstdarg> #include <cstdarg>
#include <mutex> #include <mutex>
#include <vector>
#include "xenia/base/main.h" #include "xenia/base/main.h"
#include "xenia/base/math.h" #include "xenia/base/math.h"

View File

@ -7,8 +7,8 @@
****************************************************************************** ******************************************************************************
*/ */
#ifndef XENIA_LOGGING_H_ #ifndef XENIA_BASE_LOGGING_H_
#define XENIA_LOGGING_H_ #define XENIA_BASE_LOGGING_H_
#include <cstdint> #include <cstdint>
@ -102,4 +102,4 @@ void handle_fatal(const char* fmt, ...);
} // namespace xe } // namespace xe
#endif // XENIA_LOGGING_H_ #endif // XENIA_BASE_LOGGING_H_

View File

@ -29,9 +29,9 @@ void copy_and_swap_16_unaligned(uint16_t* dest, const uint16_t* src,
__m128i input, output; __m128i input, output;
for (i = 0; i + 8 <= count; i += 8) { for (i = 0; i + 8 <= count; i += 8) {
input = _mm_loadu_si128((__m128i*)&src[i]); input = _mm_loadu_si128(reinterpret_cast<const __m128i*>(&src[i]));
output = _mm_or_si128(_mm_slli_epi16(input, 8), _mm_srli_epi16(input, 8)); output = _mm_or_si128(_mm_slli_epi16(input, 8), _mm_srli_epi16(input, 8));
_mm_storeu_si128((__m128i*)&dest[i], output); _mm_storeu_si128(reinterpret_cast<__m128i*>(&dest[i]), output);
} }
for (; i < count; ++i) { // handle residual elements for (; i < count; ++i) { // handle residual elements
@ -52,7 +52,7 @@ void copy_and_swap_32_unaligned(uint32_t* dest, const uint32_t* src,
__m128i byte3mask = _mm_set1_epi32(0x0000FF00); __m128i byte3mask = _mm_set1_epi32(0x0000FF00);
for (i = 0; i + 4 <= count; i += 4) { for (i = 0; i + 4 <= count; i += 4) {
input = _mm_loadu_si128((__m128i*)&src[i]); input = _mm_loadu_si128(reinterpret_cast<const __m128i*>(&src[i]));
// Do the four shifts // Do the four shifts
byte1 = _mm_slli_epi32(input, 24); byte1 = _mm_slli_epi32(input, 24);
@ -67,7 +67,7 @@ void copy_and_swap_32_unaligned(uint32_t* dest, const uint32_t* src,
byte3 = _mm_and_si128(byte3, byte3mask); byte3 = _mm_and_si128(byte3, byte3mask);
output = _mm_or_si128(output, byte3); output = _mm_or_si128(output, byte3);
_mm_storeu_si128((__m128i*)&dest[i], output); _mm_storeu_si128(reinterpret_cast<__m128i*>(&dest[i]), output);
} }
for (; i < count; ++i) { // handle residual elements for (; i < count; ++i) { // handle residual elements
@ -88,7 +88,7 @@ void copy_and_swap_64_unaligned(uint64_t* dest, const uint64_t* src,
__m128i byte3mask = _mm_set1_epi32(0x0000FF00); __m128i byte3mask = _mm_set1_epi32(0x0000FF00);
for (i = 0; i + 2 <= count; i += 2) { for (i = 0; i + 2 <= count; i += 2) {
input = _mm_loadu_si128((__m128i*)&src[i]); input = _mm_loadu_si128(reinterpret_cast<const __m128i*>(&src[i]));
// Do the four shifts // Do the four shifts
byte1 = _mm_slli_epi32(input, 24); byte1 = _mm_slli_epi32(input, 24);
@ -106,7 +106,7 @@ void copy_and_swap_64_unaligned(uint64_t* dest, const uint64_t* src,
// Reorder the two words // Reorder the two words
output = _mm_shuffle_epi32(output, _MM_SHUFFLE(2, 3, 0, 1)); output = _mm_shuffle_epi32(output, _MM_SHUFFLE(2, 3, 0, 1));
_mm_storeu_si128((__m128i*)&dest[i], output); _mm_storeu_si128(reinterpret_cast<__m128i*>(&dest[i]), output);
} }
for (; i < count; ++i) { // handle residual elements for (; i < count; ++i) { // handle residual elements
@ -119,9 +119,9 @@ void copy_and_swap_16_in_32_aligned(uint32_t* dest, const uint32_t* src,
size_t i; size_t i;
__m128i input, output; __m128i input, output;
for (i = 0; i + 4 <= count; i += 4) { for (i = 0; i + 4 <= count; i += 4) {
input = _mm_loadu_si128((__m128i*)&src[i]); input = _mm_loadu_si128(reinterpret_cast<const __m128i*>(&src[i]));
output = _mm_or_si128(_mm_slli_epi32(input, 16), _mm_srli_epi32(input, 16)); output = _mm_or_si128(_mm_slli_epi32(input, 16), _mm_srli_epi32(input, 16));
_mm_storeu_si128((__m128i*)&dest[i], output); _mm_storeu_si128(reinterpret_cast<__m128i*>(&dest[i]), output);
} }
for (; i < count; ++i) { // handle residual elements for (; i < count; ++i) { // handle residual elements
dest[i] = (src[i] >> 16) | (src[i] << 16); dest[i] = (src[i] >> 16) | (src[i] << 16);

View File

@ -10,9 +10,6 @@
#include "third_party/catch/include/catch.hpp" #include "third_party/catch/include/catch.hpp"
#include "xenia/base/memory.h" #include "xenia/base/memory.h"
using namespace xe;
using namespace xe::memory;
TEST_CASE("copy_and_swap_16_aligned", "Copy and Swap") { TEST_CASE("copy_and_swap_16_aligned", "Copy and Swap") {
// TODO(benvanik): tests. // TODO(benvanik): tests.
REQUIRE(true == true); REQUIRE(true == true);

View File

@ -61,16 +61,20 @@
#include <x86intrin.h> #include <x86intrin.h>
#endif // XE_PLATFORM_WIN32 #endif // XE_PLATFORM_WIN32
#if XE_PLATFORM_MAC
#include <libkern/OSByteOrder.h>
#endif // XE_PLATFORM_MAC
namespace xe { namespace xe {
#if XE_PLATFORM_WIN32 #if XE_PLATFORM_WIN32
const char path_separator = '\\'; const char kPathSeparator = '\\';
const wchar_t wpath_separator = L'\\'; const wchar_t kWPathSeparator = L'\\';
const size_t max_path = 260; // _MAX_PATH const size_t kMaxPath = 260; // _MAX_PATH
#else #else
const char path_separator = '/'; const char kPathSeparator = '/';
const wchar_t wpath_separator = L'/'; const wchar_t kWPathSeparator = L'/';
const size_t max_path = 1024; // PATH_MAX const size_t kMaxPath = 1024; // PATH_MAX
#endif // XE_PLATFORM_WIN32 #endif // XE_PLATFORM_WIN32
// Launches a web browser to the given URL. // Launches a web browser to the given URL.

View File

@ -17,7 +17,7 @@ namespace xe {
template <typename T> template <typename T>
class ResetScope { class ResetScope {
public: public:
ResetScope(T* value) : value_(value) {} explicit ResetScope(T* value) : value_(value) {}
~ResetScope() { ~ResetScope() {
if (value_) { if (value_) {
value_->Reset(); value_->Reset();

View File

@ -61,4 +61,4 @@ class RingBuffer {
} // namespace xe } // namespace xe
#endif // XENIA_BASE_RING_BUFFER_H_ #endif // XENIA_BASE_RING_BUFFER_H_

View File

@ -13,6 +13,9 @@
#include <cstdint> #include <cstdint>
#include <functional> #include <functional>
#include <memory> #include <memory>
#include <string>
#include <utility>
#include <vector>
#include "xenia/base/threading.h" #include "xenia/base/threading.h"
@ -112,4 +115,4 @@ class SocketServer {
} // namespace xe } // namespace xe
#endif // XENIA_BASE_SOCKET_H_ #endif // XENIA_BASE_SOCKET_H_

View File

@ -14,11 +14,10 @@
#include "xenia/base/logging.h" #include "xenia/base/logging.h"
// platform_win.h must come first to include Windows headers.
#include "xenia/base/platform_win.h" #include "xenia/base/platform_win.h"
#include <mstcpip.h> #include <mstcpip.h> // NOLINT(must follow platform_win.h)
#include <winsock2.h> #include <winsock2.h> // NOLINT(must follow platform_win.h)
#include <ws2tcpip.h> #include <ws2tcpip.h> // NOLINT(must follow platform_win.h)
namespace xe { namespace xe {
@ -63,7 +62,8 @@ class Win32Socket : public Socket {
return false; return false;
} }
// Connect to server. // Connect to server.
ret = connect(try_socket, ptr->ai_addr, (int)ptr->ai_addrlen); ret =
connect(try_socket, ptr->ai_addr, static_cast<int>(ptr->ai_addrlen));
if (ret == SOCKET_ERROR) { if (ret == SOCKET_ERROR) {
closesocket(try_socket); closesocket(try_socket);
try_socket = INVALID_SOCKET; try_socket = INVALID_SOCKET;
@ -133,8 +133,8 @@ class Win32Socket : public Socket {
if (socket_ == INVALID_SOCKET) { if (socket_ == INVALID_SOCKET) {
return -1; return -1;
} }
int ret = int ret = recv(socket_, reinterpret_cast<char*>(buffer),
recv(socket_, reinterpret_cast<char*>(buffer), int(buffer_capacity), 0); static_cast<int>(buffer_capacity), 0);
if (ret == SOCKET_ERROR) { if (ret == SOCKET_ERROR) {
int e = WSAGetLastError(); int e = WSAGetLastError();
if (e == WSAEWOULDBLOCK) { if (e == WSAEWOULDBLOCK) {

View File

@ -43,11 +43,11 @@ std::string::size_type find_first_of_case(const std::string& target,
std::wstring to_absolute_path(const std::wstring& path) { std::wstring to_absolute_path(const std::wstring& path) {
#if XE_PLATFORM_WIN32 #if XE_PLATFORM_WIN32
wchar_t buffer[xe::max_path]; wchar_t buffer[kMaxPath];
_wfullpath(buffer, path.c_str(), sizeof(buffer) / sizeof(wchar_t)); _wfullpath(buffer, path.c_str(), sizeof(buffer) / sizeof(wchar_t));
return buffer; return buffer;
#else #else
char buffer[xe::max_path]; char buffer[kMaxPath];
realpath(xe::to_string(path).c_str(), buffer); realpath(xe::to_string(path).c_str(), buffer);
return xe::to_wstring(buffer); return xe::to_wstring(buffer);
#endif // XE_PLATFORM_WIN32 #endif // XE_PLATFORM_WIN32

View File

@ -33,16 +33,16 @@ std::vector<std::string> split_path(const std::string& path);
// Joins two path segments with the given separator. // Joins two path segments with the given separator.
std::string join_paths(const std::string& left, const std::string& right, std::string join_paths(const std::string& left, const std::string& right,
char sep = xe::path_separator); char sep = xe::kPathSeparator);
std::wstring join_paths(const std::wstring& left, const std::wstring& right, std::wstring join_paths(const std::wstring& left, const std::wstring& right,
wchar_t sep = xe::path_separator); wchar_t sep = xe::kPathSeparator);
// Replaces all path separators with the given value and removes redundant // Replaces all path separators with the given value and removes redundant
// separators. // separators.
std::wstring fix_path_separators(const std::wstring& source, std::wstring fix_path_separators(const std::wstring& source,
wchar_t new_sep = xe::path_separator); wchar_t new_sep = xe::kPathSeparator);
std::string fix_path_separators(const std::string& source, std::string fix_path_separators(const std::string& source,
char new_sep = xe::path_separator); char new_sep = xe::kPathSeparator);
// Find the top directory name or filename from a path. // Find the top directory name or filename from a path.
std::string find_name_from_path(const std::string& path); std::string find_name_from_path(const std::string& path);

View File

@ -17,7 +17,7 @@ namespace xe {
class StringBuffer { class StringBuffer {
public: public:
StringBuffer(size_t initial_capacity = 0); explicit StringBuffer(size_t initial_capacity = 0);
~StringBuffer(); ~StringBuffer();
size_t length() const { return buffer_offset_; } size_t length() const { return buffer_offset_; }

View File

@ -19,6 +19,7 @@
#include <mutex> #include <mutex>
#include <string> #include <string>
#include <thread> #include <thread>
#include <utility>
#include <vector> #include <vector>
namespace xe { namespace xe {

View File

@ -61,7 +61,7 @@ void set_name(DWORD thread_id, const std::string& name) {
__try { __try {
RaiseException(0x406D1388, 0, sizeof(info) / sizeof(ULONG_PTR), RaiseException(0x406D1388, 0, sizeof(info) / sizeof(ULONG_PTR),
reinterpret_cast<ULONG_PTR*>(&info)); reinterpret_cast<ULONG_PTR*>(&info));
} __except (EXCEPTION_EXECUTE_HANDLER) { } __except (EXCEPTION_EXECUTE_HANDLER) { // NOLINT
} }
} }
@ -149,7 +149,7 @@ std::unique_ptr<HighResolutionTimer> HighResolutionTimer::CreateRepeating(
template <typename T> template <typename T>
class Win32Handle : public T { class Win32Handle : public T {
public: public:
Win32Handle(HANDLE handle) : handle_(handle) {} explicit Win32Handle(HANDLE handle) : handle_(handle) {}
~Win32Handle() override { ~Win32Handle() override {
CloseHandle(handle_); CloseHandle(handle_);
handle_ = nullptr; handle_ = nullptr;
@ -236,7 +236,7 @@ std::pair<WaitResult, size_t> WaitMultiple(WaitHandle* wait_handles[],
class Win32Event : public Win32Handle<Event> { class Win32Event : public Win32Handle<Event> {
public: public:
Win32Event(HANDLE handle) : Win32Handle(handle) {} explicit Win32Event(HANDLE handle) : Win32Handle(handle) {}
~Win32Event() override = default; ~Win32Event() override = default;
void Set() override { SetEvent(handle_); } void Set() override { SetEvent(handle_); }
void Reset() override { ResetEvent(handle_); } void Reset() override { ResetEvent(handle_); }
@ -255,7 +255,7 @@ std::unique_ptr<Event> Event::CreateAutoResetEvent(bool initial_state) {
class Win32Semaphore : public Win32Handle<Semaphore> { class Win32Semaphore : public Win32Handle<Semaphore> {
public: public:
Win32Semaphore(HANDLE handle) : Win32Handle(handle) {} explicit Win32Semaphore(HANDLE handle) : Win32Handle(handle) {}
~Win32Semaphore() override = default; ~Win32Semaphore() override = default;
bool Release(int release_count, int* out_previous_count) override { bool Release(int release_count, int* out_previous_count) override {
return ReleaseSemaphore(handle_, release_count, return ReleaseSemaphore(handle_, release_count,
@ -273,7 +273,7 @@ std::unique_ptr<Semaphore> Semaphore::Create(int initial_count,
class Win32Mutant : public Win32Handle<Mutant> { class Win32Mutant : public Win32Handle<Mutant> {
public: public:
Win32Mutant(HANDLE handle) : Win32Handle(handle) {} explicit Win32Mutant(HANDLE handle) : Win32Handle(handle) {}
~Win32Mutant() = default; ~Win32Mutant() = default;
bool Release() override { return ReleaseMutex(handle_) ? true : false; } bool Release() override { return ReleaseMutex(handle_) ? true : false; }
}; };
@ -285,7 +285,7 @@ std::unique_ptr<Mutant> Mutant::Create(bool initial_owner) {
class Win32Timer : public Win32Handle<Timer> { class Win32Timer : public Win32Handle<Timer> {
public: public:
Win32Timer(HANDLE handle) : Win32Handle(handle) {} explicit Win32Timer(HANDLE handle) : Win32Handle(handle) {}
~Win32Timer() = default; ~Win32Timer() = default;
bool SetOnce(std::chrono::nanoseconds due_time, bool SetOnce(std::chrono::nanoseconds due_time,
std::function<void()> opt_callback) override { std::function<void()> opt_callback) override {
@ -349,7 +349,7 @@ std::unique_ptr<Timer> Timer::CreateSynchronizationTimer() {
class Win32Thread : public Win32Handle<Thread> { class Win32Thread : public Win32Handle<Thread> {
public: public:
Win32Thread(HANDLE handle) : Win32Handle(handle) {} explicit Win32Thread(HANDLE handle) : Win32Handle(handle) {}
~Win32Thread() = default; ~Win32Thread() = default;
void set_name(std::string name) override { void set_name(std::string name) override {

View File

@ -111,7 +111,7 @@ bool X64Emitter::Emit(GuestFunction* function, HIRBuilder* builder,
out_code_address = Emplace(stack_size, function); out_code_address = Emplace(stack_size, function);
// Stash source map. // Stash source map.
source_map_arena_.CloneContents(out_source_map); source_map_arena_.CloneContents(&out_source_map);
return true; return true;
} }

View File

@ -50,7 +50,7 @@ struct TestCase {
class TestSuite { class TestSuite {
public: public:
TestSuite(const std::wstring& src_file_path) : src_file_path(src_file_path) { TestSuite(const std::wstring& src_file_path) : src_file_path(src_file_path) {
name = src_file_path.substr(src_file_path.find_last_of(xe::path_separator) + name = src_file_path.substr(src_file_path.find_last_of(xe::kPathSeparator) +
1); 1);
name = ReplaceExtension(name, L""); name = ReplaceExtension(name, L"");
map_file_path = xe::to_wstring(FLAGS_test_bin_path) + name + L".map"; map_file_path = xe::to_wstring(FLAGS_test_bin_path) + name + L".map";

View File

@ -45,7 +45,7 @@ bool RawModule::LoadFile(uint32_t base_address, const std::wstring& path) {
fclose(file); fclose(file);
// Setup debug info. // Setup debug info.
auto last_slash = fixed_path.find_last_of(xe::path_separator); auto last_slash = fixed_path.find_last_of(xe::kPathSeparator);
if (last_slash != std::string::npos) { if (last_slash != std::string::npos) {
name_ = xe::to_string(fixed_path.substr(last_slash + 1)); name_ = xe::to_string(fixed_path.substr(last_slash + 1));
} else { } else {

View File

@ -186,7 +186,7 @@ X_STATUS Emulator::Setup(ui::Window* display_window) {
X_STATUS Emulator::LaunchPath(std::wstring path) { X_STATUS Emulator::LaunchPath(std::wstring path) {
// Launch based on file type. // Launch based on file type.
// This is a silly guess based on file extension. // This is a silly guess based on file extension.
auto last_slash = path.find_last_of(xe::path_separator); auto last_slash = path.find_last_of(xe::kPathSeparator);
auto last_dot = path.find_last_of('.'); auto last_dot = path.find_last_of('.');
if (last_dot < last_slash) { if (last_dot < last_slash) {
last_dot = std::wstring::npos; last_dot = std::wstring::npos;

View File

@ -331,7 +331,7 @@ bool GL4Shader::CompileProgram(std::string source) {
// Save to disk, if we asked for it. // Save to disk, if we asked for it.
auto base_path = FLAGS_dump_shaders.c_str(); auto base_path = FLAGS_dump_shaders.c_str();
char file_name[xe::max_path]; char file_name[kMaxPath];
snprintf(file_name, xe::countof(file_name), "%s/gl4_gen_%.16llX.%s", snprintf(file_name, xe::countof(file_name), "%s/gl4_gen_%.16llX.%s",
base_path, data_hash_, base_path, data_hash_,
shader_type_ == ShaderType::kVertex ? "vert" : "frag"); shader_type_ == ShaderType::kVertex ? "vert" : "frag");

View File

@ -81,7 +81,7 @@ std::wstring ContentManager::ResolvePackageRoot(uint32_t content_type) {
// content_root/title_id/type_name/ // content_root/title_id/type_name/
auto package_root = auto package_root =
xe::join_paths(root_path_, xe::join_paths(title_id, type_name)); xe::join_paths(root_path_, xe::join_paths(title_id, type_name));
return package_root + xe::wpath_separator; return package_root + xe::kWPathSeparator;
} }
std::wstring ContentManager::ResolvePackagePath(const XCONTENT_DATA& data) { std::wstring ContentManager::ResolvePackagePath(const XCONTENT_DATA& data) {
@ -90,7 +90,7 @@ std::wstring ContentManager::ResolvePackagePath(const XCONTENT_DATA& data) {
auto package_root = ResolvePackageRoot(data.content_type); auto package_root = ResolvePackageRoot(data.content_type);
auto package_path = auto package_path =
xe::join_paths(package_root, xe::to_wstring(data.file_name)); xe::join_paths(package_root, xe::to_wstring(data.file_name));
package_path += xe::path_separator; package_path += xe::kPathSeparator;
return package_path; return package_path;
} }

View File

@ -593,9 +593,11 @@ SHIM_CALL NetDll_select_shim(PPCContext* ppc_context,
timeval* timeout_in = nullptr; timeval* timeout_in = nullptr;
timeval timeout; timeval timeout;
if (timeout_ptr) { if (timeout_ptr) {
timeout = {static_cast<long>(SHIM_MEM_32(timeout_ptr + 0)), timeout = {static_cast<int32_t>(SHIM_MEM_32(timeout_ptr + 0)),
static_cast<long>(SHIM_MEM_32(timeout_ptr + 4))}; static_cast<int32_t>(SHIM_MEM_32(timeout_ptr + 4))};
Clock::ScaleGuestDurationTimeval(&timeout.tv_sec, &timeout.tv_usec); Clock::ScaleGuestDurationTimeval(
reinterpret_cast<int32_t*>(&timeout.tv_sec),
reinterpret_cast<int32_t*>(&timeout.tv_usec));
timeout_in = &timeout; timeout_in = &timeout;
} }
int ret = select(nfds, readfds_ptr ? &readfds : nullptr, int ret = select(nfds, readfds_ptr ? &readfds : nullptr,