Skip to content

Latest commit

 

History

History
116 lines (80 loc) · 5.01 KB

README.md

File metadata and controls

116 lines (80 loc) · 5.01 KB

Xertz

A Windows API Wrapper

Definitions and datatypes

See Classes for more information
MODULE = std::pair<std::wstring, unsigned long long>
MODULE_LIST = std::vector<std::pair<std::wstring, unsigned long long>>
REGION_LIST = std::vectorXertz::MemoryRegion
PROCESS_INFO = Xertz::ProcessInfo
PROCESS_INFO_LIST = std::vectorXertz::ProcessInfo
NO_SUBSTRING = 0
IS_SUBSTRING = 1
CASE_SENSITIVE = 2
CASE_INSENSITIVE = 3
SCALAR = 0,
DECIBEL = 1,
MUTE = 2,
UNMUTE = 3

Classes

Xertz::SystemInfo

A singleton class that provides information and functions related to you system.

PROCESS_INFO Xertz::SystemInfo::GetProcessInfo(int pid)

Returns a PROCESS_INFO (Xertz::ProcessInfo) that possesses the process ID specified by pid.

PROCESS_INFO Xertz::SystemInfo::GetProcessInfo(std::wstring processName, int substring, int caseSensitive)

Returns a PROCESS_INFO (Xertz::ProcessInfo) which name matches processName considering the criteria of substring and caseSensitive.

PROCESS_INFO_LIST& Xertz::SystemInfo::GetProcessInfoList()

Returns a PROCESS_INFO_LIST& (std::vectorXertz::ProcessInfo&) containing information about all processes.

bool Xertz::SystemInfo::KillProcess(int pid)

Kills the process specified by its process ID (pid). If successful return value is true.

bool Xertz::SystemInfo::KillProcess(std::wstring processName, int substring, int caseSensitive)

Kills the process specified by its name (processName) considering the criteria of substring and caseSensitive. If successful return value is true.

bool Xertz::SystemInfo::GetMasterVolume(float* out, int scalarOrDecibel)

Writes the master volume to *out. scalarOrDecibel defines the interpretation of the audio level. If successful return value is true.

bool Xertz::SystemInfo::SetMasterVolume(float in, int scalarOrDecibel)

Sets the master volume with the value given in in. scalarOrDecibel defines the interpretation of the audio level. If successful return value is true.

bool Xertz::SystemInfo::SetMasterMute(int option)

Mutes or unmutes the Master Volume according the option. If successful return value is true.

Xertz::ProcessInfo

A class that delivers useful information of any running process and features various functions

int Xertz::ProcessInfo::GetPID()

Returns the process ID

std::wstring& Xertz::ProcessInfo::GetProcessName()

Returns the process name.

uint64_t Xertz::ProcessInfo::GetModuleAddress(std::wstring moduleName)

Returns the module address of moduleName. If an error occurred return value is -1.

MODULE_LIST& Xertz::ProcessInfo::GetModuleList()

Returns a MODULE_LIST& (std::vector<std::pair<std::wstring, unsigned long long>>&) containing addresses and names of all modules.

REGION_LIST& Xertz::ProcessInfo::GetRegionList()

Returns a REGION_LIST& (std::vectorXertz::MemoryRegion&) containing all memory regions.

HANDLE Xertz::ProcessInfo::GetHandle(int64_t accessMode, bool inheritHandle)

Returns the HANDLE.

bool Xertz::ProcessInfo::IsX64()

Returns true if 64-bit or false if 32-bit.

bool Xertz::ProcessInfo::IsRunning()

Returns true if currently running. False if suspended.

std::wstring& Xertz::ProcessInfo::GetFilePath()

Returns the exe filepath.

Xertz::MemDump Xertz::ProcessInfo::DumpMemory(uint64_t baseAddress, uint64_t startingAddress, uint64_t size)

Dumps the memory to an object of Xertz::MemDump region of size from baseAddress starting at startingAddress.

bool Xertz::ProcessInfo::FillProcessMemory(uint64_t start, uint64_t writeCount, T val, uint64_t valSize)

Fills the value of val with the specified size of size writeCount times starting at start. If successful return value is true.

T Xertz::ProcessInfo::AllocateRegion(uint64_t size, uint64_t allocationType, uint64_t protection, uint64_t address = NULL)

Allocates a new memory region of size size with the allocation type of allocationType, the protection type of protection. Address can be specified (optional). Return value is the address of the new memory range.

Xertz::MemoryRegion

A class that provides all useful information about a memory region.

T Xertz::MemoryRegion::GetBaseAddress()

Returns the Base Address of the Memory Region of type T

T Xertz::MemoryRegion::GetAllocationBase()

Returns the Allocation Base Address of the memory region of type T

uint64_t Xertz::MemoryRegion::GetAllocationProtect()

Returns the Allocation Protection type

uint64_t Xertz::MemoryRegion::GetRegionSize()

Returns the Region size

int64_t Xertz::MemoryRegion::GetState()

Returns the Mapping state

int64_t Xertz::MemoryRegion::GetProtect()

Returns the access protection code

int64_t Xertz::MemoryRegion::GetType()

Returns the Region Type

int64_t Xertz::MemoryRegion::GetPartitionId()

Returns the Partition ID