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 03:33 | Zajímavý software

    AI Claude Code od Anthropicu lépe rozumí frameworku Nette, tj. open source frameworku pro tvorbu webových aplikací v PHP. David Grudl napsal plugin Nette pro Claude Code.

    Ladislav Hagara | Komentářů: 0
    dnes 00:11 | Nová verze

    Byla vydána prosincová aktualizace aneb nová verze 1.108 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.108 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    včera 20:44 | IT novinky

    Na lasvegaském veletrhu elektroniky CES byl předveden prototyp notebooku chlazeného pomocí plazmových aktuátorů (DBD). Ačkoliv se nejedná o první nápad svého druhu, nepochybně to je první ukázka praktického použití tohoto způsobu chlazení v běžné elektronice. Co činí plazmové chladící akční členy technologickou výzvou je především vysoká produkce jedovatého ozonu, tu se prý podařilo firmě YPlasma zredukovat dielektrickou

    … více »
    NUKE GAZA! 🎆 | Komentářů: 6
    včera 16:33 | Zajímavý projekt

    Patchouli je open source implementace EMR grafického tabletu (polohovací zařízení). Projekt je hostován na GitLabu.

    Ladislav Hagara | Komentářů: 0
    včera 14:11 | IT novinky

    Český Nejvyšší soud potvrdil, že česká právní úprava plošného uchování dat o elektronické komunikaci porušuje právo Evropské unie. Pravomocným rozsudkem zamítl dovolání ministerstva průmyslu a obchodu. To se teď musí omluvit novináři Českého rozhlasu Janu Cibulkovi za zásah do práv na ochranu soukromí a osobních údajů. Ve sporu jde o povinnost provozovatelů sítí uchovávat údaje, ze kterých lze odvodit, kdo, s kým a odkud komunikoval.

    Ladislav Hagara | Komentářů: 7
    včera 02:11 | Komunita

    Google bude vydávat zdrojové kódy Androidu pouze dvakrát ročně. Ve 2. a 4. čtvrtletí.

    Ladislav Hagara | Komentářů: 0
    7.1. 17:22 | Zajímavý článek

    Bezpečnostní specialista Graham Helton z Low Orbit Security si všímá podezřelých anomálií v BGP, zaznamenaných krátce před vstupem ozbrojených sil USA na území Venezuely, které tam během bleskové speciální vojenské operace úspěšně zatkly venezuelského diktátora Madura za narkoterorismus. BGP (Border Gateway Protocol) je 'dynamický směrovací protokol, který umožňuje routerům automaticky reagovat na změny topologie počítačové sítě' a je v bezpečnostních kruzích znám jako 'notoricky nezabezpečený'.

    NUKE GAZA! 🎆 | Komentářů: 10
    7.1. 06:11 | Nová verze

    Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu dosáhl 3,58 %. Nejčastěji používané linuxové distribuce jsou Arch Linux, Linux Mint a Ubuntu. Při výběru jenom Linuxu vede SteamOS Holo s 26,32 %. Procesor AMD používá 67,43 % hráčů na Linuxu.

    Ladislav Hagara | Komentářů: 4
    7.1. 05:55 | IT novinky

    V Las Vegas probíhá veletrh CES (Consumer Electronics Show, Wikipedie). Firmy představují své novinky. Například LEGO představilo systém LEGO SMART Play: chytré kostky SMART Brick, dlaždičky SMART Tagy a SMART minifigurky. Kostka SMART Brick dokáže rozpoznat přítomnost SMART Tagů a SMART minifigurek, které se nacházejí v její blízkosti. Ty kostku SMART Brick aktivují a určí, co má dělat.

    Ladislav Hagara | Komentářů: 0
    6.1. 18:33 | Bezpečnostní upozornění

    Vládní CERT (GovCERT.CZ) upozorňuje (𝕏) na kritickou zranitelnost v jsPDF, CVE-2025-68428. Tato zranitelnost umožňuje neautentizovaným vzdáleným útočníkům číst libovolné soubory z lokálního souborového systému serveru při použití jsPDF v prostředí Node.js. Problém vzniká kvůli nedostatečné validaci vstupu u cest k souborům předávaných několika metodám jsPDF. Útočník může zneužít tuto chybu k exfiltraci citlivých

    … více »
    Ladislav Hagara | Komentářů: 6
    Které desktopové prostředí na Linuxu používáte?
     (2%)
     (5%)
     (0%)
     (10%)
     (21%)
     (4%)
     (5%)
     (3%)
     (11%)
     (53%)
    Celkem 303 hlasů
     Komentářů: 7, poslední včera 15:35
    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: 285×
    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.