zmc
2023-12-22 9fdbf60165db0400c2e8e6be2dc6e88138ac719a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
U
G=®dM¹ã@sÂdZddlZddlZddlZddlTddlmZddlmZddl    m
Z
ddl m Z ddl mZmZdd    lmZGd
d „d ƒZd Zdd d„ZddddddœZdd„Zddd„Zdd„Zdd„ZdS)zˆdistutils.ccompiler
 
Contains CCompiler, an abstract base class that defines the interface
for the Distutils compiler abstraction model.éN)Ú*)Úspawn)Ú    move_file)Úmkpath)Ú newer_group)Ú split_quotedÚexecute)Úlogc
@seZdZdZdZdZdZdZdZdZ    dZ
dZ ddddddœZ dddgZ dqdd    „Zd
d „Zd d „Zdd„Zdd„Zdrdd„Zdd„Zdd„Zdd„Zdd„Zdd„Zdd„Zd d!„Zd"d#„Zd$d%„Zd&d'„Zd(d)„Zd*d+„Zd,d-„Z d.d/„Z!dsd0d1„Z"d2d3„Z#d4d5„Z$d6d7„Z%d8d9„Z&dtd:d;„Z'dud<d=„Z(d>d?„Z)dvd@dA„Z*dBZ+dCZ,dDZ-dwdEdF„Z.dxdGdH„Z/dydIdJ„Z0dzdKdL„Z1dMdN„Z2dOdP„Z3dQdR„Z4d{dSdT„Z5d|dUdV„Z6d}dXdY„Z7d~dZd[„Z8dd\d]„Z9d€d_d`„Z:ddbdc„Z;ddde„Z<dfdg„Z=d‚dhdi„Z>djdk„Z?dldm„Z@dƒdodp„ZAdS)„Ú    CCompileraŸAbstract base class to define the interface that must be implemented
    by real compiler classes.  Also has some utility methods used by
    several compiler classes.
 
    The basic idea behind a compiler abstraction class is that each
    instance can be used for all the compile/link steps in building a
    single project.  Thus, attributes common to all of those compile and
    link steps -- include directories, macros to define, libraries to link
    against, etc. -- are attributes of the compiler instance.  To allow for
    variability in how individual files are treated, most of those
    attributes may be varied on a per-compilation or per-link basis.
    NÚczc++Zobjc)ú.cz.ccz.cppz.cxxz.mrcCsb||_||_||_d|_g|_g|_g|_g|_g|_g|_    |j
  ¡D]}|  ||j
|¡qFdS©N) Údry_runÚforceÚverboseÚ
output_dirÚmacrosÚ include_dirsÚ    librariesÚ library_dirsÚruntime_library_dirsÚobjectsÚ executablesÚkeysÚset_executable)ÚselfrrrÚkey©rúVD:\z\workplace\VsCode\pyvenv\venv\Lib\site-packages\setuptools/_distutils/ccompiler.pyÚ__init__UszCCompiler.__init__cKs<|D]2}||jkr&td||jjfƒ‚| |||¡qdS)a‹Define the executables (and options for them) that will be run
        to perform the various stages of compilation.  The exact set of
        executables that may be specified here depends on the compiler
        class (via the 'executables' class attribute), but most will have:
          compiler      the C/C++ compiler
          linker_so     linker used to create shared objects and libraries
          linker_exe    linker used to create binary executables
          archiver      static library creator
 
        On platforms with a command-line (Unix, DOS/Windows), each of these
        is a string that will be split into executable name and (optional)
        list of arguments.  (Splitting the string is done similarly to how
        Unix shells operate: words are delimited by spaces, but quotes and
        backslashes can override this.  See
        'distutils.util.split_quoted()'.)
        z$unknown executable '%s' for class %sN)rÚ
ValueErrorÚ    __class__Ú__name__r)rÚkwargsrrrrÚset_executablesys 
 
