|
|
DataMuseum.dkPresents historical artifacts from the history of: Rational R1000/400 Tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about Rational R1000/400 Tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - downloadIndex: B T
Length: 20496 (0x5010)
Types: TextFile
Names: »B«
└─⟦85b835f43⟧ Bits:30000549 8mm tape, Rational 1000, Xlib rev 6.00
└─⟦0c20f784e⟧ »DATA«
└─⟦1abbe589f⟧
└─⟦059497ac5⟧
└─⟦this⟧
with Xlbt_Arithmetic;
use Xlbt_Arithmetic;
with Xlbt_Basic;
use Xlbt_Basic;
with Xlbt_Font;
use Xlbt_Font;
with Xlbt_Font2;
use Xlbt_Font2;
with Xlbt_Misc;
use Xlbt_Misc;
with Xlbt_Reply;
use Xlbt_Reply;
with Xlbt_Request;
use Xlbt_Request;
with Xlbt_String;
use Xlbt_String;
with Xlbip_Get_Reply;
use Xlbip_Get_Reply;
with Xlbip_Internal;
use Xlbip_Internal;
with Xlbip_Put_Request;
use Xlbip_Put_Request;
with Xlbmt_Network_Types;
use Xlbmt_Network_Types;
package body Xlbp_Font_Names is
------------------------------------------------------------------------------
-- X Library Font Names
--
-- Xlbp_Font_Names - What fonts are there and where do they live?
------------------------------------------------------------------------------
-- Copyright 1989 - 1991 by Rational, Santa Clara, California.
-- Copyright 1985 - 1989 by the Massachusetts Institute of Technology
--
-- All Rights Reserved.
--
-- Permission to use, copy, modify, and distribute this software and its
-- documentation for any purpose and without fee is hereby granted,
-- provided that the above copyright notice(s) appear in all copies and that
-- both that copyright notice(s) and this permission notice appear in
-- supporting documentation, and that the names of MIT or Rational not be
-- used in advertising or publicity pertaining to distribution of the software
-- without specific, written prior permission.
--
-- MIT and Rational disclaim all warranties with regard to this software,
-- including all implied warranties of merchantability and fitness, in no
-- event shall MIT or Rational be liable for any special, indirect or
-- consequential damages or any damages whatsoever resulting from loss of use,
-- data or profits, whether in an action of contract, negligence or other
-- tortious action, arising out of or in connection with the use or performance
-- of this software.
------------------------------------------------------------------------------
--\f
function X_Get_Font_Path (Display : X_Display)
return X_String_Pointer_List is
Rep : X_Reply_Contents;
Length : S_Natural;
Succ : X_Status;
begin
----Lock the display.
Lock_Display (Display);
begin
----Send the request.
Put_X_Get_Font_Path_Request
(Display, (Kind => Get_Font_Path,
Length => X_Get_Font_Path_Request'Size / 32,
Pad => 0));
----Get the reply.
Get_Reply (Display => Display,
Code => Get_Font_Path,
Reply => Rep,
Extra => 0,
Discard => False,
Status => Succ);
----Watch for failure.
if Succ = Failed then
Unlock_Display (Display);
Sync_Handle (Display);
return None_X_String_Pointer_List;
end if;
----Return the results.
if Rep.Get_Font_Path.N_Paths /= 0 then
declare
Amount : S_Natural;
Flist : X_String_Pointer_List;
Ch : X_String (1 ..
S_Natural (Rep.Get_Font_Path.Length) * 4);
begin
Get_X_String (Display, Ch);
Flist := new X_String_Pointer_Array
(1 .. S_Natural
(Rep.Get_Font_Path.N_Paths));
Length := 1;
for I in Flist'Range loop
for J in Length .. Ch'Last loop
if Ch (J) = Nul then
Amount := J - Length;
----Ada may not be able to take the full
-- amount. Chop the string if necessary.
--/ if not Positive_Is_Large then
--// if Amount > S_Natural (Positive'Last) then
--// Amount := S_Natural (Positive'Last);
--// end if;
--/ end if;
Flist (I) := new X_String (1 .. Amount);
Flist (I).all :=
Ch (Length .. Length + Amount - 1);
Length := J + 1;
end if;
end loop;
end loop;
Unlock_Display (Display);
Sync_Handle (Display);
return Flist;
exception
when others =>
Free_X_String_Pointer_List (Flist);
raise;
end;
else
Unlock_Display (Display);
Sync_Handle (Display);
return None_X_String_Pointer_List;
end if;
----Catch exceptions.
exception
when others =>
Unlock_Display (Display);
raise;
end;
end X_Get_Font_Path;
--\f
procedure X_Set_Font_Path (Display : X_Display;
Directories : X_String_Pointer_Array) is
N : S_Natural := 0;
begin
----Lock the display.
Lock_Display (Display);
begin
----Send the request.
for I in Directories'Range loop
N := N + Directories (I)'Length + 1;
end loop;
Put_X_Set_Font_Path_Request
(Display,
(Kind => Set_Font_Path,
Length =>
X_Set_Font_Path_Request'Size / 32 + U_Short ((N + 3) / 4),
Pad => 0,
Pad1 => 0,
Pad2 => 0,
N_Fonts => Directories'Length),
N);
----Send the directory strings.
declare
P : X_String (1 .. N);
Pi : S_Natural := P'First;
begin
--
-- pack into counted strings.
--
for I in Directories'Range loop
declare
Sp : X_String_Pointer := Directories (I);
begin
for J in Sp'Range loop
P (Pi) := Sp (J);
Pi := Pi + 1;
end loop;
end;
P (Pi) := Nul;
Pi := Pi + 1;
end loop;
Put_X_String (Display, P);
end;
----Catch exceptions.
exception
when others =>
Unlock_Display (Display);
raise;
end;
----Unlock; sync; return.
Unlock_Display (Display);
Sync_Handle (Display);
end X_Set_Font_Path;
--\f
procedure X_Free_Font_Info (Info : in out X_Fonts_With_Info) is
begin
for I in Info.Info'Range loop
declare
Fs : X_Font_Struct := Info.Info (I);
begin
Free_X_Char_Struct_List_2d (Fs.Per_Char);
Free_X_Font_Prop_List (Fs.Properties);
Free_X_Font_Struct (Fs);
Info.Info (I) := None_X_Font_Struct;
end;
Free_X_String_Pointer (Info.Name (I));
end loop;
end X_Free_Font_Info;
--\f
function X_List_Fonts_With_Info
(Display : X_Display;
Pattern : X_String; -- null-terminated
Maximum_Names : U_Short) return X_Fonts_With_Info is
N_Bytes : U_Short;
Fs : S_Natural := 0;
Fsi : X_Font_Struct;
Info : X_Fonts_With_Info;
Reply : X_Reply_Contents;
Succ : X_Status;
procedure Free_It_All is
begin
for J in 1 .. Fs loop
Free_X_String_Pointer (Info.Name (Fs));
Fsi := Info.Info (Fs);
if Fsi.Properties /= null then
Free_X_Font_Prop_List (Fsi.Properties);
end if;
end loop;
end Free_It_All;
begin
----Lock the display;
Lock_Display (Display);
begin
Info.Info := new X_Font_Struct_Array
(1 .. S_Natural (Maximum_Names));
Info.Name := new X_String_Pointer_Array
(1 .. S_Natural (Maximum_Names));
----Send the request.
N_Bytes := Pattern'Length;
Put_X_List_Fonts_With_Info_Request
(Display,
(Kind => List_Fonts_With_Info,
Length => X_List_Fonts_With_Info_Request'Size / 32 +
(N_Bytes + 3) / 4,
Pad => 0,
Max_Names => Maximum_Names,
N_Bytes => N_Bytes), S_Natural (N_Bytes));
----Send the pattern.
Put_X_String (Display, Pattern);
----Read replies until we get one with 0 length.
for I in U_Short'First .. U_Short'Last loop
Get_Reply (Display => Display,
Code => List_Fonts_With_Info,
Reply => Reply,
Extra => 0,
Discard => False,
Status => Succ);
----Any failure means abort the whole thing.
if Succ = Failed then
Free_It_All;
Unlock_Display (Display);
Sync_Handle (Display);
return (Info => None_X_Font_Struct_List,
Name => None_X_String_Pointer_List);
end if;
----Zero length reply; end-of-list.
if Reply.List_Fonts_With_Info.Name_Length = 0 then
exit;
end if;
----Convert this reply into a font struct. (no per_char info)
Fs := S_Natural (I);
begin
Fsi :=
new X_Font_Struct_Rec'
((Ext_Data => null,
Font_Id => None_X_Font,
Direction =>
Reply.List_Fonts_With_Info.Draw_Direction,
Default_Char =>
(Char1 => U_Char (Reply.List_Fonts_With_Info.
Default_Char / 256),
Char2 => U_Char (Reply.List_Fonts_With_Info.
Default_Char rem 256)),
Min_Char_Or_Byte2 =>
Reply.List_Fonts_With_Info.Min_Char_Or_Byte2,
Max_Char_Or_Byte2 =>
Reply.List_Fonts_With_Info.Max_Char_Or_Byte2,
Min_Byte1 =>
Reply.List_Fonts_With_Info.Min_Byte1,
Max_Byte1 =>
Reply.List_Fonts_With_Info.Max_Byte1,
All_Chars_Exist =>
To_Boolean (Reply.List_Fonts_With_Info.
All_Chars_Exist),
Ascent =>
Reply.List_Fonts_With_Info.Font_Ascent,
Descent =>
Reply.List_Fonts_With_Info.Font_Descent,
Min_Bounds =>
Reply.List_Fonts_With_Info.Min_Bounds,
Max_Bounds =>
Reply.List_Fonts_With_Info.Max_Bounds,
Per_Char => null,
Properties => null));
exception
when others =>
Eat_Raw_Data
(Display,
S_Natural
(Reply.List_Fonts_With_Info.N_Font_Props) *
X_Font_Prop'Size / 8 +
S_Natural (Reply.List_Fonts_With_Info.Name_Length));
Free_It_All;
raise;
end;
Info.Info (Fs) := Fsi;
----Read the properties.
if Reply.List_Fonts_With_Info.N_Font_Props > 0 then
begin
Fsi.Properties :=
new X_Font_Prop_Array
(1 .. S_Natural (Reply.List_Fonts_With_Info.
N_Font_Props));
exception
when others =>
Eat_Raw_Data (Display,
S_Natural (Reply.List_Fonts_With_Info.
N_Font_Props) *
X_Font_Prop'Size / 8 +
S_Natural (Reply.List_Fonts_With_Info.
Name_Length));
Free_It_All;
raise;
end;
Get_X_Font_Prop_Array (Display, Fsi.Properties.all);
end if;
----Read the name.
declare
Buff : X_String (1 .. S_Natural (Reply.List_Fonts_With_Info.
Name_Length));
begin
Get_X_String (Display, Buff);
Info.Name (Fs) := new X_String'(Buff);
exception
when others =>
Free_It_All;
raise;
end;
end loop;
----Return our lists.
declare
Inf : X_Fonts_With_Info;
begin
Inf.Info := new X_Font_Struct_Array'(Info.Info (1 .. Fs));
Inf.Name := new X_String_Pointer_Array'(Info.Name (1 .. Fs));
Unlock_Display (Display);
Sync_Handle (Display);
return Inf;
exception
when others =>
Inf.Info.all := (Inf.Info'Range => None_X_Font_Struct);
Inf.Name.all := (Inf.Name'Range => None_X_String_Pointer);
Free_X_Font_Struct_List (Inf.Info);
Free_X_String_Pointer_List (Inf.Name);
raise;
end;
----Catch exceptions.
exception
when Storage_Error =>
----Free up heap storage.
Free_It_All;
----Read the rest of the replies. We know that we are at a reply-boundary
-- because all of the code up above does it's best to get us there.
for I in U_Short'First .. U_Short'Last loop
Get_Reply (Display => Display,
Code => List_Fonts_With_Info,
Reply => Reply,
Extra => 0,
Discard => False,
Status => Succ);
----Any failure means abort the whole thing. Zero length reply; end-of-list.
if Succ = Failed or else
Reply.List_Fonts_With_Info.Name_Length = 0 then
exit;
end if;
----Read the properties and the name.
Eat_Raw_Data
(Display,
S_Natural (Reply.List_Fonts_With_Info.N_Font_Props) *
X_Font_Prop'Size / 8 +
S_Natural (Reply.List_Fonts_With_Info.Name_Length));
end loop;
Unlock_Display (Display);
raise;
----Other types of exceptions are unexpected and may constitute bugs. In any
-- case we don't know how to recover from them.
when others =>
Free_It_All;
Unlock_Display (Display);
raise;
end;
end X_List_Fonts_With_Info;
--\f
function X_List_Fonts
(Display : X_Display;
Pattern : X_String;
Maximum_Names : U_Short) return X_String_Pointer_List is
N_Bytes : U_Short;
Rep : X_Reply_Contents;
Succ : X_Status;
begin
----Lock the display.
Lock_Display (Display);
begin
----Send the request.
N_Bytes := Pattern'Length;
Put_X_List_Fonts_Request
(Display,
(Kind => List_Fonts,
Length => X_List_Fonts_Request'Size / 32
+ (N_Bytes + 3) / 4,
Pad => 0,
Max_Names => Maximum_Names,
N_Bytes => N_Bytes), S_Natural (N_Bytes));
Put_X_String (Display, Pattern);
----Get the reply.
Get_Reply (Display => Display,
Code => List_Fonts,
Reply => Rep,
Extra => 0,
Discard => False,
Status => Succ);
if Succ = Failed then
Unlock_Display (Display);
Sync_Handle (Display);
return None_X_String_Pointer_List;
end if;
----Get the info we requested.
if Rep.List_Fonts.N_Fonts /= 0 then
declare
Amount : S_Natural;
Flist : X_String_Pointer_List;
Ch : X_String (1 .. S_Natural (Rep.List_Fonts.Length) * 4);
Chs : S_Natural;
Chf : S_Natural;
begin
Get_X_String (Display, Ch);
Flist := new X_String_Pointer_Array
(1 .. S_Natural (Rep.List_Fonts.N_Fonts));
Chs := 1;
Chf := 1;
for I in Flist'Range loop
while Chf <= Ch'Last and then Ch (Chf) /= Nul loop
Chf := Chf + 1;
end loop;
Amount := Chf - Chs;
--/ if not Positive_Is_Large then
--// if Amount > S_Natural (Positive'Last) then
--// Amount := S_Natural (Positive'Last);
--// end if;
--/ end if;
Flist (I) := new X_String (1 .. Amount);
Flist (I).all := Ch (Chs .. Chf - 1);
Chs := Chf + 1;
Chf := Chs;
end loop;
Unlock_Display (Display);
Sync_Handle (Display);
return Flist;
exception
when others =>
Free_X_String_Pointer_List (Flist);
raise;
end;
else
Unlock_Display (Display);
Sync_Handle (Display);
return None_X_String_Pointer_List;
end if;
----Catch exceptions.
exception
when others =>
Unlock_Display (Display);
raise;
end;
end X_List_Fonts;
--\f
end Xlbp_Font_Names;