hedgewars/uChat.pas
author unc0rr
Thu, 25 Dec 2008 12:30:00 +0000
changeset 1550 2331fe280aef
parent 1485 51c11e77408a
child 1819 17dac76954d1
permissions -rw-r--r--
Add Chinese translation
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
     1
(*
1066
1f1b3686a2b0 Update copyright headers a bit
unc0rr
parents: 1038
diff changeset
     2
 * Hedgewars, a free turn based strategy game
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
     3
 * Copyright (c) 2008 Andrey Korotaev <unC0Rr@gmail.com>
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
     4
 *
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License as published by
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
     7
 * the Free Software Foundation; version 2 of the License
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
     8
 *
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    12
 * GNU General Public License for more details.
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    13
 *
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    17
 *)
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    18
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    19
unit uChat;
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    20
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    21
interface
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    22
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    23
procedure AddChatString(s: shortstring);
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    24
procedure DrawChat;
946
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
    25
procedure KeyPressChat(Key: Longword);
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    26
949
866729775535 Use nick from frontend to prepend chat messages
unc0rr
parents: 948
diff changeset
    27
var UserNick: shortstring = '';
993
4319810f23c1 - Fix chat state at start
unc0rr
parents: 991
diff changeset
    28
	showAll: boolean = false;
949
866729775535 Use nick from frontend to prepend chat messages
unc0rr
parents: 948
diff changeset
    29
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    30
implementation
1035
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
    31
uses uMisc, uStore, uConsts, SDLh, uConsole, uKeys, uTeams;
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    32
990
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
    33
const MaxStrIndex = 27;
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    34
946
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
    35
type TChatLine = record
1431
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    36
		Tex: PTexture;
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    37
		Time: Longword;
1431
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    38
		Width: LongInt;
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    39
		s: shortstring;
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    40
		end;
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    41
946
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
    42
var Strs: array[0 .. MaxStrIndex] of TChatLine;
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    43
	lastStr: Longword = 0;
945
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
    44
	visibleCount: Longword = 0;
946
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
    45
	
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
    46
	InputStr: TChatLine;
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
    47
	InputStrL: array[0..260] of char; // for full str + 4-byte utf-8 char
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    48
990
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
    49
procedure SetLine(var cl: TChatLine; str: shortstring; isInput: boolean);
1118
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    50
var strSurface, resSurface: PSDL_Surface;
1431
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    51
	w, h: LongInt;
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    52
begin
1118
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    53
if cl.Tex <> nil then
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    54
	FreeTexture(cl.Tex);
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    55
990
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
    56
cl.s:= str;
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
    57
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
    58
if isInput then str:= UserNick + '> ' + str + '_';
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
    59
1118
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    60
TTF_SizeUTF8(Fontz[fnt16].Handle, Str2PChar(str), w, h);
945
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
    61
1118
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    62
resSurface:= SDL_CreateRGBSurface(0,
1431
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    63
		toPowerOf2(w),
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    64
		toPowerOf2(h),
1118
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    65
		32,
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    66
		RMask, GMask, BMask, AMask);
945
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
    67
1118
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    68
strSurface:= TTF_RenderUTF8_Solid(Fontz[fnt16].Handle, Str2PChar(str), $FFFFFF);
1431
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    69
cl.Width:= w + 4;
1118
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    70
SDL_UpperBlit(strSurface, nil, resSurface, nil);
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    71
SDL_FreeSurface(strSurface);
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    72
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    73
cl.Time:= RealTicks + 12500;
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    74
cl.Tex:= Surface2Tex(resSurface);
1431
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    75
1118
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
    76
SDL_FreeSurface(resSurface)
946
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
    77
end;
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
    78
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
    79
procedure AddChatString(s: shortstring);
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
    80
begin
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
    81
lastStr:= (lastStr + 1) mod (MaxStrIndex + 1);
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
    82
990
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
    83
SetLine(Strs[lastStr], s, false);
945
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
    84
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
    85
inc(visibleCount)
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    86
end;
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    87
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    88
procedure DrawChat;
945
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
    89
var i, t, cnt: Longword;
1431
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    90
	r: TSDL_Rect;
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
    91
begin
945
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
    92
cnt:= 0;
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
    93
t:= 0;
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
    94
i:= lastStr;
1431
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    95
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    96
r.x:= 6;
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    97
r.y:= (visibleCount - t) * 16 + 10;
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    98
r.h:= 16;
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
    99
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   100
if (GameState = gsChat)
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   101
	and (InputStr.Tex <> nil) then
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   102
	begin
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   103
	r.w:= InputStr.Width;
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   104
	DrawFillRect(r);
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   105
	DrawTexture(8, visibleCount * 16 + 10, InputStr.Tex);
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   106
	end;
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   107
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   108
dec(r.y, 16);
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   109
990
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
   110
while
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
   111
	(
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
   112
			((t < 7) and (Strs[i].Time > RealTicks))
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
   113
		or
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
   114
			((t < MaxStrIndex) and showAll)
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
   115
	)
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
   116
	and
1118
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
   117
		(Strs[i].Tex <> nil) do
945
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
   118
	begin
1431
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   119
	r.w:= Strs[i].Width;
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   120
	DrawFillRect(r);