ÿzCCompiler.set_executablescCs,t|tƒrt||t|ƒƒn t|||ƒdSr )Ú
isinstanceÚstrÚsetattrr)rrÚvaluerrrr™s
zCCompiler.set_executablecCs0d}|jD] }|d|kr"|S|d7}q
dS)Nré)r)rÚnameÚiÚdefnrrrÚ _find_macroŸs 
 
zCCompiler._find_macrocCs`|D]V}t|tƒrFt|ƒdkrFt|dtƒs8|ddkrFt|dtƒstd|ddƒ‚qdS)z×Ensures that every element of 'definitions' is a valid macro
        definition, ie. either (name,value) 2-tuple or a (name,) tuple.  Do
        nothing if all definitions are OK, raise TypeError otherwise.
        )r)ér)Nrzinvalid macro definition '%s': z.must be tuple (string,), (string, string), or z(string, None))r%ÚtupleÚlenr&Ú    TypeError)rZ definitionsr,rrrÚ_check_macro_definitions§s
 
ÿ þ
þ ýÿþz"CCompiler._check_macro_definitionscCs.| |¡}|dk    r|j|=|j ||f¡dS)a_Define a preprocessor macro for all compilations driven by this
        compiler object.  The optional parameter 'value' should be a
        string; if it is not supplied, then the macro will be defined
        without an explicit value and the exact outcome depends on the
        compiler used (XXX true? does ANSI say anything about this?)
        N©r-rÚappend)rr*r(r+rrrÚ define_macro¸s    
zCCompiler.define_macrocCs0| |¡}|dk    r|j|=|f}|j |¡dS)a³Undefine a preprocessor macro for all compilations driven by
        this compiler object.  If the same macro is defined by
        'define_macro()' and undefined by 'undefine_macro()' the last call
        takes precedence (including multiple redefinitions or
        undefinitions).  If the macro is redefined/undefined on a
        per-compilation basis (ie. in the call to 'compile()'), then that
        takes precedence.
        Nr3)rr*r+ZundefnrrrÚundefine_macroÇs
 
zCCompiler.undefine_macrocCs|j |¡dS)zóAdd 'dir' to the list of directories that will be searched for
        header files.  The compiler is instructed to search directories in
        the order in which they are supplied by successive calls to
        'add_include_dir()'.
        N)rr4©rÚdirrrrÚadd_include_dirÙszCCompiler.add_include_dircCs|dd…|_dS)aySet the list of directories that will be searched to 'dirs' (a
        list of strings).  Overrides any preceding calls to
        'add_include_dir()'; subsequence calls to 'add_include_dir()' add
        to the list passed to 'set_include_dirs()'.  This does not affect
        any list of standard include directories that the compiler may
        search by default.
        N©r©rÚdirsrrrÚset_include_dirsászCCompiler.set_include_dirscCs|j |¡dS)a¿Add 'libname' to the list of libraries that will be included in
        all links driven by this compiler object.  Note that 'libname'
        should *not* be the name of a file containing a library, but the
        name of the library itself: the actual filename will be inferred by
        the linker, the compiler, or the compiler class (depending on the
        platform).
 
        The linker will be instructed to link against libraries in the
        order they were supplied to 'add_library()' and/or
        'set_libraries()'.  It is perfectly valid to duplicate library
        names; the linker will be instructed to link against libraries as
        many times as they are mentioned.
        N)rr4)rÚlibnamerrrÚ add_libraryëszCCompiler.add_librarycCs|dd…|_dS)zôSet the list of libraries to be included in all links driven by
        this compiler object to 'libnames' (a list of strings).  This does
        not affect any standard system libraries that the linker may
        include by default.
        N)r)rZlibnamesrrrÚ set_librariesûszCCompiler.set_librariescCs|j |¡dS)a'Add 'dir' to the list of directories that will be searched for
        libraries specified to 'add_library()' and 'set_libraries()'.  The
        linker will be instructed to search for libraries in the order they
        are supplied to 'add_library_dir()' and/or 'set_library_dirs()'.
        N)rr4r7rrrÚadd_library_dirszCCompiler.add_library_dircCs|dd…|_dS)zÀSet the list of library search directories to 'dirs' (a list of
        strings).  This does not affect any standard library search path
        that the linker may search by default.
        N)rr;rrrÚset_library_dirs szCCompiler.set_library_dirscCs|j |¡dS)zlAdd 'dir' to the list of directories that will be searched for
        shared libraries at runtime.
        N)rr4r7rrrÚadd_runtime_library_dirsz!CCompiler.add_runtime_library_dircCs|dd…|_dS)zãSet the list of directories to search for shared libraries at
        runtime to 'dirs' (a list of strings).  This does not affect any
        standard search path that the runtime linker may search by
        default.
        N)rr;rrrÚset_runtime_library_dirssz"CCompiler.set_runtime_library_dirscCs|j |¡dS)zãAdd 'object' to the list of object files (or analogues, such as
        explicitly named library files or the output of "resource
        compilers") to be included in every link driven by this compiler
        object.
        N)rr4)rÚobjectrrrÚadd_link_object szCCompiler.add_link_objectcCs|dd…|_dS)zêSet the list of object files (or analogues) to be included in
        every link to 'objects'.  This does not affect any standard object
        files that the linker may include by default (such as system
        libraries).
        N)r)rrrrrÚset_link_objects(szCCompiler.set_link_objectscCs*|dkr|j}nt|tƒs"tdƒ‚|dkr2|j}n"t|tƒrL||jpFg}ntdƒ‚|dkrd|j}n*t|ttfƒr†t|ƒ|jp€g}ntdƒ‚|dkršg}|j|d|d}t    |ƒt    |ƒks¾t
‚t ||ƒ}i}    t t    |ƒƒD]B}
||
} ||
} t j | ¡d} | t j | ¡¡| | f|    | <qØ|||||    fS)z;Process arguments and decide which source files to compile.Nú%'output_dir' must be a string or Noneú/'macros' (if supplied) must be a list of tuplesú6'include_dirs' (if supplied) must be a list of stringsr)Ú    strip_dirrr))rr%r&r1rÚlistrr/Úobject_filenamesr0ÚAssertionErrorÚgen_preprocess_optionsÚrangeÚosÚpathÚsplitextrÚdirname)rZoutdirrZincdirsÚsourcesÚdependsÚextrarÚpp_optsÚbuildr+ÚsrcÚobjÚextrrrÚ_setup_compile6s>
 
ÿÿ
zCCompiler._setup_compilecCs0|dg}|rdg|dd…<|r,||dd…<|S)Nz-cz-grr)rrXÚdebugZbeforeÚcc_argsrrrÚ _get_cc_argsas 
 zCCompiler._get_cc_argscCs˜|dkr|j}nt|tƒs"tdƒ‚|dkr2|j}n"t|tƒrL||jpFg}ntdƒ‚|dkrd|j}n*t|ttfƒr†t|ƒ|jp€g}ntdƒ‚|||fS)a'Typecheck and fix-up some of the arguments to the 'compile()'
        method, and return fixed-up values.  Specifically: if 'output_dir'
        is None, replaces it with 'self.output_dir'; ensures that 'macros'
        is a list, and augments it with 'self.macros'; ensures that
        'include_dirs' is a list, and augments it with 'self.include_dirs'.
        Guarantees that the returned values are of the correct type,
        i.e. for 'output_dir' either string or None, and for 'macros' and
        'include_dirs' either list or None.
        NrHrIrJ)rr%r&r1rrLrr/)rrrrrrrÚ_fix_compile_argsjs"
 
 
ÿzCCompiler._fix_compile_argscCs*|j||d}t|ƒt|ƒks"t‚|ifS)a+Decide which souce files must be recompiled.
 
        Determine the list of object files corresponding to 'sources',
        and figure out which ones really need to be recompiled.
        Return a list of all object files and a dictionary telling
        which source files can be skipped.
        )r)rMr0rN)rrUrrVrrrrÚ _prep_compileŠs    zCCompiler._prep_compilecCsHt|ttfƒstdƒ‚t|ƒ}|dkr.|j}nt|tƒs@tdƒ‚||fS)zûTypecheck and fix up some arguments supplied to various methods.
        Specifically: ensure that 'objects' is a list; if output_dir is
        None, replace with self.output_dir.  Return fixed versions of
        'objects' and 'output_dir'.
        z,'objects' must be a list or tuple of stringsNrH)r%rLr/r1rr&)rrrrrrÚ_fix_object_argsšs
zCCompiler._fix_object_argscCs¸|dkr|j}n*t|ttfƒr2t|ƒ|jp,g}ntdƒ‚|dkrJ|j}n*t|ttfƒrlt|ƒ|jpfg}ntdƒ‚|dkr„|j}n*t|ttfƒr¦t|ƒ|jp g}ntdƒ‚|||fS)a;Typecheck and fix up some of the arguments supplied to the
        'link_*' methods.  Specifically: ensure that all arguments are
        lists, and augment them with their permanent versions
        (eg. 'self.libraries' augments 'libraries').  Return a tuple with
        fixed versions of all arguments.
        Nz3'libraries' (if supplied) must be a list of stringsz6'library_dirs' (if supplied) must be a list of stringsz>'runtime_library_dirs' (if supplied) must be a list of strings)rr%rLr/r1rr)rrrrrrrÚ _fix_lib_args«s,ÿÿÿzCCompiler._fix_lib_argscCs2|jr
dS|jr t||dd}n
t||ƒ}|SdS)zjReturn true if we need to relink the files listed in 'objects'
        to recreate 'output_file'.
        TÚnewer)ÚmissingN)rrr)rrÚ output_filererrrÚ
_need_linkÍs 
zCCompiler._need_linkc        Cs~t|tƒs|g}d}t|jƒ}|D]V}tj |¡\}}|j |¡}z |j     |¡}||kr`|}|}Wq"t
k
rvYq"Xq"|S)z|Detect the language of a given file, or list of files. Uses
        language_map, and language_order to do the job.
        N) r%rLr0Úlanguage_orderrQrRrSÚ language_mapÚgetÚindexr )    rrUÚlangrlÚsourceÚbaser\ZextlangZextindexrrrÚdetect_languageÚs
 
  zCCompiler.detect_languagecCsdS)aÕPreprocess a single C/C++ source file, named in 'source'.
        Output will be written to file named 'output_file', or stdout if
        'output_file' not supplied.  'macros' is a list of macro
        definitions as for 'compile()', which will augment the macros set
        with 'define_macro()' and 'undefine_macro()'.  'include_dirs' is a
        list of directory names that will be added to the default list.
 
        Raises PreprocessError on failure.
        Nr)rrnrgrrÚ extra_preargsÚextra_postargsrrrÚ
