Po 8. květnu 2026 už na Instagramu nebudou podporované zprávy opatřené koncovým šifrováním. V chatech, kterých se bude změna týkat, se objeví pokyny o tom, jak si média nebo zprávy z nich stáhnout, pokud si je chcete ponechat.
V lednu byla ve veřejné betě obnovena sociální síť Digg (Wikipedie). Dnes bylo oznámeno její ukončení (Hard Reset). Společnost Digg propouští velkou část týmu a přiznává, že se nepodařilo najít správné místo na trhu. Důvody jsou masivní problém s boty a silná konkurence. Společnost Digg nekončí, malý tým pokračuje v práci na zcela novém přístupu. Cílem je vybudovat platformu, kde lze důvěřovat obsahu i lidem za ním. Od dubna se do Diggu na plný úvazek vrací Kevin Rose, zakladatel Diggu z roku 2004.
MALUS je kontroverzní proprietarní nástroj, který svým zákazníkům umožňuje nechat AI, která dle tvrzení provozovatelů nikdy neviděla původní zdrojový kód, analyzovat dokumentaci, API a veřejná rozhraní jakéhokoliv open-source projektu a následně úplně od píky vygenerovat funkčně ekvivalentní software, ovšem pod libovolnou licencí.
Příspěvek na blogu Ubuntu upozorňuje na několik zranitelností v rozšíření Linuxu o mandatorní řízení přístupu AppArmor. Společně jsou označovány jako CrackArmor. Objevila je společnost Qualys (technické detaily). Neprivilegovaný lokální uživatel se může stát rootem. Chyba existuje od roku 2017. Doporučuje se okamžitá aktualizace. Problém se týká Ubuntu, Debianu nebo SUSE. Red Hat nebo Fedora pro mandatorní řízení přístupu používají SELinux.
Byla vydána nová verze 19 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v changelogu.
Bitwig Studio (Wikipedie) bylo vydáno ve verzi 6. Jedná se o proprietární multiplatformní (macOS, Windows, Linux) digitální pracovní stanici pro práci s audiem (DAW).
Společnost Igalia představila novou linuxovou distribuci (framework) s názvem Moonforge. Jedná se o distribuci určenou pro vestavěné systémy. Vychází z projektů Yocto a OpenEmbedded.
Google Chrome 146 byl prohlášen za stabilní. Nejnovější stabilní verze 146.0.7680.71 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 29 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.
D7VK byl vydán ve verzi 1.5. Jedná se o fork DXVK implementující překlad volání Direct3D 3 (novinka), 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.
Bylo vydáno Eclipse IDE 2026-03 aneb Eclipse 4.39. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
uint8_t search_sensors(void) {
uint8_t i;
uint8_t id[OW_ROMCODE_SIZE];
uint8_t diff;
bool akva1, akva2, lednice, mistnost;
while(1) {
//writestr("+4 NACITAM SENZORY");
//lfcr();
m_delay_ms(250);
nSensors = 0;
akva1_id = -1;
akva2_id = -1;
lednice_id = -1;
mistnost_id = -1;
for(uint8_t iN = 0; iN<MAXSENSORS; iN++) { // nemá vliv na chování
for(uint8_t iN2 = 0; iN2<OW_ROMCODE_SIZE; iN2++) {
gSensorIDs[iN][iN2] = 0;
}
}
for(diff = OW_SEARCH_FIRST; diff != OW_LAST_DEVICE && nSensors < MAXSENSORS; ) {
DS18X20_find_sensor( &diff, &id[0] );
if( diff == OW_PRESENCE_ERR ) break;
if( diff == OW_DATA_ERR ) break;
akva1 = true;
akva2 = true;
lednice = true;
mistnost = true;
for (i=0;i<OW_ROMCODE_SIZE;i++) {
gSensorIDs[nSensors][i]=id[i];
if(akva1) {
eeprom_busy_wait();
if( gSensorIDs[nSensors][i] != eeprom_read_byte((uint8_t*)(EEPROM_AKVA1_SENSOR+i)) ) akva1 = false;
}
if(akva2) {
eeprom_busy_wait();
if( gSensorIDs[nSensors][i] != eeprom_read_byte((uint8_t*)(EEPROM_AKVA2_SENSOR+i)) ) akva2 = false;
}
if(lednice) {
eeprom_busy_wait();
if( gSensorIDs[nSensors][i] != eeprom_read_byte((uint8_t*)(EEPROM_LEDNICE_SENSOR+i)) ) lednice = false;
}
if(mistnost) {
eeprom_busy_wait();
if( gSensorIDs[nSensors][i] != eeprom_read_byte((uint8_t*)(EEPROM_MISTNOST_SENSOR+i)) ) mistnost = false;
}
}
if(akva1 && !akva2 && !lednice && !mistnost) {
akva1_id = nSensors;
leds_add(port_led_akva1);
}
if(!akva1 && akva2 && !lednice && !mistnost) {
akva2_id = nSensors;
leds_add(port_led_akva2);
}
if(!akva1 && !akva2 && lednice && !mistnost) {
lednice_id = nSensors;
leds_add(port_led_lednice);
}
if(!akva1 && !akva2 && !lednice && mistnost) {
mistnost_id = nSensors;
}
nSensors++;
}
if( nSensors ) return nSensors;
leds_search();
leds_blink(LED_BLINK_FAST_INTERVAL);
m_delay_s(1);
}
}
void vypsat_senzory() {
nSensors = search_sensors();
for ( int i=0; i<nSensors; i++ ) {
writestr("#");
writestr_integer((int) i);
if(i == akva1_id)
writestr(":AKVA1:");
if(i == akva2_id)
writestr(":AKVA2:");
if(i == lednice_id)
writestr(":LEDNICE:");
if(i == mistnost_id)
writestr(":MISTNOST:");
writestr(" ");
writetemp(getTemp(i));
lfcr();
}
}
void uloz_senzor( uint8_t *id, uint8_t kam ) {
for (int i=0; i<OW_ROMCODE_SIZE; i++) {
eeprom_busy_wait();
eeprom_write_byte((uint8_t*)(kam+i),id[i]);
}
}
void nastav_senzor(char cilselekt) {
uint8_t sensT = (uint8_t)(rx_buffer[0]-48);
writestr_integer((int) sensT); lfcr();
if ( sensT < nSensors ) {
if(cilselekt == '1')
uloz_senzor(&gSensorIDs[sensT][0], EEPROM_AKVA1_SENSOR);
else if(cilselekt == '2')
uloz_senzor(&gSensorIDs[sensT][0], EEPROM_AKVA2_SENSOR);
else if(cilselekt == 'l')
uloz_senzor(&gSensorIDs[sensT][0], EEPROM_LEDNICE_SENSOR);
else if(cilselekt == 'm')
uloz_senzor(&gSensorIDs[sensT][0], EEPROM_MISTNOST_SENSOR);
else errorWrite(1);
writestr("+1 OK");
lfcr();
nSensors = search_sensors();
vypsat_senzory();
}
else
errorWrite(1);
}
void eeprog_vstup_podprogram() {
if(citac_ee > 0) {
for (uint8_t i=RX_BUFFER_SIZE; i>0; i--) rx_buffer[i]=0;
rs232enter=0;
rs232ready=true;
while(1) {
if(rs232enter) {
rs232ready=false;
if(cmdtest('L','S',0))
vypsat_senzory();
else if(cmdtest('S','A',1))
nastav_senzor('1');
else if(cmdtest('S','B',1))
nastav_senzor('2');
else if(cmdtest('S','L',1))
nastav_senzor('l');
else if(cmdtest('S','M',1))
nastav_senzor('m');
else if(cmdtest('E','Q',0)) {
writestr("+1 OK"); lfcr();
break;
}
else
errorWrite(3);
for (uint8_t i=RX_BUFFER_SIZE; i>0; i--) rx_buffer[i]=0;
rs232enter=0;
rs232ready=true;
}
}
}
else
errorWrite(4);
}
Samotné search_sensors(void) funguje dobře, opravdu porovnává všechny bajty identifikace senzoru vs. uložená identifikace v eeprom. Problém nastává, pokud chci uložit nový senzor. Všechny se ukládají dobře, kromě 1.(senzor #0). Pokud se jednoduše snažím uložit senzor 0 jako cokoliv, tak je první bajt vždy 0x00. Takhle vypadá část eepromky: 00FBFA97020000A728D6F797020000B72820BA9702000072. Správně ale má být 28FBFA97020000A728D6F797020000B72820BA9702000072. Co mám špatně?
Řešení dotazu:
Tiskni
Sdílej: