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í
×

včera 01:23 | Komunita

Phoronix spustil 2017 Linux Laptop Survey. Tento dotazník s otázkami zaměřenými na parametry ideálního notebooku s Linuxem lze vyplnit do 6. července.

Ladislav Hagara | Komentářů: 2
23.6. 22:44 | Nová verze

Po třech měsících vývoje od vydání verze 5.5.0 byla vydána verze 5.6.0 správce digitálních fotografií digiKam (digiKam Software Collection). Do digiKamu se mimo jiné vrátila HTML galerie a nástroj pro vytváření videa z fotografií. V Bugzille bylo uzavřeno více než 81 záznamů.

Ladislav Hagara | Komentářů: 1
23.6. 17:44 | Nová verze

Byla vydána verze 9.3 open source alternativy GitHubu, tj. softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech, GitLab. Představení nových vlastností v příspěvku na blogu a na YouTube.

Ladislav Hagara | Komentářů: 3
23.6. 13:53 | Nová verze

Simon Long představil na blogu Raspberry Pi novou verzi 2017-06-21 linuxové distribuce Raspbian určené především pro jednodeskové miniaturní počítače Raspberry Pi. Společně s Raspbianem byl aktualizován také instalační nástroj NOOBS (New Out Of the Box Software). Z novinek lze zdůraznit IDE Thonny pro vývoj v programovacím jazyce Python a především offline verzi Scratche 2.0. Ten bylo dosud možné používat pouze online. Offline bylo možné používat pouze Scratch ve verzi 1.4. Z nového Scratchu lze ovládat také GPIO piny. Scratch 2.0 vyžaduje Flash.

Ladislav Hagara | Komentářů: 1
22.6. 14:24 | Nová verze

Opera 46, verze 46.0.2597.26, byla prohlášena za stabilní. Nejnovější verze tohoto webového prohlížeče je postavena na Chromiu 59. Z novinek lze zmínit například podporu APNG (Animated Portable Network Graphics). Přehled novinek pro vývojáře na blogu Dev.Opera. Oznámení o vydání zmiňuje také první televizní reklamu.

Ladislav Hagara | Komentářů: 0
22.6. 13:37 | IT novinky

I čtenáři AbcLinuxu před dvěma lety vyplňovali dotazníky věnované Retro ThinkPadu. Nyní bylo potvrzeno, že iniciativa Retro ThinkPad je stále naživu a Lenovo připravuje speciální edici ThinkPadu jako součást oslav jeho 25. výročí.

Ladislav Hagara | Komentářů: 24
22.6. 10:22 | Komunita

Bylo oznámeno, že frontend a runtime programovacího jazyka D bude začleněn do kolekce kompilátorů GCC (GNU Compiler Collection). Správcem byl ustanoven Iain Buclaw.

Ladislav Hagara | Komentářů: 7
21.6. 18:47 | IT novinky
Bulharská firma Olimex je známá jako výrobce kvalitních mini arm desek, u nichž se snaží být maximálně open source. Kromě velké otevřenosti taktéž zaručují dlouhodobou podporu výroby, což je vítáno ve firemním prostředí. Nyní firma ohlásila ESP32-GATEWAY, malou IoT desku s Wifi, Bluetooth, Ethernetem a 20 GPIO porty za 22EUR. Tato malá deska je ořezanou verzí ESP32-EVB.
Max | Komentářů: 21
21.6. 18:00 | Zajímavý článek

LinuxGizmos (v dubnu loňského roku přejmenován na HackerBoards a v lednu letošního roku zpět na LinuxGizmos) zveřejnil výsledky čtenářské ankety o nejoblíbenější jednodeskový počítač (SBC) v roce 2017. Letos se vybíralo z 98 jednodeskových počítačů (Tabulky Google). Nejoblíbenějšími jednodeskovými počítači v letošním roce jsou Raspberry Pi 3 Model B, Raspberry Pi Zero W a Raspberry Pi 2 Model B.

Ladislav Hagara | Komentářů: 0
21.6. 14:22 | Pozvánky

Ne-konference jOpenSpace 2017 se koná od 13. do 15. října 2017 v hotelu Farma u Pelhřimova. Registrace účastníků je nutná. Více informací na stránkách ne-konference.

