Internetový prohlížeč Ladybird ohlásil tranzici z programovacího jazyka C++ do Rustu. Přechod bude probíhat postupně a nové komponenty budou dočasně koexistovat se stávajícím C++ kódem. Pro urychlení práce bude použita umělá inteligence, při portování první komponenty prohlížeče, JavaScriptového enginu LibJS, bylo během dvou týdnů pomocí nástrojů Claude Code a Codex vygenerováno kolem 25 000 řádků kódu. Nejedná se o čistě autonomní vývoj pomocí agentů.
Byl vydán Mozilla Firefox 148.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Nově lze snadno povolit nebo zakázat jednotlivé AI funkce. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 148 bude brzy k dispozici také na Flathubu a Snapcraftu.
Byla vydána nová verze 22.1.0, tj. první stabilní verze z nové řady 22.1.x, překladačové infrastruktury LLVM (Wikipedie). Přehled novinek v poznámkách k vydání: LLVM, Clang, LLD, Extra Clang Tools a Libc++.
X86CSS je experimentální webový emulátor instrukční sady x86 napsaný výhradně v CSS, tedy bez JavaScriptu nebo dalších dynamických prvků. Stránka 'spouští' assemblerovový program mikroprocesoru 8086 a názorně tak demonstruje, že i prosté CSS může fungovat jako Turingovsky kompletní jazyk. Zdrojový kód projektu je na GitHubu.
Po šesti letech byla vydána nová verze 1.3 webového rozhraní ke gitovým repozitářům CGit.
Byla vydána nová verze 6.1 linuxové distribuce Lakka (Wikipedie), jež umožňuje transformovat podporované počítače v herní konzole. Nejnovější Lakka přichází s RetroArchem 1.22.2.
Matematický software GNU Octave byl vydán ve verzi 11.1.0. Podrobnosti v poznámkách k vydání. Vedle menších změn rozhraní jsou jako obvykle zahrnuta také výkonnostní vylepšení a zlepšení kompatibility s Matlabem.
Weston, referenční implementace kompozitoru pro Wayland, byl vydán ve verzi 15.0.0. Přehled novinek v příspěvku na blogu společnosti Collabora. Vypíchnout lze Lua shell umožňující psát správu oken v jazyce Lua.
Organizace Apache Software Foundation (ASF) vydala verzi 29 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.
Ústavní soud na svých webových stránkách i v databázi NALUS (NÁLezy a USnesení Ústavního soudu) představil novou verzi chatbota využívajícího umělou inteligenci. Jeho posláním je usnadnit veřejnosti orientaci v rozsáhlé judikatuře Ústavního soudu a pomoci jí s vyhledáváním informací i na webových stránkách soudu, a to i v jiných jazycích. Jde o první nasazení umělé inteligence v rámci webových stránek a databází judikatury českých soudů.
SECTION .data cislo1 dd 8 cislo2 dd 2 vysledek dd 0 SECTION .text global _start _start: mov eax,[cislo1] mov ebx,[cislo2] add eax,ebx ;sectu cisla mov [vysledek],eax ;ulozim do vysledku mov eax,4 ;prvni parametr cislo systemoveh ovolani mov ebx,1 ;vim, ze konstanta stdout ma hodnotu 1 mov ecx,vysledek mov edx,32 ;pocet znaku int 0x80 ;zavolame jadro mov eax,1 ;cislo volani jadra - exit mov ebx,0 ;navratovy kod 0 int 0x80 ;zavolame jadro
segment code
Write_Word: ; AX=Byte
pushf
pusha
mov si,4
mov bx,10
wwcyc1: mov dx,0
div bx
add dl,'0'
mov [z_w+si],dl
dec si
cmp si,0
jnz wwcyc1
add al,'0'
mov [z_w],al
mov dx,z_w
mov si,0
wwcyc2: cmp [z_w+si],byte '0'
jne wwcont
inc dx
inc si
cmp si,4
jne wwcyc2
wwcont: call Print_Str ; viz. nize
popa
popf
ret
Print_Str: ; DX=String_offset, String='???....???','$'
pushf
pusha
mov ah,9
int 21h ;volani sluzeb DOSu
popa
popf
ret
segment data
z_w resb 2
;-------------- ;NumToAscii ;-------------- ; eax = 32b číslo ; ebx = základ soustavy ; edi = pointer na buffer, kam bude uložen text ;-------------- NumToAscii: pushad xor esi,esi .smycka_prevodu: xor edx,edx div ebx call HexDigit push edx inc esi test eax,eax jnz .smycka_prevodu cld .smycka_zapis: pop eax stosb dec esi test esi,esi jnz .smycka_zapis popad ret HexDigit: cmp dl,10 jb .mensi add dl,'A'-10 ret .mensi: or dl,'0' retPoužití:
mov eax,[vysledek] mov edi,buffer call preved v sekci .DATA buffer: TIMES 12 DB 0Délku můžeš zjistit pomocí strlen:
strlen: push eax xor ecx,ecx xor eax,eax dec ecx cld repne scasb neg ecx pop eax retŘetězec musí být uložen v ES:EDI a délka se vrátí v ecx. Jinak, abyste neřekli, že jsem blázen, tak prozradím, že je to z knihy Učíme se programovat v jazyce assembler pro PC
; překlad:
; nasm -f elf preved.asm
; ld -s -o preved preved.o
SECTION .text
global _start
_start:
; Sečtu Cislo1+Cislo2, výsledek do Vysledek
mov eax,[Cislo1]
mov ebx,[Cislo2]
add eax,ebx
mov [Vysledek],eax
; Převedu Vysledek na text do VysledekText
mov eax,[Vysledek]
mov ebx,10
mov edi,VysledekText
call NumToAscii
; Vytisknu vysledek
mov ebx,VysledekText ; ukazatel na text do ebx
mov esi,ebx ; uložím ho ještě do esi
xor edx,edx
.next:
inc edx ;v edx počítáme počet znaků, co budeme tisknout
lodsb ;načteme znak do al a k esi přičteme 1
or al,al ;jsme už na konci řetězce (al==0)
jnz .next ;ne? přičteme další znak
mov byte [esi-1],0xa ;zapíšeme místo nulového byte na konci řetězce znak nového řádku
mov eax,4 ;systémové volání write( ebx = KAM, ecx = CO, edx = KOLIK )
mov ecx, ebx ;v ebx byla adresa řetězce
mov ebx,1 ;STDOUT
;v edx již je počet znaků
int 0x80 ;přerušení
; konec programu
mov eax, 1
mov ebx, 0
int 0x80
;--------------
;NumToAscii
;--------------
; eax = 32b číslo
; ebx = základ soustavy
; edi = pointer na buffer, kam bude uložen text
;--------------
NumToAscii:
pushad
xor esi,esi
.smycka_prevodu:
xor edx,edx
div ebx
call HexDigit
push edx
inc esi
test eax,eax
jnz .smycka_prevodu
cld
.smycka_zapis:
pop eax
stosb
dec esi
test esi,esi
jnz .smycka_zapis
popad
ret
HexDigit:
cmp dl,10
jb .mensi
add dl,'A'-10
ret
.mensi:
or dl,'0'
ret
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; DATA
SECTION .data
VysledekText TIMES 20 db 0
Cislo1 dd 8
Cislo2 dd 2
Vysledek dd 0
Tiskni
Sdílej: