Rambler's Top100
"Knowledge itself is power"
F.Bacon
Поиск | Карта сайта | Помощь | О проекте | ТТХ  
 Круглый стол
  
Правила КС
>> Настройки

Фильтр вопросов
>> Новые вопросы
отслеживать по
>> Новые ответы

Избранное

Страница вопросов
Поиск по КС


Специальные проекты:
>> К л ю к в а
>> Г о л о в о л о м к и

Вопрос №

Задать вопрос
Off-topic вопросы

Помощь

 
 К н и г и
 
Книжная полка
 
 
Библиотека
 
  
  
 


Поиск
 
Поиск по КС
Поиск в статьях
Яndex© + Google©
Поиск книг

 
  
Тематический каталог
Все манускрипты

 
  
Карта VCL
ОШИБКИ
Сообщения системы

 
Форумы
 
Круглый стол
Новые вопросы

 
  
Базарная площадь
Городская площадь

 
   
С Л С

 
Летопись
 
Королевские Хроники
Рыцарский Зал
Глас народа!

 
  
ТТХ
Конкурсы
Королевская клюква

 
Разделы
 
Hello, World!
Лицей

Квинтана

 
  
Сокровищница
Подземелье Магов
Подводные камни
Свитки

 
  
Школа ОБЕРОНА

 
  
Арсенальная башня
Фолианты
Полигон

 
  
Книга Песка
Дальние земли

 
  
АРХИВЫ

 
 

Сейчас на сайте присутствуют:
 
  
 
Во Флориде и в Королевстве сейчас  04:20[Войти] | [Зарегистрироваться]
Ответ на вопрос № 71207
IBX |

13-06-2009 09:02
Здравствуйте, уважаемые коллеги.

Хочу перекомпилировать IBX в Delphi 2009, но не знаю, как это правильно сделать. Дмитрий Кузьменко из IBase в статье на своём сайте рекомендовал следующую правку в модуль IBSQL.pas:

function TIBXSQLVAR.GetCharsetSize: Integer;
begin
  case SQLVar.SQLSubtype and $FF of // здесь and $FF убирает id collate, возвращаемый Firebird
    0, 1, 2, 10, 11, 12, 13, 14, 19, 21, 22, 39,
    45, 46, 47, 50, 51, 52, 53, 54, 55, 58 :  Result := 1;
    5, 6, 8, 44, 56, 57, 64 : Result := 2;
    3 : Result := 3;
    4, 59 : Result := 4; // здесь правильно обрабатывается id UTF8 в Firebird
else
  Result := 0;
end;
end;


Ссылка на статью: http://www.ibase.ru/unicode_faq.html

Не могу разобраться, как влепить исправленные пакеты в IDE. Прошу помощи у тех, кто уже с этим разобрался.

[+] Добавить в избранные вопросы

Отслеживать ответы на этот вопрос по RSS

Ответы:


Уважаемые авторы вопросов! Большая просьба сообщить о результатах решения проблемы на этой странице.
Иначе, следящие за обсуждением, возможно имеющие аналогичные проблемы, не получают ясного представления об их решении. А авторы ответов не получают обратной связи. Что можно расценивать, как проявление неуважения к отвечающим от автора вопроса.

14-06-2009 10:33 | Сообщение от автора вопроса
Испробовал решение более подробно. Итак, последовательность перекомпиляции ibsql.pas такова (при выборе каталога установки по умолчанию):
а) Правим файл ibsql.pas (расположение по умолчанию - в каталоге c:\Program Files\CodeGear\RAD Studio\6.0\source\Win32\IBX). Текст правки - в топике вопроса.
б) Удаляем файлы ibsql.dcu из следующих каталогов:
c:\Program Files\CodeGear\RAD Studio\6.0\lib
c:\Program Files\CodeGear\RAD Studio\6.0\debug
в) Создаём тестовый проект с компонентами IBDatabase, IBTransaction и IBSQL.
г) При попытке компиляции вывалится ошибка - Can't find IBSQL.dcu
д) Открываем Project Manager, жмём Add to project и вносим исправленный ibsql.pas.
е) Компилируем проект. Если он рабочий - можно даже попробовать запустить.
ж) Ищем файл IBSQL.dcu (у меня он сформировался в том же каталоге, в котором находится IBSQL.pas) и раскидываем его по каталогам, из которых мы потёрли старый IBSQL.dcu.

