mirror of
https://github.com/Dr-Noob/cpufetch.git
synced 2026-03-25 16:00:39 +01:00
Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
b02d3d6d11 |
File diff suppressed because one or more lines are too long
@@ -1,19 +0,0 @@
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
████ ███ ███ ████████ ▜███████████
|
||||
██████ █████ █████ ███ ███ ▗▀▀▀▀▀▀▜███
|
||||
███ ███ █████████████ ███ ██ ▐█ ▐███
|
||||
███ ███ ███ ███ ███ ███ ██ ▟██ ▐███
|
||||
████████████ ███ ███ ███ ███ ████▄▄▄▄▄▄▝▜██
|
||||
███ ███ ███ ███ █████████ ████████▛ ██
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -1,3 +0,0 @@
|
||||
#!/bin/bash
|
||||
|
||||
cat intel.txt | hexdump -vC | head -n-1 | cut -d' ' -f2- | cut -d'|' -f1 | tr '\n' ' ' | tr -s ' ' | tr ' ' ',' | sed "s/,/,0x/g"
|
||||
@@ -1,19 +0,0 @@
|
||||
▁▂▃▄▅▆▆▇▇███████▇▇▆▅▅▄▂▁
|
||||
▁▃▄▆▇▛▀▀▀▀▔▔▔ ▔▔▔▀▀▀██▇▅▃
|
||||
▂▄▆█▀▀▔ ▝▜██▅▁
|
||||
▀▀▔ ▔▜██▖
|
||||
▅▅▅ ▆▆▆ ▜██▖
|
||||
▁▅ ▀▀▀ ▐██▌ ███ ██▉
|
||||
▄▛▘ ▄▄▄ ▗▄▄▄▄▄▄▃▁ ▐██▙▄▖ ▁▃▄▅▄▃ ███ ███
|
||||
▗▟▛ ███ ▐██▀▀▀▜██▖ ▐██▛▀▘ ▟██▀▀▀██▖ ███ ▗██▊
|
||||
█▛ ███ ▐██ ▕██▌ ▐██▌ ▐██▂▂▂▂▂██ ███ ▗███▘
|
||||
▐█▍ ███ ▐██ ▕██▌ ▐██▌ ▐██▛▀▀▀▀▀▀ ███ ▄██▛▘
|
||||
██▏ ███ ▐██ ▕██▌ ▐██▌ ▝██▙▁ ▁▂▃ ███ ▅███▀
|
||||
██▍ ▝██ ▐██ ▕██▌ ▀███▋ ▝▀█████▛ ▝▜█ █▀▔
|
||||
▐█▙ ▔▔▔
|
||||
▜█▙▖ ▁▂▄▖
|
||||
▜██▆▃▁ ▁▂▄▅▇███▌
|
||||
▝▜███▇▅▄▃▂▁ ▁▁▂▃▄▅▆▇███████▀▀
|
||||
▔▀▀████████▇▇▇▇▇▇▇▇▇▇███████████▛▀▀▔▔
|
||||
▔▔▀▀▀▀█████████████▀▀▀▀▀▔▔▔
|
||||
|
||||
@@ -51,7 +51,7 @@ NOTES: \n\
|
||||
}
|
||||
|
||||
void print_version() {
|
||||
printf("cpufetch v%s (%s)\n",VERSION, ARCH_STR);
|
||||
printf("cpufetch v%s (%s) [outfile branch]\n",VERSION, ARCH_STR);
|
||||
}
|
||||
|
||||
int main(int argc, char* argv[]) {
|
||||
|
||||
@@ -22,6 +22,7 @@
|
||||
#include <Windows.h>
|
||||
#endif
|
||||
|
||||
#define OUTPUT_FILE "cpufetch.txt"
|
||||
#define max(a,b) (((a)>(b))?(a):(b))
|
||||
#define MAX_ATTRIBUTES 100
|
||||
|
||||
@@ -105,7 +106,6 @@ struct attribute {
|
||||
|
||||
struct ascii {
|
||||
char art[NUMBER_OF_LINES][LINE_SIZE+1];
|
||||
unsigned char* art_unicode;
|
||||
char color1_ascii[100];
|
||||
char color2_ascii[100];
|
||||
char color1_text[100];
|
||||
@@ -160,8 +160,8 @@ struct ascii* set_ascii(VENDOR vendor, STYLE style, struct colors* cs) {
|
||||
|
||||
#ifdef ARCH_X86
|
||||
if(art->vendor == CPU_VENDOR_INTEL) {
|
||||
COL_FANCY_1 = COLOR_FG_CYAN;
|
||||
COL_FANCY_2 = COLOR_FG_WHITE;
|
||||
COL_FANCY_1 = COLOR_BG_CYAN;
|
||||
COL_FANCY_2 = COLOR_BG_WHITE;
|
||||
COL_FANCY_3 = COLOR_FG_CYAN;
|
||||
COL_FANCY_4 = COLOR_FG_WHITE;
|
||||
art->ascii_chars[0] = '#';
|
||||
@@ -263,12 +263,6 @@ struct ascii* set_ascii(VENDOR vendor, STYLE style, struct colors* cs) {
|
||||
if(cs != NULL) {
|
||||
COL_FANCY_1 = rgb_to_ansi(cs->c1, true, true);
|
||||
COL_FANCY_2 = rgb_to_ansi(cs->c2, true, true);
|
||||
#ifdef ARCH_X86
|
||||
if(art->vendor == CPU_VENDOR_INTEL) {
|
||||
COL_FANCY_1 = rgb_to_ansi(cs->c1, false, true);
|
||||
COL_FANCY_2 = rgb_to_ansi(cs->c2, false, true);
|
||||
}
|
||||
#endif
|
||||
COL_FANCY_3 = rgb_to_ansi(cs->c3, false, true);
|
||||
COL_FANCY_4 = rgb_to_ansi(cs->c4, false, true);
|
||||
}
|
||||
@@ -310,11 +304,9 @@ struct ascii* set_ascii(VENDOR vendor, STYLE style, struct colors* cs) {
|
||||
}
|
||||
|
||||
char tmp[NUMBER_OF_LINES * LINE_SIZE + 1];
|
||||
art->art_unicode = NULL;
|
||||
|
||||
#ifdef ARCH_X86
|
||||
if(art->vendor == CPU_VENDOR_INTEL)
|
||||
art->art_unicode = art_unicode_intel;
|
||||
strcpy(tmp, INTEL_ASCII);
|
||||
else if(art->vendor == CPU_VENDOR_AMD)
|
||||
strcpy(tmp, AMD_ASCII);
|
||||
else
|
||||
@@ -334,11 +326,8 @@ struct ascii* set_ascii(VENDOR vendor, STYLE style, struct colors* cs) {
|
||||
strcpy(tmp, ARM_ASCII);
|
||||
#endif
|
||||
|
||||
if(art->art_unicode != NULL) {
|
||||
for(int i=0; i < NUMBER_OF_LINES; i++) {
|
||||
for(int i=0; i < NUMBER_OF_LINES; i++)
|
||||
memcpy(art->art[i], tmp + i*LINE_SIZE, LINE_SIZE);
|
||||
}
|
||||
}
|
||||
|
||||
return art;
|
||||
}
|
||||
@@ -358,45 +347,43 @@ uint32_t longest_attribute_length(struct ascii* art) {
|
||||
}
|
||||
|
||||
#ifdef ARCH_X86
|
||||
void print_algorithm_intel(struct ascii* art, int n, bool* flag) {
|
||||
void print_algorithm_intel(FILE *file, struct ascii* art, int n, bool* flag) {
|
||||
for(int i=0; i < LINE_SIZE; i++) {
|
||||
if(*flag) {
|
||||
if(art->art[n][i] == ' ') {
|
||||
*flag = false;
|
||||
int start = -1;
|
||||
for(int i=0, newlines=0; newlines < n; i++) {
|
||||
if(art->art_unicode[i] == '\n') {
|
||||
newlines++;
|
||||
start = i;
|
||||
}
|
||||
}
|
||||
|
||||
for(int i=start+1, x=0; art->art_unicode[i] != '\n'; i++, x++) {
|
||||
if(art->art_unicode[i] == ' ') {
|
||||
printf(" ");
|
||||
fprintf(file, "%s%c%s", art->color2_ascii, art->ascii_chars[1], art->reset);
|
||||
}
|
||||
else {
|
||||
printf("%s", art->color1_ascii);
|
||||
printf("%c", art->art_unicode[i]);
|
||||
printf("%c", art->art_unicode[i + 1]);
|
||||
printf("%c", art->art_unicode[i + 2]);
|
||||
printf("%s", COLOR_RESET);
|
||||
i += 2;
|
||||
fprintf(file, "%s%c%s", art->color1_ascii, art->ascii_chars[0], art->reset);
|
||||
}
|
||||
}
|
||||
else {
|
||||
if(art->art[n][i] != ' ' && art->art[n][i] != '\0') {
|
||||
*flag = true;
|
||||
fprintf(file, "%c",' ');
|
||||
}
|
||||
else {
|
||||
fprintf(file, "%c",' ');
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void print_algorithm_amd(struct ascii* art, int n, bool* flag) {
|
||||
void print_algorithm_amd(FILE *file, struct ascii* art, int n, bool* flag) {
|
||||
*flag = false; // dummy, just silence compiler error
|
||||
|
||||
for(int i=0; i < LINE_SIZE; i++) {
|
||||
if(art->art[n][i] == '@')
|
||||
printf("%s%c%s", art->color1_ascii, art->ascii_chars[0], art->reset);
|
||||
fprintf(file, "%s%c%s", art->color1_ascii, art->ascii_chars[0], art->reset);
|
||||
else if(art->art[n][i] == '#')
|
||||
printf("%s%c%s", art->color2_ascii, art->ascii_chars[1], art->reset);
|
||||
fprintf(file, "%s%c%s", art->color2_ascii, art->ascii_chars[1], art->reset);
|
||||
else
|
||||
printf("%c",art->art[n][i]);
|
||||
fprintf(file, "%c",art->art[n][i]);
|
||||
}
|
||||
}
|
||||
|
||||
void print_ascii_x86(struct ascii* art, uint32_t la, void (*callback_print_algorithm)(struct ascii* art, int i, bool* flag)) {
|
||||
void print_ascii_x86(FILE *file, struct ascii* art, uint32_t la, void (*callback_print_algorithm)(FILE *file, struct ascii* art, int i, bool* flag)) {
|
||||
int attr_to_print = 0;
|
||||
int attr_type;
|
||||
char* attr_value;
|
||||
@@ -405,9 +392,9 @@ void print_ascii_x86(struct ascii* art, uint32_t la, void (*callback_print_algor
|
||||
uint32_t space_down = NUMBER_OF_LINES - art->n_attributes_set - space_up;
|
||||
bool flag = false;
|
||||
|
||||
printf("\n");
|
||||
fprintf(file, "\n");
|
||||
for(uint32_t n=0;n<NUMBER_OF_LINES;n++) {
|
||||
callback_print_algorithm(art, n, &flag);
|
||||
callback_print_algorithm(file, art, n, &flag);
|
||||
|
||||
if(n > space_up-1 && n < NUMBER_OF_LINES-space_down) {
|
||||
attr_type = art->attributes[attr_to_print]->type;
|
||||
@@ -415,20 +402,20 @@ void print_ascii_x86(struct ascii* art, uint32_t la, void (*callback_print_algor
|
||||
attr_to_print++;
|
||||
|
||||
space_right = 1 + (la - strlen(ATTRIBUTE_FIELDS[attr_type]));
|
||||
printf("%s%s%s%*s%s%s%s\n", art->color1_text, ATTRIBUTE_FIELDS[attr_type], art->reset, space_right, "", art->color2_text, attr_value, art->reset);
|
||||
fprintf(file, "%s%s%s%*s%s%s%s\n", art->color1_text, ATTRIBUTE_FIELDS[attr_type], art->reset, space_right, "", art->color2_text, attr_value, art->reset);
|
||||
}
|
||||
else printf("\n");
|
||||
else fprintf(file, "\n");
|
||||
}
|
||||
printf("\n");
|
||||
fprintf(file, "\n");
|
||||
}
|
||||
|
||||
void print_ascii(struct ascii* art) {
|
||||
void print_ascii(FILE *file, struct ascii* art) {
|
||||
uint32_t longest_attribute = longest_attribute_length(art);
|
||||
|
||||
if(art->vendor == CPU_VENDOR_INTEL)
|
||||
print_ascii_x86(art, longest_attribute, &print_algorithm_intel);
|
||||
print_ascii_x86(file, art, longest_attribute, &print_algorithm_intel);
|
||||
else if(art->vendor == CPU_VENDOR_AMD)
|
||||
print_ascii_x86(art, longest_attribute, &print_algorithm_amd);
|
||||
print_ascii_x86(file, art, longest_attribute, &print_algorithm_amd);
|
||||
else {
|
||||
printBug("Invalid CPU vendor: %d\n", art->vendor);
|
||||
}
|
||||
@@ -440,6 +427,8 @@ bool print_cpufetch_x86(struct cpuInfo* cpu, STYLE s, struct colors* cs) {
|
||||
if(art == NULL)
|
||||
return false;
|
||||
|
||||
FILE *output_file;
|
||||
|
||||
char* uarch = get_str_uarch(cpu);
|
||||
char* manufacturing_process = get_str_process(cpu);
|
||||
char* sockets = get_str_sockets(cpu->topo);
|
||||
@@ -450,7 +439,6 @@ bool print_cpufetch_x86(struct cpuInfo* cpu, STYLE s, struct colors* cs) {
|
||||
char* avx = get_str_avx(cpu);
|
||||
char* fma = get_str_fma(cpu);
|
||||
|
||||
|
||||
char* l1i = get_str_l1i(cpu->cach);
|
||||
char* l1d = get_str_l1d(cpu->cach);
|
||||
char* l2 = get_str_l2(cpu->cach);
|
||||
@@ -488,7 +476,12 @@ bool print_cpufetch_x86(struct cpuInfo* cpu, STYLE s, struct colors* cs) {
|
||||
return false;
|
||||
}
|
||||
|
||||
print_ascii(art);
|
||||
if((output_file = fopen(OUTPUT_FILE, "w+")) == NULL) {
|
||||
perror("fopen");
|
||||
return false;
|
||||
}
|
||||
|
||||
print_ascii(output_file, art);
|
||||
|
||||
free(manufacturing_process);
|
||||
free(max_frequency);
|
||||
|
||||
Reference in New Issue
Block a user