mirror of
https://github.com/fastfetch-cli/fastfetch.git
synced 2025-02-20 11:43:27 +08:00
Added Package Manager support for Void Linux
This adds support for xbps.
This commit is contained in:
parent
b83499d1ec
commit
f4d2b35260
@ -5,8 +5,14 @@
|
|||||||
#define FF_PACKAGES_MODULE_NAME "Packages"
|
#define FF_PACKAGES_MODULE_NAME "Packages"
|
||||||
#define FF_PACKAGES_NUM_FORMAT_ARGS 3
|
#define FF_PACKAGES_NUM_FORMAT_ARGS 3
|
||||||
|
|
||||||
static uint32_t get_num_dirs(const char* dirname) {
|
enum elementType
|
||||||
uint32_t num_dirs = 0;
|
{
|
||||||
|
enumDir = 0,
|
||||||
|
enumFile
|
||||||
|
};
|
||||||
|
|
||||||
|
static uint32_t get_num_elements(const char* dirname, enum elementType type) {
|
||||||
|
uint32_t num_elements = 0;
|
||||||
DIR * dirp;
|
DIR * dirp;
|
||||||
struct dirent *entry;
|
struct dirent *entry;
|
||||||
|
|
||||||
@ -15,23 +21,27 @@ static uint32_t get_num_dirs(const char* dirname) {
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
while((entry = readdir(dirp)) != NULL) {
|
while((entry = readdir(dirp)) != NULL) {
|
||||||
if(entry->d_type == DT_DIR)
|
if(entry->d_type == DT_DIR && type == enumDir)
|
||||||
++num_dirs;
|
++num_elements;
|
||||||
|
if(entry->d_type == DT_REG && type == enumFile)
|
||||||
|
++num_elements;
|
||||||
}
|
}
|
||||||
|
|
||||||
num_dirs -= 2; // accounting for . and ..
|
if(type == enumDir)
|
||||||
|
num_elements -= 2; // accounting for . and ..
|
||||||
|
|
||||||
closedir(dirp);
|
closedir(dirp);
|
||||||
|
|
||||||
return num_dirs;
|
return num_elements;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ffPrintPackages(FFinstance* instance)
|
void ffPrintPackages(FFinstance* instance)
|
||||||
{
|
{
|
||||||
uint32_t pacman = get_num_dirs("/var/lib/pacman/local");
|
uint32_t pacman = get_num_elements("/var/lib/pacman/local", enumDir);
|
||||||
uint32_t flatpak = get_num_dirs("/var/lib/flatpak/app");
|
uint32_t flatpak = get_num_elements("/var/lib/flatpak/app", enumDir);
|
||||||
|
uint32_t xbps = get_num_elements("/var/db/xbps", enumFile);
|
||||||
|
|
||||||
uint32_t all = pacman + flatpak;
|
uint32_t all = pacman + flatpak + xbps;
|
||||||
|
|
||||||
if(all == 0)
|
if(all == 0)
|
||||||
{
|
{
|
||||||
@ -53,6 +63,7 @@ void ffPrintPackages(FFinstance* instance)
|
|||||||
|
|
||||||
FF_PRINT_PACKAGE(pacman)
|
FF_PRINT_PACKAGE(pacman)
|
||||||
FF_PRINT_PACKAGE(flatpak)
|
FF_PRINT_PACKAGE(flatpak)
|
||||||
|
FF_PRINT_PACKAGE(xbps)
|
||||||
|
|
||||||
#undef FF_PRINT_PACKAGE
|
#undef FF_PRINT_PACKAGE
|
||||||
|
|
||||||
@ -63,7 +74,8 @@ void ffPrintPackages(FFinstance* instance)
|
|||||||
ffPrintFormatString(instance, FF_PACKAGES_MODULE_NAME, 0, &instance->config.packagesKey, &instance->config.packagesFormat, NULL, FF_PACKAGES_NUM_FORMAT_ARGS, (FFformatarg[]){
|
ffPrintFormatString(instance, FF_PACKAGES_MODULE_NAME, 0, &instance->config.packagesKey, &instance->config.packagesFormat, NULL, FF_PACKAGES_NUM_FORMAT_ARGS, (FFformatarg[]){
|
||||||
{FF_FORMAT_ARG_TYPE_UINT, &all},
|
{FF_FORMAT_ARG_TYPE_UINT, &all},
|
||||||
{FF_FORMAT_ARG_TYPE_UINT, &pacman},
|
{FF_FORMAT_ARG_TYPE_UINT, &pacman},
|
||||||
{FF_FORMAT_ARG_TYPE_UINT, &flatpak}
|
{FF_FORMAT_ARG_TYPE_UINT, &flatpak},
|
||||||
|
{FF_FORMAT_ARG_TYPE_UINT, &xbps}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user