Zdenek H. | Komentářů: 0
Chystáte se pořídit CPU AMD Ryzen?
 (6%)
 (31%)
 (1%)
 (9%)
 (44%)
 (9%)
Celkem 836 hlasů
 Komentářů: 65, poslední 1.6. 19:16
    Rozcestník

    Dotaz: fw=fopen(SETUP_FILE, "wb");

    5.8.2006 12:28 Petr Šobáň | skóre: 79 | blog: soban | Olomouc
    fw=fopen(SETUP_FILE, "wb");
    Přečteno: 84×
    Mám takový menší problém:

    Potřebuji zapisovat do souboru takže mám:

    fw=fopen(SETUP_FILE, "wb");

    No a pokud jako soubor uvedu pouze soubor tak se mě tam zapíše do aktuálního adresáře,

    #define SETUP_FILE "setup.cfg"

    ale to nechci chci ho zapisovat do /home/petr/.turnusy/ což se mě nedaří.

    #define SETUP_FILE "/home/petr/.turnusy/setup.cfg"

    Přitom ten soubor je spuštěn pod tím uživatelem petr, potřebuji poradit jak se to správně zapisuje pod linuxem, naposledy jsem si něco psal pod dosem a tam prava nejsou takže mi to fungovalo.

    Odpovědi

    Luboš Doležel (Doli) avatar 5.8.2006 12:31 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Existuje adresář /home/petr/.turnusy/ ?
    5.8.2006 12:41 Petr Šobáň | skóre: 79 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    I když existuje tak to hodí chybu.

    Právě nevím jak se to vlastně dělá zda se pod linuxem musí vytvářet adresáře zvlášť a potom se do těch adresářů přepnout a pak zapisovat jenom ty soubory.

    Právě fopen pokud je jako parametr pouze soubor tak OK pokud i s cestou tak je chyba.
    5.8.2006 12:56 Semo | skóre: 44 | blog: Semo
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Aka chyba? kontrolovat navratovu hodnotu a errno.
    If you hold a Unix shell up to your ear, you can you hear the C.
    5.8.2006 13:05 Petr Šobáň | skóre: 79 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Jo už jsem přišel na chybičku měl jsem tam blbé písmenko v cestě, takže mě to do toho adresáře zapíše pokud existuje.

    Teď bych potřeboval poradit jak vlastně najít cestu do domovského adresáře abych nemusel mít v programu natvrdo /home/petr/ když to bude spouštět třeba franta aby tam bylo /home/franta/ ?
    5.8.2006 13:08 Petr Šobáň | skóre: 79 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Abych byl přesnější něco jako ~ v bashu ?
    5.8.2006 13:41 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    printf("$HOME = %s\n", getenv("HOME"));;-)
    Kdo si hraje nezlobí:-)
    5.8.2006 13:57 Petr Šobáň | skóre: 79 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Dík taková blbost a nenapadla mě :-(
    5.8.2006 14:23 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Neni zac, preju hodne zdaru.
    Kdo si hraje nezlobí:-)
    5.8.2006 16:13 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Záleží na tom, co přesně vás zajímá. Tohle nezjistí domácí adresář, ale obsah proměnné HOME. Skutečný domácí adresář by se zjistil zhruba takto:
      buf_length = sysconf(_SC_GETPW_R_SIZE_MAX);
      char buff[buf_length];
      struct passwd pwd;
      struct passwd* rptr;
      getpwuid_r(id, &pwd, buff, buf_length, &rptr);
      if (!rptr) ...
      /* máte to v pwd.pw_name */
    
    5.8.2006 16:25 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    ano souhlasim, jen tedy s tim ze getpwuid_r() je zamaskovano v hlavickovych souborech pomoci # if defined __USE_SVID || defined __USE_MISC narozdil od getenv(), ktere je volne... holt zalezi jestli se treba program nekompiloval s -ansi... pak by to byl problem... ale jinak je jasne ze getenv() vraci pouze prommenne prostredi...
    Kdo si hraje nezlobí:-)
    5.8.2006 16:30 Petr Šobáň | skóre: 79 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Mě getenv() stačí pokud si uživatel nastaví proměnnou HOME jinam bude mít samozřejmě konfigurační soubory jinde což mě netrápí.

    PS. Program je to pouze pro mě který mi bude z databáze vypisovat co mám mět za směnu u nepravidelného turnusu.
    5.8.2006 16:30 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Jste si tím jistý? V mém pwd.h je tato funkce deklarována vždy, blok, o kterém pravděpodobně mluvíte, obsahuje pouze getpwent_r(). Pokud by byly problémy, můžete samozřejmě použít getpwuid(), ale od té doby, co jsem si začal hrát s thready, používám raději reentrantní varianty všude.
    5.8.2006 16:47 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    to proc jste pouzil _r funkci je mi zrejme, taky by me nebavilo porad pouzivat pthread_mutex_lock() a pthread_mutex_unlock() pro zamykani sdilenych dat... ovsem u me je skutecne v souboru pwd.h funkce getpwent_r() zamaskovana... staci dat man getpwent_r a zobrazi se toto (cast):
    SYNOPSIS
           #define _GNU_SOURCE
           #include <pwd.h>
    
           int getpwent_r(struct passwd *pwbuf, char *buf,
                          size_t buflen, struct passwd **pwbufp);
    
           int fgetpwent_r(FILE *fp, struct passwd *pwbuf, char *buf,
                           size_t buflen, struct passwd **pwbufp);
    coz je snad vserikajici...
    Kdo si hraje nezlobí:-)
    5.8.2006 17:05 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Co máte za distribuci? Já tam žádné '#define _GNU_SOURCE' nemám. Dokonce mám dvě verze té stránky, ani jedna neobsahuje požadavek na žádná další makra a jedna z nich je navíc označena jako POSIX Programmer's Manual. Příslušná část pwd.h pak vypadá takto:
    # if defined __USE_SVID || defined __USE_MISC
    /* This function is not part of POSIX and therefore no official
       cancellation point.  But due to similarity with an POSIX interface
       or due to the implementation it is a cancellation point and
       therefore not marked with __THROW.  */
    extern int getpwent_r (struct passwd *__restrict __resultbuf,
                           char *__restrict __buffer, size_t __buflen,
                           struct passwd **__restrict __result);
    # endif
    
    extern int getpwuid_r (__uid_t __uid,
                           struct passwd *__restrict __resultbuf,
                           char *__restrict __buffer, size_t __buflen,
                           struct passwd **__restrict __result);
    
    extern int getpwnam_r (__const char *__restrict __name,
                           struct passwd *__restrict __resultbuf,
                           char *__restrict __buffer, size_t __buflen,
                           struct passwd **__restrict __result);
    
    5.8.2006 17:18 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Distribuce gentoo... navic mam v te manualove strance vyslovne napsano ze je to GNU rozsireni posixovych funkci... V tom vasem vypisu je ale ta cast okolo te funkce taktez zamaskovana viz komentar
    This function is not part of POSIX and therefore no official
    cancellation point.  But due to similarity with an POSIX interface
    or due to the implementation it is a cancellation point and
    therefore not marked with __THROW.
    jinak jeste z manualove stranky:
    CONFORMING TO
           These  functions  are  GNU  extensions,  done in a style resembling the
           POSIX version of functions like getpwnam_r(3).
    Kdo si hraje nezlobí:-)
    5.8.2006 17:27 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");

    Kdyby to bylo rozšíření, neměla by ta funkce manuálovou stránku označenou POSIX Programmer's Manual, ty jsou jen u skutečně posixových funkcí.

    V tom vasem vypisu je ale ta cast okolo te funkce taktez zamaskovana viz komentar…

    Není. Ten komentář a podmíněný překlad se týkají jen funkce getpwent_r(), ale hned za ní je #endif, takže na getpwuid_r() a getpwnam_r() se to už nevztahuje, ty jsou deklarovány vždy.

    5.8.2006 18:30 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    sorry, trochu jsem se prekoukl co potom vlastne hledam za funkci...:-) my fault... Jo jenom tak naokraj ohledne hlavickovyho souboru pwd.h respektive aji grp.h nestalo se ti, ze kdyz jsi projizdel alokovanou pamet valgrindem pri pouziti funkci getpwnam(user); a getgrnam(group);, tak zustala alokovana pamet, ktera nesla zrusit... lamal jsem si s tim hlavu celej den a nic... free hazelo errory a jeste napsal ze tu pamet nejde zrusit ale zustalo ji tam pak min, ale porad nejaka zustala... pouzivam to na zmenu opravneni na takovym programku, nevim jak to nazvat, asi jednosmerna proxy... je to primo z nejakejch doporucenejch zdroju, jak na to... koukal jsem se trebas do zdrojaku apache a tam na nejaky uvolnovani uplne pecou, presne tak jak to bylo v tom prikladu... stejne tak v jakymkoli serveru co jsem se dival na zdrojaky... jen me stve ze tam nekde neco zustane, tak nevim...
    Kdo si hraje nezlobí:-)
    5.8.2006 19:18 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Tohle jsem nezkoumal, ale moc by mne to nepřekvapilo. Někde se paměť pro strukturu, kterou ty funkce vracejí, vzít musí a dealokovat ji knihovna dost dobře nemůže, protože neví, jak dlouho ji program bude potřebovat. Naštěstí aspoň může použít při opakovaném volání funkce stejný buffer. Tenhle přístup, kdy za uvolnění paměti není zodpovědná ani knihovna ani aplikace, považuji právě za jeden z důvodů, proč dávat přednost reentrantním verzím i v single-thread programech.
    5.8.2006 13:52 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    printf("$HOME = %s\n", getenv("HOME"));;-)
    Kdo si hraje nezlobí:-)
    5.8.2006 14:55 Petr Šobáň | skóre: 79 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Takže jsem to vyřešil tak že program nastaví svůj pracovní adresář na HOME uživatele.

    chdir( getenv("HOME") );

    No a potom otevření pro zápis do souboru:
    
    #define SETUP_FILE ".turnusy/setup.cfg"
    
    FILE *fw;
    
    fw=fopen(SETUP_FILE, "wb");
    
    if(fw==NULL)
    {
      mkdir(".turnusy", 0770);
      fw=fopen(SETUP_FILE, "wb");
      if(fw==NULL)
       {
         perror("Chyba");
         return -1;
       }
    }
    
    
    Jinak díky za pomoc.
    Luboš Doležel (Doli) avatar 5.8.2006 14:57 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Není lepší dát natvrdo ten mkdir() před první fopen()?
    5.8.2006 15:06 Petr Šobáň | skóre: 79 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Není protože ten adresář už může existovat se starými soubory.

    A snažit se vytvořit adresář který už existuje se mi nezdá správné, prostě vytvářím ho až když zjistím že tam není.
    Luboš Doležel (Doli) avatar 5.8.2006 15:17 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    No jak myslíte. Takhle máte akorát mnohem nepřehlednější kód, který se dá zkrátit. mkdir() navíc vám nic nezkazí.
    5.8.2006 15:38 Petr Šobáň | skóre: 79 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    No jo ale zase se zbytečně používá když už je adresář vytvořen, chtělo by to vyjádření nějakého odborníka na C aby rozhodl co je lepší.
    Luboš Doležel (Doli) avatar 5.8.2006 15:41 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    V každém programu se najde mnoho zbytečných věcí navíc. Jeden syscall na začátku programu navíc, tomu tedy říkám opravdu "hrůza".
    5.8.2006 16:02 Petr Šobáň | skóre: 79 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    No tak jsem dal na vás a předělal to :-)
    5.8.2006 16:02 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    No ale zase proc ho tam zbytecne vnaset, ze... no myslim ze na takoveto urvni to nema cenu ani moc resit, takoveto mini programky a jejich mini casti ktere se volaji jednou za zivot programu, stejnak mnoho zla neudelaji... mnohem dulezitejsi si myslim je otazka, zda se testuje existence $HOME a nasledne jeho adresare, s tim jestli se do nej povedlo prejit... toto je opravdu jedno, hlavne ze se to testuje a pobezi to...
    Kdo si hraje nezlobí:-)
    5.8.2006 16:07 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Osobně bych dal přednost kontrole existence a případně i access(..., W_OK). Ale asi je to věc vkusu.
    5.8.2006 16:11 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Plne souhlasim;-) ale v zrovna v tomto pripade je to i takle snad dostacujici... cili toto je na konkretnim autorovi...
    Kdo si hraje nezlobí:-)

    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.