abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×

dnes 22:33 | IT novinky

Společnosti Adobe, Apple, Facebook, Google, Microsoft a Mozilla společně oznámily konec Flashe. Podpora Flashe oficiálně skončí na konci roku 2020.

Ladislav Hagara | Komentářů: 0
dnes 05:55 | Komunita

Před 10 lety, v červenci 2007, se začal prodávat svobodný chytrý telefon Neo 1973 (vnitřní označení GTA01). Za jeho vývojem stáli vývojáři projektu Openmoko (Wikipedie). O rok později bylo možné koupit jejich druhý telefon Neo FreeRunner (GTA02). V roce 2011 byl představena platforma GTA04. Tuto platformu využívá také projekt Neo900, jehož cílem je vývoj nástupce telefonu Nokia N900. Nahlédnutí do historie Openmoko a další informace v článku na Vanille.de [Hacker News].

Ladislav Hagara | Komentářů: 20
dnes 04:44 | Komunita

Tým Debianu zabývající se reprodukovatelnými sestaveními (Reproducible Builds), tj. kdokoli může nezávisle ověřit, že daný binární .deb balíček vznikl překladem daných zdrojových kódů, oznámil, že 94 % balíčků Debianu lze přeložit a sestavit reprodukovatelně. V únory 2015 to bylo 83 % [reddit].

Ladislav Hagara | Komentářů: 4
včera 11:22 | Komunita

Mozilla.cz informuje, že na blogu Mozilly věnovaném bezpečnosti byly zveřejněny výsledky bezpečnostního auditu služby Firefox Accounts, v českých překladech účet Firefoxu, sloužící hlavně k přihlašování k synchronizaci Firefox Sync. Nalezeno bylo celkem 15 bezpečnostních chyb, z toho jedna byla označena jako kritická a tři jako vážné.

Ladislav Hagara | Komentářů: 0
včera 11:00 | Nová verze

Byla vydána první stabilní verze 1.0 svobodného komunikačního softwaru Ring (Wikipedie). Ring, původně SFLphone, je součástí projektu GNU [reddit].

Ladislav Hagara | Komentářů: 3
včera 06:00 | Zajímavý projekt

Warner Skoch na svých stránkách zveřejnil návod (YouTube) na zhotovení kapesní herní konzole MintyPi. Konzole MintyPi je postavena na Raspberry Pi Zero W a RetroPie. Jako obal slouží plechová krabička od mentolek.

Ladislav Hagara | Komentářů: 0
23.7. 02:00 | Nová verze

Byl vydán Debian 9.1, tj. první opravná verze Debianu 9 s kódovým názvem Stretch a Debian 8.9, tj. devátá opravná verze Debianu 8 s kódovým názvem Jessie. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 9 a Debianu 8 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

Ladislav Hagara | Komentářů: 36
22.7. 15:50 | Zajímavý článek

Nadace The Document Foundation (TDF) zastřešující vývoj svobodného kancelářského balíku LibreOffice zveřejnila čtyřiačtyřicetistránkovou výroční zprávu za rok 2016. K dispozici je ve formátu pdf ve vysokém (21,68 MB) a nízkém (7,1 MB) rozlišení. Zpráva byla vytvořena ve Scribusu.

Ladislav Hagara | Komentářů: 0
22.7. 14:40 | Zajímavý software

Mozilla.cz informuje, že Firefox Focus pro Android, velmi jednoduchý prohlížeč zaměřený na anonymní prohlížení, dosáhl milionu stažení. Firefox Focus blokuje sledující prvky a reklamy a při ukončení automaticky smaže všechna uložená data stránek, historii prohlížení a cookies.

Ladislav Hagara | Komentářů: 41
22.7. 14:20 | Komunita

Vyplněním dotazníku na Formuláře Google lze ovlivnit výběr výchozích aplikací v Ubuntu 18.04 LTS. Podrobnosti v příspěvku Dustina Kirklanda na Ubuntu Insights [reddit].

Ladislav Hagara | Komentářů: 11
Těžíte nějakou kryptoměnu?
 (4%)
 (3%)
 (18%)
 (76%)
Celkem 80 hlasů
 Komentářů: 4, poslední dnes 15:16
    Rozcestník

    Dotaz: zacatecnik v C - nahrazeni retezce

    19.7.2009 12:42 zacatecnik
    zacatecnik v C - nahrazeni retezce
    Přečteno: 852×

    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

    Odpovědi

    19.7.2009 13:22 fafsdfs
    Rozbalit Rozbalit vše Re: zacatecnik v C - nahrazeni retezce

    V zasade lze asi pouzit dva zpusoby:

    • V cyklu testovat rovnost dvou retezcu nebo podretezcu. Na to si bud napises jednouchou funkci nebo doporcujuju pouzit funkci strncmp ze string.h. (viz man strncmp, man string)
    • Aby jsi se citil jak v sedu, pak pouzij funkce z regex.h (pouziti je trochu slozitejsi, ale urcite na webu najdes ukazky).

    No a pak uz bych jen doporucil nenacitat vstup po znacich, ale rovnou po radcich pres (nestandardni funkci) getline.

    Fuky avatar 19.7.2009 14:52 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: zacatecnik v C - nahrazeni retezce
    Příloha:

    $ cat str_replace.c |./str_replace '<' '&lt' |./str_replace '>' '&gt'
    $ 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);
    }
    

    Fuky avatar 19.7.2009 15:36 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: zacatecnik v C - nahrazeni retezce
    Příloha:

    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);
    }
    

    19.7.2009 15:49 zacatecnik
    Rozbalit Rozbalit vše Re: zacatecnik v C - nahrazeni retezce
    Diky moc vsem
    Fuky avatar 19.7.2009 16:29 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: zacatecnik v C - nahrazeni retezce
    19.7.2009 15:49 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: zacatecnik v C - nahrazeni retezce
    Příloha:
    Já bych na to šel nějak takto...

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.