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 05:00 | Nová verze

    Rspamd (Wikipedie), tj. open source systému pro filtrování nevyžádané pošty, byl vydán v nové major verzi 4.0.0. Přehled novinek v Changelogu.

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

    SolveSpace (Wikipedie), tj. multiplatformní open source parametrický 2D/3D CAD, byl vydán v nové verzi 3.2. Přehled novinek v Changelogu na GitHubu. Vyzkoušet lze novou oficiální webovou verzi.

    Ladislav Hagara | Komentářů: 1
    včera 18:22 | Pozvánky

    Organizátoři Dne IPv6, tradiční akce věnované tématům spojeným s tímto protokolem, vyhlásili Call for Abstracts. Na webu konference mohou zájemci přihlašovat příspěvky o délce 20 nebo 40 minut či 10minutové lighting talky a to až do 30. dubna. Tvůrci programu uvítají návrhy přednášek z akademického i komerčního sektoru, které mohou být technického i netechnického zaměření. Den IPv6 se letos uskuteční 4. června a místem konání bude i

    … více »
    VSladek | Komentářů: 1
    včera 15:00 | Zajímavý software

    Euro-Office (Wikipedie) je evropský fork open source kancelářského balíku OnlyOffice. Za forkem stojí koalice firem IONOS, Nextcloud, Eurostack, XWiki, OpenProject, Soverin, Abilian a BTactic. Cílem je zajistit digitální suverenitu Evropy a snížit závislost na neevropských platformách. Projekt vznikl mimo jiné v reakci na nedávné uzavření cloudové služby OnlyOffice. OnlyOffice obviňuje Euro-Office z porušení licenčních podmínek. Na možné problémy upozorňuje i Collabora Online. Jednostranná změna licence není v pořádku.

    Ladislav Hagara | Komentářů: 21
    včera 05:11 | Komunita

    Byly zpracovány a na YouTube zveřejněny videozáznamy jednotlivých přednášek z letošního Installfestu.

    Ladislav Hagara | Komentářů: 1
    včera 00:22 | Komunita

    Během akce Arduino Days 2026 byl publikován Arduino Open Source Report 2025 (pdf) a oznámeno 7 nových produktů kompatibilních s deskou UNO Q (Arduino USB-C Power Supply, USB-C Cable, USB-C Hub, UNO Media Carrier, UNO Breakout Carrier, Bug Hopper, Modulino LED Matrix).

    Ladislav Hagara | Komentářů: 2
    29.3. 20:22 | IT novinky

    Google v pátek spustil v Česku Vyhledávání Live. Tato novinka umožňuje lidem vést plynulou konverzaci s vyhledávačem v češtině. A to prostřednictvím hlasu, nebo prostřednictvím toho, na co ukážou svým fotoaparátem či kamerou v mobilu. Rozšíření této multimodální funkce je možné díky nasazení Gemini 3.1 Flash Live, nového hlasového a audio modelu, který je od základu vícejazyčný, takže umožňuje lidem po celém světě mluvit na vyhledávač přirozeně a v jazyce, který je jim nejbližší.

    Ladislav Hagara | Komentářů: 1
    29.3. 12:55 | Zajímavý software

    Jsongrep je open-source nástroj, který efektivně prohledává JSON dokumenty (editovat je neumí). Kompiluje regulérní jazyk dotazu do podoby deterministického konečného automatu (DFA), díky čemuž prochází strom JSON dokumentu pouze jednou a je v tom tedy rychlejší než jiné nástroje jako jsou například jq, JMESPath nebo jql. Jsongrep je napsaný v programovacím jazyce Rust, zdrojový kód je dostupný na GitHubu.

    NUKE GAZA! 🎆 | Komentářů: 4
    28.3. 05:55 | Komunita

    O víkendu probíhá v Praze na Karlově náměstí 13 konference Installfest 2026. Na programu je celá řada zajímavých přednášek a workshopů. Vstup na konferenci je zcela zdarma, bez nutnosti registrace. Přednášky lze sledovat i online na YouTube.

    Ladislav Hagara | Komentářů: 12
    28.3. 05:22 | Komunita

    Mozilla a společnost Mila oznámily strategické partnerství za účelem rozvoje open source a suverénní AI. Cílem je ukázat, že open source AI může konkurovat uzavřeným systémům. Obě organizace chtějí posílit technologickou suverenitu a snížit závislost na hrstce velkých technologických firem.

    Ladislav Hagara | Komentářů: 4
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (30%)
     (3%)
     (5%)
     (2%)
     (14%)
     (24%)
    Celkem 1190 hlasů
     Komentářů: 27, poslední 17.3. 19:26
    Rozcestník

    Dotaz: pomoc s ladenim kodu v C

    17.8.2009 17:37 ext3fs
    pomoc s ladenim kodu v C
    Přečteno: 323×

    Dobry den,

     chci poprosit s pomoci nalezeni chyby v nasledujicim kodu:

    (komentuji radky kde valgrind hlasi chybu).

    char *get_term(char *str, int pos)                                              
    {                                                                               
    int n;                                                                          
    int word = 0;                                                                   
    int w = 0, w_m = 0;                                                             
    short in_word = 0;                                                              
    short out_word = 0;                                                             
    char **words;                                                                   

        for(n = 0; str[n] != '\0'; n++)                            
        {                                                          
                    if (str[n] == '<' || str[n] == ' ' || str[n] == '>')
                    {                                                   
                    if (in_word)                                        
                    {                                                   
                                    if (w > w_m)                        
                                    w_m = w;                            
                    }                                                   
                    out_word = 1;                                       
                    in_word = 0;                                        
                    w = 0;                                              
                    }                                                   
                    else if (!in_word)                                  
                    {                                                   
                    word++;                                             
                    out_word = 0;                                       
                    in_word = 1;                                        
                    }                                                   
                    if (in_word)                                        
                    w++;                                                
        }                                                               

    /*ZDE*/    if ((words = (char **)malloc(word*(sizeof(char *)))) == NULL)
            {                                                        
                    fprintf(stderr, "chps : %s\n", strerror(errno));
                    exit (1);                                        
            }                                                        
                                                                     
        for (n = 0; n < word; n++)                                   
            {                                                        
                    if ((words[n] = (char *)malloc(w_m*sizeof(char))) == NULL)
                    {                                                         
                            fprintf(stderr, "chps : %s\n", strerror(errno));  
                            exit (1);                                         
                    }                                                         
            }                                                                 

        in_word = out_word = 0;
        w = w_m = word = 0;    
        for(n = 0; str[n] != '\0'; n++)
        {
                    if (str[n] == '<' || str[n] == ' ' || str[n] == '>')
                    {
                    if (in_word)
                    {
                                    if (w > w_m)
                                    {
                                    w_m = w;
                                    }
                                    /*ZDE*/ words[word - 1][w] = '\0';
                    }
                    out_word = 1;
                    in_word = 0;
                    w = 0;
                    }
                    else if (!in_word)
                    {
                    word++;
                    out_word = 0;
                    in_word = 1;
                    }
                    if (in_word)
                    words[word - 1][w++] = str[n];
        }

        if (pos <= word)
                    return(words[pos - 1]);
        else
                    return(" ");
    }

    Funkce se vola napr get_term("<NAME opt1 opt2 opt3>", 2); a

    vrati opt1.

     

    Dekuji.

    Odpovědi

    17.8.2009 19:12 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: pomoc s ladenim kodu v C
    když to chcípe na malloc, tak jste pravděpodobně poškodil haldu zapsáním mimo meze polí. při pohledu na kód se nedivím... není to trochu moc práce kvůli takové blbosti?
    
    #include <string.h>
    #include <stdio.h>
    #include <stdlib.h>
    
    char *get_term(const char *str, int pos)
    {
            char *p, *q, *r;
            size_t len;
    
            if ((pos < 1) || !str) {
                    return NULL;
            }
            len = strlen(str);
            if ((*str != '<') || (str[len - 1] != '>')) {
                    return NULL;
            }
    
            p = (char *)str + 1;
            while (--pos) {
                    p = strchr(p, ' ');
                    if (!p || !*p) {
                            return NULL;
                    }
                    p++;
            }
            q = strchr(p, ' ');
            if (!q) {
                    q = (char *)str + len - 2;
            }
            if (p > q) {
                    return NULL;
            }
            r = malloc(q - p + 2);
            if (!r) {
                    return NULL;
            }
            memcpy(r, p, q - p + 1);
            r[q - p + 1] = '\0';
            return r;
    }
    
    int main()
    {
            const char *s = "<a b c d>";
            int i;
    
            for (i = 1; i <= 5; i++) {
                    char *p = get_term(s, i);
    
                    printf("%d: %s\n", i, p ? p : "not found");
                    if (p) {
                            free(p);
                    }
            }
            return 0;
    }
    
    
    In Ada the typical infinite loop would normally be terminated by detonation.
    17.8.2009 20:34 ext3fs
    Rozbalit Rozbalit vše Re: pomoc s ladenim kodu v C

    Dekuji za spravne nakopnuti. Kod jsem smazal a napsal znovu na polovinu radku a uz to funguje.

    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.