preprocessòs zCCompiler.preprocessc        Csx| ||||||¡\}}    }}
} | |
||¡} |    D]B} z| | \}}Wntk
r\Yq0YnX| | ||| ||
¡q0|    S)aK    Compile one or more source files.
 
        'sources' must be a list of filenames, most likely C/C++
        files, but in reality anything that can be handled by a
        particular compiler and compiler class (eg. MSVCCompiler can
        handle resource files in 'sources').  Return a list of object
        filenames, one per source filename in 'sources'.  Depending on
        the implementation, not all source files will necessarily be
        compiled, but all corresponding object filenames will be
        returned.
 
        If 'output_dir' is given, object files will be put under it, while
        retaining their original path component.  That is, "foo/bar.c"
        normally compiles to "foo/bar.o" (for a Unix implementation); if
        'output_dir' is "build", then it would compile to
        "build/foo/bar.o".
 
        'macros', if given, must be a list of macro definitions.  A macro
        definition is either a (name, value) 2-tuple or a (name,) 1-tuple.
        The former defines a macro; if the value is None, the macro is
        defined without an explicit value.  The 1-tuple case undefines a
        macro.  Later definitions/redefinitions/ undefinitions take
        precedence.
 
        'include_dirs', if given, must be a list of strings, the
        directories to add to the default include file search path for this
        compilation only.
 
        'debug' is a boolean; if true, the compiler will be instructed to
        output debug symbols in (or alongside) the object file(s).
 
        'extra_preargs' and 'extra_postargs' are implementation- dependent.
        On platforms that have the notion of a command-line (e.g. Unix,
        DOS/Windows), they are most likely lists of strings: extra
        command-line arguments to prepend/append to the compiler command
        line.  On other platforms, consult the implementation class
        documentation.  In any event, they are intended as an escape hatch
        for those occasions when the abstract compiler framework doesn't
        cut the mustard.
 
        'depends', if given, is a list of filenames that all targets
        depend on.  If a source file is older than any file in
        depends, then the source file will be recompiled.  This
        supports dependency tracking, but only at a coarse
        granularity.
 
        Raises CompileError on failure.
        )r]r`ÚKeyErrorÚ_compile)rrUrrrr^rqrrrVrrXrYr_r[rZr\rrrÚcompileÿs6 ÿÿ 
zCCompiler.compilecCsdS)zCompile 'src' to product 'obj'.Nr)rr[rZr\r_rrrXrrrruCszCCompiler._compilecCsdS)a&Link a bunch of stuff together to create a static library file.
        The "bunch of stuff" consists of the list of object files supplied
        as 'objects', the extra object files supplied to
        'add_link_object()' and/or 'set_link_objects()', the libraries
        supplied to 'add_library()' and/or 'set_libraries()', and the
        libraries supplied as 'libraries' (if any).
 
        'output_libname' should be a library name, not a filename; the
        filename will be inferred from the library name.  'output_dir' is
        the directory where the library file will be put.
 
        'debug' is a boolean; if true, debugging information will be
        included in the library (note that on most platforms, it is the
        compile step where this matters: the 'debug' flag is included here
        just for consistency).
 
        'target_lang' is the target language for which the given objects
        are being compiled. This allows specific linkage time treatment of
        certain languages.
 
        Raises LibError on failure.
        Nr)rrÚoutput_libnamerr^Ú target_langrrrÚcreate_static_libIszCCompiler.create_static_libZ shared_objectZshared_libraryÚ
executablecCst‚dS)auLink a bunch of stuff together to create an executable or
        shared library file.
 
        The "bunch of stuff" consists of the list of object files supplied
        as 'objects'.  'output_filename' should be a filename.  If
        'output_dir' is supplied, 'output_filename' is relative to it
        (i.e. 'output_filename' can provide directory components if
        needed).
 
        'libraries' is a list of libraries to link against.  These are
        library names, not filenames, since they're translated into
        filenames in a platform-specific way (eg. "foo" becomes "libfoo.a"
        on Unix and "foo.lib" on DOS/Windows).  However, they can include a
        directory component, which means the linker will look in that
        specific directory rather than searching all the normal locations.
 
        'library_dirs', if supplied, should be a list of directories to
        search for libraries that were specified as bare library names
        (ie. no directory component).  These are on top of the system
        default and those supplied to 'add_library_dir()' and/or
        'set_library_dirs()'.  'runtime_library_dirs' is a list of
        directories that will be embedded into the shared library and used
        to search for other shared libraries that *it* depends on at
        run-time.  (This may only be relevant on Unix.)
 
        'export_symbols' is a list of symbols that the shared library will
        export.  (This appears to be relevant only on Windows.)
 
        'debug' is as for 'compile()' and 'create_static_lib()', with the
        slight distinction that it actually matters on most platforms (as
        opposed to 'create_static_lib()', which includes a 'debug' flag
        mostly for form's sake).
 
        'extra_preargs' and 'extra_postargs' are as for 'compile()' (except
        of course that they supply command-line arguments for the
        particular linker being used).
 
        'target_lang' is the target language for which the given objects
        are being compiled. This allows specific linkage time treatment of
        certain languages.
 
        Raises LinkError on failure.
        N©ÚNotImplementedError)rZ target_descrÚoutput_filenamerrrrÚexport_symbolsr^rqrrÚ
build_temprxrrrÚlinkis9zCCompiler.linkc Cs2| tj||j|dd|||||||    |
| | ¡ dS)NÚshared)Úlib_type)r€r
ÚSHARED_LIBRARYÚlibrary_filename) rrrwrrrrr~r^rqrrrrxrrrÚlink_shared_lib§s
 ûzCCompiler.link_shared_libc Cs(| tj|||||||||    |
| | ¡ dSr )r€r
Ú SHARED_OBJECT) rrr}rrrrr~r^rqrrrrxrrrÚlink_shared_object¼s
üzCCompiler.link_shared_objectc Cs.| tj|| |¡||||d|||    d|
¡ dSr )r€r
Ú
EXECUTABLEÚexecutable_filename) rrZoutput_prognamerrrrr^rqrrrxrrrÚlink_executableÐs
ýzCCompiler.link_executablecCst‚dS)zkReturn the compiler option to add 'dir' to the list of
        directories searched for libraries.
        Nr{r7rrrÚlibrary_dir_optionæszCCompiler.library_dir_optioncCst‚dS)zsReturn the compiler option to add 'dir' to the list of
        directories searched for runtime libraries.
        Nr{r7rrrÚruntime_library_dir_optionìsz$CCompiler.runtime_library_dir_optioncCst‚dS)zReturn the compiler option to add 'lib' to the list of libraries
        linked into the shared library or executable.
        Nr{)rÚlibrrrÚlibrary_optionòszCCompiler.library_optionc     Csðddl}|dkrg}|dkr g}|dkr,g}|dkr8g}|jd|dd\}}t |d¡}    z*|D]}
|     d|
¡q^|     d|¡W5|     ¡Xz|j|g|d    } Wntk
r¸Yd
SXz|j| d ||d Wnt    t
fk
rêYd
SXdS) z·Return a boolean indicating whether funcname is supported on
        the current platform.  The optional arguments can be used to
        augment the compilation environment.
        rNr T)ÚtextÚwz#include "%s"
z=int main (int argc, char **argv) {
    %s();
    return 0;
}
r:Fza.out)rr) ÚtempfileÚmkstemprQÚfdopenÚcloseÚwritervÚ CompileErrorrŠÚ    LinkErrorr1) rÚfuncnameZincludesrrrr‘ÚfdÚfnameÚfZinclrrrrÚ has_functionøs<     û
 
þ
zCCompiler.has_functioncCst‚dS)aHSearch the specified list of directories for a static or shared
        library file 'lib' and return the full path to that file.  If
        'debug' true, look for a debugging version (if that makes sense on
        the current platform).  Return None if 'lib' wasn't found in any of
        the specified directories.
        Nr{)rr<rr^rrrÚfind_library_file$szCCompiler.find_library_fileÚcCs–|dkr d}g}|D]|}tj |¡\}}tj |¡d}|tj |¡d…}||jkrftd||fƒ‚|rvtj |¡}| tj     |||j
¡¡q|S)Nržr)z"unknown file type '%s' (from '%s')) rQrRrSÚ
splitdriveÚisabsÚsrc_extensionsÚUnknownFileErrorÚbasenamer4ÚjoinÚ obj_extension)rZsource_filenamesrKrZ    obj_namesÚsrc_nameror\rrrrMOs"
 
ÿ  ÿzCCompiler.object_filenamescCs0|dk    s t‚|rtj |¡}tj |||j¡Sr )rNrQrRr£r¤Úshared_lib_extension©rr£rKrrrrÚshared_object_filename`s  z CCompiler.shared_object_filenamecCs4|dk    s t‚|rtj |¡}tj |||jp.d¡S)Nrž)rNrQrRr£r¤Ú exe_extensionr¨rrrr‰fs  zCCompiler.executable_filenameÚstaticc
Csl|dk    s t‚|dkrtdƒ‚t||dƒ}t||dƒ}tj |¡\}}|||f}    |r\d}tj |||    ¡S)N)r«rZdylibZ
xcode_stubz?'lib_type' must be "static", "shared", "dylib", or "xcode_stub"Z _lib_formatZ_lib_extensionrž)rNr ÚgetattrrQrRÚsplitr¤)
rr>r‚rKrÚfmtr\r8roÚfilenamerrrr„ls ÿ zCCompiler.library_filenamer)cCst |¡dSr )r    r^)rÚmsgÚlevelrrrÚannounceszCCompiler.announcecCsddlm}|rt|ƒdS)Nr)ÚDEBUG)Údistutils.debugr³Úprint)rr°r³rrrÚ debug_print‚s zCCompiler.debug_printcCstj d|¡dS)Nz warning: %s
)ÚsysÚstderrr•)rr°rrrÚwarn‡szCCompiler.warncCst||||jƒdSr )rr)rÚfuncÚargsr°r±rrrrŠszCCompiler.executecKst|fd|ji|—ŽdS)Nr)rr)rÚcmdr#rrrrszCCompiler.spawncCst|||jdS©N)r)rr)rrZÚdstrrrrszCCompiler.move_fileéÿcCst|||jddSr½)rr)rr*Úmoderrrr“szCCompiler.mkpath)rrr)N)N)NNNNN)NNNrNNN)NrN)
NNNNNrNNNN)
NNNNNrNNNN)
NNNNNrNNNN)NNNNrNNN)NNNN)r)rrž)rrž)rrž)r«rrž)r))Nr))r¿)Br"Ú
__module__Ú __qualname__Ú__doc__Ú compiler_typer¡r¥Zstatic_lib_extensionr§Zstatic_lib_formatZshared_lib_formatrªrjrirr$rr-r2r5r6r9r=r?r@rArBrCrDrFrGr]r`rarbrcrdrhrprsrvruryr†rƒrˆr€r…r‡rŠr‹rŒrŽrœrrMr©r‰r„r²r¶r¹rrrrrrrrr
súü
 
$ 
 
+     
" ÿ
þ
Dÿ
ó
Aô
ô
ö
ÿ
,
+
 
 
ÿ
 
 
r
))zcygwin.*Úunix)ÚposixrÅ)ÚntÚmsvccCsV|dkrtj}|dkrtj}tD]0\}}t ||¡dk    sHt ||¡dk    r |Sq dS)akDetermine the default compiler to use for the given platform.
 
       osname should be one of the standard Python OS names (i.e. the
       ones returned by os.name) and platform the common value
       returned by sys.platform for the platform in question.
 
       The default values are os.name and sys.platform in case the
       parameters are not given.
    NrÅ)rQr*r·ÚplatformÚ_default_compilersÚreÚmatch)ÚosnamerÉÚpatternÚcompilerrrrÚget_default_compiler©s
 ÿ
rÐ)Z unixccompilerZ UnixCCompilerzstandard UNIX-style compiler)Z _msvccompilerZ MSVCCompilerzMicrosoft Visual C++)ÚcygwinccompilerZCygwinCCompilerz'Cygwin port of GNU C Compiler for Win32)rÑZMingw32CCompilerz(Mingw32 port of GNU C Compiler for Win32)Z bcppcompilerZ BCPPCompilerzBorland C++ Compiler)rÅrÈÚcygwinZmingw32ZbcppcCsXddlm}g}t ¡D] }| d|dt|df¡q| ¡||ƒ}| d¡dS)zyPrint list of available compilers (used by the "--help-compiler"
    options to "build", "build_ext", "build_clib").
    r)Ú FancyGetoptz    compiler=Nr.zList of available compilers:)Údistutils.fancy_getoptrÓÚcompiler_classrr4ÚsortÚ
print_help)rÓZ    compilersrÏZpretty_printerrrrÚshow_compilersÍs   
ÿrØc Csä|dkrtj}z"|dkr t|ƒ}t|\}}}Wn8tk
rhd|}|dk    r\|d|}t|ƒ‚YnXz*d|}t|ƒtj|}    t    |    ƒ|}
WnBt
k
r´t d|ƒ‚Yn$tk
rÖt d||fƒ‚YnX|
d||ƒS)a[Generate an instance of some CCompiler subclass for the supplied
    platform/compiler combination.  'plat' defaults to 'os.name'
    (eg. 'posix', 'nt'), and 'compiler' defaults to the default compiler
    for that platform.  Currently only 'posix' and 'nt' are supported, and
    the default compilers are "traditional Unix interface" (UnixCCompiler
    class) and Visual C++ (MSVCCompiler class).  Note that it's perfectly
    possible to ask for a Unix compiler object under Windows, and a
    Microsoft compiler object under Unix -- if you supply a value for
    'compiler', 'plat' is ignored.
    Nz5don't know how to compile C/C++ code on platform '%s'z with '%s' compilerz
distutils.z4can't compile C/C++ code: unable to load module '%s'zBcan't compile C/C++ code: unable to find class '%s' in module '%s') rQr*rÐrÕrtÚDistutilsPlatformErrorÚ
__import__r·ÚmodulesÚvarsÚ ImportErrorÚDistutilsModuleError) ÚplatrÏrrrÚ module_nameÚ
class_nameÚlong_descriptionr°ÚmoduleÚklassrrrÚ new_compilerÞs:  
ÿÿÿÿ
råcCs´g}|D]Ž}t|tƒr0dt|ƒkr.dks<ntd|ƒ‚t|ƒdkr\| d|d¡qt|ƒdkr|ddkrˆ| d|d¡q| d|¡q|D]}| d    |¡qœ|S)
aGenerate C pre-processor options (-D, -U, -I) as used by at least
    two types of compilers: the typical Unix compiler and Visual C++.
    'macros' is the usual thing, a list of 1- or 2-tuples, where (name,)
    means undefine (-U) macro 'name', and (name,value) means define (-D)
    macro 'name' to 'value'.  'include_dirs' is just a list of directory
    names to be added to the header file search path (-I).  Returns a list
    of command-line options suitable for either Unix compilers or Visual
    C++.
    r)r.zPbad macro definition '%s': each element of 'macros' list must be a 1- or 2-tuplez-U%srNz-D%sz-D%s=%sz-I%s)r%r/r0r1r4)rrrXZmacror8rrrrO s"$þÿ   rOc Cs°g}|D]}| | |¡¡q|D],}| |¡}t|tƒrD||}q"| |¡q"|D]V}tj |¡\}}    |rš| |g|    ¡}
|
rŠ| |
¡qª|     d|¡qT| | 
|¡¡qT|S)acGenerate linker options for searching library directories and
    linking with specific libraries.  'libraries' and 'library_dirs' are,
    respectively, lists of library names (not filenames!) and search
    directories.  Returns a list of command-line options suitable for use
    with some compiler (depending on the two format strings passed in).
    z6no library file corresponding to '%s' found (skipping)) r4r‹rŒr%rLrQrRr­rr¹rŽ) rÏrrrZlib_optsr8ÚoptrÚlib_dirZlib_nameZlib_filerrrÚgen_lib_options8s&
 
 
  ÿrè)NN)NNrrr)rÃr·rQrËÚdistutils.errorsÚdistutils.spawnrÚdistutils.file_utilrÚdistutils.dir_utilrÚdistutils.dep_utilrÚdistutils.utilrrÚ    distutilsr    r
rÊrÐrÕrØrårOrèrrrrÚ<module>s8     
ø 
--