1118
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
   121
	DrawTexture(8, (visibleCount - t) * 16 - 6, Strs[i].Tex);
1431
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   122
	dec(r.y, 16);
21ca09524f9c Draw dark background under chat text
unc0rr
parents: 1378
diff changeset
   123
	
945
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
   124
	if i = 0 then i:= MaxStrIndex else dec(i);
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
   125
	inc(cnt);
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
   126
	inc(t)
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
   127
	end;
4ead9cde4e14 - Start chat implementation: chat strings are on the screen
unc0rr
parents: 942
diff changeset
   128
947
4e0c3ad89483 - 't' key for entering chat message
unc0rr
parents: 946
diff changeset
   129
visibleCount:= cnt;
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
   130
end;
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
   131
1033
622c5de38d72 Start implementing waves
unc0rr
parents: 1001
diff changeset
   132
procedure AcceptChatString(s: shortstring);
1035
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   133
var i: TWave;
1033
622c5de38d72 Start implementing waves
unc0rr
parents: 1001
diff changeset
   134
begin
1378
1a391883261d Allow /me in chat
unc0rr
parents: 1118
diff changeset
   135
if (s[1] = '/') and (copy(s, 1, 4) <> '/me ') then
1035
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   136
	begin
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   137
	if CurrentTeam^.ExtDriven then exit;
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   138
	
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   139
	for i:= Low(TWave) to High(TWave) do
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   140
		if (s = Wavez[i].cmd) then
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   141
			begin
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   142
			ParseCommand('/taunt ' + char(i), true);
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   143
			exit
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   144
			end;
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   145
	end
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   146
	else
6f5842bc481b Hopefully done taunts implementation
unc0rr
parents: 1034
diff changeset
   147
		ParseCommand('/say ' + s, true);
1033
622c5de38d72 Start implementing waves
unc0rr
parents: 1001
diff changeset
   148
end;
622c5de38d72 Start implementing waves
unc0rr
parents: 1001
diff changeset
   149
946
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   150
procedure KeyPressChat(Key: Longword);
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   151
const firstByteMark: array[1..4] of byte = (0, $C0, $E0, $F0);
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   152
var i, btw: integer;
1001
502508979713 Fix warnings
unc0rr
parents: 993
diff changeset
   153
    utf8: shortstring;
946
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   154
begin
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   155
if Key <> 0 then
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   156
	case Key of
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   157
		8: if Length(InputStr.s) > 0 then
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   158
				begin
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   159
				InputStr.s[0]:= InputStrL[byte(InputStr.s[0])];
990
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
   160
				SetLine(InputStr, InputStr.s, true)
946
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   161
				end;
990
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
   162
		27: SetLine(InputStr, '', true);
948
5d49a92c240a Fix chat behavior
unc0rr
parents: 947
diff changeset
   163
		13, 271: begin
947
4e0c3ad89483 - 't' key for entering chat message
unc0rr
parents: 946
diff changeset
   164
			if Length(InputStr.s) > 0 then
4e0c3ad89483 - 't' key for entering chat message
unc0rr
parents: 946
diff changeset
   165
				begin
1033
622c5de38d72 Start implementing waves
unc0rr
parents: 1001
diff changeset
   166
				AcceptChatString(InputStr.s);
1118
caf47265d03f - Use DejaVuSans-Bold instead of DejaVuSans+bold
unc0rr
parents: 1116
diff changeset
   167
				SetLine(InputStr, '', false)
947
4e0c3ad89483 - 't' key for entering chat message
unc0rr
parents: 946
diff changeset
   168
				end;
948
5d49a92c240a Fix chat behavior
unc0rr
parents: 947
diff changeset
   169
			FreezeEnterKey;
946
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   170
			GameState:= gsGame
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   171
			end
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   172
	else
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   173
	if (Key < $80) then btw:= 1
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   174
	else if (Key < $800) then btw:= 2
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   175
	else if (Key < $10000) then btw:= 3
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   176
	else btw:= 4;
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   177
	
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   178
	utf8:= '';
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   179
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   180
	for i:= btw downto 2 do
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   181
		begin
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   182
		utf8:= char((Key or $80) and $BF) + utf8;
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   183
		Key:= Key shr 6
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   184
		end;
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   185
	
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   186
	utf8:= char(Key or firstByteMark[btw]) + utf8;
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   187
1485
51c11e77408a Fix chat bugs leading to serialized data corruption
unc0rr
parents: 1431
diff changeset
   188
	if byte(InputStr.s[0]) + btw > 240 then exit;
51c11e77408a Fix chat bugs leading to serialized data corruption
unc0rr
parents: 1431
diff changeset
   189
946
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   190
	InputStrL[byte(InputStr.s[0]) + btw]:= InputStr.s[0];
990
dfa6a6fe1542 Implement history for chat (27 entries), no key binding yet
unc0rr
parents: 988
diff changeset
   191
	SetLine(InputStr, InputStr.s + utf8, true)
946
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   192
	end
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   193
end;
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   194
42c5cc87cbd1 Preparing to have gsChat gamestate
unc0rr
parents: 945
diff changeset
   195
942
b41af014d85e Stub for chat implementation
unc0rr
parents:
diff changeset
   196
end.