Вот и всё.

14-06-2009 08:29
Мне посоветовали приобрести FIBPlus, которые великолепно справляются с этой задачей.

Правильный выбор. FIBPlus безотносительно проблем в портированием намного мощнее и главное удобнее устаревшего IBX.

14-06-2009 07:35 | Сообщение от автора вопроса
Насколько я понимаю, если Вы не используете Run-time packages,
то для runtime правки IBSQL.pas будет достаточно.


Я попробовал - у меня ничего не вышло. Но мне только сейчас подсказали вариант, при котором следует:
а) подправить pas-файл;
б) потереть из системы все копии ibsql.dcu, предварительно запомнив их местоположение;
в) создать новый пробный проект со связкой IBDatabase-IBTransaction-IBSQL, откомпилировать его;
г) найти, куда компилятор поместил переделанный ibsql.dcu;
д) раскидать его по местам, где прятался старый ibsql.dcu.

Не знаю, стоит ли мне это пробовать. Тот же источник сказал мне, что работать с Firebird через IBX2009 в сети невозможно - скорость работы клиента очень низка. Мне посоветовали приобрести FIBPlus, которые великолепно справляются с этой задачей. Сейчас я уже оформляю заказ и после своих испытаний собираюсь делать на D2009 свои проекты с этим набором компонентов.

Спасибо за участие.

14-06-2009 02:11
Доброго времени суток!

То Сергей Любезный
Насколько я понимаю, если Вы не используете Run-time packages,
то для runtime правки IBSQL.pas будет достаточно. Что касается dpk, то их действительно нет. Можно попробовать собрать пакет самостоятельно - для D6 есть IBX 6.084 от О.Пащенко, попробуйте по аналогии.

С уважением,

13-06-2009 09:49 | Сообщение от автора вопроса
Какие именно? В каком каталоге размещены dpk? Я их не нашёл - есть одни bpl-ки. Может быть с ними можно что-то сделать? Или лучше попробовать создать отдельный пакет?

13-06-2009 09:38
Достаточно просто перекомпилировать пакеты.

Добавьте свое cообщение

Вашe имя:  [Войти]
Ваш адрес (e-mail):На Королевстве все адреса защищаются от спам-роботов
контрольный вопрос:
Однажды, в студеную зимнюю пору я из лесу вышел, был сильный ЧТО?
в качестве ответа на вопрос или загадку следует давать только одно слово в именительном падеже и именно в такой форме, как оно используется в оригинале.
Надоело отвечать на странные вопросы? Зарегистрируйтесь на сайте.
Тип сообщения:
Текст:
Жирный шрифт  Наклонный шрифт  Подчеркнутый шрифт  Выравнивание по центру  Список  Заголовок  Разделительная линия  Код  Маленький шрифт  Крупный шрифт  Цитирование блока текста  Строчное цитирование
  • вопрос Круглого стола № XXX

  • вопрос № YYY в тесте № XXX Рыцарской Квинтаны

  • сообщение № YYY в теме № XXX Базарной площади
  • обсуждение темы № YYY Базарной площади
  •  
     Правила оформления сообщений на Королевстве

    Страница избранных вопросов Круглого стола.
      
    Время на сайте: GMT минус 5 часов

    Если вы заметили орфографическую ошибку на этой странице, просто выделите ошибку мышью и нажмите Ctrl+Enter.
    Функция может не работать в некоторых версиях броузеров.

    Web hosting for this web site provided by DotNetPark (ASP.NET, SharePoint, MS SQL hosting)  
    Software for IIS, Hyper-V, MS SQL. Tools for Windows server administrators. Server migration utilities  

     
    © При использовании любых материалов «Королевства Delphi» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

    Яндекс цитирования