summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ada/mdll.adb108
1 files changed, 66 insertions, 42 deletions
diff --git a/gcc/ada/mdll.adb b/gcc/ada/mdll.adb
index be8ace85db8..c6d09924ab7 100644
--- a/gcc/ada/mdll.adb
+++ b/gcc/ada/mdll.adb
@@ -6,7 +6,7 @@
-- --
-- B o d y --
-- --
--- Copyright (C) 1992-2004 Free Software Foundation, Inc. --
+-- Copyright (C) 1992-2005 Free Software Foundation, Inc. --
-- --
-- GNAT is free software; you can redistribute it and/or modify it under --
-- terms of the GNU General Public License as published by the Free Soft- --
@@ -38,6 +38,10 @@ package body MDLL is
use Ada;
use GNAT;
+ function Get_Dll_Name (Lib_Filename : String) return String;
+ -- Returns <Lib_Filename> if it contains a file extension otherwise it
+ -- returns <Lib_Filename>.dll.
+
---------------------------
-- Build_Dynamic_Library --
---------------------------
@@ -63,7 +67,7 @@ package body MDLL is
Def_File : aliased constant String := Def_Filename;
Jnk_File : aliased String := Base_Filename & ".jnk";
Bas_File : aliased constant String := Base_Filename & ".base";
- Dll_File : aliased String := Base_Filename & ".dll";
+ Dll_File : aliased String := Get_Dll_Name (Lib_Filename);
Exp_File : aliased String := Base_Filename & ".exp";
Lib_File : aliased constant String := "lib" & Base_Filename & ".a";
@@ -75,34 +79,36 @@ package body MDLL is
L_Afiles : Argument_List := Afiles;
-- Local afiles list. This list can be reordered to ensure that the
- -- binder ali file is not the first entry in this list.
+ -- binder ALI file is not the first entry in this list.
All_Options : constant Argument_List := Options & Largs_Options;
procedure Build_Reloc_DLL;
- -- Build a relocatable DLL with only objects file specified.
- -- this use the well known 5 steps build. (see GNAT User's Guide).
+ -- Build a relocatable DLL with only objects file specified. This uses
+ -- the well known five step build (see GNAT User's Guide).
procedure Ada_Build_Reloc_DLL;
- -- Build a relocatable DLL with Ada code.
- -- this use the well known 5 steps build. (see GNAT User's Guide).
+ -- Build a relocatable DLL with Ada code. This uses the well known five
+ -- step build (see GNAT User's Guide).
procedure Build_Non_Reloc_DLL;
- -- Build a non relocatable DLL containing no Ada code.
+ -- Build a non relocatable DLL containing no Ada code
procedure Ada_Build_Non_Reloc_DLL;
- -- Build a non relocatable DLL with Ada code.
+ -- Build a non relocatable DLL with Ada code
---------------------
-- Build_Reloc_DLL --
---------------------
procedure Build_Reloc_DLL is
+
+ Objects_Exp_File : constant OS_Lib.Argument_List :=
+ Exp_File'Unchecked_Access & Ofiles;
-- Objects plus the export table (.exp) file
- Objects_Exp_File : constant OS_Lib.Argument_List
- := Exp_File'Unchecked_Access & Ofiles;
Success : Boolean;
+
begin
if not Quiet then
Text_IO.Put_Line ("building relocatable DLL...");
@@ -115,7 +121,7 @@ package body MDLL is
end if;
end if;
- -- 1) Build base file with objects files.
+ -- 1) Build base file with objects files
Utl.Gcc (Output_File => Jnk_File,
Files => Ofiles,
@@ -123,14 +129,14 @@ package body MDLL is
Base_File => Bas_File,
Build_Lib => True);
- -- 2) Build exp from base file.
+ -- 2) Build exp from base file
Utl.Dlltool (Def_File, Dll_File, Lib_File,
Base_File => Bas_File,
Exp_Table => Exp_File,
Build_Import => False);
- -- 3) Build base file with exp file and objects files.
+ -- 3) Build base file with exp file and objects files
Utl.Gcc (Output_File => Jnk_File,
Files => Objects_Exp_File,
@@ -150,6 +156,7 @@ package body MDLL is
declare
Params : OS_Lib.Argument_List :=
Adr_Opt'Unchecked_Access & All_Options;
+
begin
if Map_File then
Params := Map_Opt'Unchecked_Access & Params;
@@ -180,6 +187,7 @@ package body MDLL is
procedure Ada_Build_Reloc_DLL is
Success : Boolean;
+
begin
if not Quiet then
Text_IO.Put_Line ("Building relocatable DLL...");
@@ -192,7 +200,7 @@ package body MDLL is
end if;
end if;
- -- 1) Build base file with objects files.
+ -- 1) Build base file with objects files
Utl.Gnatbind (L_Afiles, Options & Bargs_Options);
@@ -208,14 +216,14 @@ package body MDLL is
Utl.Gnatlink (L_Afiles (L_Afiles'Last).all, Params);
end;
- -- 2) Build exp from base file.
+ -- 2) Build exp from base file
Utl.Dlltool (Def_File, Dll_File, Lib_File,
Base_File => Bas_File,
Exp_Table => Exp_File,
Build_Import => False);
- -- 3) Build base file with exp file and objects files.
+ -- 3) Build base file with exp file and objects files
Utl.Gnatbind (L_Afiles, Options & Bargs_Options);
@@ -278,6 +286,7 @@ package body MDLL is
procedure Build_Non_Reloc_DLL is
Success : Boolean;
+
begin
if not Quiet then
Text_IO.Put_Line ("building non relocatable DLL...");
@@ -291,7 +300,7 @@ package body MDLL is
end if;
end if;
- -- Build exp table and the lib .a file.
+ -- Build exp table and the lib .a file
Utl.Dlltool (Def_File, Dll_File, Lib_File,
Exp_Table => Exp_File,
@@ -325,10 +334,11 @@ package body MDLL is
-- Ada_Build_Non_Reloc_DLL --
-----------------------------
- -- Build a non relocatable DLL with Ada code.
+ -- Build a non relocatable DLL with Ada code
procedure Ada_Build_Non_Reloc_DLL is
Success : Boolean;
+
begin
if not Quiet then
Text_IO.Put_Line ("building non relocatable DLL...");
@@ -342,7 +352,7 @@ package body MDLL is
end if;
end if;
- -- Build exp table and the lib .a file.
+ -- Build exp table and the lib .a file
Utl.Dlltool (Def_File, Dll_File, Lib_File,
Exp_Table => Exp_File,
@@ -378,9 +388,9 @@ package body MDLL is
end Ada_Build_Non_Reloc_DLL;
begin
- -- On Windows the binder file must not be in the first position
- -- in the list. This is due to the way DLL's are built on Windows.
- -- We swap the first ali with the last one if it is the case.
+ -- On Windows the binder file must not be in the first position in the
+ -- list. This is due to the way DLL's are built on Windows. We swap the
+ -- first ali with the last one if it is the case.
if L_Afiles'Length > 1 then
declare
@@ -422,43 +432,57 @@ package body MDLL is
Def_Filename : String)
is
- procedure Build_Import_Library (Def_Base_Filename : String);
- -- Build an import library.
- -- this is to build only a .a library to link against a DLL.
-
- Base_Filename : constant String := MDLL.Fil.Ext_To (Lib_Filename);
+ procedure Build_Import_Library (Lib_Filename : String);
+ -- Build an import library. This is to build only a .a library to link
+ -- against a DLL.
--------------------------
-- Build_Import_Library --
--------------------------
- procedure Build_Import_Library (Def_Base_Filename : String) is
- Def_File : String renames Def_Filename;
- Dll_File : constant String := Def_Base_Filename & ".dll";
- Lib_File : constant String := "lib" & Base_Filename & ".a";
+ procedure Build_Import_Library (Lib_Filename : String) is
+ Def_File : String renames Def_Filename;
+ Dll_File : constant String := Get_Dll_Name (Lib_Filename);
+ Base_Filename : constant String := MDLL.Fil.Ext_To (Lib_Filename);
+ Lib_File : constant String := "lib" & Base_Filename & ".a";
begin
if not Quiet then
Text_IO.Put_Line ("Building import library...");
- Text_IO.Put_Line ("make " & Lib_File &
- " to use dynamic library " & Dll_File);
+ Text_IO.Put_Line
+ ("make " & Lib_File & " to use dynamic library " & Dll_File);
end if;
- Utl.Dlltool (Def_File, Dll_File, Lib_File,
- Build_Import => True);
+ Utl.Dlltool
+ (Def_File, Dll_File, Lib_File, Build_Import => True);
end Build_Import_Library;
+ -- Start of processing for Build_Import_Library
+
begin
- -- If the library has the form lib<name>.a then the def file should
- -- be <name>.def and the DLL to link against <name>.dll
- -- this is a Windows convention and we try as much as possible to
- -- follow the platform convention.
+ -- If the library has the form lib<name>.a then the def file should be
+ -- <name>.def and the DLL to link against <name>.dll. This is a Windows
+ -- convention and we try as much as possible to follow the platform
+ -- convention.
if Lib_Filename'Length > 3 and then Lib_Filename (1 .. 3) = "lib" then
- Build_Import_Library (Base_Filename (4 .. Base_Filename'Last));
+ Build_Import_Library (Lib_Filename (4 .. Lib_Filename'Last));
else
- Build_Import_Library (Base_Filename);
+ Build_Import_Library (Lib_Filename);
end if;
end Build_Import_Library;
+ ------------------
+ -- Get_Dll_Name --
+ ------------------
+
+ function Get_Dll_Name (Lib_Filename : in String) return String is
+ begin
+ if MDLL.Fil.Get_Ext (Lib_Filename) = "" then
+ return Lib_Filename & ".dll";
+ else
+ return Lib_Filename;
+ end if;
+ end Get_Dll_Name;
+
end MDLL;