* Create declarative module scaffolding * Added ram module (WIP) * Updates to options, styling and more. * Added function for styling custom modules. * Added utility functions and cleaned up code * Type and fn name updates. * Update module utils to handle absent values. * Added icon color in style2 that was missing. * Linted utils.ts * Add CPU module and update RAM module to use /proc/meminfo. * Added disk storage module. * Consolidate code * Added netstat module and removed elements from systray default ignore list. * Added keyboard layout module. * Fix hook types and move module to customModules directory * Added updates modules. * Spacing updates * Added weather module. * Added power menu and power module in bar. Increased update default interval to 6 ours. * Updated styling of bar buttons, made power menu label toggleable, etc. * Consolidate code and add dynamic tooltips based on data being used. * Make default custom mogules matugen compatible * Update base theme * Fix custom module background coloring * Remove testing opacity. * Update themes to account for new modules * Update nix stuff for libgtop (Need someone to test this) * Update nix * Update fractions to multiplications * Move styling in style directory * Implement a polling framework for variables that can dynamically adjust polling intervals. * Netstat module updates when interface name is changed. * Readme update
43 lines
1.4 KiB
TypeScript
43 lines
1.4 KiB
TypeScript
const GLib = imports.gi.GLib;
|
|
|
|
import { divide } from 'customModules/utils';
|
|
import { Variable as VariableType } from 'types/variable';
|
|
|
|
export const calculateRamUsage = (round: VariableType<boolean>) => {
|
|
try {
|
|
const [success, meminfoBytes] = GLib.file_get_contents('/proc/meminfo');
|
|
|
|
if (!success || !meminfoBytes) {
|
|
throw new Error('Failed to read /proc/meminfo or file content is null.');
|
|
}
|
|
|
|
const meminfo = new TextDecoder('utf-8').decode(meminfoBytes);
|
|
|
|
const totalMatch = meminfo.match(/MemTotal:\s+(\d+)/);
|
|
const availableMatch = meminfo.match(/MemAvailable:\s+(\d+)/);
|
|
|
|
if (!totalMatch || !availableMatch) {
|
|
throw new Error('Failed to parse /proc/meminfo for memory values.');
|
|
}
|
|
|
|
const totalRamInBytes = parseInt(totalMatch[1], 10) * 1024;
|
|
const availableRamInBytes = parseInt(availableMatch[1], 10) * 1024;
|
|
|
|
let usedRam = totalRamInBytes - availableRamInBytes;
|
|
usedRam = isNaN(usedRam) || usedRam < 0 ? 0 : usedRam;
|
|
|
|
|
|
return {
|
|
percentage: divide([totalRamInBytes, usedRam], round.value),
|
|
total: totalRamInBytes,
|
|
used: usedRam,
|
|
free: availableRamInBytes,
|
|
};
|
|
|
|
} catch (error) {
|
|
console.error('Error calculating RAM usage:', error);
|
|
return { total: 0, used: 0, percentage: 0 };
|
|
}
|
|
};
|
|
|