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 12:33 | Humor

Byl vydán remake filmu Ghost in the Shell. Tentokrát v Bashi. Zhlédnout lze online na "ssh ghost@theshell.xyz" [Hacker News].

Ladislav Hagara | Komentářů: 8
včera 20:40 | Zajímavý článek

Lukáš Růžička v článku S Hydrogenem za lepší rytmus aneb bubeníkem snadno a rychle na MojeFedora.cz představuje automatického bubeníka s názvem Hydrogen (Wikipedie): Hydrogen je velmi vydařený program, který rozhodně nesmí chybět ve výbavě žádného linuxového muzikanta. Umožňuje nejen vytváření jednoduchých bicích doprovodů, ale také sofistikované programování bicích a perkusí, jehož výsledek se naprosto vyrovná drahým

… více »
Ladislav Hagara | Komentářů: 7
včera 13:55 | Zajímavý projekt

UPSat (Twitter) je první open source nanodružice (CubeSat). Jedná se o společný projekt nadace Libre Space Foundation a University of Patras. Repozitáře projektu jsou k dispozici na GitHubu. Pod Libre Space Foundation patří také projekt SatNOGS (zprávička), projekt globální sítě open source pozemních satelitních stanic, vítězný projekt soutěže The Hackaday Prize 2014. UPSat je součástí mise QB50 (Twitter). ID UPSatu je GR02. GPS přijímač na UPSatu je od české společnosti SkyFox Labs. Součástí mise QB50 je i česká nanodružice VZLUSAT-1 s ID CZ02.

Ladislav Hagara | Komentářů: 4
21.4. 15:00 | Komunita

V diskusním listu Thunderbird planning vývojáři poštovního klienta Thunderbird řeší, zda by nebylo možné budoucí Thunderbird postavit nad webovými technologiemi, tj. nad Electronem, stejně jako například Nylas Mail. Gecko, nad kterým je Thunderbird postaven, se má hodně změnit. V plánu je odstranění vlastností, které Firefox už nepotřebuje, ale Thunderbird je na nich závislý [Hacker News, reddit].

Ladislav Hagara | Komentářů: 91
21.4. 10:22 | Bezpečnostní upozornění

Společnost Oracle vydala čtvrtletní bezpečnostní aktualizaci svých softwarových produktů (CPU, Critical Patch Update). Opraveno bylo celkově 299 bezpečnostních chyb. V Oracle Java SE je například opraveno 8 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 7 z nich. V Oracle MySQL je opraveno 39 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 11 z nich.

Ladislav Hagara | Komentářů: 8
21.4. 10:00 | Pozvánky

V úterý 25. dubna proběhne další Prague Containers Meetup. Přijďte se nechat inspirovat jak zlepšit build/delivery pipeline vašich kontejnerových aplikací.

little-drunk-jesus | Komentářů: 2
20.4. 21:33 | Komunita

Na Launchpadu se objevilo kódové jméno následující verze Ubuntu. Ubuntu 17.10 bude Artful Aardvark (mazaný hrabáč) [OMG! Ubuntu!].

Ladislav Hagara | Komentářů: 11
20.4. 20:11 | Zajímavý software

MojeFedora.cz informuje, že společnost Nylas oznámila vydání verze 2.0 poštovního klienta Nylas Mail (původně Nylas N1), která již plně podporuje Linux. Obchodní model společnosti je tzv. open core. Samotný klient je open source, ale uživatel si musí připlatit za některé pokročilé funkce. V základu se lze připojit k GMailu nebo libovolnému účtu přes IMAP. Podpora Exchange je pouze v placené verzi. Klient je napsaný nad Electronem.

Ladislav Hagara | Komentářů: 12
20.4. 15:55 | Zajímavý článek

České centrum pro investigativní žurnalistiku (ČCIŽ) publikovalo na svých stránkách článek s názvem Je česká státní správa „rukojmím Microsoftu“?. Drtivá většina české veřejné správy je závislá na výrobcích softwarového gigantu Microsoft – a nijak zvlášť jí to nevadí.

Ladislav Hagara | Komentářů: 21
20.4. 02:48 | Nová verze

Google Chrome 58 byl prohlášen za stabilní. Nejnovější stabilní verze 58.0.3029.81 tohoto webového prohlížeče přináší řadu oprav a vylepšení (YouTube). Opraveno bylo 29 bezpečnostních chyb. Mezi nimi i chyba umožňující phishing s unicode doménami.

Ladislav Hagara | Komentářů: 0
Chystáte se pořídit CPU AMD Ryzen?
 (4%)
 (35%)
 (0%)
 (7%)
 (45%)
 (10%)
