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 13:55 | Nová verze

    Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 0
    dnes 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

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

    Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.

    Ladislav Hagara | Komentářů: 0
    21.12. 05:00 | Nová verze

    Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 2
    21.12. 01:55 | Nová verze

    GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.

    Ladislav Hagara | Komentářů: 0
    19.12. 17:22 | IT novinky

    Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.

    Ladislav Hagara | Komentářů: 14
    19.12. 17:00 | Komunita

    Nový CEO Mozilla Corporation Anthony Enzor-DeMeo tento týden prohlásil, že by se Firefox měl vyvinout v moderní AI prohlížeč. Po bouřlivých diskusích na redditu ujistil, že v nastavení Firefoxu bude existovat volba pro zakázání všech AI funkcí.

    Ladislav Hagara | Komentářů: 1
    19.12. 10:11 | IT novinky

    V pořadí šestou knihou autora Martina Malého, která vychází v Edici CZ.NIC, správce české národní domény, je titul Kity, bity, neurony. Kniha s podtitulem Moderní technologie pro hobby elektroniku přináší ucelený pohled na svět současných technologií a jejich praktické využití v domácích elektronických projektech. Tento knižní průvodce je ideální pro každého, kdo se chce podívat na současné trendy v oblasti hobby elektroniky, od

    … více »
    Ladislav Hagara | Komentářů: 10
    19.12. 03:11 | Komunita

    Linux Foundation zveřejnila Výroční zprávu za rok 2025 (pdf). Příjmy Linux Foundation byly 311 miliónů dolarů. Výdaje 285 miliónů dolarů. Na podporu linuxového jádra (Linux Kernel Project) šlo 8,4 miliónu dolarů. Linux Foundation podporuje téměř 1 500 open source projektů.

    Ladislav Hagara | Komentářů: 0
    19.12. 02:11 | Zajímavý článek

    Jean-Baptiste Mardelle se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.12.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (27%)
     (2%)
     (13%)
     (2%)
     (2%)
     (2%)
     (11%)
     (27%)
     (16%)
    Celkem 56 hlasů
     Komentářů: 16, poslední včera 23:13
    Rozcestník

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

    5.8.2006 12:28 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    fw=fopen(SETUP_FILE, "wb");
    Přečteno: 250×
    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: 80 | 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: 45 | 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: 80 | 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: 80 | 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: 80 | 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: 80 | 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: 80 | 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: 80 | 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: 80 | 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: 80 | 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.