Samba (Wikipedie), svobodná implementace SMB a Active Directory, byla vydána ve verzi 4.23.0. Počínaje verzí Samba 4.23 jsou unixová rozšíření SMB3 ve výchozím nastavení povolena. Přidána byla podpora SMB3 přes QUIC. Nová utilita smb_prometheus_endpoint exportuje metriky ve formátu Prometheus.
Správcovský tým repozitáře F-Droid pro Android sdílí doporučení, jak řešit žádosti o odstranění nelegálního obsahu. Základem je mít nastavené formální procesy, vyhrazenou e-mailovou adresu a být transparentní. Zdůrazňují také důležitost volby jurisdikce (F-Droid je v Nizozemsku).
Byly publikovány informace o další zranitelnosti v procesorech. Nejnovější zranitelnost byla pojmenována VMScape (CVE-2025-40300, GitHub) a v upstream Linuxech je již opravena. Jedná se o variantu Spectre. KVM host může číst data z uživatelského prostoru hypervizoru, např. QEMU.
V červenci loňského roku organizace Apache Software Foundation (ASF) oznámila, že se částečně přestane dopouštět kulturní apropriace a změní své logo. Dnes bylo nové logo představeno. "Indiánské pírko" bylo nahrazeno dubovým listem a text Apache Software Foundation zkratkou ASF. Slovo Apache se bude "zatím" dál používat. Oficiální název organizace zůstává Apache Software Foundation, stejně jako názvy projektů, například Apache HTTP Server.
Byla vydána (𝕏) srpnová aktualizace aneb nová verze 1.104 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.104 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Spotify spustilo přehrávání v bezztrátové kvalitě. V předplatném Spotify Premium.
Spoluzakladatel a předseda správní rady americké softwarové společnosti Oracle Larry Ellison vystřídal spoluzakladatele automobilky Tesla a dalších firem Elona Muska na postu nejbohatšího člověka světa. Hodnota Ellisonova majetku díky dnešnímu prudkému posílení ceny akcií Oraclu odpoledne vykazovala nárůst o více než 100 miliard dolarů a dosáhla 393 miliard USD (zhruba 8,2 bilionu Kč). Hodnota Muskova majetku činila zhruba 385 miliard dolarů.
Bylo vydáno Eclipse IDE 2025-09 aneb Eclipse 4.37. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
T-Mobile od 15. září zpřístupňuje RCS (Rich Communication Services) zprávy i pro iPhone.
Společnost ARM představila platformu Arm Lumex s Arm C1 CPU Cluster a Arm Mali G1-Ultra GPU pro vlajkové chytré telefony a počítače nové generace.
Ahoj vsem. Omlouvam se za lama dotaz a predem rikam, ze nejde o skolni ulohu, jen me tpo zajima. Pujcil jsem si od kamose knizku o programovani v C a rad bych se na nedco zeptal. Chtel bych nacist soubor jako vstup a nahradit hledany retezec necim jinym. V unixu se to dela programem sed, ale tady nevim.
Tohle by melo nacist vstup a to mi chodi
#include <stdio.h>
main ()
{
int a;
a = getchar();
while (a !=EOF) {
putchar(a);
}
}
ale musim tam nekam "napasovat" neco jako
if (a == 'hledany retezec') ....
Dekuji za radu vsem, Tomas
V zasade lze asi pouzit dva zpusoby:
No a pak uz bych jen doporucil nenacitat vstup po znacich, ale rovnou po radcich pres (nestandardni funkci) getline.
$ cat str_replace.c |./str_replace '<' '<' |./str_replace '>' '>' $ echo -e "abcd abcd abcd abcd\naaa\nbbb" |./str_replace b X aXcd aXcd aXcd aXcd aaa XXX
#include <stdio.h> #include <stdlib.h> #include <string.h> #define LINE_MAX 1023 #define MATCH_MAX 1024 static int str_replace(char *p_str, size_t str_max, char *p_old, char *p_new) { int i; int len; int line_new_len; int str_len = strlen(p_str); int old_len = 0; int new_len = strlen(p_new); int seek = 0; char line_new[str_max+1]; char *p_match[MATCH_MAX]; p_match[0] = p_str; for (i = 1; i < MATCH_MAX; ++i) { p_match[i] = NULL; } for (i = 1; i < MATCH_MAX; ++i) { if ((p_match[i] = strstr(p_match[i-1]+old_len, p_old)) == NULL) { break; } if (i == 1) { old_len = strlen(p_old); } } line_new_len = (str_len + (new_len - old_len) * (i-1)); if (line_new_len >= str_max) { return -1; } memset(line_new, '\0', str_max+1); for (i = 1; i < MATCH_MAX; ++i) { if (p_match[i] == NULL) { if (i > 1) { strncpy(line_new+seek, p_new, new_len); seek += new_len; } strcpy(line_new+seek, p_match[i-1]+old_len); break; } else { if ((len = p_match[i] - p_match[i-1]) > 0) { if (i > 1) { strncpy(line_new+seek, p_new, new_len); seek += new_len; len -= old_len; strncpy(line_new+seek, p_match[i-1]+old_len, len); seek += len; } else { strncpy(line_new+seek, p_match[i-1], len); seek += len; } } } } memset(p_str, '\0', str_max+1); strncpy(p_str, line_new, str_max); return 0; } int main(int argc, char *argv[]) { char line[LINE_MAX+1]; if (argc != 3) { printf("Usage: %s OLD NEW\n", argv[0]); exit(EXIT_SUCCESS); } memset(line, '\0', LINE_MAX+1); while (fgets(line, LINE_MAX+1, stdin) != NULL) { if (str_replace(line, LINE_MAX, argv[1], argv[2]) == -1) { printf("output buffer is small\n"); exit(EXIT_FAILURE); } printf("%s", line); } exit(EXIT_SUCCESS); }
Ještě by se Ti mohla hodit ukázka jak pracovat s regex.
#include <stdlib.h> #include <stdio.h> #include <string.h> #include <sys/types.h> #include <regex.h> /* * Example: * * YYYY-MM-DDTHH:MM:SS.sss * * PATTERN = '^([0-9]{4})-([0-9]{2})-([0-9]{2})T([0-9]{2}):([0-9]{2}):([0-9]{2}.[0-9]*)$' * STRING = '2009-07-14T20:36:01.123' * * result: * * match start = 0, match stop = 23 * year = 2009 * month = 07 * day = 14 * hour = 20 * minute = 36 * second = 01.123 */ #define MATCH_SIZE 7 #define STRING_MAX 63 static void substr_copy(char *in, char *out, int begin, int end) { int size = end - begin; if (size > STRING_MAX) { size = STRING_MAX; } memset(out, 0, STRING_MAX+1); strncpy(out, in+begin, size); } int main(int argc, char *argv[]) { int retcode; char year[STRING_MAX+1]; char month[STRING_MAX+1]; char day[STRING_MAX+1]; char hour[STRING_MAX+1]; char minute[STRING_MAX+1]; char second[STRING_MAX+1]; char *pattern; char *string; regmatch_t match[MATCH_SIZE]; regex_t re; if (argc != 3) { printf("Usage: %s PATTERN STRING\n", argv[0]); exit(EXIT_SUCCESS); } pattern = argv[1]; string = argv[2]; if ((retcode = regcomp(&re, pattern, REG_EXTENDED)) != 0) { fprintf(stderr, "regcomp() failure: %i\n", retcode); exit(EXIT_FAILURE); } if (regexec(&re, string, MATCH_SIZE, match, 0) == REG_NOMATCH) { fprintf(stderr, "regexec() pattern '%s' not found in string '%s'\n", pattern, string); exit(EXIT_FAILURE); } regfree(&re); substr_copy(string, year, match[1].rm_so, match[1].rm_eo); substr_copy(string, month, match[2].rm_so, match[2].rm_eo); substr_copy(string, day, match[3].rm_so, match[3].rm_eo); substr_copy(string, hour, match[4].rm_so, match[4].rm_eo); substr_copy(string, minute, match[5].rm_so, match[5].rm_eo); substr_copy(string, second, match[6].rm_so, match[6].rm_eo); printf("match start = %i, match stop = %i\n", match[0].rm_so, match[0].rm_eo); printf("year = %s\n", year); printf("month = %s\n", month); printf("day = %s\n", day); printf("hour = %s\n", hour); printf("minute = %s\n", minute); printf("second = %s\n", second); exit(EXIT_SUCCESS); }
Případně by Tě ještě mohla zajímat fce g_regex_replace () z GLib: Perl-compatible regular expressions a nebo knihovna The Better String Library.
Tiskni
Sdílej: