Wine bylo po roce vývoje od vydání verze 10.0 vydáno v nové stabilní verzi 11.0. Přehled novinek na GitLabu. Vypíchnuta je podpora NTSYNC a dokončení architektury WoW64.
Byl vydán Mozilla Firefox 147.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Firefox nově podporuje Freedesktop.org XDG Base Directory Specification. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 147 bude brzy k dispozici také na Flathubu a Snapcraftu.
Asociace repair.org udělila anticeny těm nejhorším produktům představeným na veletrhu CES 2026. Oceněnými jsou například šmírující kamery Amazon Ring AI, chytrý běžecký pás od společnosti Merach, která otevřeně přiznává, že nedokáže zabezpečit osobní data uživatelů, případně jednorázové lízátko, které rozvibrovává čelisti uživatele a tak přehrává hudbu. Absolutním vítězem je lednička od Samsungu, která zobrazuje reklamy a kterou lze otevřít pouze hlasovým příkazem přes cloudovou službu.
Íránští protirežimní aktivisté si všímají 30% až 80% ztráty packetů při komunikaci se satelity služby Starlink. Mohlo by se jednat o vedlejší důsledek rušení GPS, kterou pozemní přijímače Starlinku používají k výpočtu polohy satelitů a kterou se režim rovněž snaží blokovat, podle bezpečnostního experta a iranisty Amira Rashidiho je ale pravděpodobnější příčinou terestrické rušení přímo satelitní komunikace Starlinku podobnou
… více »Evropská komise (EK) zvažuje, že zařadí komunikační službu WhatsApp americké společnosti Meta mezi velké internetové platformy, které podléhají přísnější regulaci podle unijního nařízení o digitálních službách (DSA). Firmy s více než 45 miliony uživatelů jsou podle DSA považovány za velmi velké on-line platformy (Very Large Online Platforms; VLOP) a podléhají přísnějším pravidlům EU pro internetový obsah. Pravidla po
… více »Tržní hodnota technologické společnosti Alphabet poprvé v historii přesáhla čtyři biliony dolarů (83 bilionů Kč). Stalo se tak poté, co Apple oznámil, že bude na poli umělé inteligence (AI) spolupracovat s dceřinou firmou Alphabetu, společností Google.
Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 161 (pdf).
Po delší době vývoje vyšla nativní linuxová verze virtuálního bubeníka MT-PowerDrumKit 2 ve formátu VST3. Mezi testovanými hosty jsou Reaper, Ardour, Bitwig a Carla.
Desktopové prostředí Budgie bylo vydáno ve verzi 10.10. Dokončena byla migrace z X11 na Wayland. Budgie 10 vstupuje do režimu údržby. Vývoj se přesouvá k Budgie 11. Dlouho se řešilo, v čem bude nové Budgie napsáno. Budgie 10 je postaveno nad GTK 3. Přemýšlelo se také nad přepsáním z GTK do EFL. Budgie 11 bude nakonec postaveno nad Qt 6.
OpenChaos.dev je 'samovolně se vyvíjející open source projekt' s nedefinovaným cílem. Každý týden mohou lidé hlasovat o návrzích (pull requestech), přičemž vítězný návrh se integruje do kódu projektu (repozitář na GitHubu). Hlasováním je možné změnit téměř vše, včetně tohoto pravidla. Hlasování končí vždy v neděli v 9:00 UTC.
#!/bin/bash
for file in /home/hates/maily/*; do
FILE="$file"
ID=`echo $file | cut -d "." -f 1-1 | cut -d "/" -f 5-5`
MAIL=`grep ${ID} /home/hates/adresy.txt | cut -d " " -f 2-2`
echo "Soubor $file odeslan na mail ${MAIL}"
cat $file | mail ${MAIL}
done;
Staci malinko upravit pro tvoje potreby. mozna to jde i jednoduseji. pomoci awk primo rozparsovat ten radek v adresy.txt a potom odeslat prislusny soubor.
Za druhe vlakno se velmi omlouvam, trochu se mi to nepovedlo, nebyl to umysl.
Za skript velmi dekuji, po napasovani na moje podminky funguje velmi dobre. Mel bych jen dve poznamky.
1) Potrebuji poslat soubor jako prilohu, nikoli jako telo mailu. Neco jako:
mutt -s "soubor" -a $file $(MAIL) < default_message.txt
coz mi zatim nefunguje, ale snad to nejak doladim. Pokud by jste vedel, rad se poucim.
2)V puvodnim dotazu jsem nezminil moznost, ze pocet souboru nemusi korespondovat s poctem adres. Dalo by se to jeste zohlednit?
Diky.
#!/bin/bash
# soubor s obsahem mailu musi byt ve tvaru
# <jmeno>.<pripona>
SOUBOR_ADRES="/home/hates/adresy.txt"
SUBJECT="Automaticky odesilany mail"
echo `date +%c` >> /home/hates/neodeslane_maily.txt
for file in /home/hates/maily/*; do
FILE="$file"
ID=`echo $file | cut -d "." -f 1-1 | cut -d "/" -f 5-5`
MAIL=`grep ${ID} ${SOUBOR_ADRES} | cut -d " " -f 2-2`
if [ -z ${MAIL} ]; then
echo "Soubor $file nebyl odeslan. Adresa s ID ${ID} neexistuje" << /home/hates/neodeslane_maily.txt
else
echo "Soubor $file odeslan na mail ${MAIL}"
echo "Odeslan mail s ID ${ID}" | mutt -s "${SUBJECT}" -a $file ${MAIL} > $file
fi
done;
#!/usr/bin/python
# -*- coding: utf-8 -*-
import os
adresy = {}
for line in file('adresy.txt'):
f, addr = line.split()
filename = f + '.txt'
try:
if filename not in adresy[addr]:
adresy[addr].append(filename)
else:
print "Duplicit line", filename, addr
except KeyError:
adresy[addr] = [filename]
for adresa, soubory in adresy.iteritems():
att = '-a ' + ' -a '.join(soubory)
print 'mutt -s "Rozeslane soubory"', adresa, att
projde seznam adres, zjistí co komu poslat, oznámí duplicity a nachystá příkaz pro odeslání. Třeba z tohohle:
001 jenda@koza.com 002 pavel@ovce.com 230 franta@jetel.com 003 pavel@ovce.com 240 franta@jetel.com 200 franta@jetel.com 240 franta@jetel.comUdělá toto:
Duplicit line 240.txt franta@jetel.com mutt -s "Rozeslane soubory" jenda@koza.com -a 001.txt mutt -s "Rozeslane soubory" pavel@ovce.com -a 002.txt -a 003.txt mutt -s "Rozeslane soubory" franta@jetel.com -a 230.txt -a 240.txt -a 200.txt
#!/usr/bin/python
# -*- coding: utf-8 -*-
import os
subject = 'rozeslane soubory'
body = 'Rozeslane soubory\n'
datadir = '/home/honza/datadir'
def posli(adresa, soubory):
cmd = ['mutt', '-s', subject]
for soubor in soubory:
cmd.extend(('-a', os.path.join(datadir, soubor)))
cmd.append(adresa)
print cmd
#w, r = os.popen2(cmd)
#w.write(body)
#w.close()
adresy = {}
souborynadisku = dict([(x, None) for x in os.listdir(datadir)])
souboryvadresach = {}
for linenum, line in enumerate(file('adresy.txt')):
try:
f, addr = line.split()
except:
print 'radek %d: "%s" je divny' %(linenum, line.strip())
continue
filename = f + '.txt'
souboryvadresach[filename] = None
if filename not in souborynadisku:
print 'radek %d: soubor "%s" chybi' %(linenum, filename)
continue
try:
adresy[addr].append(filename)
except KeyError:
adresy[addr] = [filename]
for snd in souborynadisku:
if snd not in souboryvadresach:
print 'Soubor "%s" neni komu poslat' %snd
adr = adresy.keys()
adr.sort()
for adresa in adr:
soubory = adresy[adresa]
posli(adresa, soubory)
Ukázalo se, že je potřeba odchytit co nejvíc chybových situací (divné řádky, chybějící soubory, přebývající soubory), tak se to trochu nafouklo a na efektivitu jsem pak už přestal hledět. Ale prý to funguje
Tiskni
Sdílej: