Richard Biener oznámil vydání verze 16.1 (16.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 16. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.
Zulip Server z open source komunikační platformy Zulip (Wikipedie, GitHub) byl vydán ve verzi 12.0. Přehled novinek v příspěvku na blogu.
Před 30 lety, tj. v úterý 30. dubna 1996, byl spuštěn Seznam.cz.
Byly zpracovány a zveřejněny všechny videozáznamy, které stojí za zveřejnění, z konference FOSDEM 2026.
Od úterý 28. dubna musí nově uváděné notebooky v Evropské unii podporovat nabíjení přes USB-C. Jednotná nabíječka byla schválena Evropským parlamentem v říjnu 2022.
Byly publikovány informace o kritické zranitelnosti CVE-2026-31431 pojmenované Copy Fail v Linuxu, konkrétně v kryptografii (AF_ALG). Běžný uživatel může získat práva roota (lokální eskalaci práv). Na všech distribucích Linuxu vydaných od roku 2017. Pomocí 732bajtového skriptu. V upstreamu je již opraveno. Zranitelnost byla nalezena pomocí AI Xint Code.
Textový editor Zed dospěl do verze 1.0. Představení v příspěvku na blogu.
Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.
VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.
Bylo oznámeno vydání Fedora Linuxu 44. Ve finální verzi vychází šest oficiálních edic: Fedora Workstation a Fedora KDE Plasma Desktop pro desktopové, Fedora Server pro serverové, Fedora IoT pro internet věcí, Fedora Cloud pro cloudové nasazení a Fedora CoreOS pro ty, kteří preferují neměnné systémy. Vedle nich jsou k dispozici také další atomické desktopy, spiny a laby. Podrobný přehled novinek v samostatných článcích na stránkách
… více »Řešení dotazu:
#include <stdio.h>
int main (void)
{
int a;
int b;
int c;
int d;
/* za tento komentar chci vlozit */
return (0);
}
po:
#include <stdio.h>
int main (void)
{
int a;
int b;
int c;
int d;
/* za tento komentar chci vlozit */
int a;
int b;return (0);
} int c;
int d;
Jde o Vim verze 7.2
INSERT INTO tab1 (name) VALUES ("abc");
INSERT INTO tab1 (name) VALUES ("def");
/* chci vytvorit novy SQL prikaz s temi stringy - mezi tyhle dva inserty */
INSERT INTO tab2 (num) VALUES (1);
INSERT INTO tab2 (num) VALUES (2);
výsledek:
INSERT INTO tab1 (name) VALUES ("abc");
INSERT INTO tab1 (name) VALUES ("def");
/* chci vytvorit novy SQL prikaz s temi stringy - mezi tyhle dva inserty */
abc
defINSERT INTO tab2 (num) VALUES (1);
INSERT INTO tab2 (num) VALUES (2);
Jasně, kdyby to byl další insert, tak si zkopíruju celé řádky a blokově přepíšu to co potřebuju (tabulka, sloupce,...), ale o to tu teď nejde. Jde o to, jestli je tohle insert-replace chování správné a pokud ano, tak jak provést čistý insert s blokem textu?
abc defa vložil ho na prázdný řádek příkazem "p" (paste). Nevím k čemu to má být dobré? Každopádně se vim zachoval standardně, odsunul vše co je na následujících řádcích doprava a vložil blok tam, kam jste chtěl. Spíš bych čekal že ho budete vkládat třeba na místo kde je "1" aby blok
1 2nahradil blokem
abc def? Tak pokud najedete na jedničku a dáte "p", tak se to vloží tam, před(nebo za) 1 a 2 se vloží abc a def. 1 a 1 pak ještě musíte blokově smazat. Pokud chcete vytvořit nový SQL příkaz, tak ho ale musíte přece nejdřív vytvořit ;), tedy napsat nějaké to nové INSERT INTO a pak až vkládat blok, ne? Nic takového (ani pokus o to) ve vašem příkladu nevidím :( Takže nevím jestli se to chová nějak opravdu divně nebo jen něco divného děláte :)
Pokud chcete vytvořit nový SQL příkaz, tak ho ale musíte přece nejdřív vytvořit ;), tedy napsat nějaké to nové INSERT INTO a pak až vkládat blok, ne? Nic takového (ani pokus o to) ve vašem příkladu nevidím :( Takže nevím jestli se to chová nějak opravdu divně nebo jen něco divného děláte :)(OT, ale...) Já bych to řešil tak, že bych si nakopíroval hodnoty a pak přes makro bych doplnil to SQL okolo. Ale tak jak píšete by to taky šlo.
INSERT INTO tab1 (name) VALUES ("abc");
INSERT INTO tab1 (name) VALUES ("def");
/* chci vytvorit novy SQL prikaz s temi stringy - opravit tyto dva inserty */
INSERT INTO tab2 (num) VALUES (1);
INSERT INTO tab2 (num) VALUES (2);
INSERT INTO tab1 (name) VALUES ("abc");
INSERT INTO tab1 (name) VALUES ("def");
/* chci vytvorit novy SQL prikaz s temi stringy - opravit tyto dva inserty */
INSERT INTO tab2 (num) VALUES (1abc);
INSERT INTO tab2 (num) VALUES (2def);
ještě smazat blokově 1 a 2 (bývalo by bylo lepší předem)
INSERT INTO tab1 (name) VALUES ("abc");
INSERT INTO tab1 (name) VALUES ("def");
/* chci vytvorit novy SQL prikaz s temi stringy - opravit tyto dva inserty */
INSERT INTO tab2 (num) VALUES (abc);
INSERT INTO tab2 (num) VALUES (def);
voilà.
Další možnost:
INSERT INTO tab1 (name) VALUES ("abc");
INSERT INTO tab1 (name) VALUES ("def");
/* chci vytvorit novy SQL prikaz s temi stringy - opravit tento jeden insert (se nevleze) */
INSERT INTO tab2 (num) VALUES (1);
DELETE * FROM tab2 where id='foo';
INSERT INTO tab1 (name) VALUES ("abc");
INSERT INTO tab1 (name) VALUES ("def");
/* chci vytvorit novy SQL prikaz s temi stringy - opravit tento jeden insert (se nevleze) */
INSERT INTO tab2 (num) VALUES (1abc);
DELETE * FROM tab2 where id='foodef';
moje chyba, neohlídal jsem si počet řádků.
Tiskni
Sdílej: