Ondřej Filip publikoval reportáž z ceremonie podpisu kořenové zóny DNS. Zhlédnout lze také jeho nedávnou přednášku Jak se podepisuje kořenová zóna Internetu v rámci cyklu Fyzikální čtvrtky FEL ČVUT.
Společnost BenQ uvádí na trh novou řadu monitorů RD určenou pro programátory. První z nich je RD240Q.
Byl aktualizován seznam 500 nejvýkonnějších superpočítačů na světě TOP500. Nejvýkonnějším superpočítačem nadále zůstává Frontier od HPE (Cray) s výkonem 1,206 exaFLOPS. Druhá Aurora má oproti loňsku přibližně dvojnásobný počet jader a dvojnásobný výkon: 1,012 exaFLOPS. Novým počítačem v první desítce je na 6. místě Alps. Novým českým počítačem v TOP500 je na 112. místě C24 ve Škoda Auto v Mladé Boleslavi. Ostravská Karolina, GPU
… více »GHC (Glasgow Haskell Compiler, Wikipedie), tj. překladač funkcionálního programovacího jazyka Haskell (Wikipedie), byl vydán ve verzi 9.10.1. Přehled novinek v poznámkách k vydání.
Po 9 týdnech vývoje od vydání Linuxu 6.8 oznámil Linus Torvalds vydání Linuxu 6.9. Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna. Později také na Linux Kernel Newbies.
Byla vydána verze 0.2.0 v Rustu napsaného frameworku Pingora pro vytváření rychlých, spolehlivých a programovatelných síťových systémů. Společnost Cloudflare jej letos v únoru uvolnila pod licencí Apache 2.0.
Open source RDP (Remote Desktop Protocol) server xrdp (Wikipedie) byl vydán ve verzi 0.10.0. Z novinek je vypíchnuta podpora GFX (Graphic Pipeline Extension). Nová větev řeší také několik bezpečnostních chyb.
Rocky Linux byl vydán v nové stabilní verzi 9.4. Přehled novinek v poznámkách k vydání.
Dellu byla odcizena databáze zákazníků (jméno, adresa, seznam zakoupených produktů) [Customer Care, Bleeping Computer].
V lednu byl otevřen editor kódů Zed od autorů editoru Atom a Tree-sitter. Tenkrát běžel pouze na macOS. Byl napevno svázán s Metalem. Situace se ale postupně mění. V aktuálním příspěvku Kdy Zed na Linuxu? na blogu Zedu vývojáři popisují aktuální stav. Blíží se alfa verze.
/proc/self/exe
ukazuje na aktuální binárku...
#include <limits.h> #include <stdio.h> #include <string.h> #include <unistd.h> /* Finds the path containing the currently running program executable. The path is placed into BUFFER, which is of length LEN. Returns the number of characters in the path, or -1 on error. */ size_t get_executable_path (char* buffer, size_t len) { char* path_end; /* Read the target of /proc/self/exe. */ if (readlink ("/proc/self/exe", buffer, len) <= 0) return -1; /* Find the last occurrence of a forward slash, the path separator. */ path_end = strrchr (buffer, '/'); if (path_end == NULL) return -1; /* Advance to the character past the last slash. */ ++path_end; /* Obtain the directory containing the program by truncating the path after the last slash. */ *path_end = '\0'; /* The length of the path is the number of characters up through the last slash. */ return (size_t) (path_end - buffer); } int main () { char path[PATH_MAX]; get_executable_path (path, sizeof (path)); printf ("this program is in the directory %s\n", path); return 0; }
strrchr
na bufferu hned po readlink
? Mě se to nezdá:
readlink() does not append a null byte to buf.
int main(int argc, char* argv[]) { printf("%s\n", argv[0]) return 0; }
#include <libgen.h> int main(int argc, char* argv[]) { printf("%s\n", dirname(argv[0])) return 0; }argv[0] mi připadá mnohem portabilnější než /proc (který třeba nemusí být ani na všech Linuxových instalacích, o jiných unix-like OS či win/dos ani nemluvě).
#include <stdio.h> int main(int argc,char** argv) { int i; for(i=0;i<argc;i++) printf("ARG %d: %s\n", i, argv[i]); return 0; }
lubos@ares ~ $ ./test ARG 0: ./testTomu říkáte absolutní cesta?
$0
na funkční cestu k němu.
/proc/self/exe
.
Navíc je potřeba mít na paměti, že na otázku "ve kterém adresáři se nachází tento soubor" nemusí být jednoznačná odpověď nebo dokonce může odpověď znít "v žádném"…
PATH
, jen jménem, bude v argv[0]
jen to jméno.
Tiskni Sdílej: