Line data Source code
1 : /* Managing temporary directories and their content within libgccjit.so
2 : Copyright (C) 2014-2026 Free Software Foundation, Inc.
3 : Contributed by David Malcolm <dmalcolm@redhat.com>.
4 :
5 : This file is part of GCC.
6 :
7 : GCC is free software; you can redistribute it and/or modify it
8 : under the terms of the GNU General Public License as published by
9 : the Free Software Foundation; either version 3, or (at your option)
10 : any later version.
11 :
12 : GCC is distributed in the hope that it will be useful, but
13 : WITHOUT ANY WARRANTY; without even the implied warranty of
14 : MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 : General Public License for more details.
16 :
17 : You should have received a copy of the GNU General Public License
18 : along with GCC; see the file COPYING3. If not see
19 : <http://www.gnu.org/licenses/>. */
20 :
21 : #ifndef JIT_TEMPDIR_H
22 : #define JIT_TEMPDIR_H
23 :
24 : #include "jit-logging.h"
25 :
26 : namespace gcc {
27 :
28 : namespace jit {
29 :
30 : /* A class to keep track of the jit::playback::context's tempdir.
31 :
32 : The tempdir has the following layout:
33 :
34 : /tmp/libgccjit-XXXXXX/
35 : ./fake.c
36 : (doesn't exist, but the rest of the
37 : compiler needs a source code filename)
38 :
39 : ./fake.s
40 : (created by toplev::main)
41 :
42 : ./fake.so
43 : (created by playback::context::convert_to_dso).
44 :
45 : It is normally deleted from the filesystem in the playback::context's
46 : dtor, unless GCC_JIT_BOOL_OPTION_KEEP_INTERMEDIATES was set. */
47 :
48 : class tempdir : public log_user
49 : {
50 : public:
51 : tempdir (logger *logger, int keep_intermediates);
52 : ~tempdir ();
53 :
54 : bool create ();
55 :
56 16 : const char * get_path () const { return m_path_tempdir; }
57 1331 : const char * get_path_c_file () const { return m_path_c_file; }
58 1239 : const char * get_path_s_file () const { return m_path_s_file; }
59 2241 : const char * get_path_so_file () const { return m_path_so_file; }
60 :
61 : /* Add PATH to the vec of tempfiles that must be unlinked.
62 : Take ownership of the buffer PATH; it will be freed. */
63 61 : void add_temp_file (char *path) { m_tempfiles.safe_push (path); }
64 :
65 : private:
66 : /* Was GCC_JIT_BOOL_OPTION_KEEP_INTERMEDIATES set? If so, keep the
67 : on-disk tempdir around after this wrapper object goes away. */
68 : int m_keep_intermediates;
69 :
70 : /* Allocated using xmalloc (by xstrdup). */
71 : char *m_path_template;
72 :
73 : /* This either aliases m_path_template, or is NULL. */
74 : char *m_path_tempdir;
75 :
76 : /* The following are allocated using xmalloc. */
77 : char *m_path_c_file;
78 : char *m_path_s_file;
79 : char *m_path_so_file;
80 :
81 : /* Other files within the tempdir to be cleaned up:
82 : - certain ahead-of-time compilation artifacts (.o and .exe files)
83 : - dumpfiles that were requested via gcc_jit_context_enable_dump. */
84 : auto_vec <char *> m_tempfiles;
85 : };
86 :
87 : } // namespace gcc::jit
88 :
89 : } // namespace gcc
90 :
91 : #endif /* JIT_TEMPDIR_H */
|