23 июня 2015

32-bit Oracle 11g in Slackware 14.1

Installing software

  • download Oracle 11g binaries from oracle.com
  • copy 32-bit version of libstdc++.so.5.0.7 to /usr/lib/
  • create link /usr/lib/libstdc++.so.5 to /usr/lib/libstdc++.so.5.0.7
  • create link /lib/libgcc_s.so.1 to /usr/lib/libgcc_s.so.1
  • create user oracle with single group users
  • switch to user oracle and unpack downloaded parts of Oracle 11g
  • merge them in single directory database
  • execute runInstaller
  • select Install database sofware only, do not install Enterprise manager
  • ignore all checks and prerequisites
  • during installation there will be one error when compiling emdctl, ignore it and continue

Creating database

  • setup several variables for oracle user
cat /home/oracle/.bashrc
export ORACLE_HOME=/home/oracle/app/oracle/product/11.2.0/dbhome_1
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib
export PATH=$PATH:$ORACLE_HOME/bin
  • run dbca command and setup DB options
  • edit /etc/oratab - switch N to Y
Now you should be able to start and stop oracle instanse from user oracle with these commands:
dbstart $ORACLE_HOME
dbshut $ORACLE_HOME

26 октября 2011

Registering Nook simple touch

Registering "Nook Simple Touch" is not so simple. This device doesn't work with my personal router "Asus WL500gp v2". Nook finds network, but is unable to connect neither WPA/PSK nor Open System, network is not hidden. I solved this registering Nook at my office. There is router "AP2100 Dlink" and Nook works fine with it.

13 октября 2011

05 декабря 2010

Bad fonts after update

Several days ago there was huge update in the Slackware-current.
After that my fonts became rather ugly. After some investigation I've found that the reason was in freetype package. The freetype site wrotes:

Since May 2010, all patents related to bytecode hinting have expired worldwide. It it thus no longer necessary to disable the bytecode interpreter, and starting with FreeType version 2.4, it is enabled by default.
The affected patents are
Patent #1: US5155805: Method and apparatus for moving control points in displaying digital typeface on raster output devices
Patent #2: US5159668: Method and apparatus for manipulating outlines in improving digital typeface on raster output devices
Patent #3: US5325479: Method and apparatus for moving control points in displaying digital typeface on raster output devices


How can this be turned off? Seeking the web I've found the answer at the Alien Pastures blog.
A nice way to restore old behaviour of freetype.
cd /etc/fonts/conf.d ; ln -sf ../conf.avail/10-autohint.conf .

Thank you, Eric!

22 ноября 2010

Iterating over lua-table items in C

Warning! The code above does not check for recursive nesting.

We have table "tb" in our lua-script.
Let's create a function to print this table in C. "printTable" for example.
tb = {'a', 'b', {{'one', 'two'}, 'aa', 'bb', 'cc'}, 'd'}
printTable(tb)

Here we go.
#include <lua.h>
#include <stdio.h>

