Полёты — Аэродинамическая труба
Давно задумывался о том, что хотелось бы полетать в аэродинамической трубе. Но, во-первых её у нас не было, во-вторых предполагалось, что сие занятие совсем не из дешёвых. Не так давно (кажется) в Алматы труба появилась, заведует ей компания EasyFly.
О моих впечатлениях внутри поста…
IT — Calibri и Ubuntu
В очередной раз увидев как рисует браузер латинские буквы в microsoft-овском шрифте Calibri, решил это дело как-нибудь починить. Эксперементальным путём выяснил, что шрифт в системе есть, и что браузеры его правильно подхватывают, что уродливыми края у букв становятся только у латинских символов, и что только при размере <=16px. В итоге Google дал мне такой ответ:
Calibri fonts and other cleartype fonts have bitmap versions embedded in them which activate at small sizes, which makes it look bad. To disable this and get correct smoothing at all sizes do this:
Create a .fonts.conf file in your home directory, paste this in it:<match target="font"> <edit name="embeddedbitmap" mode="assign"> <bool>false</bool> </edit> </match>
Перезагрузив браузер (похоже, что для Chromium-а теперь это тривиально сделать невозможно, т.к. он работает аки daemon, но никаких иконок в tray-е не рисует) — убедился что уродливые границы исчезли.
Полёты — Видео с #УТС2014, Уш-Коныр
Видео заснято на китайский вариант GoPro. Старт с Уш-Коныра, посадка возле пивзавода LineBrew, по пути на 31км. ДП: Aeros Discus 13B. Трек. 24 июля 2014г.
Под катом ещё 2 видео.
IT — Экономия на числе запросов
До недавнего времени я предполагал, что 1 кривой INSERT SQL-запрос c ON DUPLICATE KEY UPDATE, должен выполняться быстрее, чем 2400 простых UPDATE SQL-запросов. Но на деле оказалось, что пляски с ON DUPLICATE KEY очень сильно гасят производительность. Более того — 2400 простых INSERT-ов с 3 изменямыми полями выполняются всего за 500-1000ms.
Собственно макеты запросов. Вариант с ON DUPLICATE KEY:
INSERT tbl (id, f1, f2, f3)
VALUES (1, 1, '2', 3), (2, 4, '5', 6) ...
ON DUBLICATE KEY UPDATE f1=VALUES(f1), f2=VALUES(f2), f3=VALUES(f3);
Вариант с UPDATE-ом:
UPDATE tbl SET f1=1, f2='2', f3=6 WHERE id = 1
Возможно, есть более элегантный вариант сделать 2400 UPDATE-ов не по всем полям (что отсеивает REPLACE INTO), используя всего 1 запрос, но я его не знаю :(
UPD 0. Шеф подсказал, что можно поступить примерно следующим образом — сформировать временную таблицу, содержащую все изменяемые данные, а следующим запросом простым UPDATE-ом с JOIN-ом считать оттуда данные. Правда следует учесть все тонкости работы с временными таблицами в mySQL.
IT — Knockout и this
Knockout, безусловно, весьма мощная библиотека, которая позволяет сэкономить море времени, но некоторые моменты в её работе, мне показались неудобными. Про один из них эта заметка. Binding «click» просит указать метод, но особенности JavaScript-а, не позволяют удобным способом указать метод и объект this, для его вызова. В итоге мы имеем вот такие вот уродливые конструкции
<span data-bind="click: $root.save.bind($root)"></span>
<span data-bind="click: $root.edit.bind($root, 'someParameter')"></span>
У меня возникло желание как это дело упростить. Я решил остановиться на таком варианте:
<span data-bind="click: @save"></span>
<span data-bind="click: [@edit, 'someParameter']"></span>
Возможно, не очень очевидный синтаксис, но никто не мешает придумать свой :) Итак, задача состоит в том, чтобы заставить knockout эти конструкции принимать за нужный метод. Для этого воспользуемся хаком preprocess для binding-а click. У меня получилось примерно так:
ko.bindingHandlers.click.preprocess = function( val )
{
val = $.trim( val );
if( val[ 0 ] === '@' )
{
var method = val.substr( 1 );
return 'function(){ return $root["' + method + '"].apply( $root, arguments ); }';
}
if( val[ 0 ] === '[' && val[ val.length - 1 ] === ']' )
{
val = $.trim( val.substr( 1, val.length - 2 ) );
var params = val.split( /\s*,\s*/ );
if( params[ 0 ] && params[ 0 ][ 0 ] === '@' )
{
var method = params.shift().substr( 1 );
var args = params.join(', ');
var js = 'function()\n' +
'{\n' +
'\tvar args = [ ' + params + ' ].concat( _.toArray( arguments ) );\n' +
'\treturn $root["' + method + '"].apply( $root, args );\n' +
'}';
return js;
}
}
return val;
}
Решение пока черновое и не обкатанное. К тому же на click-е мир клином не сошёлся и нужно что-то более универсальное.