1 ------------------------------------------------------------------------------
3 -- GNAT COMPILER COMPONENTS --
9 -- Copyright (C) 2003-2013, Free Software Foundation, Inc. --
11 -- GNAT is free software; you can redistribute it and/or modify it under --
12 -- terms of the GNU General Public License as published by the Free Soft- --
13 -- ware Foundation; either version 3, or (at your option) any later ver- --
14 -- sion. GNAT is distributed in the hope that it will be useful, but WITH- --
15 -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY --
16 -- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License --
17 -- for more details. You should have received a copy of the GNU General --
18 -- Public License distributed with GNAT; see file COPYING3. If not, go to --
19 -- http://www.gnu.org/licenses for a complete copy of the license. --
21 -- GNAT was originally developed by the GNAT team at New York University. --
22 -- Extensive contributions were provided by Ada Core Technologies Inc. --
24 ------------------------------------------------------------------------------
26 with GNAT
.Directory_Operations
; use GNAT
.Directory_Operations
;
28 with Hostparm
; use Hostparm
;
30 with Output
; use Output
;
32 package body Tempdir
is
34 Tmpdir_Needs_To_Be_Displayed
: Boolean := True;
36 Tmpdir
: constant String := "TMPDIR";
37 Gnutmpdir
: constant String := "GNUTMPDIR";
38 Temp_Dir
: String_Access
:= new String'("");
40 ----------------------
41 -- Create_Temp_File --
42 ----------------------
44 procedure Create_Temp_File
45 (FD : out File_Descriptor;
46 Name : out Path_Name_Type)
48 File_Name : String_Access;
49 Current_Dir : constant String := Get_Current_Dir;
51 function Directory return String;
52 -- Returns Temp_Dir.all if not empty, else return current directory
58 function Directory return String is
60 if Temp_Dir'Length /= 0 then
67 -- Start of processing Tempdir
70 if Temp_Dir'Length /= 0 then
72 -- In verbose mode, display once the value of TMPDIR, so that
73 -- if temp files cannot be created, it is easier to understand
74 -- where temp files are supposed to be created.
76 if Verbose_Mode and then Tmpdir_Needs_To_Be_Displayed then
77 Write_Str ("TMPDIR = """);
78 Write_Str (Temp_Dir.all);
80 Tmpdir_Needs_To_Be_Displayed := False;
83 -- Change directory to TMPDIR before creating the temp file,
84 -- then change back immediately to the previous directory.
86 Change_Dir (Temp_Dir.all);
87 Create_Temp_File (FD, File_Name);
88 Change_Dir (Current_Dir);
91 Create_Temp_File (FD, File_Name);
94 if FD = Invalid_FD then
95 Write_Line ("could not create temporary file in " & Directory);
100 Path_Name : constant String :=
102 (Directory & Directory_Separator & File_Name.all);
104 Name_Len := Path_Name'Length;
105 Name_Buffer (1 .. Name_Len) := Path_Name;
110 end Create_Temp_File;
116 procedure Use_Temp_Dir (Status : Boolean) is
122 -- On VMS, if GNUTMPDIR is defined, use it
125 Dir := Getenv (Gnutmpdir);
127 -- Otherwise, if GNUTMPDIR is not defined, try TMPDIR
129 if Dir'Length = 0 then
130 Dir := Getenv (Tmpdir);
134 Dir := Getenv (Tmpdir);
141 and then Dir'Length > 0
142 and then Is_Absolute_Path (Dir.all)
143 and then Is_Directory (Dir.all)
145 Temp_Dir := new String'(Normalize_Pathname
(Dir
.all));
147 Temp_Dir
:= new String'("");
153 -- Start of elaboration for package Tempdir
156 Use_Temp_Dir (Status => True);