#define TRACE(format, ...) \
fprintf(stderr, "%s:%d " format "\n", __FILE__, __LINE__, ## __VA_ARGS__)

static int print_table__(lua_State* ls, const int tableIndex)
{
char buf[100] = {};
int i = 0;
for (; i < tableIndex; ++i) buf[i] = ' ';

lua_pushnil(ls);
while (lua_next(ls, tableIndex) != 0) {
if (lua_isnumber(ls, tableIndex + 2)) {
TRACE("%s%s - %d", buf,
lua_typename(ls, lua_type(ls, tableIndex + 2)),
(int)lua_tonumber(ls, tableIndex + 2));
} else if (lua_isstring(ls, tableIndex + 2)) {
TRACE("%s%s - %s", buf,
lua_typename(ls, lua_type(ls, tableIndex + 2)),
lua_tostring(ls, tableIndex + 2));
} else if (lua_istable(ls, tableIndex + 2)) {
TRACE("%stable", buf);
print_table__(ls, tableIndex + 2);
}
lua_pop(ls, 1);
}
return 0;
}

static int print_table(lua_State* ls)
{
return print_table__(ls, 1);
}

int main(int ac, char* av[])
{
lua_State* ls = luaL_newstate(); // init Lua-interpreter

lua_register(ls, "printTable", print_table); // register "printTable" function
luaL_loadfile(ls, "script.lua"); // load script.lua
lua_pcall(ls, 0, LUA_MULTRET, 0); // execute script

lua_close(ls);
return 0;
}

What we have here?
The Lua interpreter creates special separate stack for any function. When we enter the "print_table" function this stack contains only one element - table "tb".
We call inner "print_table__" function with one argument - table position on the stack. Stack index starts with 1 and then is incremented by 1 for every element pushed onto stack.
Inside "print_stack__" function we compute buf for nice alignment and then execute "lua_pushnil". It pushes "nil" value onto stack so we have two elements there:
2 - nil
1 - tb

Then we call "lua_next". This function considers max stack value as key ("nil" in our case). It pops key from the stack and pushes key-value pair. The stack looks like:
3 - "1"
2 - key
1 - tb

Then we check and print value. If the value is table we execute recursive call of "print_table__" with its index. At the end of iteration we call "lua_pop" and pop 1 last element from the stack. The stack again:
2 - key
1 - table

Calling "lua_next" we iterate over all keys in table.

08 октября 2010

Google Sync on Samsung S3370 (Corby 3G)

Active Sync Settings:
server URL: m.google.com
username: youruser@gmail.com
password: yourpassword
domain:
use SSL: yes

Warning: All existing contacts in your phone will be removed. Backup them before setting up sync.

28 октября 2009

Все дороги ведут к Слуцкому?

И все же, не удержусь и напишу. Интересно будет посмотреть насколько мои предположения совпадут с событиями предстоящего года-двух.

Газзаев -> Зико -> Рамос -> Слуцкий
Еще в прошлом году, после объявления о скором уходе Газзаева я задумывался о будущем тренере ЦСКА. Лучшей кандидатурой я видел Божовича, тогда тренировавшего пермский "Амкар". Игра "Амкара" впечатляла своей цельностью и организованностью. Фантастическая победа ЦСКА в кубке именно над "Амкаром" это только подтверждает. Думаю все видевшие тот матч не станут отрицать, что большую часть матча доминировали именно пермяки. Только в самом конце ЦСКА вырвал победу за счет лучших физических кондиций и мастерства.
Кстати недавнее поражение от "Москвы" чем-то похоже на тот финал. Первый тайм - доминирование команды Божовича, второй - попытка спастись. То, что удалось команде Газзаева весной 2008 не удалось команде Рамоса осенью 2009.
Можно предположить какой выбор стоял перед Гинером прошлой осенью. Договоренность с Рамосом и освобождающийся из "Амкара" Божович. Возможно еще кто-то, но я рассмотрю именно их, так как Божович впечатлил меня, а Гинер сам рассказал про Рамоса. Как мне кажется, выбор очевиден: Рамос - больше опыта, больше трофеев. Но тут вмешался "Реал" и вариант с Рамосом отпал. К этому времени Божовича оперативно увела "Москва". Божович не захотел быть запасным вариантом, хотя и в сильную команду, чем заслужил мое еще большее уважение. В цейтноте был взят Зико.
При Зико команда играла плохо, но два трофея выиграла. За трофеи спасибо. Могла ли команда играть лучше - сказать сложно. И в последнем сезоне Газзаева весна не удалась. Летом продажа двух ведущих игроков атаки: Жирков и Вагнер. Игра пропадает совсем, результат тоже, затем пропадает и Зико.
А между тем Рамос уже свободен. Лига Чемпионов манит любого тренера, и Рамос соглашается взяться за дело.
Работа у Рамоса идет с переменным успехом, но случаются травмы еще у трех (!) атакующих игроков (Пилиев, Гонсалес и Гильерме) и шансов на Лигу по итогам года практически не остается. Играть только в чемпионате России Рамосу не интересно. В тоже время свободен Слуцкий. Выбор у Гинера между большим контрактом сильного европейского тренера, которому будет неинтересно работать и меньшим контрактом российского перспективного тренера, у которого мотивация будет зашкаливать. Результат выбора уже известен. Слуцкий в ЦСКА.

Богатый клуб -> Сокращение финансирования -> Слуцкий
Уменьшение инвестиций в связи с финансовым кризисом, полугодовое отсутствие спонсора и строящийся стадион очевидно стоили немалых убытков акционерам ЦСКА. В такой ситуации логичным выглядит решение на время уменьшить амбиции, снизить расходы на команду и сконцентрироваться на постройке стадиона. Завершение стройки сразу же сильно облегчит бюджет. Пока же ограничиться наличием способной молодежи. Полагаю, Газзаев не захотел еще раз начинать все с начала и ушел в более сильный клуб. Не захотел строить молодую команду в чужой стране и Рамос.
В это время появился свободный специалист, неплохо себя зарекомендовавший именно работой с молодежью - Слуцкий.

Что дальше
Первое и главное - постройка своего стадиона. Ради этого будут продажи игроков и облегчение зарплатной ведомости.
Второе - поддержка команды на уровне 4-6 места. Необходимо привлекать спонсоров, а к слабой команде они не пойдут. Все таки ЦСКА достаточно известный бренд и возможность выгодного спонсорского контракта будет практически всегда.
Третье - воспитание/покупка молодых игроков. На свободные деньги, которых похоже будет мало, будут набирать молодых и перспективных. Кто-то может и "выстрелит".

Надежды и ожидания
Полагаю зимой из команды уйдут Игнашевич, Красич, Алдонин. Надеюсь за ними последуют и Одиа с Карвалью. Видимо закончит играть Рахимич, хотя еще год поиграть. выходя на замену. он может. В любом случае будет здорово, если Элвер останется в клубе, даже не в качестве игрока. Не очень ясна ситуация с Акинфеевым. Если строить новую команду с ним, необходима уверенность, что ближайшие 2-3 года от точно никуда не уйдет. Если такая договоренность не будет достигнута, однозначно Игоря надо отпускать. Опытным братьям и Шемберасу уезжать куда-то, как мне кажется, не имеет смысла. Молодым Нециду, Щенникову и Пилиеву тоже нужно оставаться, чтобы доказывать свое мастерство. Прибавим сюда еще Мамаева и Дзагоева, у которых опыта уже немало, несмотря на молодость, Плюс Гонсалес и Гильерме. Подбор игроков в общем-то уже приличный. А если еще молодые африканцы Секу, Осени, Маазу выйдут на свой лучший уровень - это будет очень серьезное усиление.

Акинфеев
Чосич Григорьев Березуцкий А. Березуцкий В. Щенников
Мамаев Шемберас
Дзагоев
Гильерме Нецид

Акинфеев
Григорьев Березуцкий А. Березуцкий В.
Мамаев Шемберас
Маазу Дзагоев Гонсалес
Гильерме Нецид


Счастливый конец
Пока строится стадион Слуцкий тренирует, молодые игроки набираются опыта. Затем возвращается Газзаев, покупается две-три звезды и выигрывается Лига Чемпионов.

PS:
А в это межсезонье, добыть бы Тарасова у "Москвы", Рязанцева у "Рубина", да еще Семака бы вернуть. Вот кто настоящий капитан.

02 октября 2009

vim tip

function! s:insert_gates(arg)
let gatename = toupper(a:arg) . "_" . substitute(toupper(expand("%:t")), "\\.", "_", "g")
execute "normal i#ifndef " . gatename
execute "normal o#define " . gatename . "\n\n\n"
execute "normal Go#endif /* " . gatename . " */\n"
normal kkk
endfunction
command -nargs=1 PragmaOnce call s:insert_gates()

Небольшая полезность для C/C++. Аналог "#pragma once".
По префиксу и имени файла генерирует "защитные" define'ы.
В качестве префикса может использоваться имя проекта, например.

28 августа 2009

vim tip

1,$!sort

Пропустить регион через фильтр. В данном случае пропустить через sort строки файла от первой до последней.

g/^ \+DEBUG.*/. d

Удалить все строки начинающиеся с DEBUG.


function! s:svn_annotate()
let lineNum = line('.')
execute '1,$!svn ann %'
execute "normal ".lineNum."gg"
endfun
command! -nargs=0 SvnAnn call s:svn_annotate()

Удобно посмотреть через SVN кто менял данную строчку.

09 июля 2009

per-user установка с помощью easy_install

с версии 2.6 в python появились полезные настройки:
PYTHONNOUSERSITE
PYTHONUSERBASE
PEP 370

Чтобы иметь возможность устанавливать сторонние python-пакеты локально с помощью easy_install или setup.py (distutils) достаточно выставить переменную:
PYTHONUSERBASE=/home/evgeny/local

и прописать опцию user в ~/.pydistutils.cfg

[install]
user=True