Open source modální textový editor Helix, inspirovaný editory Vim, Neovim či Kakoune, byl vydán ve verzi 25.07. Přehled novinek se záznamy terminálových sezení v asciinema v oznámení na webu. Detailně v CHANGELOGu na GitHubu.
Americký výrobce čipů Nvidia získal od vlády prezidenta Donalda Trumpa souhlas s prodejem svých pokročilých počítačových čipů používaných k vývoji umělé inteligence (AI) H20 do Číny. Prodej těchto čipů speciálně upravených pro čínský trh by tak mohl být brzy obnoven, uvedla firma na svém blogu. Americká vláda zakázala prodej v dubnu, v době eskalace obchodního sporu mezi oběma zeměmi. Tehdy to zdůvodnila obavami, že by čipy mohla využívat čínská armáda.
3D software Blender byl vydán ve verzi 4.5 s prodlouženou podporou. Podrobnosti v poznámkách k vydání. Videopředstavení na YouTube.
Open source webový aplikační framework Django slaví 20. narozeniny.
V Brestu dnes začala konference vývojářů a uživatelů linuxové distribuce Debian DebConf25. Na programu je řada zajímavých přednášek. Sledovat je lze online.
Před 30 lety, tj. 14. července 1995, se začala používat přípona .mp3 pro soubory s hudbou komprimovanou pomocí MPEG-2 Audio Layer 3.
Výroba 8bitových domácích počítačů Commodore 64 byla ukončena v dubnu 1994. Po více než 30 letech byl představen nový oficiální Commodore 64 Ultimate (YouTube). S deskou postavenou na FPGA. Ve 3 edicích v ceně od 299 dolarů a plánovaným dodáním v říjnu a listopadu letošního roku.
Společnost Hugging Face ve spolupráci se společností Pollen Robotics představila open source robota Reachy Mini (YouTube). Předobjednat lze lite verzi za 299 dolarů a wireless verzi s Raspberry Pi 5 za 449 dolarů.
Dnes v 17:30 bude oficiálně vydána open source počítačová hra DOGWALK vytvořena v 3D softwaru Blender a herním enginu Godot. Release party proběhne na YouTube od 17:00.
McDonald's se spojil se společností Paradox a pracovníky nabírá také pomocí AI řešení s virtuální asistentkou Olivii běžící na webu McHire. Ian Carroll a Sam Curry se na toto AI řešení blíže podívali a opravdu je překvapilo, že se mohli přihlásit pomocí jména 123456 a hesla 123456 a získat přístup k údajům o 64 milionech uchazečů o práci.
|v C. Kod nize funguje jako rourapro prikazy bez parametru, ale premyslim, jak to udelat, aby roura fungovala obecne, tj. zpracovavala by jako argumenty shellovske prikazy i s jejich pripadnymi parametry. Kod nize spousti shellovsky prikaz
prikaz1 | prikaz2 dvajako
./pipe prikaz1 prikaz 2a ja bych chtel aby to fungovalo napriklad jako:
./pipe prikaz1 -abcde prikaz2 -a -b -cNapadaji me jenom same drsne zpusoby jak to vyresit, pomoci ruzneho parsovani, ale tim by se kod stal prilis robustni
int main(int argc,char **argv) { int fd[2]; pipe(fd); pid_t childpid; pid_t pid = fork(); if (childpid == -1) { perror("Error forking..."); exit(1); } if (pid == -1) return -1; if (pid == 0) { close(fd[1]); //close write to pipe, in child dup2(fd[0], STDIN_FILENO); // Replace stdin with the read end of the pipe close(fd[0]); // Don't need another copy of the pipe read end hanging about execlp(argv[2],argv[2],argv[3],NULL); } else { close(fd[0]); //close read from pipe, in parent dup2(fd[1], STDOUT_FILENO); // Replace stdout with the write end of the pipe close(fd[1]); // Don't need another copy of the pipe write end hanging about execlp(argv[1],argv[1],NULL); } return EXIT_SUCCESS; }
Řešení dotazu:
./pipe command1 -s -tisicem param etru %DELIMITER% command2 -s -jinym --tisicem par ametru
cat test
a druhý xargs file
, nedokážete určit, kde to správně rozdělit (záměrně jsem vybral taková jména, kde každé slovo je zároveň i jméno existujícího programu).
Nejjednodušší řešení je to zauvozovkovat, tedy aby se ten program i s parametry předával jako jeden parametr, a místo execlp
použít system
:
./pipe "prikaz1 -abcde" "prikaz2 -a -b -c"
@Vysledny kod vypada takto:
int main(int argc,char *argv[]) { if (argc < 2) { printf("Programme must be run with with arguments and using pipe shell symbol as a delimiter!\n" "For example: ./pipe ls -la @ grep -v .c\n"); exit(1); } int count; int fd[2]; char command1[50]; char command2[50]; char arguments1[50]; char arguments2[50]; strcpy(command1, argv[1]); strcpy(arguments1, " "); strcpy(arguments2, " "); count = 2; for (; count < argc; count++) { if (strcmp(argv[count], "@") == 0) { break; } strcat(arguments1, argv[count]); strcat(arguments1, " "); } arguments1[strlen(arguments1)-1] = '\0'; //removing ending space strcat(command1, arguments1); strcpy(command2, argv[count+1]); count += 2; for ( ; count < argc; count++) { strcat(arguments2, argv[count]); strcat(arguments2, " "); } arguments1[strlen(arguments2)-1] = '\0'; strcat(command2, arguments2); pipe(fd); pid_t pid = fork(); if (pid == -1) return -1; if (pid == 0) { close(fd[1]); //close write to pipe, in child dup2(fd[0], STDIN_FILENO); // Replace stdin with the read end of the pipe close(fd[0]); // Don't need another copy of the pipe read end hanging about system(command2); } else { close(fd[0]); //close read from pipe, in parent dup2(fd[1], STDOUT_FILENO); // Replace stdout with the write end of the pipe close(fd[1]); // Don't need another copy of the pipe write end hanging about; system(command1); } return EXIT_SUCCESS; }
mkfifo()?
fopen: No such file or directoryDOsavadni kod:
int main(int argc,char *argv[]) { if (argc < 2) { printf("Programme must be run with with arguments and using pipe shell symbol as a delimiter!\n" "For example: ./pipe ls -la @ grep -v .c\n"); exit(1); } int count, fw, fr; char command1[50]; char command2[50]; char arguments1[50]; char arguments2[50]; strcpy(command1, argv[1]); strcpy(arguments1, " "); strcpy(arguments2, " "); count = 2; for (; count < argc; count++) { if (strcmp(argv[count], "@") == 0) { break; } strcat(arguments1, argv[count]); strcat(arguments1, " "); } arguments1[strlen(arguments1)-1] = '\0'; //removing ending space strcat(command1, arguments1); strcpy(command2, argv[count+1]); count += 2; for ( ; count < argc; count++) { strcat(arguments2, argv[count]); strcat(arguments2, " "); } arguments1[strlen(arguments2)-1] = '\0'; strcat(command2, arguments2); mkfifo(FIFO_FILE, S_IFIFO|0666); pid_t pid = fork(); if (pid == -1) return -1; if (pid == 0) { //close(fifo); //close write to pipe, in child //dup2(fifo, STDIN_FILENO); // Replace stdin with the read end of the pipe //close(fifo); // Don't need another copy of the pipe read end hanging about if(fr = fopen(FIFO_FILE, "r") == NULL) { perror("fopen"); exit(1); } dup2(fr, STDIN_FILENO); close(fr); system(command2); } else { //close(fifo); //close read from pipe, in parent //dup2(fifo, STDOUT_FILENO); // Replace stdout with the write end of the pipe //close(fifo); // Don't need another copy of the pipe write end hanging about; if(fw = fopen(FIFO_FILE, "w") == NULL) { perror("fopen"); exit(1); } dup2(fw, STDOUT_FILENO); close(fw); system(command1); } return EXIT_SUCCESS; }
Tiskni
Sdílej: