Společnost Valve publikovala přehled To nej roku 2025 ve službě Steam aneb ohlédnutí za nejprodávanějšími, nejhranějšími a dalšími nej hrami roku 2025.
Byly publikovány výsledky průzkumu mezi uživateli Blenderu uskutečněného v říjnu a listopadu 2025. Zúčastnilo se více než 5000 uživatelů.
V dokumentově orientované databázi MongoDB byla nalezena a v upstreamu již opravena kritická bezpečností chyba CVE-2025-14847 aneb MongoBleed.
Při úklidu na Utažské univerzitě se ve skladovacích prostorách náhodou podařilo nalézt magnetickou pásku s kopií Unixu V4. Páska byla zaslána do počítačového muzea, kde se z pásky úspěšně podařilo extrahovat data a Unix spustit. Je to patrně jediný známý dochovaný exemplář tohoto 52 let starého Unixu, prvního vůbec programovaného v jazyce C.
FFmpeg nechal kvůli porušení autorských práv odstranit z GitHubu jeden z repozitářů patřících čínské technologické firmě Rockchip. Důvodem bylo porušení LGPL ze strany Rockchipu. Rockchip byl FFmpegem na porušování LGPL upozorněn již téměř před dvěma roky.
K dispozici je nový CLI nástroj witr sloužící k analýze běžících procesů. Název je zkratkou slov why-is-this-running, 'proč tohle běží'. Klade si za cíl v 'jediném, lidsky čitelném, výstupu vysvětlit odkud daný spuštěný proces pochází, jak byl spuštěn a jaký řetězec systémů je zodpovědný za to, že tento proces právě teď běží'. Witr je napsán v jazyce Go.
Yazi je správce souborů běžící v terminálu. Napsán je v programovacím jazyce Rust. Podporuje asynchronní I/O operace. Vydán byl v nové verzi 25.12.29. Instalovat jej lze také ze Snapcraftu.
Od soboty do úterý probíhá v Hamburku konference 39C3 (Chaos Communication Congress) věnovaná také počítačové bezpečnosti nebo hardwaru. Program (jiná verze) slibuje řadu zajímavých přednášek. Streamy a záznamy budou k dispozici na media.ccc.de.
Byl představen nový Xserver Phoenix, kompletně od nuly vyvíjený v programovacím jazyce Zig. Projekt Phoenix si klade za cíl být moderní alternativou k X.Org serveru.
XLibre Xserver byl 21. prosince vydán ve verzi 25.1.0, 'winter solstice release'. Od založení tohoto forku X.Org serveru se jedná o vůbec první novou minor verzi (inkrementovalo se to druhé číslo v číselném kódu verze).
#!/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: