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).
Wayback byl vydán ve verzi 0.3. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.
Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.
Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.
Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.
Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.
Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.
Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.
Zdravím, narazil jsem na problém, s nímž si nevím rady. Netuším, zda to způsobují Rails či MySQL, hádám, že spíš to druhé bude pravdou...
Zde uvádím část kódu, který by se měl postarat o vygenerování tabulky. Nutno dodat, že jsem postupoval podle tohoto návodu:
class AddPlanningTable < ActiveRecord::Migration
def self.up
create_table :plans do |table|
table.column :treatment_id, :integer, :limit => 10, :default => 0
table.column :name, :string
end
add_index "plans", ["treatment_id"], :name => "fk_plans_treatment"
execute 'ALTER TABLE plans ADD CONSTRAINT fk_plans_treatment FOREIGN KEY ( treatment_id ) REFERENCES treatments( id )'
end
def self.down
drop_table :plans
end
end
Po zadání rake migrate se ovšem dozvím následující:
(in /home/dau/development/) rake aborted! Mysql::Error: Can't create table './oncosys_dev/#sql-a96_ab.frm' (errno: 150): ALTER TABLE plans ADD CONSTRAINT fk_plans_treatment FOREIGN KEY ( treatment_id ) REFERENCES treatments( id )
Zajímavé je, že to tabulku vytvoří, nicméně Rails na to reagují zmateně a nelze ji pak pomocí Migrations odstranit.
Vše je bez problému jen v případě, že v definici nepoužiji generování cizího klíče - ovšem to je právě to, co nepotřebuji. Cizí klíč v tabulce musí být nutně definován. Stejná chybová hláška se objeví i v případě, že tabulku vygeneruji bez cizího klíče a pak se snažím jej přidat přímo v mysql. Přiznám se, že jsem zmaten a nevím si rady.
Nevíte někdo, co s tím? Bez vyřešení tohoto problému se nemůžu pohnout dál. Ještě bych dodal, že používám Gentoo Linux, MySQL v. 4.0.25, Rails 1.0.0.
Zahledal jsem na netu, chyba 105 nějakým způsobem opravdu souvisí s generováním cizího klíče, nicméně myslím, že všechny požadavky na indexy mám splněny. Pro pořádek ještě znovu udávám výpis struktury pár tabulek (s omezeným počtem hodnot):
CREATE TABLE machines ( id tinyint(3) unsigned NOT NULL auto_increment, name varchar(50) NOT NULL default '', kind_of_machine varchar(5) default NULL, PRIMARY KEY (id), UNIQUE KEY name (name) ) TYPE=InnoDB COMMENT='Table of machines'; -- -------------------------------------------------------- CREATE TABLE plans ( id int(11) NOT NULL auto_increment, treatment_id int(10) default '0', name varchar(255) default NULL, PRIMARY KEY (id), KEY treatment_id (treatment_id) ) TYPE=InnoDB; -- -------------------------------------------------------- CREATE TABLE treatments ( id int(10) unsigned NOT NULL auto_increment, patient_id int(10) unsigned default '0', machine_id tinyint(3) unsigned default '0', plan varchar(6) default NULL, description varchar(200) default NULL, PRIMARY KEY (id), KEY plan (plan), KEY machine_id (machine_id), KEY patient_id (patient_id) ) TYPE=InnoDB COMMENT='Basic table with treatments'; -- -- Omezení pro tabulku `treatments` -- ALTER TABLE `treatments` ADD CONSTRAINT `fk_treatments_machine` FOREIGN KEY (`machine_id`) REFERENCES `machines` (`id`), ADD CONSTRAINT `fk_treatments_patient` FOREIGN KEY (`patient_id`) REFERENCES `patients` (`id`);
Tiskni
Sdílej: