-
Новости от 19-Jan-2007 (KOL & MCK v2.86)
[*] KOL: символ условной компиляции TOOLBAR_FORCE_CHILDALIGN больше не действует для Win98 т.к. может там приводит к краху приложения. При создании совместимых с Win9x приложений, избегайте размещения на инструментальной линейке выравниваемых дочерних контролов.
[+] Добавлены метод TWStrList.Last и функция WCharIn. В методе TWStrList.MergeFromStream, обеспечивается удаление ведущего символа $FEFF при загрузке текста Unicode из файла. В методе TWStrList.SetText, обеспечивается терминирующий символ 0.
[*] UNICODE_CTRLS: может теперь комбинироваться с символом USE_PROP (константы ID_SELF и ID_PREVPROC объявлены как KOLString).
[-] Для UNICODE_CTRLS, исправлено свойство TOpenDirDialog.InitialPath.
[+] Добавлены функции: Scrollbar_GetMinPos, Scrollbar_SetMinPos, Scrollbar_SetAll, Scrollbar_GetMaxPos, Scrollbar_SetMaxPos, Scrollbar_GetCurPos, Scrollbar_SetCurPos, Scrollbar_SetPageSz, Scrollbar_GetPageSz, Scrollbar_SetLineSz, Scrollbar_GetLineSz - для использования вместе с модулем ToGRush в дуальном коде.
[*] IndexOfChar, IndexOfStr изменены и понимают #0 как обычный символ, не обязательно завершающий строку.
[-] MCK: при генерации кода для установки нестандартного цвета (Color) добавлено приведение типа для предотвращения выдачи предупреждения компилятором.
[-] Дл случаев, когда CanResize = false или запрещены иконки минимизации и/или максимизации формы, так же окну отправляется сообщение WM_INITMENU, что обеспечивает корректное запрещение соответствующих пунктов системного меню.
[+] Свойство LikeSpeedButton обеспечено для зеркальных контролов TKOLCheckBox, TKOLRadioBox, и теперь может быть обеспечено для любого потомка TKOLCustomControl простым перечислением свойства в списке публикуемых.
[*] Обновлены компоненты TKOLGif, TKOLPng.
-
Хорошее обновление. Спасибо
-
Исправьте, пожалуйста, Parse(). При Separators равном одному символу все работает, а при двухсимвольном (напр #13#10) разделителе глючит. Необходимо заменить Delete( S, 1, Pos ) на Delete( S, 1, Pos+Length(Separators)-1 ) . Посмотрите, может меня глючит?. Версия KOL 2.83.
-
> [-] Дл случаев, когда CanResize = false или запрещены > иконки минимизации и/или максимизации формы, так же > окну отправляется сообщение WM_INITMENU, что > обеспечивает корректное запрещение соответствующих пунктов > системного меню.
> [-] For cases when CanResize is false or minimize or maximize > icon are disabled, also a code is generated which sends > WM_INITMENU to a form window handle at startup. This provides > correct disabling of correspondent system menu items as > well.
Sorry - still does not work. I still have to add WM_INITMENU to disable maximize menu item:
CanResize := False;
Perform(WM_INITMENU,0,0);
Problem only on first click of form system menu. Click on task bar icon is ok.
-
В Parse нет многоимвольных сепараторов. Это просто множество символов, из которых первый найденный считается разделителем.
-
System menu: For me it works. Check please if WM_INITMENU performed in _1.inc file.
-
> System menu: > For me it works. Check please if WM_INITMENU performed in _1.inc file.
I do not use MCK. With this simlpe KOL test, restore and maximize are incorrect. program test;
uses
Windows, Messages, KOL;
begin
Applet := NewForm(nil,'Test');
Applet.CanResize := False;
Run(Applet);
end.
-
Without MCK, it must be called since several different reasons are there in several possible combinations. In MCK, just Perform(WM_INITMENU,... generated and run.
-
В начале этого года была плановая смена пароля на сервере www.kolnmck.ru... С хозяином сайта Гэндальфом связаться не могу...надеюсь что пока... Т.ч. обновления пока не ожидается :(
-
> Vladimir Kladov © (19.01.08 20:01) [4] > первый найденный считается разделителем.
И удаляется только он один, а остальные остаются. Пример: const
br=#13#10;
var
s:string;
begin
s:='Один'+br+'Два'+br+'Три';
Showmessage(parse(s,br)); Showmessage(parse(s,br)); Showmessage(parse(s,br)); end;
-
> WM_INITMENU
За это спасибо.
-
И удаляется только он один, а остальные остаются.
Так и должно быть. Для многосимвольных разделитей напишите свой parse.
-
Новости от 19-Jan-2007 (KOL & MCK v2.86)
=)
-
In KOL.PAS line 33228: fDefWndProc := @Params.WindowClass.lpfnWndProc; Is FCP21 correct? I think it should be {$ifdef FPC}
-
Если кому интересно. Версия 2.86 нормально компилируется в FreePascal вот с такой доработкой: 1. В файле koldef.inc: - перед строчками
{------------------------------------
by Thaddy de Koning:
поставить
(Рекомендую работать именно с FreePascal версии 2) В результате получается:
{------------------------------------
by Thaddy de Koning:
2. В файле kol.pas, в той строчке, которую указал Jon:
fDefWndProc := @Params.WindowClass.lpfnWndProc;
изменить {$ifdef FPC21} на {$ifdef FPC}:
fDefWndProc := @Params.WindowClass.lpfnWndProc;
Теперь у меня компилируется без ошибок. Но с кучей варнингов... :) Компилятор FPC 2.2.0.
-
Символы условной компиляции для того и придуманы, чтобы их можно было задавать не модифицируя исходный файл. В опциях проекта, например, или в командной строке компилятора. FPC21 отличается от FPC из-за бага в FPC2.0, который был исправлен в 2.1. Соответственно, надо ставить оба символа в FPC выше 2.0.
-
Тогда поправка к моему предыдущему постингу. :) Файл kol.pas не править, а в файл koldef.inc добавить DEFINE:
-
дык наверное нет директивы на тот случай если юзаете 20 фпц а не 21
-
в KOL.pas много раз встречается несостыковка
в interface стоит {$IFNDEF STREAM_COMPAT} const {$ENDIF} а в implementation стоит const
без скобок.
строки 25169 25204 25242 25267 25635
бяка всплыла при использовании KOLPNG которая в свою очередь использует KOLZLIB в которой сопсно и используются эти недопереписанные строки.
кстати в сам KOLZLIB надо тогда внести эти директивы компиляции если уж руководствоватсья такой логикой.
-
о, гм, вижу запись об обновлении KOLPNG :)
-
и, кстати даты на сайте не обновлены. это я про KOLGIF KOLPNG.
Перечитал внимательно новости. хм. KOLZLIB тоже обновлен. Хорошо, значит из моих слов актуально только про kol.pas
-
Bug found with ListView. ListView.OnMouse up does not respond to button up messages. Instead it responds to mouse double click messages. Here is a simple demonstration: program test;
uses
KOL;
var
Counter: Integer;
procedure ListViewMouseUp(Dummy: Pointer; Sender: PControl; var Mouse: TMouseEventData);
begin
Applet.Caption := Int2Str(PControl(Sender).LVCurItem);
end;
begin
Applet := NewForm(nil,'Test');
with NewListView(Applet,lvsDetail,[lvoGridLines,lvoRowSelect],nil,nil,nil)^ do
begin
SetAlign(caClient);
LVColAdd('Column 1',taCenter,200);
LVColAdd('Column 2',taCenter,200);
LVColAdd('Column 3',taCenter,200);
OnMouseUp := TOnMouse(MakeMethod(nil,@ListViewMouseUp));
Counter := 0;
repeat
LVItemAdd(Int2Str(Counter));
Inc(Counter);
until Counter = 100;
end;
Run(Applet);
end. Tested in ASM and PAS version (D7 WinXP).
-
Заметил небольшой баг в MCK для меню с OwnerDraw := TRUE; свойство OwnerDraw := TRUE; устанавливается только для меню верхнего уровня, а вот для подменю нет. Пока исправил так (жирным - то что добавил):
procedure TKOLMenuItem.SetupAttributesLast(SL: TStringList; const MenuName: String); var I: Integer; MI: TKOLMenuItem; begin if FownerDraw then SL.Add( ' ' + MenuName + '.Items[ ' + IntToStr( ItemIndex ) + ' ].OwnerDraw := TRUE;' );
for I := 0 to Count - 1 do begin MI := SubItems[ I ]; MI.SetupAttributesLast( SL, MenuName ); end; end;
-
странно. при попытке распарсить пустую строку бабахает. очень странно. а дома работает.
-
Если обновлять от скаченного KOL&MCK-2.80 до 2.86, то на последнем апдейте kolmck285to286.upd не обновляется mckCtrls.pas, говорит об ошибке
-
У меня нормально обновилось с 2,85 на 2,86
-
Баг: asm-версия IndexOfStr зацикливается если в S нет Sub. С паскаль-версией всё нормально, возвращает -1.
-
Что-то Владимир пропал.
Вот еще баг нашел. Не понятно только, как вообще раньше работало, и долго уже....
procedure TWStrList.SetText(const Value: WideString); .... L := (Length( Value ) + 1) * Sizeof( WideChar ); GetMem( fText, L ); System.Move( Value[ 1 ], fText^, L );
fText[ L+1 ] := #0; // Вот здесь падает, что и не удивительно, т.к #0 заносится куда-то в двое дальше длины строки
fTextBufSz := Length( Value ); ....
Предлагаю такое исправление: procedure TWStrList.SetText(const Value: WideString); .... fTextBufSz := Length( Value ); L := (fTextBufSz + 1) * Sizeof( WideChar ); GetMem( fText, L ); System.Move( Value[ 1 ], fText^, L ); fText[ fTextBufSz ] := #0; ....
-
Не пропал. Не дождётесь. Версия 2.87: Новости от 21марта 2008 (KOL & MCK v2.87)
[+] Добавлены функции NextPowerOf2, ToRadix, FromRadiStr,
InsertSeparators, Str2File.
[*] UNICODE_CTRLS: обновлены функции IndexOfChar, IndexOfCharsMin,
IndexOfStr (с использованием типа KOLString).
[+] Добавлены функции CrackStack_MapInResource и CrackStack_MapInFile
(могут использоваться при отладке).
[-] Исправлена функция NormalizeUnixText.
[-] Свойство TStream.Size исправлено для memory stream для случая
присваивания значения 0 пустому потоку данных.
[+] Исправлена функция TWStrList.SetText (by mdw).
-
> Не пропал. Не дождётесь. Гы...
-
Vladimir Kladov © (21.03.08 18:45) [28] > > Версия 2.87: Владимир, подключите UNICODE_CTRLS. У меня 8 ошибок сразу выпало...
-
1. function CrackStack_MapInResource( const MapName: String; Max_length: Integer; HandleSuspiciousAddresses: Boolean ): String; Строка: Resource2Stream( MapStrm, hInstance, PChar( MapName ), RT_RCDATA ); 2е ошибки: несоответствие типов Char и WideChar... Еще насколько я понимаю надо в функции, String на KOLString заменить...
2. function ToRadix( number: Radix_Int; radix: Integer; min_digits: Integer ): KOLString; Ошибка: несовпадает объявление.
3. function InsertSeparators( const s: KOLString; chars_between: Integer; Separator: KOLChar ): KOLString; Ошибка: несовпадает объявление.
4. function IndexOfChar( const S : KOLString; Chr : KOLChar ) : Integer; Строка: F := StrScanLen( P, Chr, Length( S ) ); Ошибка: несоответствие типов Char и WideChar...
-
Вообще функция IndexOfChar как то странно поддержку UNICODE осуществляет... function IndexOfChar( const S : KOLString; Chr : KOLChar ) : Integer;
var P, F : PChar;
begin
P := PChar( S );
F := StrScan( P, Chr );
F := StrScanLen( P, Chr, Length( S ) );
Result := -1;
if (F = nil) or (S = '') then Exit;
Result := Integer( F ) - Integer( P )
+ 1 ;
if (S[ Result ] <> Chr) then
Result := -1;
end; Кроме объявления ничего и нет. В самом начале строка S - WideString приводится к PChar...да и потом Ansi-версия StrScanLen откуда-то взялась...
-
Еще один вопрос.
А чем собственно результат IndexOfChar(S, Chr) отличается от Pos(Chr, S)? Или я чего-то недопонимаю?
В любом случае, в 2.87 IndexOfChar не работает с UNICODE.
|