Celkem 282 hlasů
 Komentářů: 32, poslední dnes 12:24
    Rozcestník

    Dotaz: čtení /proc/sys/dev/cdrom/info

    Jardík avatar 12.11.2006 00:02 Jardík | skóre: 40 | blog: jarda_bloguje
    čtení /proc/sys/dev/cdrom/info
    Přečteno: 216×
    Mám takový problém. Snažím se přečíst soubor /proc/sys/dev/cdrom/info, bohužel se mi nedaří. Soubor je otevřen POSIX funkcí open() s přístupem O_RDONLY. Soubor se otevře (tj. funkce nevrátí -1). Poté v cyklu načítám bajt po bajtu (v souboru nelze seekovat a zjistit tak jeho velikost):
    while( read( fd, (void*)&bajt, 1 ) == 1 )
    {
      ....
    }
    
    Problém je v tom, že se načte pouze první znak. Pro další pak funkce vrátí 0 (ne -1, což by znamenalo chybu). Zajímalo by mě, jak takový soubor načíst.
    Věřím v jednoho Boha.

    Odpovědi

    Jardík avatar 13.11.2006 21:04 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: čtení /proc/sys/dev/cdrom/info
    Tak jsem se porozhlídnul všude možně po internetu a našel jsem jeden útržek kódu, kde na soubor v proc byly také použity fce open a read s tím rozdílem, že tam byl buffer něco přes 8000. Poprvé bylo vrácen počet přečtených bajtů a v druhé 0 (tj. EOF). Tak mě napadá, jestli se celý soubor nemusí přečíst najednou????? Nějak se mi kvůli tomu nechce prasit můj kód, takže se radši ptám. Pokud nikdo vědět nebude, tak to asi vyzkouším. Následuje výstup strace -r, kde se načte jen první znak C ze souboru. Zajímavé je, cat vypíše soubor celý (že by dostatečný buffer?). Další zarážející věcí je, že funkce getline() si klidně čte po řádcích. Jak jsem ale řekl, chtěl bych použít funkci open() a read() - kvůli jiným možnostem otevírání, než mi nabízí funkce fopen().
    0.000040 write(1, "Debug: Application constructor -"..., 40) = 40
    0.000491 write(1, "Debug: Application contructor - "..., 37) = 37
    0.000170 brk(0)                    = 0x804a000
    0.000027 brk(0x806b000)            = 0x806b000
    0.000043 open("/proc/sys/dev/cdrom/info", O_RDONLY|O_LARGEFILE) = 3
    0.000073 write(1, "File opened", 11) = 11
    0.000069 write(1, "\n", 1)         = 1
    0.000081 read(3, "C", 1)           = 1
    0.000041 write(1, "Debug: something readed\n", 24) = 24
    0.000088 read(3, "", 1)            = 0
    0.000028 write(1, "C", 1)          = 1
    0.000059 write(1, "\n", 1)         = 1
    0.000073 read(3, "", 1)            = 0
    0.000031 write(1, "Debug: Application::run() - begi"..., 35) = 35
    0.000088 close(3)                  = 0
    
    Zde je část kódu programu:
    int main( ... )
    {
    	...
    	File cdroms;
    	File stdOut;
    	stdOut.openStdOut();
    	if( cdroms.open("/proc/sys/dev/cdrom/info", fmReadOnly ) )
    	{
    		stdOut.writeLine("File opened");
    		String line;
    		while( cdroms.readLine(line) )
    		{
    			stdOut.writeLine(line);
    		}
    		cdroms.close();
    	}
    	...
    }
    
    bool File::open( const String& fileName, FileMode mode, Permission perms )
    {
    	close();
    	m_pHandle = ::open( fileName.cStr(), mode | O_LARGEFILE, (mode_t)perms );
    	return opened();
    }
    
    Int64 File::read( Byte *data, Int64 size ) const
    {
    	if( size <= 0 ) return 0;
    	if(!opened()) return -1;
    	Int64 totalReaded = 0;
    	Int64 readed = 0, toRead = 0;
    	do{
    		toRead = MIN(size-totalReaded,SSIZE_MAX);
    		readed = (Int64)::read( m_pHandle, (void*)data, (size_t)toRead );
    		if( readed == 0 ) break; //EOF
    		if( readed < 0 ) return readed; //error
    		totalReaded += readed;
    		data += readed;
    	} while(totalReaded < size);	
    	return totalReaded;
    }
    
    bool File::readLine( String& str ) const
    {
    	bool somethingReaded = false;
    	str.clear();
    	Char chr;
    	
    	if( read( (Byte*)&chr, 1 ) == 1 )
    	{
    		somethingReaded = true;
    		do{
    			if( chr == 0 ) break;
    			else if( chr == '\r' ) {
    				prevR = true;
    				break;
    			} else if( chr == '\n' ) {
    				if(prevR) {
    					prevR = false;
    					continue;
    				} else break;
    			} else {
    				prevR = false;
    				str.append(chr);
    			}
    		} while( read( (Byte*)&chr, 1 ) == 1 );
    	}
    	
    	return somethingReaded;
    }
    
    Věřím v jednoho Boha.
    Jardík avatar 13.11.2006 21:33 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: čtení /proc/sys/dev/cdrom/info
    Hmm, takže jsem se dočetl, že je to bug v kernelu: http://lkml.org/lkml/2006/10/20/121.
    Věřím v jednoho Boha.

    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.