Intel nedávno představil a pod licencí SIL Open Font License (OFL) na GitHubu zveřejnil font Intel One Mono. Font je určen především pro zobrazování textu v emulátorech terminálu a vývojových prostředích (Přehled fontů s pevnou šířkou).
Na redditu byly publikovány zajímavé QR kódy vygenerované pomocí Stable Diffusion. Přehled použitého softwaru v článku na Ars Technica.
Byl vydán Mozilla Firefox 114.0. Přehled novinek v poznámkách k vydání, poznámkách k vydání pro firmy a na stránce věnované vývojářům. Nově jsou také na Linuxu podporovány USB FIDO2/WebAuthn bezpečnostní klíče. WebTransport je ve výchozím stavu povolen. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 114 je již k dispozici také na Flathubu a Snapcraftu.
Byla vydána červnová aktualizace aneb verze 2023.06-1 linuxové distribuce OSMC (Open Source Media Center). Z novinek lze zdůraznit povýšení verze multimediálního centra Kodi na 20. Na léto je plánováno představení nového vlajkového zařízení Vero, jež nahradí Vero 4K +.
Už zítra 7. června od 17 hodin proběhne SUSE Czech Open House 2023 aneb den otevřených dveří pražské pobočky SUSE. Těšit se lze na komentovanou prohlídku nebo přednášku o spotřebě procesorů.
Na vývojářské konferenci Applu WWDC23 byla představena řada novinek (cz): brýle Apple Vision Pro, MacBook Air 15” s čipem M2, Mac Studio s čipem M2 Max nebo M2 Ultra, Mac Pro s čipem M2 Ultra, iOS 17, iPadOS 17, macOS Sonoma, watchOS 10, …
Chystá se poslední jarní Virtuální Bastlírna. Nachystejte si ledové kávy, mojita a vodní chladiče a pojďte se se strahovskými bastlíři pobavit o technice a bastlení! Ptáte se, co mají bastlíři za novinky? Například se ukázalo, že OLED s SSD1306 ve skutečnosti nejsou nutně jen černobílé. Vyšla také nová verze KiCADu včetně betaverze pluginu pro tvorbu databázových knihoven pro KiCAD v InvenTree a na internetu se objevil USB
… více »6. červen je dnem za skutečný internet (neboli Světový den IPv6). Již tradiční příležitost urgovat svého ISP, kdy zavede do sítě IPv6, ale také příležitost šířit osvětu i mezi netechnické uživatele. V současnosti má IPv6 v ČR jen cca 20 % uživatelů (podle statistik společností Akamai a Google).
Festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí Maker Faire Prague 2023 proběhne o víkendu 10. a 11. června na Výstavišti Praha.
Byla vydána verze 8.18 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání.
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: