mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-25 18:50:57 +00:00 
			
		
		
		
	add make-4.3.tar.gz
This commit is contained in:
		
							parent
							
								
									0a0997a872
								
							
						
					
					
						commit
						19f70a154e
					
				
					 458 changed files with 239669 additions and 0 deletions
				
			
		
							
								
								
									
										1282
									
								
								third_party/make/ABOUT-NLS
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1282
									
								
								third_party/make/ABOUT-NLS
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										90
									
								
								third_party/make/AUTHORS
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								third_party/make/AUTHORS
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,90 @@ | |||
| ----------------------------------- | ||||
| 
 | ||||
| GNU make development up to version 3.75 by: | ||||
|     Roland McGrath <roland@gnu.org> | ||||
| 
 | ||||
| 
 | ||||
| Development starting with GNU make 3.76 by: | ||||
|     Paul D. Smith <psmith@gnu.org> | ||||
| 
 | ||||
|     Additional development starting with GNU make 3.81 by: | ||||
|         Boris Kolpackov <boris@kolpackov.net> | ||||
| 
 | ||||
| 
 | ||||
| GNU Make User's Manual | ||||
|   Written by: | ||||
|     Richard M. Stallman <rms@gnu.org> | ||||
| 
 | ||||
|   Edited by: | ||||
|     Roland McGrath <roland@gnu.org> | ||||
|     Bob Chassell <bob@gnu.org> | ||||
|     Melissa Weisshaus <melissa@gnu.org> | ||||
|     Paul D. Smith <psmith@gnu.org> | ||||
| 
 | ||||
| ----------------------------------- | ||||
| GNU make porting efforts: | ||||
| 
 | ||||
|   Port to VMS by: | ||||
|       Klaus Kaempf <kkaempf@progis.de> | ||||
|       Hartmut Becker <Hartmut.Becker@hp.com> | ||||
|       Archive support/Bug fixes by: | ||||
|         John W. Eaton <jwe@bevo.che.wisc.edu> | ||||
|         Martin Zinser <zinser@decus.decus.de> | ||||
| 
 | ||||
|   Port to Amiga by: | ||||
|       Aaron Digulla <digulla@fh-konstanz.de> | ||||
| 
 | ||||
|   Port to MS-DOS (DJGPP), OS/2, and MS-Windows (native/MinGW) by: | ||||
|       DJ Delorie <dj@delorie.com> | ||||
|       Rob Tulloh <rob_tulloh@tivoli.com> | ||||
|       Eli Zaretskii <eliz@gnu.org> | ||||
|       Jonathan Grant <jg@jguk.org> | ||||
|       Andreas Beuning <andreas.buening@nexgo.de> | ||||
|       Earnie Boyd <earnie@uses.sf.net> | ||||
|       Troy Runkel <Troy.Runkel@mathworks.com> | ||||
| 
 | ||||
| ----------------------------------- | ||||
| Other contributors: | ||||
| 
 | ||||
|   Janet Carson <janet_carson@tivoli.com> | ||||
|   Howard Chu <hyc@highlandsun.com> | ||||
|   Ludovic Courtès <ludo@gnu.org> | ||||
|   Paul Eggert <eggert@twinsun.com> | ||||
|   Ramon Garcia Fernandez <ramon.garcia.f@gmail.com> | ||||
|   Klaus Heinz <kamar@ease.rhein-main.de> | ||||
|   Michael Joosten | ||||
|   Jim Kelton <jim_kelton@tivoli.com> | ||||
|   David Lubbren <uhay@rz.uni-karlsruhe.de> | ||||
|   Tim Magill <tim.magill@telops.gte.com> | ||||
|   Markus Mauhart <qwe123@chello.at> | ||||
|   Greg McGary <greg@mcgary.org> | ||||
|   Thien-Thi Nguyen <ttn@gnuvola.org> | ||||
|   Thomas Riedl <thomas.riedl@siemens.com> | ||||
|   Han-Wen Nienhuys <hanwen@cs.uu.nl> | ||||
|   Andreas Schwab <schwab@issan.informatik.uni-dortmund.de> | ||||
|   Carl Staelin (Princeton University) | ||||
|   Ian Stewartson (Data Logic Limited) | ||||
|   David A. Wheeler <dwheeler@dwheeler.com> | ||||
|   David Boyce <dsb@boyski.com> | ||||
|   Frank Heckenbach <f.heckenbach@fh-soft.de> | ||||
|   Kaz Kylheku <kaz@kylheku.com> | ||||
|   Christof Warlich <cwarlich@gmx.de> | ||||
| 
 | ||||
| With suggestions/comments/bug reports from a cast of ... well ... | ||||
| hundreds, anyway :) | ||||
| 
 | ||||
| ------------------------------------------------------------------------------- | ||||
| Copyright (C) 1997-2020 Free Software Foundation, Inc. | ||||
| This file is part of GNU Make. | ||||
| 
 | ||||
| GNU Make is free software; you can redistribute it and/or modify it under the | ||||
| terms of the GNU General Public License as published by the Free Software | ||||
| Foundation; either version 3 of the License, or (at your option) any later | ||||
| version. | ||||
| 
 | ||||
| GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR | ||||
| A PARTICULAR PURPOSE.  See the GNU General Public License for more details. | ||||
| 
 | ||||
| You should have received a copy of the GNU General Public License along with | ||||
| this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
							
								
								
									
										246
									
								
								third_party/make/Basic.mk
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										246
									
								
								third_party/make/Basic.mk
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,246 @@ | |||
| # Basic GNU -*-Makefile-*- to build GNU make
 | ||||
| #
 | ||||
| # NOTE:
 | ||||
| # If you have no 'make' program at all to process this makefile:
 | ||||
| #   * On Windows, run ".\buildw32.bat" to bootstrap one.
 | ||||
| #   * On MS-DOS, run ".\builddos.bat" to bootstrap one.
 | ||||
| #
 | ||||
| # Once you have a GNU make program created, you can use it with this makefile
 | ||||
| # to keep it up to date if you make changes, as:
 | ||||
| #
 | ||||
| #   make.exe -f Basic.mk
 | ||||
| #
 | ||||
| # Copyright (C) 2017-2020 Free Software Foundation, Inc.
 | ||||
| # This file is part of GNU Make.
 | ||||
| #
 | ||||
| # GNU Make is free software; you can redistribute it and/or modify it under
 | ||||
| # the terms of the GNU General Public License as published by the Free Software
 | ||||
| # Foundation; either version 3 of the License, or (at your option) any later
 | ||||
| # version.
 | ||||
| #
 | ||||
| # GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY
 | ||||
| # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 | ||||
| # FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
 | ||||
| # details.
 | ||||
| #
 | ||||
| # You should have received a copy of the GNU General Public License along with
 | ||||
| # this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
| 
 | ||||
| all: | ||||
| 
 | ||||
| src = src/ | ||||
| lib = lib/ | ||||
| 
 | ||||
| make_SOURCES = $(src)ar.c $(src)arscan.c $(src)commands.c $(src)default.c $(src)dir.c $(src)expand.c $(src)file.c $(src)function.c $(src)getopt.c $(src)getopt1.c $(src)guile.c $(src)hash.c $(src)implicit.c $(src)job.c $(src)load.c $(src)loadapi.c $(src)main.c $(src)misc.c $(src)output.c $(src)read.c $(src)remake.c $(src)rule.c $(src)signame.c $(src)strcache.c $(src)variable.c $(src)version.c $(src)vpath.c | ||||
| glob_SOURCES = $(lib)fnmatch.c $(lib)glob.c | ||||
| loadavg_SOURCES = $(lib)getloadavg.c | ||||
| alloca_SOURCES = $(lib)alloca.c | ||||
| w32_SOURCES = $(src)w32/pathstuff.c $(src)w32/w32os.c $(src)w32/compat/dirent.c $(src)w32/compat/posixfcn.c $(src)w32/subproc/misc.c $(src)w32/subproc/sub_proc.c $(src)w32/subproc/w32err.c | ||||
| vms_SOURCES = $(src)vms_exit.c $(src)vms_export_symbol.c $(src)vms_progname.c $(src)vmsfunctions.c $(src)vmsify.c | ||||
| amiga_SOURCES = $(src)amiga.c | ||||
| 
 | ||||
| posix_SOURCES = $(src)posixos.c | ||||
| remote_SOURCES = $(src)remote-stub.c | ||||
| 
 | ||||
| OUTDIR = | ||||
| SRCDIR = . | ||||
| 
 | ||||
| OBJEXT = o | ||||
| EXEEXT = | ||||
| 
 | ||||
| PREFIX = /usr/local | ||||
| INCLUDEDIR = $(PREFIX)/include | ||||
| LIBDIR = $(PREFIX)/lib | ||||
| LOCALEDIR = $(PREFIX)/share | ||||
| 
 | ||||
| PROG = $(OUTDIR)make$(EXEEXT) | ||||
| 
 | ||||
| prog_SOURCES = $(make_SOURCES) $(remote_SOURCES) | ||||
| 
 | ||||
| BUILT_SOURCES = | ||||
| 
 | ||||
| OBJECTS = $(patsubst %.c,$(OUTDIR)%.$(OBJEXT),$(prog_SOURCES)) | ||||
| 
 | ||||
| OBJDIRS = $(addsuffix .,$(sort $(dir $(OBJECTS)))) | ||||
| 
 | ||||
| # Use the default value of CC
 | ||||
| LD = $(CC) | ||||
| 
 | ||||
| # Reserved for command-line override
 | ||||
| CPPFLAGS = | ||||
| CFLAGS = -g -O2 | ||||
| LDFLAGS = | ||||
| 
 | ||||
| extra_CPPFLAGS = -DHAVE_CONFIG_H -I$(OUTDIR)src -I$(SRCDIR)/src -I$(OUTDIR)lib -I$(SRCDIR)/lib \
 | ||||
| 	-DLIBDIR=\"$(LIBDIR)\" -DINCLUDEDIR=\"$(INCLUDEDIR)\" -DLOCALEDIR=\"$(LOCALDIR)\" | ||||
| extra_CFLAGS = | ||||
| extra_LDFLAGS = $(extra_CFLAGS) $(CFLAGS) | ||||
| 
 | ||||
| C_SOURCE = -c | ||||
| OUTPUT_OPTION = -o $@ | ||||
| LINK_OUTPUT = -o $@ | ||||
| 
 | ||||
| # Command lines
 | ||||
| 
 | ||||
| # $(call COMPILE.cmd,<src>,<tgt>)
 | ||||
| COMPILE.cmd = $(CC) $(extra_CFLAGS) $(CFLAGS) $(extra_CPPFLAGS) $(CPPFLAGS) $(TARGET_ARCH) $(OUTPUT_OPTION) $(C_SOURCE) $1 | ||||
| 
 | ||||
| # $(call LINK.cmd,<objectlist>)
 | ||||
| LINK.cmd = $(LD) $(extra_LDFLAGS) $(LDFLAGS) $(TARGET_ARCH) $1 $(LDLIBS) $(LINK_OUTPUT) | ||||
| 
 | ||||
| # $(CHECK.cmd)
 | ||||
| CHECK.cmd = cd $(SRCDIR)/tests && ./run_make_tests -make $(shell cd $(<D) && pwd)/$(<F) | ||||
| 
 | ||||
| # $(call MKDIR.cmd,<dirlist>)
 | ||||
| MKDIR.cmd = mkdir -p $1 | ||||
| 
 | ||||
| # $(call RM.cmd,<filelist>)
 | ||||
| RM.cmd = rm -f $1 | ||||
| 
 | ||||
| # $(call CP.cmd,<from>,<to>)
 | ||||
| CP.cmd = cp $1 $2 | ||||
| 
 | ||||
| CLEANSPACE = $(call RM.cmd,$(OBJECTS) $(PROG) $(BUILT_SOURCES)) | ||||
| 
 | ||||
| # Load overrides for the above variables.
 | ||||
| include $(firstword $(wildcard $(SRCDIR)/mk/$(lastword $(subst -, ,$(MAKE_HOST)).mk) $(OUTDIR)mk/Posix.mk $(SRCDIR)/mk/Posix.mk)) | ||||
| 
 | ||||
| VERSION = 4.3 | ||||
| 
 | ||||
| VPATH = $(SRCDIR) | ||||
| 
 | ||||
| all: $(PROG) | ||||
| 
 | ||||
| $(PROG): $(OBJECTS) | ||||
| 	$(call LINK.cmd,$^) | ||||
| 
 | ||||
| $(OBJECTS): $(OUTDIR)%.$(OBJEXT): %.c | ||||
| 	$(call COMPILE.cmd,$<) | ||||
| 
 | ||||
| $(OBJECTS): | $(OBJDIRS) $(BUILT_SOURCES) | ||||
| 
 | ||||
| $(OBJDIRS): | ||||
| 	$(call MKDIR.cmd,$@) | ||||
| 
 | ||||
| check: | ||||
| 	$(CHECK.cmd) | ||||
| 
 | ||||
| clean: | ||||
| 	$(CLEANSPACE) | ||||
| 
 | ||||
| $(filter %.h,$(BUILT_SOURCES)): %.h : %.in.h | ||||
| 	$(call RM.cmd,$@) | ||||
| 	$(call CP.cmd,$<,$@) | ||||
| 
 | ||||
| .PHONY: all check clean | ||||
| 
 | ||||
| # --------------- DEPENDENCIES
 | ||||
| #
 | ||||
| 
 | ||||
| # src/.deps/amiga.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/ar.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/arscan.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/commands.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/default.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/dir.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/expand.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/file.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/function.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/getopt.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/getopt1.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/guile.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/hash.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/implicit.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/job.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/load.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/loadapi.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/main.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/misc.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/output.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/posixos.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/read.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/remake.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/remote-cstms.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/remote-stub.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/rule.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/signame.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/strcache.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/variable.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/version.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/vms_exit.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/vms_export_symbol.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/vms_progname.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/vmsfunctions.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/vmsify.Po
 | ||||
| # dummy
 | ||||
| 
 | ||||
| # src/.deps/vpath.Po
 | ||||
| # dummy
 | ||||
							
								
								
									
										674
									
								
								third_party/make/COPYING
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										674
									
								
								third_party/make/COPYING
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,674 @@ | |||
|                     GNU GENERAL PUBLIC LICENSE | ||||
|                        Version 3, 29 June 2007 | ||||
| 
 | ||||
|  Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/> | ||||
|  Everyone is permitted to copy and distribute verbatim copies | ||||
|  of this license document, but changing it is not allowed. | ||||
| 
 | ||||
|                             Preamble | ||||
| 
 | ||||
|   The GNU General Public License is a free, copyleft license for | ||||
| software and other kinds of works. | ||||
| 
 | ||||
|   The licenses for most software and other practical works are designed | ||||
| to take away your freedom to share and change the works.  By contrast, | ||||
| the GNU General Public License is intended to guarantee your freedom to | ||||
| share and change all versions of a program--to make sure it remains free | ||||
| software for all its users.  We, the Free Software Foundation, use the | ||||
| GNU General Public License for most of our software; it applies also to | ||||
| any other work released this way by its authors.  You can apply it to | ||||
| your programs, too. | ||||
| 
 | ||||
|   When we speak of free software, we are referring to freedom, not | ||||
| price.  Our General Public Licenses are designed to make sure that you | ||||
| have the freedom to distribute copies of free software (and charge for | ||||
| them if you wish), that you receive source code or can get it if you | ||||
| want it, that you can change the software or use pieces of it in new | ||||
| free programs, and that you know you can do these things. | ||||
| 
 | ||||
|   To protect your rights, we need to prevent others from denying you | ||||
| these rights or asking you to surrender the rights.  Therefore, you have | ||||
| certain responsibilities if you distribute copies of the software, or if | ||||
| you modify it: responsibilities to respect the freedom of others. | ||||
| 
 | ||||
|   For example, if you distribute copies of such a program, whether | ||||
| gratis or for a fee, you must pass on to the recipients the same | ||||
| freedoms that you received.  You must make sure that they, too, receive | ||||
| or can get the source code.  And you must show them these terms so they | ||||
| know their rights. | ||||
| 
 | ||||
|   Developers that use the GNU GPL protect your rights with two steps: | ||||
| (1) assert copyright on the software, and (2) offer you this License | ||||
| giving you legal permission to copy, distribute and/or modify it. | ||||
| 
 | ||||
|   For the developers' and authors' protection, the GPL clearly explains | ||||
| that there is no warranty for this free software.  For both users' and | ||||
| authors' sake, the GPL requires that modified versions be marked as | ||||
| changed, so that their problems will not be attributed erroneously to | ||||
| authors of previous versions. | ||||
| 
 | ||||
|   Some devices are designed to deny users access to install or run | ||||
| modified versions of the software inside them, although the manufacturer | ||||
| can do so.  This is fundamentally incompatible with the aim of | ||||
| protecting users' freedom to change the software.  The systematic | ||||
| pattern of such abuse occurs in the area of products for individuals to | ||||
| use, which is precisely where it is most unacceptable.  Therefore, we | ||||
| have designed this version of the GPL to prohibit the practice for those | ||||
| products.  If such problems arise substantially in other domains, we | ||||
| stand ready to extend this provision to those domains in future versions | ||||
| of the GPL, as needed to protect the freedom of users. | ||||
| 
 | ||||
|   Finally, every program is threatened constantly by software patents. | ||||
| States should not allow patents to restrict development and use of | ||||
| software on general-purpose computers, but in those that do, we wish to | ||||
| avoid the special danger that patents applied to a free program could | ||||
| make it effectively proprietary.  To prevent this, the GPL assures that | ||||
| patents cannot be used to render the program non-free. | ||||
| 
 | ||||
|   The precise terms and conditions for copying, distribution and | ||||
| modification follow. | ||||
| 
 | ||||
|                        TERMS AND CONDITIONS | ||||
| 
 | ||||
|   0. Definitions. | ||||
| 
 | ||||
|   "This License" refers to version 3 of the GNU General Public License. | ||||
| 
 | ||||
|   "Copyright" also means copyright-like laws that apply to other kinds of | ||||
| works, such as semiconductor masks. | ||||
| 
 | ||||
|   "The Program" refers to any copyrightable work licensed under this | ||||
| License.  Each licensee is addressed as "you".  "Licensees" and | ||||
| "recipients" may be individuals or organizations. | ||||
| 
 | ||||
|   To "modify" a work means to copy from or adapt all or part of the work | ||||
| in a fashion requiring copyright permission, other than the making of an | ||||
| exact copy.  The resulting work is called a "modified version" of the | ||||
| earlier work or a work "based on" the earlier work. | ||||
| 
 | ||||
|   A "covered work" means either the unmodified Program or a work based | ||||
| on the Program. | ||||
| 
 | ||||
|   To "propagate" a work means to do anything with it that, without | ||||
| permission, would make you directly or secondarily liable for | ||||
| infringement under applicable copyright law, except executing it on a | ||||
| computer or modifying a private copy.  Propagation includes copying, | ||||
| distribution (with or without modification), making available to the | ||||
| public, and in some countries other activities as well. | ||||
| 
 | ||||
|   To "convey" a work means any kind of propagation that enables other | ||||
| parties to make or receive copies.  Mere interaction with a user through | ||||
| a computer network, with no transfer of a copy, is not conveying. | ||||
| 
 | ||||
|   An interactive user interface displays "Appropriate Legal Notices" | ||||
| to the extent that it includes a convenient and prominently visible | ||||
| feature that (1) displays an appropriate copyright notice, and (2) | ||||
| tells the user that there is no warranty for the work (except to the | ||||
| extent that warranties are provided), that licensees may convey the | ||||
| work under this License, and how to view a copy of this License.  If | ||||
| the interface presents a list of user commands or options, such as a | ||||
| menu, a prominent item in the list meets this criterion. | ||||
| 
 | ||||
|   1. Source Code. | ||||
| 
 | ||||
|   The "source code" for a work means the preferred form of the work | ||||
| for making modifications to it.  "Object code" means any non-source | ||||
| form of a work. | ||||
| 
 | ||||
|   A "Standard Interface" means an interface that either is an official | ||||
| standard defined by a recognized standards body, or, in the case of | ||||
| interfaces specified for a particular programming language, one that | ||||
| is widely used among developers working in that language. | ||||
| 
 | ||||
|   The "System Libraries" of an executable work include anything, other | ||||
| than the work as a whole, that (a) is included in the normal form of | ||||
| packaging a Major Component, but which is not part of that Major | ||||
| Component, and (b) serves only to enable use of the work with that | ||||
| Major Component, or to implement a Standard Interface for which an | ||||
| implementation is available to the public in source code form.  A | ||||
| "Major Component", in this context, means a major essential component | ||||
| (kernel, window system, and so on) of the specific operating system | ||||
| (if any) on which the executable work runs, or a compiler used to | ||||
| produce the work, or an object code interpreter used to run it. | ||||
| 
 | ||||
|   The "Corresponding Source" for a work in object code form means all | ||||
| the source code needed to generate, install, and (for an executable | ||||
| work) run the object code and to modify the work, including scripts to | ||||
| control those activities.  However, it does not include the work's | ||||
| System Libraries, or general-purpose tools or generally available free | ||||
| programs which are used unmodified in performing those activities but | ||||
| which are not part of the work.  For example, Corresponding Source | ||||
| includes interface definition files associated with source files for | ||||
| the work, and the source code for shared libraries and dynamically | ||||
| linked subprograms that the work is specifically designed to require, | ||||
| such as by intimate data communication or control flow between those | ||||
| subprograms and other parts of the work. | ||||
| 
 | ||||
|   The Corresponding Source need not include anything that users | ||||
| can regenerate automatically from other parts of the Corresponding | ||||
| Source. | ||||
| 
 | ||||
|   The Corresponding Source for a work in source code form is that | ||||
| same work. | ||||
| 
 | ||||
|   2. Basic Permissions. | ||||
| 
 | ||||
|   All rights granted under this License are granted for the term of | ||||
| copyright on the Program, and are irrevocable provided the stated | ||||
| conditions are met.  This License explicitly affirms your unlimited | ||||
| permission to run the unmodified Program.  The output from running a | ||||
| covered work is covered by this License only if the output, given its | ||||
| content, constitutes a covered work.  This License acknowledges your | ||||
| rights of fair use or other equivalent, as provided by copyright law. | ||||
| 
 | ||||
|   You may make, run and propagate covered works that you do not | ||||
| convey, without conditions so long as your license otherwise remains | ||||
| in force.  You may convey covered works to others for the sole purpose | ||||
| of having them make modifications exclusively for you, or provide you | ||||
| with facilities for running those works, provided that you comply with | ||||
| the terms of this License in conveying all material for which you do | ||||
| not control copyright.  Those thus making or running the covered works | ||||
| for you must do so exclusively on your behalf, under your direction | ||||
| and control, on terms that prohibit them from making any copies of | ||||
| your copyrighted material outside their relationship with you. | ||||
| 
 | ||||
|   Conveying under any other circumstances is permitted solely under | ||||
| the conditions stated below.  Sublicensing is not allowed; section 10 | ||||
| makes it unnecessary. | ||||
| 
 | ||||
|   3. Protecting Users' Legal Rights From Anti-Circumvention Law. | ||||
| 
 | ||||
|   No covered work shall be deemed part of an effective technological | ||||
| measure under any applicable law fulfilling obligations under article | ||||
| 11 of the WIPO copyright treaty adopted on 20 December 1996, or | ||||
| similar laws prohibiting or restricting circumvention of such | ||||
| measures. | ||||
| 
 | ||||
|   When you convey a covered work, you waive any legal power to forbid | ||||
| circumvention of technological measures to the extent such circumvention | ||||
| is effected by exercising rights under this License with respect to | ||||
| the covered work, and you disclaim any intention to limit operation or | ||||
| modification of the work as a means of enforcing, against the work's | ||||
| users, your or third parties' legal rights to forbid circumvention of | ||||
| technological measures. | ||||
| 
 | ||||
|   4. Conveying Verbatim Copies. | ||||
| 
 | ||||
|   You may convey verbatim copies of the Program's source code as you | ||||
| receive it, in any medium, provided that you conspicuously and | ||||
| appropriately publish on each copy an appropriate copyright notice; | ||||
| keep intact all notices stating that this License and any | ||||
| non-permissive terms added in accord with section 7 apply to the code; | ||||
| keep intact all notices of the absence of any warranty; and give all | ||||
| recipients a copy of this License along with the Program. | ||||
| 
 | ||||
|   You may charge any price or no price for each copy that you convey, | ||||
| and you may offer support or warranty protection for a fee. | ||||
| 
 | ||||
|   5. Conveying Modified Source Versions. | ||||
| 
 | ||||
|   You may convey a work based on the Program, or the modifications to | ||||
| produce it from the Program, in the form of source code under the | ||||
| terms of section 4, provided that you also meet all of these conditions: | ||||
| 
 | ||||
|     a) The work must carry prominent notices stating that you modified | ||||
|     it, and giving a relevant date. | ||||
| 
 | ||||
|     b) The work must carry prominent notices stating that it is | ||||
|     released under this License and any conditions added under section | ||||
|     7.  This requirement modifies the requirement in section 4 to | ||||
|     "keep intact all notices". | ||||
| 
 | ||||
|     c) You must license the entire work, as a whole, under this | ||||
|     License to anyone who comes into possession of a copy.  This | ||||
|     License will therefore apply, along with any applicable section 7 | ||||
|     additional terms, to the whole of the work, and all its parts, | ||||
|     regardless of how they are packaged.  This License gives no | ||||
|     permission to license the work in any other way, but it does not | ||||
|     invalidate such permission if you have separately received it. | ||||
| 
 | ||||
|     d) If the work has interactive user interfaces, each must display | ||||
|     Appropriate Legal Notices; however, if the Program has interactive | ||||
|     interfaces that do not display Appropriate Legal Notices, your | ||||
|     work need not make them do so. | ||||
| 
 | ||||
|   A compilation of a covered work with other separate and independent | ||||
| works, which are not by their nature extensions of the covered work, | ||||
| and which are not combined with it such as to form a larger program, | ||||
| in or on a volume of a storage or distribution medium, is called an | ||||
| "aggregate" if the compilation and its resulting copyright are not | ||||
| used to limit the access or legal rights of the compilation's users | ||||
| beyond what the individual works permit.  Inclusion of a covered work | ||||
| in an aggregate does not cause this License to apply to the other | ||||
| parts of the aggregate. | ||||
| 
 | ||||
|   6. Conveying Non-Source Forms. | ||||
| 
 | ||||
|   You may convey a covered work in object code form under the terms | ||||
| of sections 4 and 5, provided that you also convey the | ||||
| machine-readable Corresponding Source under the terms of this License, | ||||
| in one of these ways: | ||||
| 
 | ||||
|     a) Convey the object code in, or embodied in, a physical product | ||||
|     (including a physical distribution medium), accompanied by the | ||||
|     Corresponding Source fixed on a durable physical medium | ||||
|     customarily used for software interchange. | ||||
| 
 | ||||
|     b) Convey the object code in, or embodied in, a physical product | ||||
|     (including a physical distribution medium), accompanied by a | ||||
|     written offer, valid for at least three years and valid for as | ||||
|     long as you offer spare parts or customer support for that product | ||||
|     model, to give anyone who possesses the object code either (1) a | ||||
|     copy of the Corresponding Source for all the software in the | ||||
|     product that is covered by this License, on a durable physical | ||||
|     medium customarily used for software interchange, for a price no | ||||
|     more than your reasonable cost of physically performing this | ||||
|     conveying of source, or (2) access to copy the | ||||
|     Corresponding Source from a network server at no charge. | ||||
| 
 | ||||
|     c) Convey individual copies of the object code with a copy of the | ||||
|     written offer to provide the Corresponding Source.  This | ||||
|     alternative is allowed only occasionally and noncommercially, and | ||||
|     only if you received the object code with such an offer, in accord | ||||
|     with subsection 6b. | ||||
| 
 | ||||
|     d) Convey the object code by offering access from a designated | ||||
|     place (gratis or for a charge), and offer equivalent access to the | ||||
|     Corresponding Source in the same way through the same place at no | ||||
|     further charge.  You need not require recipients to copy the | ||||
|     Corresponding Source along with the object code.  If the place to | ||||
|     copy the object code is a network server, the Corresponding Source | ||||
|     may be on a different server (operated by you or a third party) | ||||
|     that supports equivalent copying facilities, provided you maintain | ||||
|     clear directions next to the object code saying where to find the | ||||
|     Corresponding Source.  Regardless of what server hosts the | ||||
|     Corresponding Source, you remain obligated to ensure that it is | ||||
|     available for as long as needed to satisfy these requirements. | ||||
| 
 | ||||
|     e) Convey the object code using peer-to-peer transmission, provided | ||||
|     you inform other peers where the object code and Corresponding | ||||
|     Source of the work are being offered to the general public at no | ||||
|     charge under subsection 6d. | ||||
| 
 | ||||
|   A separable portion of the object code, whose source code is excluded | ||||
| from the Corresponding Source as a System Library, need not be | ||||
| included in conveying the object code work. | ||||
| 
 | ||||
|   A "User Product" is either (1) a "consumer product", which means any | ||||
| tangible personal property which is normally used for personal, family, | ||||
| or household purposes, or (2) anything designed or sold for incorporation | ||||
| into a dwelling.  In determining whether a product is a consumer product, | ||||
| doubtful cases shall be resolved in favor of coverage.  For a particular | ||||
| product received by a particular user, "normally used" refers to a | ||||
| typical or common use of that class of product, regardless of the status | ||||
| of the particular user or of the way in which the particular user | ||||
| actually uses, or expects or is expected to use, the product.  A product | ||||
| is a consumer product regardless of whether the product has substantial | ||||
| commercial, industrial or non-consumer uses, unless such uses represent | ||||
| the only significant mode of use of the product. | ||||
| 
 | ||||
|   "Installation Information" for a User Product means any methods, | ||||
| procedures, authorization keys, or other information required to install | ||||
| and execute modified versions of a covered work in that User Product from | ||||
| a modified version of its Corresponding Source.  The information must | ||||
| suffice to ensure that the continued functioning of the modified object | ||||
| code is in no case prevented or interfered with solely because | ||||
| modification has been made. | ||||
| 
 | ||||
|   If you convey an object code work under this section in, or with, or | ||||
| specifically for use in, a User Product, and the conveying occurs as | ||||
| part of a transaction in which the right of possession and use of the | ||||
| User Product is transferred to the recipient in perpetuity or for a | ||||
| fixed term (regardless of how the transaction is characterized), the | ||||
| Corresponding Source conveyed under this section must be accompanied | ||||
| by the Installation Information.  But this requirement does not apply | ||||
| if neither you nor any third party retains the ability to install | ||||
| modified object code on the User Product (for example, the work has | ||||
| been installed in ROM). | ||||
| 
 | ||||
|   The requirement to provide Installation Information does not include a | ||||
| requirement to continue to provide support service, warranty, or updates | ||||
| for a work that has been modified or installed by the recipient, or for | ||||
| the User Product in which it has been modified or installed.  Access to a | ||||
| network may be denied when the modification itself materially and | ||||
| adversely affects the operation of the network or violates the rules and | ||||
| protocols for communication across the network. | ||||
| 
 | ||||
|   Corresponding Source conveyed, and Installation Information provided, | ||||
| in accord with this section must be in a format that is publicly | ||||
| documented (and with an implementation available to the public in | ||||
| source code form), and must require no special password or key for | ||||
| unpacking, reading or copying. | ||||
| 
 | ||||
|   7. Additional Terms. | ||||
| 
 | ||||
|   "Additional permissions" are terms that supplement the terms of this | ||||
| License by making exceptions from one or more of its conditions. | ||||
| Additional permissions that are applicable to the entire Program shall | ||||
| be treated as though they were included in this License, to the extent | ||||
| that they are valid under applicable law.  If additional permissions | ||||
| apply only to part of the Program, that part may be used separately | ||||
| under those permissions, but the entire Program remains governed by | ||||
| this License without regard to the additional permissions. | ||||
| 
 | ||||
|   When you convey a copy of a covered work, you may at your option | ||||
| remove any additional permissions from that copy, or from any part of | ||||
| it.  (Additional permissions may be written to require their own | ||||
| removal in certain cases when you modify the work.)  You may place | ||||
| additional permissions on material, added by you to a covered work, | ||||
| for which you have or can give appropriate copyright permission. | ||||
| 
 | ||||
|   Notwithstanding any other provision of this License, for material you | ||||
| add to a covered work, you may (if authorized by the copyright holders of | ||||
| that material) supplement the terms of this License with terms: | ||||
| 
 | ||||
|     a) Disclaiming warranty or limiting liability differently from the | ||||
|     terms of sections 15 and 16 of this License; or | ||||
| 
 | ||||
|     b) Requiring preservation of specified reasonable legal notices or | ||||
|     author attributions in that material or in the Appropriate Legal | ||||
|     Notices displayed by works containing it; or | ||||
| 
 | ||||
|     c) Prohibiting misrepresentation of the origin of that material, or | ||||
|     requiring that modified versions of such material be marked in | ||||
|     reasonable ways as different from the original version; or | ||||
| 
 | ||||
|     d) Limiting the use for publicity purposes of names of licensors or | ||||
|     authors of the material; or | ||||
| 
 | ||||
|     e) Declining to grant rights under trademark law for use of some | ||||
|     trade names, trademarks, or service marks; or | ||||
| 
 | ||||
|     f) Requiring indemnification of licensors and authors of that | ||||
|     material by anyone who conveys the material (or modified versions of | ||||
|     it) with contractual assumptions of liability to the recipient, for | ||||
|     any liability that these contractual assumptions directly impose on | ||||
|     those licensors and authors. | ||||
| 
 | ||||
|   All other non-permissive additional terms are considered "further | ||||
| restrictions" within the meaning of section 10.  If the Program as you | ||||
| received it, or any part of it, contains a notice stating that it is | ||||
| governed by this License along with a term that is a further | ||||
| restriction, you may remove that term.  If a license document contains | ||||
| a further restriction but permits relicensing or conveying under this | ||||
| License, you may add to a covered work material governed by the terms | ||||
| of that license document, provided that the further restriction does | ||||
| not survive such relicensing or conveying. | ||||
| 
 | ||||
|   If you add terms to a covered work in accord with this section, you | ||||
| must place, in the relevant source files, a statement of the | ||||
| additional terms that apply to those files, or a notice indicating | ||||
| where to find the applicable terms. | ||||
| 
 | ||||
|   Additional terms, permissive or non-permissive, may be stated in the | ||||
| form of a separately written license, or stated as exceptions; | ||||
| the above requirements apply either way. | ||||
| 
 | ||||
|   8. Termination. | ||||
| 
 | ||||
|   You may not propagate or modify a covered work except as expressly | ||||
| provided under this License.  Any attempt otherwise to propagate or | ||||
| modify it is void, and will automatically terminate your rights under | ||||
| this License (including any patent licenses granted under the third | ||||
| paragraph of section 11). | ||||
| 
 | ||||
|   However, if you cease all violation of this License, then your | ||||
| license from a particular copyright holder is reinstated (a) | ||||
| provisionally, unless and until the copyright holder explicitly and | ||||
| finally terminates your license, and (b) permanently, if the copyright | ||||
| holder fails to notify you of the violation by some reasonable means | ||||
| prior to 60 days after the cessation. | ||||
| 
 | ||||
|   Moreover, your license from a particular copyright holder is | ||||
| reinstated permanently if the copyright holder notifies you of the | ||||
| violation by some reasonable means, this is the first time you have | ||||
| received notice of violation of this License (for any work) from that | ||||
| copyright holder, and you cure the violation prior to 30 days after | ||||
| your receipt of the notice. | ||||
| 
 | ||||
|   Termination of your rights under this section does not terminate the | ||||
| licenses of parties who have received copies or rights from you under | ||||
| this License.  If your rights have been terminated and not permanently | ||||
| reinstated, you do not qualify to receive new licenses for the same | ||||
| material under section 10. | ||||
| 
 | ||||
|   9. Acceptance Not Required for Having Copies. | ||||
| 
 | ||||
|   You are not required to accept this License in order to receive or | ||||
| run a copy of the Program.  Ancillary propagation of a covered work | ||||
| occurring solely as a consequence of using peer-to-peer transmission | ||||
| to receive a copy likewise does not require acceptance.  However, | ||||
| nothing other than this License grants you permission to propagate or | ||||
| modify any covered work.  These actions infringe copyright if you do | ||||
| not accept this License.  Therefore, by modifying or propagating a | ||||
| covered work, you indicate your acceptance of this License to do so. | ||||
| 
 | ||||
|   10. Automatic Licensing of Downstream Recipients. | ||||
| 
 | ||||
|   Each time you convey a covered work, the recipient automatically | ||||
| receives a license from the original licensors, to run, modify and | ||||
| propagate that work, subject to this License.  You are not responsible | ||||
| for enforcing compliance by third parties with this License. | ||||
| 
 | ||||
|   An "entity transaction" is a transaction transferring control of an | ||||
| organization, or substantially all assets of one, or subdividing an | ||||
| organization, or merging organizations.  If propagation of a covered | ||||
| work results from an entity transaction, each party to that | ||||
| transaction who receives a copy of the work also receives whatever | ||||
| licenses to the work the party's predecessor in interest had or could | ||||
| give under the previous paragraph, plus a right to possession of the | ||||
| Corresponding Source of the work from the predecessor in interest, if | ||||
| the predecessor has it or can get it with reasonable efforts. | ||||
| 
 | ||||
|   You may not impose any further restrictions on the exercise of the | ||||
| rights granted or affirmed under this License.  For example, you may | ||||
| not impose a license fee, royalty, or other charge for exercise of | ||||
| rights granted under this License, and you may not initiate litigation | ||||
| (including a cross-claim or counterclaim in a lawsuit) alleging that | ||||
| any patent claim is infringed by making, using, selling, offering for | ||||
| sale, or importing the Program or any portion of it. | ||||
| 
 | ||||
|   11. Patents. | ||||
| 
 | ||||
|   A "contributor" is a copyright holder who authorizes use under this | ||||
| License of the Program or a work on which the Program is based.  The | ||||
| work thus licensed is called the contributor's "contributor version". | ||||
| 
 | ||||
|   A contributor's "essential patent claims" are all patent claims | ||||
| owned or controlled by the contributor, whether already acquired or | ||||
| hereafter acquired, that would be infringed by some manner, permitted | ||||
| by this License, of making, using, or selling its contributor version, | ||||
| but do not include claims that would be infringed only as a | ||||
| consequence of further modification of the contributor version.  For | ||||
| purposes of this definition, "control" includes the right to grant | ||||
| patent sublicenses in a manner consistent with the requirements of | ||||
| this License. | ||||
| 
 | ||||
|   Each contributor grants you a non-exclusive, worldwide, royalty-free | ||||
| patent license under the contributor's essential patent claims, to | ||||
| make, use, sell, offer for sale, import and otherwise run, modify and | ||||
| propagate the contents of its contributor version. | ||||
| 
 | ||||
|   In the following three paragraphs, a "patent license" is any express | ||||
| agreement or commitment, however denominated, not to enforce a patent | ||||
| (such as an express permission to practice a patent or covenant not to | ||||
| sue for patent infringement).  To "grant" such a patent license to a | ||||
| party means to make such an agreement or commitment not to enforce a | ||||
| patent against the party. | ||||
| 
 | ||||
|   If you convey a covered work, knowingly relying on a patent license, | ||||
| and the Corresponding Source of the work is not available for anyone | ||||
| to copy, free of charge and under the terms of this License, through a | ||||
| publicly available network server or other readily accessible means, | ||||
| then you must either (1) cause the Corresponding Source to be so | ||||
| available, or (2) arrange to deprive yourself of the benefit of the | ||||
| patent license for this particular work, or (3) arrange, in a manner | ||||
| consistent with the requirements of this License, to extend the patent | ||||
| license to downstream recipients.  "Knowingly relying" means you have | ||||
| actual knowledge that, but for the patent license, your conveying the | ||||
| covered work in a country, or your recipient's use of the covered work | ||||
| in a country, would infringe one or more identifiable patents in that | ||||
| country that you have reason to believe are valid. | ||||
| 
 | ||||
|   If, pursuant to or in connection with a single transaction or | ||||
| arrangement, you convey, or propagate by procuring conveyance of, a | ||||
| covered work, and grant a patent license to some of the parties | ||||
| receiving the covered work authorizing them to use, propagate, modify | ||||
| or convey a specific copy of the covered work, then the patent license | ||||
| you grant is automatically extended to all recipients of the covered | ||||
| work and works based on it. | ||||
| 
 | ||||
|   A patent license is "discriminatory" if it does not include within | ||||
| the scope of its coverage, prohibits the exercise of, or is | ||||
| conditioned on the non-exercise of one or more of the rights that are | ||||
| specifically granted under this License.  You may not convey a covered | ||||
| work if you are a party to an arrangement with a third party that is | ||||
| in the business of distributing software, under which you make payment | ||||
| to the third party based on the extent of your activity of conveying | ||||
| the work, and under which the third party grants, to any of the | ||||
| parties who would receive the covered work from you, a discriminatory | ||||
| patent license (a) in connection with copies of the covered work | ||||
| conveyed by you (or copies made from those copies), or (b) primarily | ||||
| for and in connection with specific products or compilations that | ||||
| contain the covered work, unless you entered into that arrangement, | ||||
| or that patent license was granted, prior to 28 March 2007. | ||||
| 
 | ||||
|   Nothing in this License shall be construed as excluding or limiting | ||||
| any implied license or other defenses to infringement that may | ||||
| otherwise be available to you under applicable patent law. | ||||
| 
 | ||||
|   12. No Surrender of Others' Freedom. | ||||
| 
 | ||||
|   If conditions are imposed on you (whether by court order, agreement or | ||||
| otherwise) that contradict the conditions of this License, they do not | ||||
| excuse you from the conditions of this License.  If you cannot convey a | ||||
| covered work so as to satisfy simultaneously your obligations under this | ||||
| License and any other pertinent obligations, then as a consequence you may | ||||
| not convey it at all.  For example, if you agree to terms that obligate you | ||||
| to collect a royalty for further conveying from those to whom you convey | ||||
| the Program, the only way you could satisfy both those terms and this | ||||
| License would be to refrain entirely from conveying the Program. | ||||
| 
 | ||||
|   13. Use with the GNU Affero General Public License. | ||||
| 
 | ||||
|   Notwithstanding any other provision of this License, you have | ||||
| permission to link or combine any covered work with a work licensed | ||||
| under version 3 of the GNU Affero General Public License into a single | ||||
| combined work, and to convey the resulting work.  The terms of this | ||||
| License will continue to apply to the part which is the covered work, | ||||
| but the special requirements of the GNU Affero General Public License, | ||||
| section 13, concerning interaction through a network will apply to the | ||||
| combination as such. | ||||
| 
 | ||||
|   14. Revised Versions of this License. | ||||
| 
 | ||||
|   The Free Software Foundation may publish revised and/or new versions of | ||||
| the GNU General Public License from time to time.  Such new versions will | ||||
| be similar in spirit to the present version, but may differ in detail to | ||||
| address new problems or concerns. | ||||
| 
 | ||||
|   Each version is given a distinguishing version number.  If the | ||||
| Program specifies that a certain numbered version of the GNU General | ||||
| Public License "or any later version" applies to it, you have the | ||||
| option of following the terms and conditions either of that numbered | ||||
| version or of any later version published by the Free Software | ||||
| Foundation.  If the Program does not specify a version number of the | ||||
| GNU General Public License, you may choose any version ever published | ||||
| by the Free Software Foundation. | ||||
| 
 | ||||
|   If the Program specifies that a proxy can decide which future | ||||
| versions of the GNU General Public License can be used, that proxy's | ||||
| public statement of acceptance of a version permanently authorizes you | ||||
| to choose that version for the Program. | ||||
| 
 | ||||
|   Later license versions may give you additional or different | ||||
| permissions.  However, no additional obligations are imposed on any | ||||
| author or copyright holder as a result of your choosing to follow a | ||||
| later version. | ||||
| 
 | ||||
|   15. Disclaimer of Warranty. | ||||
| 
 | ||||
|   THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY | ||||
| APPLICABLE LAW.  EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT | ||||
| HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY | ||||
| OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, | ||||
| THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | ||||
| PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM | ||||
| IS WITH YOU.  SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF | ||||
| ALL NECESSARY SERVICING, REPAIR OR CORRECTION. | ||||
| 
 | ||||
|   16. Limitation of Liability. | ||||
| 
 | ||||
|   IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING | ||||
| WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS | ||||
| THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY | ||||
| GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE | ||||
| USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF | ||||
| DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD | ||||
| PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), | ||||
| EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF | ||||
| SUCH DAMAGES. | ||||
| 
 | ||||
|   17. Interpretation of Sections 15 and 16. | ||||
| 
 | ||||
|   If the disclaimer of warranty and limitation of liability provided | ||||
| above cannot be given local legal effect according to their terms, | ||||
| reviewing courts shall apply local law that most closely approximates | ||||
| an absolute waiver of all civil liability in connection with the | ||||
| Program, unless a warranty or assumption of liability accompanies a | ||||
| copy of the Program in return for a fee. | ||||
| 
 | ||||
|                      END OF TERMS AND CONDITIONS | ||||
| 
 | ||||
|             How to Apply These Terms to Your New Programs | ||||
| 
 | ||||
|   If you develop a new program, and you want it to be of the greatest | ||||
| possible use to the public, the best way to achieve this is to make it | ||||
| free software which everyone can redistribute and change under these terms. | ||||
| 
 | ||||
|   To do so, attach the following notices to the program.  It is safest | ||||
| to attach them to the start of each source file to most effectively | ||||
| state the exclusion of warranty; and each file should have at least | ||||
| the "copyright" line and a pointer to where the full notice is found. | ||||
| 
 | ||||
|     <one line to give the program's name and a brief idea of what it does.> | ||||
|     Copyright (C) <year>  <name of author> | ||||
| 
 | ||||
|     This program is free software: you can redistribute it and/or modify | ||||
|     it under the terms of the GNU General Public License as published by | ||||
|     the Free Software Foundation, either version 3 of the License, or | ||||
|     (at your option) any later version. | ||||
| 
 | ||||
|     This program is distributed in the hope that it will be useful, | ||||
|     but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|     GNU General Public License for more details. | ||||
| 
 | ||||
|     You should have received a copy of the GNU General Public License | ||||
|     along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| Also add information on how to contact you by electronic and paper mail. | ||||
| 
 | ||||
|   If the program does terminal interaction, make it output a short | ||||
| notice like this when it starts in an interactive mode: | ||||
| 
 | ||||
|     <program>  Copyright (C) <year>  <name of author> | ||||
|     This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. | ||||
|     This is free software, and you are welcome to redistribute it | ||||
|     under certain conditions; type `show c' for details. | ||||
| 
 | ||||
| The hypothetical commands `show w' and `show c' should show the appropriate | ||||
| parts of the General Public License.  Of course, your program's commands | ||||
| might be different; for a GUI interface, you would use an "about box". | ||||
| 
 | ||||
|   You should also get your employer (if you work as a programmer) or school, | ||||
| if any, to sign a "copyright disclaimer" for the program, if necessary. | ||||
| For more information on this, and how to apply and follow the GNU GPL, see | ||||
| <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
|   The GNU General Public License does not permit incorporating your program | ||||
| into proprietary programs.  If your program is a subroutine library, you | ||||
| may consider it more useful to permit linking proprietary applications with | ||||
| the library.  If this is what you want to do, use the GNU Lesser General | ||||
| Public License instead of this License.  But first, please read | ||||
| <http://www.gnu.org/philosophy/why-not-lgpl.html>. | ||||
							
								
								
									
										2684
									
								
								third_party/make/ChangeLog
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2684
									
								
								third_party/make/ChangeLog
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										182
									
								
								third_party/make/Makefile.am
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										182
									
								
								third_party/make/Makefile.am
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,182 @@ | |||
| # This is a -*-Makefile-*-, or close enough | ||||
| # | ||||
| # Copyright (C) 1997-2020 Free Software Foundation, Inc. | ||||
| # This file is part of GNU Make. | ||||
| # | ||||
| # GNU Make is free software; you can redistribute it and/or modify it under | ||||
| # the terms of the GNU General Public License as published by the Free Software | ||||
| # Foundation; either version 3 of the License, or (at your option) any later | ||||
| # version. | ||||
| # | ||||
| # GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS | ||||
| # FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more | ||||
| # details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License along with | ||||
| # this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| AUTOMAKE_OPTIONS = dist-lzip silent-rules std-options subdir-objects nostdinc | ||||
| ACLOCAL_AMFLAGS = -I m4 | ||||
| 
 | ||||
| MAKE_HOST =	@MAKE_HOST@ | ||||
| 
 | ||||
| SUBDIRS =	lib po doc | ||||
| 
 | ||||
| bin_PROGRAMS =	make | ||||
| include_HEADERS = src/gnumake.h | ||||
| 
 | ||||
| man_MANS =	doc/make.1 | ||||
| 
 | ||||
| make_SRCS =	src/ar.c src/arscan.c src/commands.c src/commands.h \ | ||||
| 		src/debug.h src/default.c src/dep.h src/dir.c src/expand.c \ | ||||
| 		src/file.c src/filedef.h src/function.c src/getopt.c \ | ||||
| 		src/getopt.h src/getopt1.c src/gettext.h src/guile.c \ | ||||
| 		src/hash.c src/hash.h src/implicit.c src/job.c src/job.h \ | ||||
| 		src/load.c src/loadapi.c src/main.c src/makeint.h src/misc.c \ | ||||
| 		src/os.h src/output.c src/output.h src/read.c src/remake.c \ | ||||
| 		src/rule.c src/rule.h src/signame.c src/strcache.c \ | ||||
| 		src/variable.c src/variable.h src/version.c src/vpath.c | ||||
| 
 | ||||
| w32_SRCS =	src/w32/pathstuff.c src/w32/w32os.c src/w32/compat/dirent.c \ | ||||
| 		src/w32/compat/posixfcn.c src/w32/include/dirent.h \ | ||||
| 		src/w32/include/dlfcn.h src/w32/include/pathstuff.h \ | ||||
| 		src/w32/include/sub_proc.h src/w32/include/w32err.h \ | ||||
| 		src/w32/subproc/misc.c src/w32/subproc/proc.h \ | ||||
| 		src/w32/subproc/sub_proc.c src/w32/subproc/w32err.c | ||||
| 
 | ||||
| vms_SRCS =	src/vms_exit.c src/vms_export_symbol.c src/vms_progname.c \ | ||||
| 		src/vmsdir.h src/vmsfunctions.c src/vmsify.c | ||||
| 
 | ||||
| amiga_SRCS =	src/amiga.c src/amiga.h | ||||
| 
 | ||||
| glob_SRCS =	lib/fnmatch.c lib/fnmatch.h lib/glob.c lib/glob.h | ||||
| 
 | ||||
| alloca_SRCS =	lib/alloca.c | ||||
| 
 | ||||
| loadavg_SRCS =	lib/getloadavg.c | ||||
| 
 | ||||
| make_SOURCES =	$(make_SRCS) | ||||
| EXTRA_make_SOURCES = $(amiga_SRCS) $(vms_SRCS) | ||||
| 
 | ||||
| make_LDADD =	$(LIBOBJS) $(GUILE_LIBS) lib/libgnu.a $(GETLOADAVG_LIBS) \ | ||||
| 		@LIBINTL@ | ||||
| 
 | ||||
| localedir =	$(datadir)/locale | ||||
| 
 | ||||
| AM_CPPFLAGS =	-Isrc -I$(top_srcdir)/src -Ilib -I$(top_srcdir)/lib \ | ||||
| 		-DLIBDIR=\"$(libdir)\" -DINCLUDEDIR=\"$(includedir)\" \ | ||||
| 		-DLOCALEDIR=\"$(localedir)\" | ||||
| 
 | ||||
| AM_CFLAGS =	$(GUILE_CFLAGS) | ||||
| 
 | ||||
| if WINDOWSENV | ||||
|   make_SOURCES += $(w32_SRCS) | ||||
|   AM_CPPFLAGS  += -I $(top_srcdir)/src/w32/include | ||||
| else | ||||
|   make_SOURCES += src/posixos.c | ||||
| endif | ||||
| 
 | ||||
| if USE_CUSTOMS | ||||
|   make_SOURCES += src/remote-cstms.c | ||||
| else | ||||
|   make_SOURCES += src/remote-stub.c | ||||
| endif | ||||
| 
 | ||||
| # Extra stuff to include in the distribution. | ||||
| 
 | ||||
| mk_FILES =	Basic.mk mk/msdosdjgpp.mk mk/Amiga.mk mk/VMS.mk mk/Windows32.mk | ||||
| # We don't need this, since the standard automake output will do. | ||||
| #mk/Posix.mk.in | ||||
| 
 | ||||
| m4_FILES =	m4/gnulib-cache.m4 | ||||
| 
 | ||||
| test_FILES =	tests/run_make_tests tests/run_make_tests.bat \ | ||||
| 		tests/run_make_tests.pl tests/test_driver.pl \ | ||||
| 		tests/config-flags.pm.in tests/config_flags_pm.com \ | ||||
| 		tests/config-flags.pm.W32 \ | ||||
| 		tests/mkshadow tests/thelp.pl tests/guile.supp tests/README | ||||
| # test/scripts are added via dist-hook below. | ||||
| 
 | ||||
| EXTRA_DIST =	ChangeLog README build.sh build.cfg.in $(man_MANS) \ | ||||
| 		README.customs README.OS2 \ | ||||
| 		README.Amiga SCOPTIONS src/config.ami \ | ||||
| 		README.DOS builddos.bat src/configh.dos \ | ||||
| 		README.W32 build_w32.bat src/config.h.W32 \ | ||||
| 		README.VMS makefile.com src/config.h-vms src/vmsjobs.c \ | ||||
| 		vms_export_symbol_test.com \ | ||||
| 		src/gmk-default.scm src/gmk-default.h \ | ||||
| 		$(mk_FILES) $(m4_FILES) $(test_FILES) | ||||
| 
 | ||||
| # --------------- Generate the Guile default module content | ||||
| 
 | ||||
| src/guile.$(OBJEXT): src/gmk-default.h | ||||
| src/gmk-default.h: $(top_srcdir)/src/gmk-default.scm | ||||
| 	(echo 'static const char *const GUILE_module_defn = " '\\ \ | ||||
| 	  && sed -e 's/;.*//' -e '/^[ \t]*$$/d' -e 's/"/\\"/g' -e 's/$$/ \\/' \ | ||||
| 		 $(top_srcdir)/src/gmk-default.scm \ | ||||
| 	  && echo '";') > src/gmk-default.h | ||||
| 
 | ||||
| # --------------- Local DIST Section | ||||
| 
 | ||||
| # Install the mk and tests subdirectories | ||||
| # | ||||
| dist-hook: | ||||
| 	(cd $(top_srcdir); \ | ||||
| 	 sub=`find tests/scripts -follow \( -name .git -o -name .deps -o -name work -o -name .gitignore -o -name \*.orig -o -name \*.rej -o -name \*~ -o -name \*.out -o -name Makefile \) -prune -o -type f -print`; \ | ||||
| 	 tar chf - $$sub) \ | ||||
| 	| (cd $(distdir); tar xfBp -) | ||||
| 
 | ||||
| 
 | ||||
| # --------------- Local CHECK Section | ||||
| 
 | ||||
| check-local: check-regression | ||||
| 	@banner=" Regression PASSED: GNU Make $(VERSION) ($(MAKE_HOST)) built with $(CC) "; \ | ||||
| 	dashes=`echo "$$banner" | sed s/./=/g`; \ | ||||
| 	echo; \ | ||||
| 	echo "$$dashes"; \ | ||||
| 	echo "$$banner"; \ | ||||
| 	echo "$$dashes"; \ | ||||
| 	echo | ||||
| 
 | ||||
| # > check-regression | ||||
| # | ||||
| # Look for the make test suite, and run it if found and we can find perl. | ||||
| # If we're building outside the tree, we use symlinks to make a local copy of | ||||
| # the test suite.  Unfortunately the test suite itself isn't localizable yet. | ||||
| # | ||||
| MAKETESTFLAGS = | ||||
| 
 | ||||
| .PHONY: check-regression | ||||
| 
 | ||||
| check-regression: tests/config-flags.pm | ||||
| 	@if test -f '$(top_srcdir)/tests/run_make_tests'; then \ | ||||
| 	  ulimit -n 128; \ | ||||
| 	  if $(PERL) -v >/dev/null 2>&1; then \ | ||||
| 	    case `cd '$(top_srcdir)'; pwd` in `pwd`) : ;; \ | ||||
| 	      *) test -d tests || mkdir tests; \ | ||||
| 		 rm -f srctests; \ | ||||
| 		 if ln -s '$(top_srcdir)/tests' srctests; then \ | ||||
| 		   for f in run_make_tests run_make_tests.pl test_driver.pl scripts jhelp.pl; do \ | ||||
| 		     rm -f tests/$$f; ln -s ../srctests/$$f tests; \ | ||||
| 		   done; fi ;; \ | ||||
| 	    esac; \ | ||||
| 	    echo "cd tests && $(PERL) $(PERLFLAGS) ./run_make_tests.pl -srcdir $(abs_top_srcdir) -make ../make$(EXEEXT) $(MAKETESTFLAGS)"; \ | ||||
| 	    cd tests && $(PERL) $(PERLFLAGS) ./run_make_tests.pl -srcdir '$(abs_top_srcdir)' -make '../make$(EXEEXT)' $(MAKETESTFLAGS); \ | ||||
| 	  else \ | ||||
| 	    echo "Can't find a working Perl ($(PERL)); the test suite requires Perl."; \ | ||||
| 	  fi; \ | ||||
| 	else \ | ||||
| 	  echo "Can't find the GNU Make test suite ($(top_srcdir)/tests)."; \ | ||||
| 	fi | ||||
| 
 | ||||
| 
 | ||||
| # --------------- Maintainer's Section | ||||
| 
 | ||||
| # Tell automake that I haven't forgotten about this file and it will be | ||||
| # created before we build a distribution (see maintMakefile in the Git | ||||
| # distribution). | ||||
| 
 | ||||
| README: | ||||
| 
 | ||||
| @MAINT_MAKEFILE@ | ||||
							
								
								
									
										2030
									
								
								third_party/make/Makefile.in
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2030
									
								
								third_party/make/Makefile.in
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										1635
									
								
								third_party/make/NEWS
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1635
									
								
								third_party/make/NEWS
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										188
									
								
								third_party/make/README
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										188
									
								
								third_party/make/README
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,188 @@ | |||
| This directory contains the 4.3 release of GNU Make. | ||||
| 
 | ||||
| See the file NEWS for the user-visible changes from previous releases. | ||||
| In addition, there have been bugs fixed. | ||||
| 
 | ||||
| Please check the system-specific notes below for any caveats related to your | ||||
| operating system. | ||||
| 
 | ||||
| If you are trying to build GNU make from a Git clone rather than a downloaded | ||||
| source distribution, see the README.git file for instructions. | ||||
| 
 | ||||
| For source distribution building and installation instructions, see the file | ||||
| INSTALL. | ||||
| 
 | ||||
| If you need to build GNU Make and have no other 'make' program to use, you can | ||||
| use the shell script 'build.sh' instead.  To do this, first run 'configure' as | ||||
| described in INSTALL.  Then, instead of typing 'make' to build the program, | ||||
| type 'sh build.sh'.  This should compile the program in the current directory. | ||||
| Then you will have a Make program that you can use for './make install', or | ||||
| whatever else. | ||||
| 
 | ||||
| Some systems' Make programs cannot process the Makefile for GNU Make.  If you | ||||
| get errors from your system's Make when building GNU Make, try using | ||||
| 'build.sh' instead. | ||||
| 
 | ||||
| 
 | ||||
| GNU Make is free software.  See the file COPYING for copying conditions. | ||||
| GNU Make is copyright by the Free Software Foundation.  Copyright notices | ||||
| condense sequential years into a range; e.g. "1987-1994" means all years | ||||
| from 1987 to 1994 inclusive. | ||||
| 
 | ||||
| Downloading | ||||
| ----------- | ||||
| 
 | ||||
| GNU Make can be obtained in many different ways.  See a description here: | ||||
| 
 | ||||
|   http://www.gnu.org/software/software.html | ||||
| 
 | ||||
| 
 | ||||
| Documentation | ||||
| ------------- | ||||
| 
 | ||||
| GNU make is fully documented in the GNU Make manual, which is contained | ||||
| in this distribution as the file make.texinfo.  You can also find | ||||
| on-line and preformatted (PostScript and DVI) versions at the FSF's web | ||||
| site.  There is information there about ordering hardcopy documentation. | ||||
| 
 | ||||
|   http://www.gnu.org/ | ||||
|   http://www.gnu.org/doc/doc.html | ||||
|   http://www.gnu.org/manual/manual.html | ||||
| 
 | ||||
| 
 | ||||
| Development | ||||
| ----------- | ||||
| 
 | ||||
| GNU Make development is hosted by Savannah, the FSF's online development | ||||
| management tool.  Savannah is here: | ||||
| 
 | ||||
|   http://savannah.gnu.org | ||||
| 
 | ||||
| And the GNU Make development page is here: | ||||
| 
 | ||||
|   http://savannah.gnu.org/projects/make/ | ||||
| 
 | ||||
| You can find most information concerning the development of GNU Make at | ||||
| this site. | ||||
| 
 | ||||
| 
 | ||||
| Bug Reporting | ||||
| ------------- | ||||
| 
 | ||||
| You can send GNU make bug reports to <bug-make@gnu.org>.  Please see the | ||||
| section of the GNU make manual entitled 'Problems and Bugs' for | ||||
| information on submitting useful and complete bug reports. | ||||
| 
 | ||||
| You can also use the online bug tracking system in the Savannah GNU Make | ||||
| project to submit new problem reports or search for existing ones: | ||||
| 
 | ||||
|   http://savannah.gnu.org/bugs/?group=make | ||||
| 
 | ||||
| If you need help using GNU make, try these forums: | ||||
| 
 | ||||
|   help-make@gnu.org | ||||
|   help-utils@gnu.org | ||||
|   news:gnu.utils.help | ||||
|   news:gnu.utils.bug | ||||
| 
 | ||||
| 
 | ||||
| Git Access | ||||
| ---------- | ||||
| 
 | ||||
| The GNU make source repository is available via Git from the GNU Savannah Git | ||||
| server; look here for details: | ||||
| 
 | ||||
|   http://savannah.gnu.org/git/?group=make | ||||
| 
 | ||||
| Please note: you won't be able to build GNU make from Git without installing | ||||
| appropriate maintainer's tools, such as GNU m4, automake, autoconf, Perl, GNU | ||||
| make, and GCC. | ||||
| 
 | ||||
| See the README.git file for instructions on how to build GNU make once these | ||||
| tools are available.  We make no guarantees about the contents or quality of | ||||
| the latest code in the Git repository: it is not unheard of for code that is | ||||
| known to be broken to be checked in.  Use at your own risk. | ||||
| 
 | ||||
| 
 | ||||
| System-specific Notes | ||||
| --------------------- | ||||
| 
 | ||||
| It has been reported that the XLC 1.2 compiler on AIX 3.2 is buggy such | ||||
| that if you compile make with 'cc -O' on AIX 3.2, it will not work | ||||
| correctly.  It is said that using 'cc' without '-O' does work. | ||||
| 
 | ||||
| The standard /bin/sh on SunOS 4.1.3_U1 and 4.1.4 is broken and cannot be | ||||
| used to configure GNU make.  Please install a different shell such as | ||||
| bash or pdksh in order to run "configure".  See this message for more | ||||
| information: | ||||
|   http://mail.gnu.org/archive/html/bug-autoconf/2003-10/msg00190.html | ||||
| 
 | ||||
| One area that is often a problem in configuration and porting is the code | ||||
| to check the system's current load average.  To make it easier to test and | ||||
| debug this code, you can do 'make check-loadavg' to see if it works | ||||
| properly on your system.  (You must run 'configure' beforehand, but you | ||||
| need not build Make itself to run this test.) | ||||
| 
 | ||||
| Another potential source of porting problems is the support for large | ||||
| files (LFS) in configure for those operating systems that provide it. | ||||
| Please report any bugs that you find in this area.  If you run into | ||||
| difficulties, then as a workaround you should be able to disable LFS by | ||||
| adding the '--disable-largefile' option to the 'configure' script. | ||||
| 
 | ||||
| On systems that support micro- and nano-second timestamp values and | ||||
| where stat(2) provides this information, GNU make will use it when | ||||
| comparing timestamps to get the most accurate possible result.  However, | ||||
| note that many current implementations of tools that *set* timestamps do | ||||
| not preserve micro- or nano-second granularity.  This means that "cp -p" | ||||
| and other similar tools (tar, etc.) may not exactly duplicate timestamps | ||||
| with micro- and nano-second granularity on some systems.  If your build | ||||
| system contains rules that depend on proper behavior of tools like "cp | ||||
| -p", you should consider using the .LOW_RESOLUTION_TIME pseudo-target to | ||||
| force make to treat them properly.  See the manual for details. | ||||
| 
 | ||||
| 
 | ||||
| Ports | ||||
| ----- | ||||
| 
 | ||||
|   - See README.customs for details on integrating GNU make with the | ||||
|     Customs distributed build environment from the Pmake distribution. | ||||
| 
 | ||||
|   - See README.VMS for details about GNU Make on OpenVMS. | ||||
| 
 | ||||
|   - See README.Amiga for details about GNU Make on AmigaDOS. | ||||
| 
 | ||||
|   - See README.W32 for details about GNU Make on Windows NT, 95, or 98. | ||||
| 
 | ||||
|   - See README.DOS for compilation instructions on MS-DOS and MS-Windows | ||||
|     using DJGPP tools. | ||||
| 
 | ||||
|     A precompiled binary of the MSDOS port of GNU Make is available as part | ||||
|     of DJGPP; see the WWW page http://www.delorie.com/djgpp/ for more | ||||
|     information. | ||||
| 
 | ||||
|     The Cygwin project maintains its own port of GNU make.  That port may have | ||||
|     patches which are not present in this version.  If you are using Cygwin | ||||
|     you should use their version of GNU make, and if you have questions about | ||||
|     it you should start by asking on those mailing lists and forums. | ||||
| 
 | ||||
| Please note there are two _separate_ ports of GNU make for Microsoft | ||||
| systems: a native Windows tool built with (for example) MSVC or Cygwin, | ||||
| and a DOS-based tool built with DJGPP.  Please be sure you are looking | ||||
| at the right README! | ||||
| 
 | ||||
|  | ||||
| ------------------------------------------------------------------------------- | ||||
| Copyright (C) 1988-2020 Free Software Foundation, Inc. | ||||
| This file is part of GNU Make. | ||||
| 
 | ||||
| GNU Make is free software; you can redistribute it and/or modify it under the | ||||
| terms of the GNU General Public License as published by the Free Software | ||||
| Foundation; either version 3 of the License, or (at your option) any later | ||||
| version. | ||||
| 
 | ||||
| GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR | ||||
| A PARTICULAR PURPOSE.  See the GNU General Public License for more details. | ||||
| 
 | ||||
| You should have received a copy of the GNU General Public License along with | ||||
| this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
							
								
								
									
										80
									
								
								third_party/make/README.Amiga
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								third_party/make/README.Amiga
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,80 @@ | |||
| Short: Port of GNU make with SAS/C (no ixemul.library required) | ||||
| Author: GNU, Amiga port by Aaron "Optimizer" Digulla | ||||
| Uploader: Aaron "Optimizer" Digulla (digulla@fh-konstanz.de) | ||||
| Type: dev/c | ||||
| 
 | ||||
| This is a pure Amiga port of GNU make. It needs no extra libraries or | ||||
| anything. It has the following features (in addition to any features of | ||||
| GNU make): | ||||
| 
 | ||||
| - Runs Amiga-Commands with SystemTags() (Execute) | ||||
| - Can run multi-line statements | ||||
| - Allows to use Device-Names in targets: | ||||
| 
 | ||||
|         c:make : make.o | ||||
| 
 | ||||
|     is ok. To distinguish between device-names and target : or ::, MAKE | ||||
|     looks for spaces. If there are any around :, it's taken as a target | ||||
|     delimiter, if there are none, it's taken as the name of a device. Note | ||||
|     that "make:make.o" tries to create "make.o" on the device "make:". | ||||
| - Replaces @@ by a newline in any command line: | ||||
| 
 | ||||
|         if exists make @@\ | ||||
|             delete make.bak quiet @@\ | ||||
|             rename make make.bak @@\ | ||||
|         endif @@\ | ||||
|         $(CC) Link Make.o To make | ||||
| 
 | ||||
|     works. Note that the @@ must stand alone (i.e., "make@@\" is illegal). | ||||
|     Also be careful that there is a space after the "\" (i.e., at the | ||||
|     beginning of the next line). | ||||
| - Can be made resident to save space and time | ||||
| - Amiga specific wildcards can be used in $(wildcard ...) | ||||
| 
 | ||||
| BUGS: | ||||
| - The line | ||||
| 
 | ||||
|     dummy.h : src/*.c | ||||
| 
 | ||||
| tries to make dummy.h from "src/*.c" (i.e., no wildcard-expansion takes | ||||
| place). You have to use "$(wildcard src/*.c)" instead. | ||||
| 
 | ||||
| COMPILING FROM SCRATCH | ||||
| ---------------------- | ||||
| 
 | ||||
| To recompile, you need SAS/C 6.51. | ||||
| 
 | ||||
| As of GNU make 4.3, the build environment has been cleaned up and alternate | ||||
| make files (including smakefiles) have been removed.  If you have an existing | ||||
| version of GNU make available you _should_ be able to run: | ||||
| 
 | ||||
|    make -f Basic.mk | ||||
| 
 | ||||
| However this is untested. | ||||
| 
 | ||||
| If you have an Amiga system and would like to collaborate on getting | ||||
| bootstrapping to work properly please contact bug-make@gnu.org. | ||||
| 
 | ||||
| INSTALLATION | ||||
| 
 | ||||
| Copy make somewhere in your search path (e.g., sc:c or sc:bin). | ||||
| If you plan to use recursive makes, install make resident: | ||||
| 
 | ||||
|     Resident make Add | ||||
| 
 | ||||
|  | ||||
| ------------------------------------------------------------------------------- | ||||
| Copyright (C) 1995-2020 Free Software Foundation, Inc. | ||||
| This file is part of GNU Make. | ||||
| 
 | ||||
| GNU Make is free software; you can redistribute it and/or modify it under the | ||||
| terms of the GNU General Public License as published by the Free Software | ||||
| Foundation; either version 3 of the License, or (at your option) any later | ||||
| version. | ||||
| 
 | ||||
| GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR | ||||
| A PARTICULAR PURPOSE.  See the GNU General Public License for more details. | ||||
| 
 | ||||
| You should have received a copy of the GNU General Public License along with | ||||
| this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
							
								
								
									
										296
									
								
								third_party/make/README.DOS
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										296
									
								
								third_party/make/README.DOS
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,296 @@ | |||
| Port of GNU Make to 32-bit protected mode on MSDOS and MS-Windows. | ||||
| 
 | ||||
| Builds with DJGPP v2 port of GNU C/C++ compiler and utilities. | ||||
| 
 | ||||
| 
 | ||||
| New (since 3.74) DOS-specific features: | ||||
| 
 | ||||
|    1. Supports long filenames when run from DOS box on Windows 9x. | ||||
| 
 | ||||
|    2. Supports both stock DOS COMMAND.COM and Unix-style shells | ||||
|       (details in 'Notes' below). | ||||
| 
 | ||||
|    3. Supports DOS drive letters in dependencies and pattern rules. | ||||
| 
 | ||||
|    4. Better support for DOS-style backslashes in pathnames (but see | ||||
|       'Notes' below). | ||||
| 
 | ||||
|    5. The $(shell) built-in can run arbitrary complex commands, | ||||
|       including pipes and redirection, even when COMMAND.COM is your | ||||
|       shell. | ||||
| 
 | ||||
|    6. Can be built without floating-point code (see below). | ||||
| 
 | ||||
|    7. Supports signals in child programs and restores the original | ||||
|       directory if the child was interrupted. | ||||
| 
 | ||||
|    8. Can be built without (a previous version of) Make. | ||||
| 
 | ||||
|    9. The build process requires only standard tools.  (Optional | ||||
|       targets like "check:" still need additional programs, though, | ||||
|       see below.) | ||||
| 
 | ||||
|   10. Beginning with v3.78, the test suite works in the DJGPP | ||||
|       environment (requires Perl and auxiliary tools; see below). | ||||
| 
 | ||||
| 
 | ||||
| To install a binary distribution: | ||||
| 
 | ||||
|    Simply unzip the makNNNb.zip file (where NNN is the version number) | ||||
|    preserving the directory structure (-d switch if you use PKUNZIP). | ||||
|    If you are installing Make on Windows 9X or Windows 2000, use an | ||||
|    unzip program that supports long filenames in zip files.  After | ||||
|    unzipping, make sure the directory with make.exe is on your PATH, | ||||
|    and that's all you need to use Make. | ||||
| 
 | ||||
| 
 | ||||
| To build from sources: | ||||
| 
 | ||||
|    1. Unzip the archive, preserving the directory structure (-d switch | ||||
|       if you use PKUNZIP).  If you build Make on Windows 9X or Windows | ||||
|       2000, use an unzip program that supports long filenames in zip | ||||
|       files. | ||||
| 
 | ||||
|       If you are unpacking an official GNU source distribution, use | ||||
|       either DJTAR (which is part of the DJGPP development | ||||
|       environment), or the DJGPP port of GNU Tar. | ||||
| 
 | ||||
|    2. If you have a working Make already, you can run: | ||||
| 
 | ||||
|           make -f Basic.mk | ||||
| 
 | ||||
|    3. If you don't have a working Make already you can bootstrap one | ||||
|       by running: | ||||
| 
 | ||||
|           .\builddos.bat | ||||
| 
 | ||||
|    4. If you are building from outside of the source directory, you | ||||
|       need to tell Make where the sources are, like this: | ||||
| 
 | ||||
|           make -f c:/djgpp/gnu/make/Basic.mk SRCDIR=c:/djgpp/gnu/make | ||||
| 
 | ||||
|       or: | ||||
| 
 | ||||
|           c:/djgpp/gnu/make/builddos.bat c:/djgpp/gnu/make | ||||
| 
 | ||||
|    5. To run the test suite, type "make check".  This requires a Unix | ||||
|       shell (I used the DJGPP port of Bash 2.03), Perl, Sed, Fileutils | ||||
|       and Sh-utils. | ||||
| 
 | ||||
|    6. To install copy make.exe to the preferred location. | ||||
| 
 | ||||
|       Since GNU make 4.3, support for customized platform installations | ||||
|       has been removed.  If you'd like to collaborate on reinstating | ||||
|       these capabilities, contact bug-make@gnu.org. | ||||
| 
 | ||||
| 
 | ||||
| Notes: | ||||
| ----- | ||||
| 
 | ||||
|    1. The shell issue. | ||||
| 
 | ||||
|       This is probably the most significant improvement, first | ||||
|       introduced in the port of GNU Make 3.75. | ||||
| 
 | ||||
|       The original behavior of GNU Make is to invoke commands | ||||
|       directly, as long as they don't include characters special to | ||||
|       the shell or internal shell commands, because that is faster. | ||||
|       When shell features like redirection or filename wildcards are | ||||
|       involved, Make calls the shell. | ||||
| 
 | ||||
|       This port supports both DOS shells (the stock COMMAND.COM and its | ||||
|       4DOS/NDOS replacements), and Unix-style shells (tested with the | ||||
|       venerable Stewartson's 'ms_sh' 2.3 and the DJGPP port of 'bash' by | ||||
|       Daisuke Aoyama <jack@st.rim.or.jp>). | ||||
| 
 | ||||
|       When the $SHELL variable points to a Unix-style shell, Make | ||||
|       works just like you'd expect on Unix, calling the shell for any | ||||
|       command that involves characters special to the shell or | ||||
|       internal shell commands.  The only difference is that, since | ||||
|       there is no standard way to pass command lines longer than the | ||||
|       infamous DOS 126-character limit, this port of Make writes the | ||||
|       command line to a temporary disk file and then invokes the shell | ||||
|       on that file. | ||||
| 
 | ||||
|       If $SHELL points to a DOS-style shell, however, Make will not | ||||
|       call it automatically, as it does with Unix shells.  Stock | ||||
|       COMMAND.COM is too dumb and would unnecessarily limit the | ||||
|       functionality of Make.  For example, you would not be able to | ||||
|       use long command lines in commands that use redirection or | ||||
|       pipes.  Therefore, when presented with a DOS shell, this port of | ||||
|       Make will emulate most of the shell functionality, like | ||||
|       redirection and pipes, and shall only call the shell when a | ||||
|       batch file or a command internal to the shell is invoked.  (Even | ||||
|       when a command is an internal shell command, Make will first | ||||
|       search the $PATH for it, so that if a Makefile calls 'mkdir', | ||||
|       you can install, say, a port of GNU 'mkdir' and have it called | ||||
|       in that case.) | ||||
| 
 | ||||
|       The key to all this is the extended functionality of 'spawn' and | ||||
|       'system' functions from the DJGPP library; this port just calls | ||||
|       'system' where it would invoke the shell on Unix.  The most | ||||
|       important aspect of these functions is that they use a special | ||||
|       mechanism to pass long (up to 16KB) command lines to DJGPP | ||||
|       programs.  In addition, 'system' emulates some internal | ||||
|       commands, like 'cd' (so that you can now use forward slashes | ||||
|       with it, and can also change the drive if the directory is on | ||||
|       another drive).  Another aspect worth mentioning is that you can | ||||
|       call Unix shell scripts directly, provided that the shell whose | ||||
|       name is mentioned on the first line of the script is installed | ||||
|       anywhere along the $PATH.  It is impossible to tell here | ||||
|       everything about these functions; refer to the DJGPP library | ||||
|       reference for more details. | ||||
| 
 | ||||
|       The $(shell) built-in is implemented in this port by calling | ||||
|       'popen'.  Since 'popen' calls 'system', the above considerations | ||||
|       are valid for $(shell) as well.  In particular, you can put | ||||
|       arbitrary complex commands, including pipes and redirection, | ||||
|       inside $(shell), which is in many cases a valid substitute for | ||||
|       the Unix-style command substitution (`command`) feature. | ||||
| 
 | ||||
| 
 | ||||
|    2. "SHELL=/bin/sh" -- or is it? | ||||
| 
 | ||||
|       Many Unix Makefiles include a line which sets the SHELL, for | ||||
|       those versions of Make which don't have this as the default. | ||||
|       Since many DOS systems don't have 'sh' installed (in fact, most | ||||
|       of them don't even have a '/bin' directory), this port takes | ||||
|       such directives with a grain of salt.  It will only honor such a | ||||
|       directive if the basename of the shell name (like 'sh' in the | ||||
|       above example) can indeed be found in the directory that is | ||||
|       mentioned in the SHELL= line ('/bin' in the above example), or | ||||
|       in the current working directory, or anywhere on the $PATH (in | ||||
|       that order).  If the basename doesn't include a filename | ||||
|       extension, Make will look for any known extension that indicates | ||||
|       an executable file (.exe, .com, .bat, .btm, .sh, and even .sed | ||||
|       and .pl).  If any such file is found, then $SHELL will be | ||||
|       defined to the exact pathname of that file, and that shell will | ||||
|       hence be used for the rest of processing.  But if the named | ||||
|       shell is *not* found, the line which sets it will be effectively | ||||
|       ignored, leaving the value of $SHELL as it was before.  Since a | ||||
|       lot of decisions that this port makes depend on the gender of | ||||
|       the shell, I feel it doesn't make any sense to tailor Make's | ||||
|       behavior to a shell which is nowhere to be found. | ||||
| 
 | ||||
|       Note that the above special handling of "SHELL=" only happens | ||||
|       for Makefiles; if you set $SHELL in the environment or on the | ||||
|       Make command line, you are expected to give the complete | ||||
|       pathname of the shell, including the filename extension. | ||||
| 
 | ||||
|       The default value of $SHELL is computed as on Unix (see the Make | ||||
|       manual for details), except that if $SHELL is not defined in the | ||||
|       environment, $COMSPEC is used.  Also, if an environment variable | ||||
|       named $MAKESHELL is defined, it takes precedence over both | ||||
|       $COMSPEC and $SHELL.  Note that, unlike Unix, $SHELL in the | ||||
|       environment *is* used to set the shell (since on MSDOS, it's | ||||
|       unlikely that the interactive shell will not be suitable for | ||||
|       Makefile processing). | ||||
| 
 | ||||
|       The bottom line is that you can now write Makefiles where some | ||||
|       of the targets require a real (i.e. Unix-like) shell, which will | ||||
|       nevertheless work when such shell is not available (provided, of | ||||
|       course, that the commands which should always work, don't | ||||
|       require such a shell).  More important, you can convert Unix | ||||
|       Makefiles to MSDOS and leave the line which sets the shell | ||||
|       intact, so that people who do have Unixy shell could use it for | ||||
|       targets which aren't converted to DOS (like 'install' and | ||||
|       'uninstall', for example). | ||||
| 
 | ||||
| 
 | ||||
|    3. Default directories. | ||||
| 
 | ||||
|       GNU Make knows about standard directories where it searches for | ||||
|       library and include files mentioned in the Makefile.  Since | ||||
|       MSDOS machines don't have standard places for these, this port | ||||
|       will search ${DJDIR}/lib and ${DJDIR}/include respectively. | ||||
|       $DJDIR is defined automatically by the DJGPP startup code as the | ||||
|       root of the DJGPP installation tree (unless you've tampered with | ||||
|       the DJGPP.ENV file).  This should provide reasonable default | ||||
|       values, unless you moved parts of DJGPP to other directories. | ||||
| 
 | ||||
| 
 | ||||
|    4. Letter-case in filenames. | ||||
| 
 | ||||
|       If you run Make on Windows 9x, you should be aware of the | ||||
|       letter-case issue.  Make is internally case-sensitive, but all | ||||
|       file operations are case-insensitive on Windows 9x, so | ||||
|       e.g. files 'FAQ', 'faq' and 'Faq' all refer to the same file, as | ||||
|       far as Windows is concerned.  The underlying DJGPP C library | ||||
|       functions honor the letter-case of the filenames they get from | ||||
|       the OS, except that by default, they down-case 8+3 DOS filenames | ||||
|       which are stored in upper case in the directory and would break | ||||
|       many Makefiles otherwise.  (The details of which filenames are | ||||
|       converted to lower case are explained in the DJGPP libc docs, | ||||
|       under the '_preserve_fncase' and '_lfn_gen_short_fname' | ||||
|       functions, but as a thumb rule, any filename that is stored in | ||||
|       upper case in the directory, is a valid DOS 8+3 filename and | ||||
|       doesn't include characters invalid on MSDOS FAT filesystems, | ||||
|       will be automatically down-cased.)  User reports that I have | ||||
|       indicate that this default behavior is generally what you'd | ||||
|       expect; however, your input is most welcome. | ||||
| 
 | ||||
|       In any case, if you hit a situation where you must force Make to | ||||
|       get the 8+3 DOS filenames in upper case, set FNCASE=y in the | ||||
|       environment or in the Makefile. | ||||
| 
 | ||||
| 
 | ||||
|    5. DOS-style pathnames. | ||||
| 
 | ||||
|       There are a lot of places throughout the program sources which | ||||
|       make implicit assumptions about the pathname syntax.  In | ||||
|       particular, the directories are assumed to be separated by '/', | ||||
|       and any pathname which doesn't begin with a '/' is assumed to be | ||||
|       relative to the current directory.  This port attempts to | ||||
|       support DOS-style pathnames which might include the drive letter | ||||
|       and use backslashes instead of forward slashes.  However, this | ||||
|       support is not complete; I feel that pursuing this support too | ||||
|       far might break some more important features, particularly if | ||||
|       you use a Unix-style shell (where a backslash is a quote | ||||
|       character).  I only consider support of backslashes desirable | ||||
|       because some Makefiles invoke non-DJGPP programs which don't | ||||
|       understand forward slashes.  A notable example of such programs | ||||
|       is the standard programs which come with MSDOS.  Otherwise, you | ||||
|       are advised to stay away from backslashes whenever possible.  In | ||||
|       particular, filename globbing won't work on pathnames with | ||||
|       backslashes, because the GNU 'glob' library doesn't support them | ||||
|       (backslash is special in filename wildcards, and I didn't want | ||||
|       to break that). | ||||
| 
 | ||||
|       One feature which *does* work with backslashes is the filename- | ||||
|       related built-in functions such as $(dir), $(notdir), etc. | ||||
|       Drive letters in pathnames are also fully supported. | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| Bug reports: | ||||
| ----------- | ||||
| 
 | ||||
|    Bugs that are clearly related to the MSDOS/DJGPP port should be | ||||
|    reported first on the comp.os.msdos.djgpp news group (if you cannot | ||||
|    post to Usenet groups, write to the DJGPP mailing list, | ||||
|    <djgpp@delorie.com>, which is an email gateway into the above news | ||||
|    group).  For other bugs, please follow the procedure explained in | ||||
|    the "Bugs" chapter of the Info docs.  If you don't have an Info | ||||
|    reader, look up that chapter in the 'make.i1' file with any text | ||||
|    browser/editor. | ||||
| 
 | ||||
| 
 | ||||
|    Enjoy, | ||||
|                         Eli Zaretskii <eliz@is.elta.co.il> | ||||
| 
 | ||||
|  | ||||
| ------------------------------------------------------------------------------- | ||||
| Copyright (C) 1996-2020 Free Software Foundation, Inc. | ||||
| This file is part of GNU Make. | ||||
| 
 | ||||
| GNU Make is free software; you can redistribute it and/or modify it under the | ||||
| terms of the GNU General Public License as published by the Free Software | ||||
| Foundation; either version 3 of the License, or (at your option) any later | ||||
| version. | ||||
| 
 | ||||
| GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR | ||||
| A PARTICULAR PURPOSE.  See the GNU General Public License for more details. | ||||
| 
 | ||||
| You should have received a copy of the GNU General Public License along with | ||||
| this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
							
								
								
									
										176
									
								
								third_party/make/README.OS2
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										176
									
								
								third_party/make/README.OS2
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,176 @@ | |||
| Port of GNU make to OS/2. | ||||
| 
 | ||||
| Features of GNU make that do not work under OS/2: | ||||
|   - remote job execution | ||||
|   - dynamic load balancing | ||||
| 
 | ||||
| 
 | ||||
| Special features of the OS/2 version: | ||||
| 
 | ||||
| Due to the fact that some people might want to use sh syntax in | ||||
| Makefiles while others might want to use OS/2's native shell cmd.exe, | ||||
| GNU make supports both shell types. The following list defines the order | ||||
| that is used to determine the shell: | ||||
| 
 | ||||
|  1. The shell specified by the environment variable MAKESHELL. | ||||
|  2. The shell specified by the SHELL variable within a Makefile. Like | ||||
|     Unix, SHELL is NOT taken from the environment. | ||||
|  3. The shell specified by the COMSPEC environment variable. | ||||
|  4. The shell specified by the OS2_SHELL environment variable. | ||||
|  5. If none of the above is defined /bin/sh is used as default.  This | ||||
|     happens e.g. in the make testsuite. | ||||
| 
 | ||||
| Note: - Points 3 and 4 can be turned off at compile time by adding | ||||
|         -DNO_CMD_DEFAULT to the CPPFLAGS. | ||||
|       - DOS support is not tested for EMX and therefore might not work. | ||||
|       - The UNIXROOT environment variable is supported to find /bin/sh | ||||
|         if it is not on the current drive. | ||||
| 
 | ||||
| 
 | ||||
| COMPILATION OF GNU MAKE FOR OS/2: | ||||
| 
 | ||||
| I. ***** SPECIAL OPTIONS ***** | ||||
| 
 | ||||
|  - At compile time you can turn off that cmd is used as default shell | ||||
|    (but only /bin/sh). Simply set CPPFLAGS="-DNO_CMD_DEFAULT" and make | ||||
|    will not use cmd unless you cause it to do so by setting MAKESHELL to | ||||
|    cmd or by specifying SHELL=cmd in your Makefile. | ||||
| 
 | ||||
|  - At compile time you can set CPPFLAGS="-DNO_CHDIR2" to turn off that | ||||
|    GNU make prints drive letters. This is necessary if you want to run | ||||
|    the testsuite. | ||||
| 
 | ||||
| 
 | ||||
| II. ***** REQUIREMENTS FOR THE COMPILATION ***** | ||||
| 
 | ||||
| A standard Unix like build environment: | ||||
| 
 | ||||
|  - sh compatible shell (ksh, bash, ash, but tested only with pdksh 5.2.14 | ||||
|    release 2) | ||||
|    If you use pdksh it is recommended to update to 5.2.14 release 2. Older | ||||
|    versions may not work! You can get this version at | ||||
|    http://www.math.ohio-state.edu/~ilya/software/os2/pdksh-5.2.14-bin-2.zip | ||||
|  - GNU file utilities (make sure that install.exe from the file utilities | ||||
|    is in front of your PATH before X:\OS2\INSTALL\INSTALL.EXE. I recommend | ||||
|    also to change the filename to ginstall.exe instead of install.exe | ||||
|    to avoid confusion with X:\OS2\INSTALL\INSTALL.EXE) | ||||
|  - GNU shell utilities | ||||
|  - GNU text utilities | ||||
|  - gawk | ||||
|  - grep | ||||
|  - sed | ||||
|  - GNU make 3.79.1 (special OS/2 patched version) or higher | ||||
|  - perl 5.005 or higher | ||||
|  - GNU texinfo (you can use 3.1 (gnuinfo.zip), but I recommend 4.0) | ||||
| 
 | ||||
| If you want to recreate the configuration files (developers only!) | ||||
| you need also: GNU m4 1.4, autoconf 2.59, automake 1.9.6 (or compatible) | ||||
| 
 | ||||
| 
 | ||||
| III. ***** COMPILATION AND INSTALLATION ***** | ||||
| 
 | ||||
|  a) ** Developers only - Everyone else should skip this section ** | ||||
|     To recreate the configuration files use: | ||||
| 
 | ||||
|       export EMXSHELL=ksh | ||||
|       aclocal -I config | ||||
|       automake | ||||
|       autoconf | ||||
|       autoheader | ||||
| 
 | ||||
| 
 | ||||
| b) Installation into x:/usr | ||||
| 
 | ||||
|    Note: Although it is possible to compile make using "./configure", | ||||
|          "make", "make install" this is not recommended.  In particular, | ||||
|          you must ALWAYS use LDFLAGS="-Zstack 0x6000" because the default | ||||
|          stack size is far to small and make will not work properly! | ||||
| 
 | ||||
| Recommended environment variables and installation options: | ||||
| 
 | ||||
|     export ac_executable_extensions=".exe" | ||||
|     export CPPFLAGS="-D__ST_MT_ERRNO__" | ||||
|     export CFLAGS="-O2 -Zomf -Zmt" | ||||
|     export LDFLAGS="-Zcrtdll -Zlinker /exepack:2 -Zlinker /pm:vio -Zstack 0x6000" | ||||
|     export RANLIB="echo" | ||||
|     ./configure --prefix=x:/usr --infodir=x:/usr/share/info --mandir=x:/usr/share/man --without-included-gettext | ||||
|     make AR=emxomfar | ||||
|     make install | ||||
| 
 | ||||
| Note: If you use gcc 2.9.x I recommend to set also LIBS="-lgcc" | ||||
| 
 | ||||
| Note: You can add -DNO_CMD_DEFAULT and -DNO_CHDIR2 to CPPFLAGS. | ||||
|       See section I. for details. | ||||
| 
 | ||||
| 
 | ||||
| IV. ***** NLS support ***** | ||||
| 
 | ||||
| GNU make has NLS (National Language Support), with the following | ||||
| caveats: | ||||
| 
 | ||||
|  a) It will only work with GNU gettext, and | ||||
|  b) GNU gettext support is not included in the GNU make package. | ||||
| 
 | ||||
| Therefore, if you wish to enable the internationalization features of | ||||
| GNU make you must install GNU gettext on your system before configuring | ||||
| GNU make. | ||||
| 
 | ||||
| You can choose the languages to be installed. To install support for | ||||
| English, German and French only enter: | ||||
| 
 | ||||
|   export LINGUAS="en de fr" | ||||
| 
 | ||||
| If you don't specify LINGUAS all languages are installed. | ||||
| 
 | ||||
| If you don't want NLS support (English only) use the option | ||||
| --disable-nls for the configure script.  Note if GNU gettext is not | ||||
| installed then NLS will not be enabled regardless of this flag. | ||||
| 
 | ||||
| 
 | ||||
| V. ***** Running the make test suite ***** | ||||
| 
 | ||||
| To run the included make test suite you have to set | ||||
| 
 | ||||
|   CPPFLAGS="-D__ST_MT_ERRNO__ -DNO_CMD_DEFAULT -DNO_CHDIR2" | ||||
| 
 | ||||
| before you compile make. This is due to some restrictions of the | ||||
| testsuite itself. -DNO_CMD_DEFAULT causes make to use /bin/sh as default | ||||
| shell in every case. Normally you could simply set MAKESHELL="/bin/sh" | ||||
| to do this but the testsuite ignores the environment. -DNO_CHDIR2 causes | ||||
| make not to use drive letters for directory names (i.e. _chdir2() and | ||||
| _getcwd2() are NOT used).  The testsuite interpretes the whole output of | ||||
| make, especially statements like make[1]: Entering directory | ||||
| 'C:/somewhere/make-3.79.1/tests' where the testsuite does not expect the | ||||
| drive letter. This would be interpreted as an error even if there is | ||||
| none. | ||||
| 
 | ||||
| To run the testsuite do the following: | ||||
| 
 | ||||
|   export CPPFLAGS="-D__ST_MT_ERRNO__ -DNO_CMD_DEFAULT -DNO_CHDIR2" | ||||
|   export CFLAGS="-Zomf -O2 -Zmt" | ||||
|   export LDFLAGS="-Zcrtdll -s -Zlinker /exepack:2 -Zlinker /pm:vio -Zstack 0x6000" | ||||
|   export RANLIB="echo" | ||||
|   ./configure --prefix=x:/usr --disable-nls | ||||
|   make AR=emxomfar | ||||
|   make check | ||||
| 
 | ||||
| All tests should work fine with the exception of one of the "INCLUDE_DIRS" | ||||
| tests which will fail if your /usr/include directory is on a drive different | ||||
| from the make source tree. | ||||
| 
 | ||||
|  | ||||
| ------------------------------------------------------------------------------- | ||||
| Copyright (C) 2003-2020 Free Software Foundation, Inc. | ||||
| This file is part of GNU Make. | ||||
| 
 | ||||
| GNU Make is free software; you can redistribute it and/or modify it under the | ||||
| terms of the GNU General Public License as published by the Free Software | ||||
| Foundation; either version 3 of the License, or (at your option) any later | ||||
| version. | ||||
| 
 | ||||
| GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR | ||||
| A PARTICULAR PURPOSE.  See the GNU General Public License for more details. | ||||
| 
 | ||||
| You should have received a copy of the GNU General Public License along with | ||||
| this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
							
								
								
									
										515
									
								
								third_party/make/README.VMS
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										515
									
								
								third_party/make/README.VMS
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,515 @@ | |||
| Overview:                                                       -*-text-mode-*- | ||||
| --------- | ||||
| 
 | ||||
|   This version of GNU make has been tested on: | ||||
|   OpenVMS V8.3/V8.4 (Alpha) and V8.4 (Integrity) AND V7.3 (VAX) | ||||
| 
 | ||||
|   This version of GNU Make is intended to be run from DCL to run | ||||
|   make scripts with a special syntax that is described below.  It | ||||
|   likely will not be able to run unmodified Unix makefiles. | ||||
| 
 | ||||
|   There is an older implementation of GNU Make that was ported to GNV. | ||||
|   Work is now in progress to merge that port to get a single version | ||||
|   of GNU Make available.  When that merge is done, GNU Make will auto | ||||
|   detect that it is running under a Posix shell and then operate as close to | ||||
|   GNU Make on Unix as possible. | ||||
| 
 | ||||
|   The descriptions below are for running GNU make from DCL or equivalent. | ||||
| 
 | ||||
| Recipe differences: | ||||
| ------------------- | ||||
| 
 | ||||
|   GNU Make for OpenVMS can not currently run native Unix make files because of | ||||
|   differences in the implementation. | ||||
| 
 | ||||
|   I am trying to document the current behavior in this section.  This is based | ||||
|   on the information in the file NEWS. and running the test suite. | ||||
|   TODO: More tests are needed to validate and demonstrate the OpenVMS | ||||
|   expected behavior. | ||||
| 
 | ||||
|   In some cases the older behavior of GNU Make when run from DCL is not | ||||
|   compatible with standard makefile behavior. | ||||
| 
 | ||||
|   This behavior can be changed when running GNU Make from DCL by setting | ||||
|   either DCL symbols or logical names of the format GNV$.  The settings | ||||
|   are enabled with a string starting with one of '1', 'T', or 'E' for "1", | ||||
|   "TRUE", or "ENABLE".  They are disabled with a '0', 'F', or 'D' for "1", | ||||
|   "FALSE", or "DISABLE".  If they are not explicitly set to one of these | ||||
|   values, then they will be set to their default values. | ||||
| 
 | ||||
|   The value of the setting DECC$FILENAME_UNIX_REPORT or | ||||
|   DECC$FILENAME_UNIX_ONLY will now cause the $(dir x) function to return | ||||
|   './' or '[]' as appropriate. | ||||
| 
 | ||||
|   The name GNV$MAKE_OLD_VMS when enabled will cause GNU Make to behave as | ||||
|   much as the older method as can be done with out disabling VMS features. | ||||
|   When it is disabled GNU Make have the new behavior which more closely | ||||
|   matches Unix Make behavior. | ||||
| 
 | ||||
|   The default is currently the old behavior when running GNU Make from DCL. | ||||
|   In the future this may change.  When running make from GNV Bash the new | ||||
|   behavior is the default. | ||||
| 
 | ||||
|   This is a global setting that sets the default behavior for several other | ||||
|   options that can be individually changed.  Many of the individual settings | ||||
|   are to make it so that the self tests for GNU Make need less VMS specific | ||||
|   modifications. | ||||
| 
 | ||||
|   The name GNV$MAKE_COMMA when enabled will cause GNU Make to expect a comma | ||||
|   for a path separator and use a comma for the separator for a list of files. | ||||
|   When disabled, it will cause GNU Make to use a colon for a path separator | ||||
|   and a space for the separator for a list of files.  The default is to be | ||||
|   enabled if the GNU Make is set to the older behavior. | ||||
| 
 | ||||
|   The name GNV$MAKE_SHELL_SIM when enabled will cause GNU Make to try to | ||||
|   simulate a Posix shell more closely.  The following behaviors occur: | ||||
| 
 | ||||
|     * Single quotes are converted to double quotes and any double | ||||
|       quotes inside of them are doubled.  No environment variable expansion | ||||
|       is simulated. | ||||
|     * A exit command status will be converted to a Posix Exit | ||||
|       where 0 is success and non-zero is failure. | ||||
|     * The $ character will cause environment variable expansion. | ||||
|     * Environent variables can be set on the command line before a command. | ||||
| 
 | ||||
|   VMS generally uses logical name search lists instead of path variables | ||||
|   where the resolution is handled by VMS independent of the program.  Which | ||||
|   means that it is likely that nothing will notice if the default path | ||||
|   specifier is changed in the future. | ||||
| 
 | ||||
|   Currently the built in VMS specific macros and recipes depend on the comma | ||||
|   being used as a file list separator. | ||||
|   TODO: Remove this dependency as other functions in GNU Make depend on a | ||||
|   space being used as a separator. | ||||
| 
 | ||||
|   The format for recipes are a combination of Unix macros, a subset of | ||||
|   simulated UNIX commands, some shell emulation, and OpenVMS commands. | ||||
|   This makes the resulting makefiles unique to the OpenVMS port of GNU make. | ||||
| 
 | ||||
|   If you are creating a OpenVMS specific makefile from scratch, you should also | ||||
|   look at MMK (Madgoat Make) available at https://github.com/endlesssoftware/mmk | ||||
|   MMK uses full OpenVMS syntax and a persistent subprocess is used for the | ||||
|   recipe lines, allowing multiple line rules. | ||||
| 
 | ||||
|   The default makefile search order is "makefile.vms", "gnumakefile", | ||||
|   "makefile".  TODO: See if that lookup is case sensitive. | ||||
| 
 | ||||
|   When Make is invoked from DCL, it will create a foreign command | ||||
|   using the name of executable image, with any facility prefix removed, | ||||
|   for the duration of the make program, so it can be used internally | ||||
|   to recursively run make().  The macro MAKE_COMMAND will be set to | ||||
|   this foreign command. | ||||
| 
 | ||||
|   When make is launched from an exec*() command from a C program, | ||||
|   the foreign command is not created.  The macro MAKE_COMMAND will be | ||||
|   set to the actual command passed as argv[0] to the exec*() function. | ||||
| 
 | ||||
|   If the DCL symbol or logical name GNV$MAKE_USE_MCR exists, then | ||||
|   the macro MAKE_COMMAND will be set to be an "MCR" command with the | ||||
|   absolute path used by DCL to launch make.  The foreign command | ||||
|   will not be created. | ||||
| 
 | ||||
|   The macro MAKE is set to be the same value as the macro MAKE_COMMAND | ||||
|   on all platforms. | ||||
| 
 | ||||
|   Each recipe command is normally run as a separate spawned processes, | ||||
|   except for the cases documented below where a temporary DCL command | ||||
|   file may be used. | ||||
| 
 | ||||
|   BUG: Testing has shown that the commands in the temporary command files | ||||
|   are not always created properly.  This issue is still under investigation. | ||||
| 
 | ||||
|   Any macros marked as exported are temporarily created as DCL symbols | ||||
|   for child images to use.  DCL symbol substitution is not done with these | ||||
|   commands. | ||||
|   Untested: Symbol substitution. | ||||
| 
 | ||||
|   When a temporary DCL command file is used, DCL symbol substitution | ||||
|   will work. | ||||
| 
 | ||||
|   For VMS 7.3-1 and earlier, command lines are limited to 255 characters | ||||
|   or 1024 characters in a command file. | ||||
|   For VMS 7.3-2 and later, command lines are limited to 4059 characters | ||||
|   or 8192 characters in a command file. | ||||
| 
 | ||||
|   VMS limits each token of a command line to 256 characters, and limits | ||||
|   a command line to 127 tokens. | ||||
| 
 | ||||
|   Command lines above the limit length are written to a command file | ||||
|   in sys$scratch:. | ||||
| 
 | ||||
|   In order to handle Unix style extensions to VMS DCL, GNU Make has | ||||
|   parsed the recipe commands and them modified them as needed.  The | ||||
|   parser has been re-written to resolve numerous bugs in handling | ||||
|   valid VMS syntax and potential buffer overruns. | ||||
| 
 | ||||
|   The new parser may need whitespace characters where DCL does not require | ||||
|   it, and also may require that quotes are matched were DCL forgives if | ||||
|   they are not.  There is a small chance that existing VMS specific makefiles | ||||
|   will be affected. | ||||
| 
 | ||||
|   The '<', '>' was previously implemented using command files.  Now | ||||
|   GNU Make will check to see if the is already a VMS "PIPE" command and | ||||
|   if it is not, will convert the command to a VMS "PIPE" command. | ||||
| 
 | ||||
|   The '>>' redirection has been implemented by using a temporary command file. | ||||
|   This will be described later. | ||||
| 
 | ||||
|   The DCL symbol or logical name GNV$MAKE_USE_CMD_FILE when set to a | ||||
|   string starting with one of '1','T', or 'E' for "1", "TRUE", or "ENABLE", | ||||
|   then temporary DCL command files are always used for running commands. | ||||
| 
 | ||||
|   Some recipe strings with embedded new lines will not be handled correctly | ||||
|   when a command file is used. | ||||
| 
 | ||||
|   GNU Make generally does text comparisons for the targets and sources.  The | ||||
|   make program itself can handle either Unix or OpenVMS format filenames, but | ||||
|   normally does not do any conversions from one format to another. | ||||
|   TODO: The OpenVMS format syntax handling is incomplete. | ||||
|   TODO: ODS-5 EFS support is missing. | ||||
|   BUG: The internal routines to convert filenames to and from OpenVMS format | ||||
|   do not work correctly. | ||||
| 
 | ||||
|   Note: In the examples below, line continuations such as a backslash may have | ||||
|   been added to make the examples easier to read in this format. | ||||
|   BUG: That feature does not completely work at this time. | ||||
| 
 | ||||
|   Since the OpenVMS utilities generally expect OpenVMS format paths, you will | ||||
|   usually have to use OpenVMS format paths for rules and targets. | ||||
|   BUG: Relative OpenVMS paths may not work in targets, especially combined | ||||
|   with vpaths.  This is because GNU make will just concatenate the directories | ||||
|   as it does on Unix. | ||||
| 
 | ||||
|   The variables $^ and $@ separate files with commas instead of spaces. | ||||
|   This is controlled by the name GNV$MAKE_COMMA as documented in the | ||||
|   previous section. | ||||
| 
 | ||||
|   While this may seem the natural thing to do with OpenVMS, it actually | ||||
|   causes problems when trying to use other make functions that expect the | ||||
|   files to be separated by spaces.  If you run into this, you need the | ||||
|   following workaround to convert the output. | ||||
|   TODO: Look at have the $^ and $@ use spaces like on Unix and have | ||||
|   and easy to use function to do the conversions and have the built | ||||
|   in OpenVMS specific recipes and macros use it. | ||||
| 
 | ||||
|   Example: | ||||
| 
 | ||||
| comma := , | ||||
| empty := | ||||
| space := $(empty) $(empty) | ||||
| 
 | ||||
| foo: $(addsuffix .3,$(subs $(comma),$(space),$^) | ||||
| 
 | ||||
| 
 | ||||
|   Makefile variables are looked up in the current environment. You can set | ||||
|   symbols or logicals in DCL and evaluate them in the Makefile via | ||||
|   $(<name-of-symbol-or-logical>).  Variables defined in the Makefile | ||||
|   override OpenVMS symbols/logicals. | ||||
| 
 | ||||
|   OpenVMS logical and symbols names show up as "environment" using the | ||||
|   origin function.  when the "-e" option is specified, the origion function | ||||
|   shows them as "environment override".  On Posix the test scripts indicate | ||||
|   that they should show up just as "environment". | ||||
| 
 | ||||
|   When GNU make reads in a symbol or logical name into the environment, it | ||||
|   converts any dollar signs found to double dollar signs for convenience in | ||||
|   using DCL symbols and logical names in recipes.  When GNU make exports a | ||||
|   DCL symbol for a child process, if the first dollar sign found is followed | ||||
|   by second dollar sign, then all double dollar signs will be convirted to | ||||
|   single dollar signs. | ||||
| 
 | ||||
|   The variable $(ARCH) is predefined as IA64, ALPHA or VAX respectively. | ||||
|   Makefiles for different OpenVMS systems can now be written by checking | ||||
|   $(ARCH).  Since IA64 and ALPHA are similar, usually just a check for | ||||
|   VAX or not VAX is sufficient. | ||||
| 
 | ||||
|   You may have to update makefiles that assume VAX if not ALPHA. | ||||
| 
 | ||||
| ifeq ($(ARCH),VAX) | ||||
|   $(ECHO) "On the VAX" | ||||
| else | ||||
|   $(ECHO) "On the ALPHA  or IA64" | ||||
| endif | ||||
| 
 | ||||
|   Empty commands are handled correctly and don't end in a new DCL process. | ||||
| 
 | ||||
|   The exit command needs to have OpenVMS exit codes.  To pass a Posix code | ||||
|   back to the make script, you need to encode it by multiplying it by 8 | ||||
|   and then adding %x1035a002 for a failure code and %x1035a001 for a | ||||
|   success.  Make will interpret any posix code other than 0 as a failure. | ||||
|   TODO: Add an option have simulate Posix exit commands in recipes. | ||||
| 
 | ||||
|   Lexical functions can be used in pipes to simulate shell file test rules. | ||||
| 
 | ||||
|   Example: | ||||
| 
 | ||||
|   Posix: | ||||
| b : c ; [ -f $@ ] || echo >> $@ | ||||
| 
 | ||||
|   OpenVMS: | ||||
| b : c ; if f$$search("$@") then pipe open/append xx $@ ; write xx "" ; close xx | ||||
| 
 | ||||
| 
 | ||||
|   You can also use pipes and turning messages off to silently test for a | ||||
|   failure. | ||||
| 
 | ||||
| x = %x1035a00a | ||||
| 
 | ||||
| %.b : %.c | ||||
| <tab>pipe set mess/nofac/noiden/nosev/notext ; type $^/output=$@ || exit $(x) | ||||
| 
 | ||||
| 
 | ||||
| Runtime issues: | ||||
| 
 | ||||
|   The OpenVMS C Runtime has a convention for encoding a Posix exit status into | ||||
|   to OpenVMS exit codes.  These status codes will have the hex value of | ||||
|   0x35a000.  OpenVMS exit code may also have a hex value of %x10000000 set on | ||||
|   them.  This is a flag to tell DCL not to write out the exit code. | ||||
| 
 | ||||
|   To convert an OpenVMS encoded Posix exit status code to the original code | ||||
|   You subtract %x35a000 and any flags from the OpenVMS code and divide it by 8. | ||||
| 
 | ||||
|   WARNING: Backward-incompatibility! | ||||
|   The make program exit now returns the same encoded Posix exit code as on | ||||
|   Unix. Previous versions returned the OpenVMS exit status code if that is what | ||||
|   caused the recipe to fail. | ||||
|   TODO: Provide a way for scripts calling make to obtain that OpenVMS status | ||||
|   code. | ||||
| 
 | ||||
|   Make internally has two error codes, MAKE_FAILURE and MAKE_TROUBLE.  These | ||||
|   will have the error "-E-" severity set on exit. | ||||
| 
 | ||||
|   MAKE_TROUBLE is returned only if the option "-q" or "--question" is used and | ||||
|   has a Posix value of 1 and an OpenVMS status of %x1035a00a. | ||||
| 
 | ||||
|   MAKE_FAILURE has a Posix value of 2 and an OpenVMS status of %x1035a012. | ||||
| 
 | ||||
|   Output from GNU make may have single quotes around some values where on | ||||
|   other platforms it does not.  Also output that would be in double quotes | ||||
|   on some platforms may show up as single quotes on VMS. | ||||
| 
 | ||||
|   There may be extra blank lines in the output on VMS. | ||||
|   https://savannah.gnu.org/bugs/?func=detailitem&item_id=41760 | ||||
| 
 | ||||
|   There may be a "Waiting for unfinished jobs..." show up in the output. | ||||
| 
 | ||||
|   Error messages generated by Make or Unix utilities may slightly vary from | ||||
|   Posix platforms.  Typically the case may be different. | ||||
| 
 | ||||
|   When make deletes files, on posix platforms it writes out 'rm' and the list | ||||
|   of files.  On VMS, only the files are writen out, one per line. | ||||
|   TODO: VMS | ||||
| 
 | ||||
|   There may be extra leading white space or additional or missing whitespace | ||||
|   in the output of recipes. | ||||
| 
 | ||||
|   GNU Make uses sys$scratch: for the tempfiles that it creates. | ||||
| 
 | ||||
|   The OpenVMS CRTL library maps /tmp to sys$scratch if the TMP: logical name | ||||
|   does not exist.  As the CRTL may use both sys$scratch: and /tmp internally, | ||||
|   if you define the TMP logical name to be different than SYS$SCRATCH:, | ||||
|   you may end up with only some temporary files in TMP: and some in SYS$SCRATCH: | ||||
| 
 | ||||
|   The default include directory for including other makefiles is | ||||
|   SYS$SYSROOT:[SYSLIB] (I don't remember why I didn't just use | ||||
|   SYS$LIBRARY: instead; maybe it wouldn't work that way). | ||||
|   TODO:  A better default may be desired. | ||||
| 
 | ||||
|   If the device for a file in a recipe does not exist, on OpenVMS an error | ||||
|   message of "stat: <file>: no such device or address" will be output. | ||||
| 
 | ||||
|   Make ignores success, informational, or warning errors (-S-, -I-, or | ||||
|   -W-).  But it will stop on -E- and -F- errors. (unless you do something | ||||
|   to override this in your makefile, or whatever). | ||||
| 
 | ||||
| 
 | ||||
| Unix compatibilty features: | ||||
| --------------------------- | ||||
| 
 | ||||
|   If the command 'echo' is seen, any single quotes on the line will be | ||||
|   converted to double quotes. | ||||
| 
 | ||||
|   The variable $(CD) is implemented as a built in Change Directory | ||||
|   command. This invokes the 'builtin_cd'  Executing a 'set default' | ||||
|   recipe doesn't do the trick, since it only affects the subprocess | ||||
|   spawned for that command. | ||||
| 
 | ||||
|   The 'builtin_cd' is generally expected to be on its own line. | ||||
|   The 'builtin_cd' either from the expansion of $(CD) or directly | ||||
|   put in a recipe line will be executed before any other commands in | ||||
|   that recipe line.  DCL parameter substitution will not work for the | ||||
|   'builtin_cd' command. | ||||
| 
 | ||||
|   Putting a 'builtin_cd' in a pipeline or an IF-THEN line should not be | ||||
|   done because the 'builtin_cd' is always executed | ||||
|   and executed first.  The directory change is persistent. | ||||
| 
 | ||||
|   Unix shell style I/O redirection is supported. You can now write lines like: | ||||
|   "<tab>mcr sys$disk:[]program.exe < input.txt > output.txt &> error.txt" | ||||
| 
 | ||||
|   Posix shells have ":" as a null command.  These are now handled. | ||||
|   https://savannah.gnu.org/bugs/index.php?41761 | ||||
| 
 | ||||
|   A note on appending the redirected output.  A simple mechanism is | ||||
|   implemented to make ">>" work in action lines. In OpenVMS there is no simple | ||||
|   feature like ">>" to have DCL command or program output redirected and | ||||
|   appended to a file. GNU make for OpenVMS implements the redirection | ||||
|   of ">>" by using a command procedure. | ||||
| 
 | ||||
|   The current algorithm creates the output file if it does not exist and | ||||
|   then uses the DCL open/append to extend it.  SYS$OUTPUT is then directed | ||||
|   to that file. | ||||
| 
 | ||||
|   The implementation supports only one redirected append output to a file | ||||
|   and that redirection is done before any other commands in that line | ||||
|   are executed, so it redirects all output for that command. | ||||
| 
 | ||||
|   The older implementation wrote the output to a temporary file in | ||||
|   in sys$scratch: and then attempted to append the file to the existing file. | ||||
|   The temporary file names looked like "CMDxxxxx.". Any time the created | ||||
|   command procedure can not complete, this happens. Pressing Ctrl+Y to | ||||
|   abort make is one case. | ||||
| 
 | ||||
|   In case of Ctrl+Y the associated command procedure is left in SYS$SCRATCH:. | ||||
|   The command procedures will be named gnv$make_cmd*.com. | ||||
| 
 | ||||
|   The CtrlY handler now uses $delprc to delete all children. This way also | ||||
|   actions with DCL commands will be stopped. As before the CtrlY handler | ||||
|   then sends SIGQUIT to itself, which is handled in common code. | ||||
| 
 | ||||
|   Temporary command files are now deleted in the OpenVMS child termination | ||||
|   handler. That deletes them even if a Ctrl+C was pressed. | ||||
|   TODO: Does the previous section about >> leaving files still apply? | ||||
| 
 | ||||
|   The behavior of pressing Ctrl+C is not changed. It still has only an effect, | ||||
|   after the current action is terminated. If that doesn't happen or takes too | ||||
|   long, Ctrl+Y should be used instead. | ||||
| 
 | ||||
| 
 | ||||
| Build Options: | ||||
| 
 | ||||
|   Added support to have case sensitive targets and dependencies but to | ||||
|   still use case blind file names. This is especially useful for Java | ||||
|   makefiles on VMS: | ||||
| 
 | ||||
| <TAB>.SUFFIXES : | ||||
| <TAB>.SUFFIXES : .class .java | ||||
| <TAB>.java.class : | ||||
| <TAB><TAB>javac "$<" | ||||
| <TAB>HelloWorld.class :      HelloWorld.java | ||||
| 
 | ||||
|   A new macro WANT_CASE_SENSITIVE_TARGETS in config.h-vms was introduced. | ||||
|   It needs to be enabled to get this feature; default is disabled. | ||||
|   TODO: This should be a run-time setting based on if the process | ||||
|   has been set to case sensitive. | ||||
| 
 | ||||
| 
 | ||||
| Unimplemented functionality: | ||||
| 
 | ||||
|   The new feature "Loadable objects" is not yet supported. If you need it, | ||||
|   please send a change request or submit a bug report. | ||||
| 
 | ||||
|   The new option --output-sync (-O) is accepted but has no effect: GNU make | ||||
|   for OpenVMS does not support running multiple commands simultaneously. | ||||
| 
 | ||||
| 
 | ||||
| Self test failures and todos: | ||||
| ----------------------------- | ||||
| 
 | ||||
|   The test harness can not handle testing some of the VMS specific modes | ||||
|   because of the features needed for to be set for the Perl to run. | ||||
|   Need to find a way to set the VMS features before running make as a | ||||
|   child. | ||||
| 
 | ||||
|   GNU make was not currently translating the OpenVMS encoded POSIX values | ||||
|   returned to it back to the Posix values.  I have temporarily modified the | ||||
|   Perl test script to compensate for it.  This should be being handled | ||||
|   internally to Make. | ||||
|   TODO: Verify and update the Perl test script. | ||||
| 
 | ||||
|   The features/parallelism test was failing. OpenVMS is executing the rules | ||||
|   in sequence not in parallel as this feature was not implemented. | ||||
|   GNU Make on VMS no longer claims it is implemented. | ||||
|   TODO: Implement it. | ||||
| 
 | ||||
|   Symlink support is not present.  Symlinks are supported by OpenVMS 8.3 and | ||||
|   later. | ||||
| 
 | ||||
|   Error messages should be supressed with the "-" at the beginning of a line. | ||||
|   On openVMS they were showing up.  TODO: Is this still an issue? | ||||
| 
 | ||||
|   The internal vmsify and unixify OpenVMS to/from UNIX are not handling logical | ||||
|   names correctly. | ||||
| 
 | ||||
| 
 | ||||
| Build instructions: | ||||
| ------------------ | ||||
| 
 | ||||
|   Don't use the HP C V7.2-001 compiler, which has an incompatible change | ||||
|   how __STDC__ is defined. This results at least in compile time warnings. | ||||
| 
 | ||||
| Make a 1st version | ||||
|        $ @makefile.com  ! ignore any compiler and/or linker warning | ||||
|        $ copy make.exe 1st-make.exe | ||||
| 
 | ||||
|   Use the 1st version to generate a 2nd version as a test. | ||||
|        $ mc sys$disk:[]1st-make clean  ! ignore any file not found messages | ||||
|        $ mc sys$disk:[]1st-make | ||||
| 
 | ||||
|   Verify your 2nd version by building Make again. | ||||
|        $ copy make.exe 2nd-make.exe | ||||
|        $ mc sys$disk:[]2nd-make clean | ||||
|        $ mc sys$disk:[]2nd-make | ||||
| 
 | ||||
| 
 | ||||
| Running the tests: | ||||
| ------------------ | ||||
| 
 | ||||
|   Running the tests on OpenVMS requires the following software to be installed | ||||
|   as most of the tests are Unix oriented. | ||||
| 
 | ||||
|   * Perl 5.18 or later. | ||||
|     https://sourceforge.net/projects/vmsperlkit/files/ | ||||
|   * GNV 2.1.3 + Updates including a minimum of: | ||||
|     * Bash 4.3.30 | ||||
|     * ld_tools 3.0.2 | ||||
|     * coreutils 8.21 | ||||
|    https://sourceforge.net/p/gnv/wiki/InstallingGNVPackages/ | ||||
|    https://sourceforge.net/projects/gnv/files/ | ||||
| 
 | ||||
|    As the test scripts need to create some foreign commands that persist | ||||
|    after the test is run, it is recommend that either you use a subprocess or | ||||
|    a dedicated login to run the tests. | ||||
| 
 | ||||
|    To get detailed information for running the tests: | ||||
| 
 | ||||
|    $ set default [.tests] | ||||
|    $ @run_make_tests help | ||||
| 
 | ||||
|    Running the script with no parameters will run all the tests. | ||||
| 
 | ||||
|    After the the test script has been run once in a session, assuming | ||||
|    that you built make in sys$disk:[make], you can redefined the | ||||
|    "bin" logical name as follows: | ||||
| 
 | ||||
|    $ define bin sys$disk:[make],gnv$gnu:[bin] | ||||
| 
 | ||||
|    Then you can use Perl to run the scripts. | ||||
| 
 | ||||
|    $ perl run_make_tests.pl | ||||
| 
 | ||||
| 
 | ||||
| Acknowlegements: | ||||
| ---------------- | ||||
| 
 | ||||
| See NEWS. for details of past changes. | ||||
| 
 | ||||
|   These are the currently known contributers to this port. | ||||
| 
 | ||||
|   Hartmut Becker | ||||
|   John Malmberg | ||||
|   Michael Gehre | ||||
|   John Eisenbraun | ||||
|   Klaus Kaempf | ||||
|   Mike Moretti | ||||
|   John W. Eaton | ||||
							
								
								
									
										361
									
								
								third_party/make/README.W32
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										361
									
								
								third_party/make/README.W32
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,361 @@ | |||
| This version of GNU make has been tested on: | ||||
|   Microsoft Windows 2000/XP/2003/Vista/7/8/10 | ||||
| It has also been used on Windows 95/98/NT, and on OS/2. | ||||
| 
 | ||||
| It builds with the MinGW port of GCC (tested with GCC 3.4.2, 4.8.1, | ||||
| and 4.9.3). | ||||
| 
 | ||||
| It also builds with MSVC 2.x, 4.x, 5.x, 6.x, 2005, 2008, 2010, 2012, | ||||
| 2013, and 2015 as well as with .NET 7.x and .NET 2003. | ||||
| 
 | ||||
| Building with Guile is supported (tested with Guile 2.0.x).  To build | ||||
| with Guile, you will need, in addition to Guile itself, its dependency | ||||
| libraries and the pkg-config program.  The latter is used to figure out | ||||
| which compilation and link switches and libraries need to be mentioned | ||||
| on the compiler command lines to correctly link with Guile.  A Windows | ||||
| port of pkg-config can be found on ezwinports site: | ||||
| 
 | ||||
|   http://sourceforge.net/projects/ezwinports/ | ||||
| 
 | ||||
| The libraries on which Guile depends can vary depending on your | ||||
| version and build of Guile.  At the very least, the Boehm's GC library | ||||
| will be needed, and typically also GNU MP, libffi, libunistring, and | ||||
| libtool's libltdl.  Whoever built the port of Guile you have should | ||||
| also provide you with these dependencies or a URL where to download | ||||
| them.  A precompiled 32-bit Windows build of Guile is available from | ||||
| the ezwinports site mentioned above. | ||||
| 
 | ||||
| The Windows port of GNU make is maintained jointly by various people. | ||||
| It was originally made by Rob Tulloh. | ||||
| It is currently maintained by Eli Zaretskii. | ||||
| 
 | ||||
| 
 | ||||
| Do this first, regardless of the build method you choose: | ||||
| --------------------------------------------------------- | ||||
| 
 | ||||
|  1. Edit config.h.W32 to your liking (especially the few shell-related | ||||
|     defines near the end, or HAVE_CASE_INSENSITIVE_FS which corresponds | ||||
|     to './configure --enable-case-insensitive-file-system').  (We don't | ||||
|     recommend to define HAVE_CASE_INSENSITIVE_FS, but you may wish to | ||||
|     consider that if you have a lot of files whose names are in upper | ||||
|     case, while Makefile rules are written for lower-case versions.) | ||||
| 
 | ||||
| 
 | ||||
| Building with (MinGW-)GCC using build_w32.bat | ||||
| --------------------------------------------- | ||||
| 
 | ||||
|  2. Open a W32 command prompt for your installed (MinGW-)GCC, setup a | ||||
|     correct PATH and other environment variables for it, then execute ... | ||||
| 
 | ||||
|         .\build_w32.bat gcc | ||||
| 
 | ||||
|     This produces gnumake.exe in the GccRel directory. | ||||
| 
 | ||||
|     If you want a version of GNU make built with debugging enabled, | ||||
|     add the --debug option.  Output goes into the GccDebug directory. | ||||
| 
 | ||||
|     The batch file will probe for Guile installation, and will build | ||||
|     gnumake.exe with Guile if it finds it.  If you have Guile | ||||
|     installed, but want to build Make without Guile support, type | ||||
| 
 | ||||
|         .\build_w32.bat --without-guile gcc | ||||
| 
 | ||||
| 
 | ||||
| Building with (MSVC++-)cl using build_w32.bat | ||||
| --------------------------------------------- | ||||
| 
 | ||||
|  2. Open a command shell, then execute ... | ||||
| 
 | ||||
|         .\build_w32.bat | ||||
| 
 | ||||
|     This produces a 64bit Release build of gnumake.exe in .\WinRel, using | ||||
|     the compiler found on the %Path%.  If no compiler is found, the batch | ||||
|     file will probe your system and choose the newest MSVC version it can | ||||
|     find. | ||||
| 
 | ||||
|     If you want a 32bit version of GNU make, add the --x86 option. | ||||
| 
 | ||||
|     If you want a Debug build of GNU make, add the --debug option.  Output | ||||
|     will go into the .\WinDebug directory. | ||||
| 
 | ||||
|     The batch file will probe for Guile installation, and will build | ||||
|     gnumake.exe with Guile if it finds it.  If Guile is installed, | ||||
|     but you prefer to build GNU make without Guile support, add the | ||||
|     --without-guile option. | ||||
| 
 | ||||
| 
 | ||||
| Building with (MinGW-)GCC using GNU make | ||||
| ---------------------------------------- | ||||
| 
 | ||||
|  2. If you already have a version of GNU make available you can use it | ||||
|     to build this version.  Open a W32 command prompt for your installed | ||||
|     (MinGW-)GCC, setup a correct PATH and other environment variables | ||||
|     for it, then execute ... | ||||
| 
 | ||||
|         make -f Basic.mk TOOLCHAIN=gcc | ||||
| 
 | ||||
|     This produces GccRel\gnumake.exe. | ||||
|     If you want a version of GNU make built with debugging enabled, | ||||
|     add the TARGET_TYPE=debug option: | ||||
| 
 | ||||
|         make -f Basic.mk TOOLCHAIN=gcc TARGET_TYPE=debug | ||||
| 
 | ||||
|     The makefile doesn't support Guile integration.  Use build_w32.bat | ||||
|     if you want to build with Guile support. | ||||
| 
 | ||||
| 
 | ||||
| Building with (MSVC++-)cl using GNU make | ||||
| ---------------------------------------- | ||||
| 
 | ||||
|  2. If you already have a version of GNU make available you can use it | ||||
|     to build this version.  Open a W32 command prompt for your installed | ||||
|     (MSVC++-)cl, setup a correct PATH and other environment variables | ||||
|     for it (usually via executing vcvars32.bat or vsvars32.bat from the | ||||
|     cl-installation, or using a corresponding start menu entry from the | ||||
|     cl-installation), then execute ... | ||||
| 
 | ||||
|         make -f Basic.mk | ||||
| 
 | ||||
|     This produces an optimized WinRel/gnumake.exe. | ||||
|     If you want a version of GNU make built with debugging enabled, | ||||
|     add the TARGET_TYPE=debug option: | ||||
| 
 | ||||
|         make -f Basic.mk TARGET_TYPE=debug | ||||
| 
 | ||||
|     The makefile doesn't support Guile integration.  Use build_w32.bat | ||||
|     if you want to build with Guile support. | ||||
| 
 | ||||
| 
 | ||||
| Running the test suite | ||||
| ---------------------- | ||||
| 
 | ||||
|  3. You will need an installation of Perl.  Be sure to use a relatively | ||||
|     modern version: older versions will sometimes throw spurious errors. | ||||
| 
 | ||||
|     To run the suite after building using GNU make, use: | ||||
| 
 | ||||
|         make -f Basic.mk check | ||||
| 
 | ||||
|     Alternatively if you'd like to run tests by hand, use: | ||||
| 
 | ||||
|         cd tests | ||||
|         .\run_make_tests.bat -make <path-to-make> | ||||
| 
 | ||||
|     I've found <path-to-make> seems to want forward-slashes in the path. | ||||
|     For example if building with .\build_w32.bat non-debug, use: | ||||
| 
 | ||||
|         cd tests | ||||
|         .\run_make_tests.bat -make ../WinRel/gnumake.exe | ||||
| 
 | ||||
|     I've tested this with the MSYS2 shell and POSIX tools installation | ||||
|     that you get by installing Git for Windows. | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| ------------------- | ||||
| -- Notes/Caveats -- | ||||
| ------------------- | ||||
| 
 | ||||
| GNU make on Windows 32-bit platforms: | ||||
| 
 | ||||
|         This version of make is ported natively to Windows32 platforms | ||||
|         (Windows NT 3.51, Windows NT 4.0, Windows 2000, Windows XP, | ||||
|         Windows 95, and Windows 98). It does not rely on any 3rd party | ||||
|         software or add-on packages for building. The only thing | ||||
|         needed is a Windows compiler.  Two compilers supported | ||||
|         officially are the MinGW port of GNU GCC, and the various | ||||
|         versions of the Microsoft C compiler. | ||||
| 
 | ||||
|         Do not confuse this port of GNU make with other Windows32 projects | ||||
|         which provide a GNU make binary. These are separate projects | ||||
|         and are not connected to this port effort. | ||||
| 
 | ||||
| GNU make and sh.exe: | ||||
| 
 | ||||
|         This port prefers if you have a working sh.exe somewhere on | ||||
|         your system. If you don't have sh.exe, the port falls back to | ||||
|         MSDOS mode for launching programs (via a batch file).  The | ||||
|         MSDOS mode style execution has not been tested that carefully | ||||
|         though (The author uses GNU bash as sh.exe). | ||||
| 
 | ||||
|         There are very few true ports of Bourne shell for NT right now. | ||||
|         There is a version of GNU bash available from Cygnus "Cygwin" | ||||
|         porting effort (http://www.cygwin.com/). | ||||
|         Other possibilities are the MKS version of sh.exe, or building | ||||
|         your own with a package like NutCracker (DataFocus) or Portage | ||||
|         (Consensys).  Also MinGW includes sh (http://mingw.org/). | ||||
| 
 | ||||
| GNU make and brain-dead shells (BATCH_MODE_ONLY_SHELL): | ||||
| 
 | ||||
|         Some versions of Bourne shell do not behave well when invoked | ||||
|         as 'sh -c' from CreateProcess().  The main problem is they seem | ||||
|         to have a hard time handling quoted strings correctly. This can | ||||
|         be circumvented by writing commands to be executed to a batch | ||||
|         file and then executing the command by calling 'sh file'. | ||||
| 
 | ||||
|         To work around this difficulty, this version of make supports | ||||
|         a batch mode.  When BATCH_MODE_ONLY_SHELL is defined at compile | ||||
|         time, make forces all command lines to be executed via script | ||||
|         files instead of by command line.  In this mode you must have a | ||||
|         working sh.exe in order to use parallel builds (-j). | ||||
| 
 | ||||
|         A native Windows32 system with no Bourne shell will also run | ||||
|         in batch mode.  All command lines will be put into batch files | ||||
|         and executed via $(COMSPEC) (%COMSPEC%).  However, parallel | ||||
|         builds ARE supported with Windows shells (cmd.exe and | ||||
|         command.com).  See the next section about some peculiarities | ||||
|         of parallel builds on Windows. | ||||
| 
 | ||||
| Support for parallel builds | ||||
| 
 | ||||
|         Parallel builds (-jN) are supported in this port.  The number of | ||||
|         concurrent processes has a hard limit of 4095. | ||||
| 
 | ||||
| GNU make and Cygnus GNU Windows32 tools: | ||||
| 
 | ||||
|         Good news! Make now has native support for Cygwin sh. To enable, | ||||
|         define the HAVE_CYGWIN_SHELL in config.h and rebuild make | ||||
|         from scratch. This version of make tested with B20.1 of Cygwin. | ||||
|         Do not define BATCH_MODE_ONLY_SHELL if you use HAVE_CYGWIN_SHELL. | ||||
| 
 | ||||
| GNU make and the MKS shell: | ||||
| 
 | ||||
|         There is now semi-official support for the MKS shell. To turn this | ||||
|         support on, define HAVE_MKS_SHELL in the config.h.W32 before you | ||||
|         build make.  Do not define BATCH_MODE_ONLY_SHELL if you turn | ||||
|         on HAVE_MKS_SHELL. | ||||
| 
 | ||||
| GNU make handling of drive letters in pathnames (PATH, vpath, VPATH): | ||||
| 
 | ||||
|         There is a caveat that should be noted with respect to handling | ||||
|         single character pathnames on Windows systems.  When colon is | ||||
|         used in PATH variables, make tries to be smart about knowing when | ||||
|         you are using colon as a separator versus colon as a drive | ||||
|         letter.  Unfortunately, something as simple as the string 'x:/' | ||||
|         could be interpreted 2 ways: (x and /) or (x:/). | ||||
| 
 | ||||
|         Make chooses to interpret a letter plus colon (e.g. x:/) as a | ||||
|         drive letter pathname.  If it is necessary to use single | ||||
|         character directories in paths (VPATH, vpath, Path, PATH), the | ||||
|         user must do one of two things: | ||||
| 
 | ||||
|          a. Use semicolon as the separator to disambiguate colon. For | ||||
|             example use 'x;/' if you want to say 'x' and '/' are | ||||
|             separate components. | ||||
| 
 | ||||
|          b. Qualify the directory name so that there is more than | ||||
|             one character in the path(s) used. For example, none | ||||
|             of these settings are ambiguous: | ||||
| 
 | ||||
|               ./x:./y | ||||
|               /some/path/x:/some/path/y | ||||
|               x:/some/path/x:x:/some/path/y | ||||
| 
 | ||||
|         Please note that you are free to mix colon and semi-colon in the | ||||
|         specification of paths.  Make is able to figure out the intended | ||||
|         result and convert the paths internally to the format needed | ||||
|         when interacting with the operating system, providing the path | ||||
|         is not within quotes, e.g. "x:/test/test.c". | ||||
| 
 | ||||
|         You are encouraged to use colon as the separator character. | ||||
|         This should ease the pain of deciding how to handle various path | ||||
|         problems which exist between platforms.  If colon is used on | ||||
|         both Unix and Windows systems, then no ifdef'ing will be | ||||
|         necessary in the makefile source. | ||||
| 
 | ||||
| Pathnames and white space: | ||||
| 
 | ||||
|         Unlike Unix, Windows 95/NT systems encourage pathnames which | ||||
|         contain white space (e.g. C:\Program Files\). These sorts of | ||||
|         pathnames are valid on Unix too, but are never encouraged. | ||||
|         There is at least one place in make (VPATH/vpath handling) where | ||||
|         paths containing white space will simply not work. There may be | ||||
|         others too. I chose to not try and port make in such a way so | ||||
|         that these sorts of paths could be handled. I offer these | ||||
|         suggestions as workarounds: | ||||
| 
 | ||||
|                 1. Use 8.3 notation. i.e. "x:/long~1/", which is actually | ||||
|                    "x:\longpathtest".  Type "dir /x" to view these filenames | ||||
|                    within the cmd.exe shell. | ||||
|                 2. Rename the directory so it does not contain white space. | ||||
| 
 | ||||
|         If you are unhappy with this choice, this is free software | ||||
|         and you are free to take a crack at making this work. The code | ||||
|         in w32/pathstuff.c and vpath.c would be the places to start. | ||||
| 
 | ||||
| Pathnames and Case insensitivity: | ||||
| 
 | ||||
|         Unlike Unix, Windows 95/NT systems are case insensitive but case | ||||
|         preserving.  For example if you tell the file system to create a | ||||
|         file named "Target", it will preserve the case.  Subsequent access to | ||||
|         the file with other case permutations will succeed (i.e. opening a | ||||
|         file named "target" or "TARGET" will open the file "Target"). | ||||
| 
 | ||||
|         By default, GNU make retains its case sensitivity when comparing | ||||
|         target names and existing files or directories.  It can be | ||||
|         configured, however, into a case preserving and case insensitive | ||||
|         mode by adding a define for HAVE_CASE_INSENSITIVE_FS to | ||||
|         config.h.W32. | ||||
| 
 | ||||
|         For example, the following makefile will create a file named | ||||
|         Target in the directory subdir which will subsequently be used | ||||
|         to satisfy the dependency of SUBDIR/DepTarget on SubDir/TARGET. | ||||
|         Without HAVE_CASE_INSENSITIVE_FS configured, the dependency link | ||||
|         will not be made: | ||||
| 
 | ||||
|         subdir/Target: | ||||
|                 touch $@ | ||||
| 
 | ||||
|         SUBDIR/DepTarget: SubDir/TARGET | ||||
|                 cp $^ $@ | ||||
| 
 | ||||
|         Reliance on this behavior also eliminates the ability of GNU make | ||||
|         to use case in comparison of matching rules.  For example, it is | ||||
|         not possible to set up a C++ rule using %.C that is different | ||||
|         than a C rule using %.c.  GNU make will consider these to be the | ||||
|         same rule and will issue a warning. | ||||
| 
 | ||||
| SAMBA/NTFS/VFAT: | ||||
| 
 | ||||
|         I have not had any success building the debug version of this | ||||
|         package using SAMBA as my file server. The reason seems to be | ||||
|         related to the way VC++ 4.0 changes the case name of the pdb | ||||
|         filename it is passed on the command line. It seems to change | ||||
|         the name always to to lower case. I contend that the VC++ | ||||
|         compiler should not change the casename of files that are passed | ||||
|         as arguments on the command line. I don't think this was a | ||||
|         problem in MSVC 2.x, but I know it is a problem in MSVC 4.x. | ||||
| 
 | ||||
|         The package builds fine on VFAT and NTFS filesystems. | ||||
| 
 | ||||
|         Most all of the development I have done to date has been using | ||||
|         NTFS and long file names. I have not done any considerable work | ||||
|         under VFAT. VFAT users may wish to be aware that this port of | ||||
|         make does respect case sensitivity. | ||||
| 
 | ||||
| FAT: | ||||
| 
 | ||||
|         Version 3.76 added support for FAT filesystems. Make works | ||||
|         around some difficulties with stat'ing of files and caching of | ||||
|         filenames and directories internally. | ||||
| 
 | ||||
| Bug reports: | ||||
| 
 | ||||
|         Please submit bugs via the normal bug reporting mechanism which | ||||
|         is described in the GNU make manual and the base README. | ||||
|  | ||||
| ------------------------------------------------------------------------------- | ||||
| Copyright (C) 1996-2020 Free Software Foundation, Inc. | ||||
| This file is part of GNU Make. | ||||
| 
 | ||||
| GNU Make is free software; you can redistribute it and/or modify it under the | ||||
| terms of the GNU General Public License as published by the Free Software | ||||
| Foundation; either version 3 of the License, or (at your option) any later | ||||
| version. | ||||
| 
 | ||||
| GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR | ||||
| A PARTICULAR PURPOSE.  See the GNU General Public License for more details. | ||||
| 
 | ||||
| You should have received a copy of the GNU General Public License along with | ||||
| this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
							
								
								
									
										4
									
								
								third_party/make/README.cosmo
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								third_party/make/README.cosmo
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,4 @@ | |||
| ORIGIN | ||||
| 
 | ||||
|     GNU Make 4.3 | ||||
|     http://ftp.gnu.org/gnu/make/make-4.3.tar.gz | ||||
							
								
								
									
										112
									
								
								third_party/make/README.customs
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										112
									
								
								third_party/make/README.customs
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,112 @@ | |||
|                                                             -*-indented-text-*- | ||||
| 
 | ||||
| GNU make can utilize the Customs library, distributed with Pmake, to | ||||
| provide builds distributed across multiple hosts. | ||||
| 
 | ||||
| In order to utilize this capability, you must first download and build | ||||
| the Customs library.  It is contained in the Pmake distribution, which | ||||
| can be obtained at: | ||||
| 
 | ||||
|   ftp://ftp.icsi.berkeley.edu/pub/ai/stolcke/software/ | ||||
| 
 | ||||
| This integration was tested (superficially) with Pmake 2.1.33. | ||||
| 
 | ||||
| 
 | ||||
| BUILDING CUSTOMS | ||||
| ---------------- | ||||
| 
 | ||||
| First, build pmake and Customs.  You need to build pmake first, because | ||||
| Customs require pmake to build.  Unfortunately, this is not trivial; | ||||
| please see the pmake and Customs documentation for details.  The best | ||||
| place to look for instructions is in the pmake-2.1.33/INSTALL file. | ||||
| 
 | ||||
| Note that the 2.1.33 Pmake distribution comes with a set of patches to | ||||
| GNU make, distributed in the pmake-2.1.33/etc/gnumake/ directory.  These | ||||
| patches are based on GNU make 3.75 (there are patches for earlier | ||||
| versions of GNU make, also).  The parts of this patchfile which relate | ||||
| directly to Customs support have already been incorporated into this | ||||
| version of GNU make, so you should _NOT_ apply the patch file. | ||||
| 
 | ||||
| However, there are a few non-Customs specific (as far as I could tell) | ||||
| changes here which are not incorporated (for example, the modification | ||||
| to try expanding -lfoo to libfoo.so).  If you rely on these changes | ||||
| you'll need to re-apply them by hand. | ||||
| 
 | ||||
| Install the Customs library and header files according to the | ||||
| documentation.  You should also install the man pages (contrary to | ||||
| comments in the documentation, they weren't installed automatically for | ||||
| me; I had to cd to the 'pmake-2.1.33/doc' directory and run 'pmake | ||||
| install' there directly). | ||||
| 
 | ||||
| 
 | ||||
| BUILDING GNU MAKE | ||||
| ----------------- | ||||
| 
 | ||||
| Once you've installed Customs, you can build GNU make to use it.  When | ||||
| configuring GNU make, merely use the '--with-customs=DIR' option. | ||||
| Provide the directory containing the 'lib' and 'include/customs' | ||||
| subdirectories as DIR.  For example, if you installed the customs | ||||
| library in /usr/local/lib and the headers in /usr/local/include/customs, | ||||
| then you'd pass '--with-customs=/usr/local' as an option to configure. | ||||
| 
 | ||||
| Run make (or use build.sh) normally to build GNU make as described in | ||||
| the INSTALL file. | ||||
| 
 | ||||
| See the documentation for Customs for information on starting and | ||||
| configuring Customs. | ||||
| 
 | ||||
| 
 | ||||
| INVOKING CUSTOMS-IZED GNU MAKE | ||||
| ----------------------------- | ||||
| 
 | ||||
| One thing you should be aware of is that the default build environment | ||||
| for Customs requires root permissions.  Practically, this means that GNU | ||||
| make must be installed setuid root to use Customs. | ||||
| 
 | ||||
| If you don't want to do this, you can build Customs such that root | ||||
| permissions are not necessary.  Andreas Stolcke <stolcke@speech.sri.com> | ||||
| writes: | ||||
| 
 | ||||
|  > pmake, gnumake or any other customs client program is not required to | ||||
|  > be suid root if customs was compiled WITHOUT the USE_RESERVED_PORTS | ||||
|  > option in customs/config.h.  Make sure the "customs" service in | ||||
|  > /etc/services is defined accordingly (port 8231 instead of 1001). | ||||
| 
 | ||||
|  > Not using USE_RESERVED_PORTS means that a user with programming | ||||
|  > skills could impersonate another user by writing a fake customs | ||||
|  > client that pretends to be someone other than himself.  See the | ||||
|  > discussion in etc/SECURITY. | ||||
| 
 | ||||
| 
 | ||||
| PROBLEMS | ||||
| -------- | ||||
| 
 | ||||
| SunOS 4.1.x: | ||||
|   The customs/sprite.h header file #includes the <malloc.h> header | ||||
|   files; this conflicts with GNU make's configuration so you'll get a | ||||
|   compile error if you use GCC (or any other ANSI-capable C compiler). | ||||
| 
 | ||||
|   I commented out the #include in sprite.h:107: | ||||
| 
 | ||||
|     #if defined(sun) || defined(ultrix) || defined(hpux) || defined(sgi) | ||||
|     /* #include <malloc.h> */ | ||||
|     #else | ||||
| 
 | ||||
|   YMMV. | ||||
| 
 | ||||
|  | ||||
| ------------------------------------------------------------------------------- | ||||
| Copyright (C) 1998-2020 Free Software Foundation, Inc. | ||||
| This file is part of GNU Make. | ||||
| 
 | ||||
| GNU Make is free software; you can redistribute it and/or modify it under the | ||||
| terms of the GNU General Public License as published by the Free Software | ||||
| Foundation; either version 3 of the License, or (at your option) any later | ||||
| version. | ||||
| 
 | ||||
| GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR | ||||
| A PARTICULAR PURPOSE.  See the GNU General Public License for more details. | ||||
| 
 | ||||
| You should have received a copy of the GNU General Public License along with | ||||
| this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
							
								
								
									
										13
									
								
								third_party/make/SCOPTIONS
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								third_party/make/SCOPTIONS
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,13 @@ | |||
| ERRORREXX | ||||
| OPTIMIZE | ||||
| NOVERSION | ||||
| OPTIMIZERTIME | ||||
| OPTIMIZERALIAS | ||||
| DEFINE HAVE_CONFIG_H | ||||
| DEFINE INCLUDEDIR="include:" | ||||
| DEFINE LIBDIR="lib:" | ||||
| DEFINE NO_ALLOCA | ||||
| DEFINE NO_ARCHIVES | ||||
| IGNORE=161 | ||||
| IGNORE=100 | ||||
| STARTUP=cres | ||||
							
								
								
									
										1493
									
								
								third_party/make/aclocal.m4
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1493
									
								
								third_party/make/aclocal.m4
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										348
									
								
								third_party/make/build-aux/compile
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										348
									
								
								third_party/make/build-aux/compile
									
										
									
									
										vendored
									
									
										Executable file
									
								
							|  | @ -0,0 +1,348 @@ | |||
| #! /bin/sh | ||||
| # Wrapper for compilers which do not understand '-c -o'. | ||||
| 
 | ||||
| scriptversion=2018-03-07.03; # UTC | ||||
| 
 | ||||
| # Copyright (C) 1999-2018 Free Software Foundation, Inc. | ||||
| # Written by Tom Tromey <tromey@cygnus.com>. | ||||
| # | ||||
| # This program is free software; you can redistribute it and/or modify | ||||
| # it under the terms of the GNU General Public License as published by | ||||
| # the Free Software Foundation; either version 2, or (at your option) | ||||
| # any later version. | ||||
| # | ||||
| # This program is distributed in the hope that it will be useful, | ||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| # GNU General Public License for more details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| # As a special exception to the GNU General Public License, if you | ||||
| # distribute this file as part of a program that contains a | ||||
| # configuration script generated by Autoconf, you may include it under | ||||
| # the same distribution terms that you use for the rest of that program. | ||||
| 
 | ||||
| # This file is maintained in Automake, please report | ||||
| # bugs to <bug-automake@gnu.org> or send patches to | ||||
| # <automake-patches@gnu.org>. | ||||
| 
 | ||||
| nl=' | ||||
| ' | ||||
| 
 | ||||
| # We need space, tab and new line, in precisely that order.  Quoting is | ||||
| # there to prevent tools from complaining about whitespace usage. | ||||
| IFS=" ""	$nl" | ||||
| 
 | ||||
| file_conv= | ||||
| 
 | ||||
| # func_file_conv build_file lazy | ||||
| # Convert a $build file to $host form and store it in $file | ||||
| # Currently only supports Windows hosts. If the determined conversion | ||||
| # type is listed in (the comma separated) LAZY, no conversion will | ||||
| # take place. | ||||
| func_file_conv () | ||||
| { | ||||
|   file=$1 | ||||
|   case $file in | ||||
|     / | /[!/]*) # absolute file, and not a UNC file | ||||
|       if test -z "$file_conv"; then | ||||
| 	# lazily determine how to convert abs files | ||||
| 	case `uname -s` in | ||||
| 	  MINGW*) | ||||
| 	    file_conv=mingw | ||||
| 	    ;; | ||||
| 	  CYGWIN*) | ||||
| 	    file_conv=cygwin | ||||
| 	    ;; | ||||
| 	  *) | ||||
| 	    file_conv=wine | ||||
| 	    ;; | ||||
| 	esac | ||||
|       fi | ||||
|       case $file_conv/,$2, in | ||||
| 	*,$file_conv,*) | ||||
| 	  ;; | ||||
| 	mingw/*) | ||||
| 	  file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'` | ||||
| 	  ;; | ||||
| 	cygwin/*) | ||||
| 	  file=`cygpath -m "$file" || echo "$file"` | ||||
| 	  ;; | ||||
| 	wine/*) | ||||
| 	  file=`winepath -w "$file" || echo "$file"` | ||||
| 	  ;; | ||||
|       esac | ||||
|       ;; | ||||
|   esac | ||||
| } | ||||
| 
 | ||||
| # func_cl_dashL linkdir | ||||
| # Make cl look for libraries in LINKDIR | ||||
| func_cl_dashL () | ||||
| { | ||||
|   func_file_conv "$1" | ||||
|   if test -z "$lib_path"; then | ||||
|     lib_path=$file | ||||
|   else | ||||
|     lib_path="$lib_path;$file" | ||||
|   fi | ||||
|   linker_opts="$linker_opts -LIBPATH:$file" | ||||
| } | ||||
| 
 | ||||
| # func_cl_dashl library | ||||
| # Do a library search-path lookup for cl | ||||
| func_cl_dashl () | ||||
| { | ||||
|   lib=$1 | ||||
|   found=no | ||||
|   save_IFS=$IFS | ||||
|   IFS=';' | ||||
|   for dir in $lib_path $LIB | ||||
|   do | ||||
|     IFS=$save_IFS | ||||
|     if $shared && test -f "$dir/$lib.dll.lib"; then | ||||
|       found=yes | ||||
|       lib=$dir/$lib.dll.lib | ||||
|       break | ||||
|     fi | ||||
|     if test -f "$dir/$lib.lib"; then | ||||
|       found=yes | ||||
|       lib=$dir/$lib.lib | ||||
|       break | ||||
|     fi | ||||
|     if test -f "$dir/lib$lib.a"; then | ||||
|       found=yes | ||||
|       lib=$dir/lib$lib.a | ||||
|       break | ||||
|     fi | ||||
|   done | ||||
|   IFS=$save_IFS | ||||
| 
 | ||||
|   if test "$found" != yes; then | ||||
|     lib=$lib.lib | ||||
|   fi | ||||
| } | ||||
| 
 | ||||
| # func_cl_wrapper cl arg... | ||||
| # Adjust compile command to suit cl | ||||
| func_cl_wrapper () | ||||
| { | ||||
|   # Assume a capable shell | ||||
|   lib_path= | ||||
|   shared=: | ||||
|   linker_opts= | ||||
|   for arg | ||||
|   do | ||||
|     if test -n "$eat"; then | ||||
|       eat= | ||||
|     else | ||||
|       case $1 in | ||||
| 	-o) | ||||
| 	  # configure might choose to run compile as 'compile cc -o foo foo.c'. | ||||
| 	  eat=1 | ||||
| 	  case $2 in | ||||
| 	    *.o | *.[oO][bB][jJ]) | ||||
| 	      func_file_conv "$2" | ||||
| 	      set x "$@" -Fo"$file" | ||||
| 	      shift | ||||
| 	      ;; | ||||
| 	    *) | ||||
| 	      func_file_conv "$2" | ||||
| 	      set x "$@" -Fe"$file" | ||||
| 	      shift | ||||
| 	      ;; | ||||
| 	  esac | ||||
| 	  ;; | ||||
| 	-I) | ||||
| 	  eat=1 | ||||
| 	  func_file_conv "$2" mingw | ||||
| 	  set x "$@" -I"$file" | ||||
| 	  shift | ||||
| 	  ;; | ||||
| 	-I*) | ||||
| 	  func_file_conv "${1#-I}" mingw | ||||
| 	  set x "$@" -I"$file" | ||||
| 	  shift | ||||
| 	  ;; | ||||
| 	-l) | ||||
| 	  eat=1 | ||||
| 	  func_cl_dashl "$2" | ||||
| 	  set x "$@" "$lib" | ||||
| 	  shift | ||||
| 	  ;; | ||||
| 	-l*) | ||||
| 	  func_cl_dashl "${1#-l}" | ||||
| 	  set x "$@" "$lib" | ||||
| 	  shift | ||||
| 	  ;; | ||||
| 	-L) | ||||
| 	  eat=1 | ||||
| 	  func_cl_dashL "$2" | ||||
| 	  ;; | ||||
| 	-L*) | ||||
| 	  func_cl_dashL "${1#-L}" | ||||
| 	  ;; | ||||
| 	-static) | ||||
| 	  shared=false | ||||
| 	  ;; | ||||
| 	-Wl,*) | ||||
| 	  arg=${1#-Wl,} | ||||
| 	  save_ifs="$IFS"; IFS=',' | ||||
| 	  for flag in $arg; do | ||||
| 	    IFS="$save_ifs" | ||||
| 	    linker_opts="$linker_opts $flag" | ||||
| 	  done | ||||
| 	  IFS="$save_ifs" | ||||
| 	  ;; | ||||
| 	-Xlinker) | ||||
| 	  eat=1 | ||||
| 	  linker_opts="$linker_opts $2" | ||||
| 	  ;; | ||||
| 	-*) | ||||
| 	  set x "$@" "$1" | ||||
| 	  shift | ||||
| 	  ;; | ||||
| 	*.cc | *.CC | *.cxx | *.CXX | *.[cC]++) | ||||
| 	  func_file_conv "$1" | ||||
| 	  set x "$@" -Tp"$file" | ||||
| 	  shift | ||||
| 	  ;; | ||||
| 	*.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO]) | ||||
| 	  func_file_conv "$1" mingw | ||||
| 	  set x "$@" "$file" | ||||
| 	  shift | ||||
| 	  ;; | ||||
| 	*) | ||||
| 	  set x "$@" "$1" | ||||
| 	  shift | ||||
| 	  ;; | ||||
|       esac | ||||
|     fi | ||||
|     shift | ||||
|   done | ||||
|   if test -n "$linker_opts"; then | ||||
|     linker_opts="-link$linker_opts" | ||||
|   fi | ||||
|   exec "$@" $linker_opts | ||||
|   exit 1 | ||||
| } | ||||
| 
 | ||||
| eat= | ||||
| 
 | ||||
| case $1 in | ||||
|   '') | ||||
|      echo "$0: No command.  Try '$0 --help' for more information." 1>&2 | ||||
|      exit 1; | ||||
|      ;; | ||||
|   -h | --h*) | ||||
|     cat <<\EOF | ||||
| Usage: compile [--help] [--version] PROGRAM [ARGS] | ||||
| 
 | ||||
| Wrapper for compilers which do not understand '-c -o'. | ||||
| Remove '-o dest.o' from ARGS, run PROGRAM with the remaining | ||||
| arguments, and rename the output as expected. | ||||
| 
 | ||||
| If you are trying to build a whole package this is not the | ||||
| right script to run: please start by reading the file 'INSTALL'. | ||||
| 
 | ||||
| Report bugs to <bug-automake@gnu.org>. | ||||
| EOF | ||||
|     exit $? | ||||
|     ;; | ||||
|   -v | --v*) | ||||
|     echo "compile $scriptversion" | ||||
|     exit $? | ||||
|     ;; | ||||
|   cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \ | ||||
|   icl | *[/\\]icl | icl.exe | *[/\\]icl.exe ) | ||||
|     func_cl_wrapper "$@"      # Doesn't return... | ||||
|     ;; | ||||
| esac | ||||
| 
 | ||||
| ofile= | ||||
| cfile= | ||||
| 
 | ||||
| for arg | ||||
| do | ||||
|   if test -n "$eat"; then | ||||
|     eat= | ||||
|   else | ||||
|     case $1 in | ||||
|       -o) | ||||
| 	# configure might choose to run compile as 'compile cc -o foo foo.c'. | ||||
| 	# So we strip '-o arg' only if arg is an object. | ||||
| 	eat=1 | ||||
| 	case $2 in | ||||
| 	  *.o | *.obj) | ||||
| 	    ofile=$2 | ||||
| 	    ;; | ||||
| 	  *) | ||||
| 	    set x "$@" -o "$2" | ||||
| 	    shift | ||||
| 	    ;; | ||||
| 	esac | ||||
| 	;; | ||||
|       *.c) | ||||
| 	cfile=$1 | ||||
| 	set x "$@" "$1" | ||||
| 	shift | ||||
| 	;; | ||||
|       *) | ||||
| 	set x "$@" "$1" | ||||
| 	shift | ||||
| 	;; | ||||
|     esac | ||||
|   fi | ||||
|   shift | ||||
| done | ||||
| 
 | ||||
| if test -z "$ofile" || test -z "$cfile"; then | ||||
|   # If no '-o' option was seen then we might have been invoked from a | ||||
|   # pattern rule where we don't need one.  That is ok -- this is a | ||||
|   # normal compilation that the losing compiler can handle.  If no | ||||
|   # '.c' file was seen then we are probably linking.  That is also | ||||
|   # ok. | ||||
|   exec "$@" | ||||
| fi | ||||
| 
 | ||||
| # Name of file we expect compiler to create. | ||||
| cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'` | ||||
| 
 | ||||
| # Create the lock directory. | ||||
| # Note: use '[/\\:.-]' here to ensure that we don't use the same name | ||||
| # that we are using for the .o file.  Also, base the name on the expected | ||||
| # object file name, since that is what matters with a parallel build. | ||||
| lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d | ||||
| while true; do | ||||
|   if mkdir "$lockdir" >/dev/null 2>&1; then | ||||
|     break | ||||
|   fi | ||||
|   sleep 1 | ||||
| done | ||||
| # FIXME: race condition here if user kills between mkdir and trap. | ||||
| trap "rmdir '$lockdir'; exit 1" 1 2 15 | ||||
| 
 | ||||
| # Run the compile. | ||||
| "$@" | ||||
| ret=$? | ||||
| 
 | ||||
| if test -f "$cofile"; then | ||||
|   test "$cofile" = "$ofile" || mv "$cofile" "$ofile" | ||||
| elif test -f "${cofile}bj"; then | ||||
|   test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile" | ||||
| fi | ||||
| 
 | ||||
| rmdir "$lockdir" | ||||
| exit $ret | ||||
| 
 | ||||
| # Local Variables: | ||||
| # mode: shell-script | ||||
| # sh-indentation: 2 | ||||
| # eval: (add-hook 'before-save-hook 'time-stamp) | ||||
| # time-stamp-start: "scriptversion=" | ||||
| # time-stamp-format: "%:y-%02m-%02d.%02H" | ||||
| # time-stamp-time-zone: "UTC0" | ||||
| # time-stamp-end: "; # UTC" | ||||
| # End: | ||||
							
								
								
									
										1667
									
								
								third_party/make/build-aux/config.guess
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										1667
									
								
								third_party/make/build-aux/config.guess
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										684
									
								
								third_party/make/build-aux/config.rpath
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										684
									
								
								third_party/make/build-aux/config.rpath
									
										
									
									
										vendored
									
									
										Executable file
									
								
							|  | @ -0,0 +1,684 @@ | |||
| #! /bin/sh | ||||
| # Output a system dependent set of variables, describing how to set the | ||||
| # run time search path of shared libraries in an executable. | ||||
| # | ||||
| #   Copyright 1996-2014 Free Software Foundation, Inc. | ||||
| #   Taken from GNU libtool, 2001 | ||||
| #   Originally by Gordon Matzigkeit <gord@gnu.ai.mit.edu>, 1996 | ||||
| # | ||||
| #   This file is free software; the Free Software Foundation gives | ||||
| #   unlimited permission to copy and/or distribute it, with or without | ||||
| #   modifications, as long as this notice is preserved. | ||||
| # | ||||
| # The first argument passed to this file is the canonical host specification, | ||||
| #    CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM | ||||
| # or | ||||
| #    CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM | ||||
| # The environment variables CC, GCC, LDFLAGS, LD, with_gnu_ld | ||||
| # should be set by the caller. | ||||
| # | ||||
| # The set of defined variables is at the end of this script. | ||||
| 
 | ||||
| # Known limitations: | ||||
| # - On IRIX 6.5 with CC="cc", the run time search patch must not be longer | ||||
| #   than 256 bytes, otherwise the compiler driver will dump core. The only | ||||
| #   known workaround is to choose shorter directory names for the build | ||||
| #   directory and/or the installation directory. | ||||
| 
 | ||||
| # All known linkers require a '.a' archive for static linking (except MSVC, | ||||
| # which needs '.lib'). | ||||
| libext=a | ||||
| shrext=.so | ||||
| 
 | ||||
| host="$1" | ||||
| host_cpu=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'` | ||||
| host_vendor=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\2/'` | ||||
| host_os=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'` | ||||
| 
 | ||||
| # Code taken from libtool.m4's _LT_CC_BASENAME. | ||||
| 
 | ||||
| for cc_temp in $CC""; do | ||||
|   case $cc_temp in | ||||
|     compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; | ||||
|     distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; | ||||
|     \-*) ;; | ||||
|     *) break;; | ||||
|   esac | ||||
| done | ||||
| cc_basename=`echo "$cc_temp" | sed -e 's%^.*/%%'` | ||||
| 
 | ||||
| # Code taken from libtool.m4's _LT_COMPILER_PIC. | ||||
| 
 | ||||
| wl= | ||||
| if test "$GCC" = yes; then | ||||
|   wl='-Wl,' | ||||
| else | ||||
|   case "$host_os" in | ||||
|     aix*) | ||||
|       wl='-Wl,' | ||||
|       ;; | ||||
|     mingw* | cygwin* | pw32* | os2* | cegcc*) | ||||
|       ;; | ||||
|     hpux9* | hpux10* | hpux11*) | ||||
|       wl='-Wl,' | ||||
|       ;; | ||||
|     irix5* | irix6* | nonstopux*) | ||||
|       wl='-Wl,' | ||||
|       ;; | ||||
|     linux* | k*bsd*-gnu | kopensolaris*-gnu) | ||||
|       case $cc_basename in | ||||
|         ecc*) | ||||
|           wl='-Wl,' | ||||
|           ;; | ||||
|         icc* | ifort*) | ||||
|           wl='-Wl,' | ||||
|           ;; | ||||
|         lf95*) | ||||
|           wl='-Wl,' | ||||
|           ;; | ||||
|         nagfor*) | ||||
|           wl='-Wl,-Wl,,' | ||||
|           ;; | ||||
|         pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) | ||||
|           wl='-Wl,' | ||||
|           ;; | ||||
|         ccc*) | ||||
|           wl='-Wl,' | ||||
|           ;; | ||||
|         xl* | bgxl* | bgf* | mpixl*) | ||||
|           wl='-Wl,' | ||||
|           ;; | ||||
|         como) | ||||
|           wl='-lopt=' | ||||
|           ;; | ||||
|         *) | ||||
|           case `$CC -V 2>&1 | sed 5q` in | ||||
|             *Sun\ F* | *Sun*Fortran*) | ||||
|               wl= | ||||
|               ;; | ||||
|             *Sun\ C*) | ||||
|               wl='-Wl,' | ||||
|               ;; | ||||
|           esac | ||||
|           ;; | ||||
|       esac | ||||
|       ;; | ||||
|     newsos6) | ||||
|       ;; | ||||
|     *nto* | *qnx*) | ||||
|       ;; | ||||
|     osf3* | osf4* | osf5*) | ||||
|       wl='-Wl,' | ||||
|       ;; | ||||
|     rdos*) | ||||
|       ;; | ||||
|     solaris*) | ||||
|       case $cc_basename in | ||||
|         f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) | ||||
|           wl='-Qoption ld ' | ||||
|           ;; | ||||
|         *) | ||||
|           wl='-Wl,' | ||||
|           ;; | ||||
|       esac | ||||
|       ;; | ||||
|     sunos4*) | ||||
|       wl='-Qoption ld ' | ||||
|       ;; | ||||
|     sysv4 | sysv4.2uw2* | sysv4.3*) | ||||
|       wl='-Wl,' | ||||
|       ;; | ||||
|     sysv4*MP*) | ||||
|       ;; | ||||
|     sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) | ||||
|       wl='-Wl,' | ||||
|       ;; | ||||
|     unicos*) | ||||
|       wl='-Wl,' | ||||
|       ;; | ||||
|     uts4*) | ||||
|       ;; | ||||
|   esac | ||||
| fi | ||||
| 
 | ||||
| # Code taken from libtool.m4's _LT_LINKER_SHLIBS. | ||||
| 
 | ||||
| hardcode_libdir_flag_spec= | ||||
| hardcode_libdir_separator= | ||||
| hardcode_direct=no | ||||
| hardcode_minus_L=no | ||||
| 
 | ||||
| case "$host_os" in | ||||
|   cygwin* | mingw* | pw32* | cegcc*) | ||||
|     # FIXME: the MSVC++ port hasn't been tested in a loooong time | ||||
|     # When not using gcc, we currently assume that we are using | ||||
|     # Microsoft Visual C++. | ||||
|     if test "$GCC" != yes; then | ||||
|       with_gnu_ld=no | ||||
|     fi | ||||
|     ;; | ||||
|   interix*) | ||||
|     # we just hope/assume this is gcc and not c89 (= MSVC++) | ||||
|     with_gnu_ld=yes | ||||
|     ;; | ||||
|   openbsd*) | ||||
|     with_gnu_ld=no | ||||
|     ;; | ||||
| esac | ||||
| 
 | ||||
| ld_shlibs=yes | ||||
| if test "$with_gnu_ld" = yes; then | ||||
|   # Set some defaults for GNU ld with shared library support. These | ||||
|   # are reset later if shared libraries are not supported. Putting them | ||||
|   # here allows them to be overridden if necessary. | ||||
|   # Unlike libtool, we use -rpath here, not --rpath, since the documented | ||||
|   # option of GNU ld is called -rpath, not --rpath. | ||||
|   hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' | ||||
|   case "$host_os" in | ||||
|     aix[3-9]*) | ||||
|       # On AIX/PPC, the GNU linker is very broken | ||||
|       if test "$host_cpu" != ia64; then | ||||
|         ld_shlibs=no | ||||
|       fi | ||||
|       ;; | ||||
|     amigaos*) | ||||
|       case "$host_cpu" in | ||||
|         powerpc) | ||||
|           ;; | ||||
|         m68k) | ||||
|           hardcode_libdir_flag_spec='-L$libdir' | ||||
|           hardcode_minus_L=yes | ||||
|           ;; | ||||
|       esac | ||||
|       ;; | ||||
|     beos*) | ||||
|       if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then | ||||
|         : | ||||
|       else | ||||
|         ld_shlibs=no | ||||
|       fi | ||||
|       ;; | ||||
|     cygwin* | mingw* | pw32* | cegcc*) | ||||
|       # hardcode_libdir_flag_spec is actually meaningless, as there is | ||||
|       # no search path for DLLs. | ||||
|       hardcode_libdir_flag_spec='-L$libdir' | ||||
|       if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then | ||||
|         : | ||||
|       else | ||||
|         ld_shlibs=no | ||||
|       fi | ||||
|       ;; | ||||
|     haiku*) | ||||
|       ;; | ||||
|     interix[3-9]*) | ||||
|       hardcode_direct=no | ||||
|       hardcode_libdir_flag_spec='${wl}-rpath,$libdir' | ||||
|       ;; | ||||
|     gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) | ||||
|       if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then | ||||
|         : | ||||
|       else | ||||
|         ld_shlibs=no | ||||
|       fi | ||||
|       ;; | ||||
|     netbsd*) | ||||
|       ;; | ||||
|     solaris*) | ||||
|       if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then | ||||
|         ld_shlibs=no | ||||
|       elif $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then | ||||
|         : | ||||
|       else | ||||
|         ld_shlibs=no | ||||
|       fi | ||||
|       ;; | ||||
|     sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) | ||||
|       case `$LD -v 2>&1` in | ||||
|         *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*) | ||||
|           ld_shlibs=no | ||||
|           ;; | ||||
|         *) | ||||
|           if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then | ||||
|             hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-rpath,$libdir`' | ||||
|           else | ||||
|             ld_shlibs=no | ||||
|           fi | ||||
|           ;; | ||||
|       esac | ||||
|       ;; | ||||
|     sunos4*) | ||||
|       hardcode_direct=yes | ||||
|       ;; | ||||
|     *) | ||||
|       if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then | ||||
|         : | ||||
|       else | ||||
|         ld_shlibs=no | ||||
|       fi | ||||
|       ;; | ||||
|   esac | ||||
|   if test "$ld_shlibs" = no; then | ||||
|     hardcode_libdir_flag_spec= | ||||
|   fi | ||||
| else | ||||
|   case "$host_os" in | ||||
|     aix3*) | ||||
|       # Note: this linker hardcodes the directories in LIBPATH if there | ||||
|       # are no directories specified by -L. | ||||
|       hardcode_minus_L=yes | ||||
|       if test "$GCC" = yes; then | ||||
|         # Neither direct hardcoding nor static linking is supported with a | ||||
|         # broken collect2. | ||||
|         hardcode_direct=unsupported | ||||
|       fi | ||||
|       ;; | ||||
|     aix[4-9]*) | ||||
|       if test "$host_cpu" = ia64; then | ||||
|         # On IA64, the linker does run time linking by default, so we don't | ||||
|         # have to do anything special. | ||||
|         aix_use_runtimelinking=no | ||||
|       else | ||||
|         aix_use_runtimelinking=no | ||||
|         # Test if we are trying to use run time linking or normal | ||||
|         # AIX style linking. If -brtl is somewhere in LDFLAGS, we | ||||
|         # need to do runtime linking. | ||||
|         case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) | ||||
|           for ld_flag in $LDFLAGS; do | ||||
|             if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then | ||||
|               aix_use_runtimelinking=yes | ||||
|               break | ||||
|             fi | ||||
|           done | ||||
|           ;; | ||||
|         esac | ||||
|       fi | ||||
|       hardcode_direct=yes | ||||
|       hardcode_libdir_separator=':' | ||||
|       if test "$GCC" = yes; then | ||||
|         case $host_os in aix4.[012]|aix4.[012].*) | ||||
|           collect2name=`${CC} -print-prog-name=collect2` | ||||
|           if test -f "$collect2name" && \ | ||||
|             strings "$collect2name" | grep resolve_lib_name >/dev/null | ||||
|           then | ||||
|             # We have reworked collect2 | ||||
|             : | ||||
|           else | ||||
|             # We have old collect2 | ||||
|             hardcode_direct=unsupported | ||||
|             hardcode_minus_L=yes | ||||
|             hardcode_libdir_flag_spec='-L$libdir' | ||||
|             hardcode_libdir_separator= | ||||
|           fi | ||||
|           ;; | ||||
|         esac | ||||
|       fi | ||||
|       # Begin _LT_AC_SYS_LIBPATH_AIX. | ||||
|       echo 'int main () { return 0; }' > conftest.c | ||||
|       ${CC} ${LDFLAGS} conftest.c -o conftest | ||||
|       aix_libpath=`dump -H conftest 2>/dev/null | sed -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0  *\(.*\)$/\1/; p; } | ||||
| }'` | ||||
|       if test -z "$aix_libpath"; then | ||||
|         aix_libpath=`dump -HX64 conftest 2>/dev/null | sed -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0  *\(.*\)$/\1/; p; } | ||||
| }'` | ||||
|       fi | ||||
|       if test -z "$aix_libpath"; then | ||||
|         aix_libpath="/usr/lib:/lib" | ||||
|       fi | ||||
|       rm -f conftest.c conftest | ||||
|       # End _LT_AC_SYS_LIBPATH_AIX. | ||||
|       if test "$aix_use_runtimelinking" = yes; then | ||||
|         hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" | ||||
|       else | ||||
|         if test "$host_cpu" = ia64; then | ||||
|           hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib' | ||||
|         else | ||||
|           hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" | ||||
|         fi | ||||
|       fi | ||||
|       ;; | ||||
|     amigaos*) | ||||
|       case "$host_cpu" in | ||||
|         powerpc) | ||||
|           ;; | ||||
|         m68k) | ||||
|           hardcode_libdir_flag_spec='-L$libdir' | ||||
|           hardcode_minus_L=yes | ||||
|           ;; | ||||
|       esac | ||||
|       ;; | ||||
|     bsdi[45]*) | ||||
|       ;; | ||||
|     cygwin* | mingw* | pw32* | cegcc*) | ||||
|       # When not using gcc, we currently assume that we are using | ||||
|       # Microsoft Visual C++. | ||||
|       # hardcode_libdir_flag_spec is actually meaningless, as there is | ||||
|       # no search path for DLLs. | ||||
|       hardcode_libdir_flag_spec=' ' | ||||
|       libext=lib | ||||
|       ;; | ||||
|     darwin* | rhapsody*) | ||||
|       hardcode_direct=no | ||||
|       if { case $cc_basename in ifort*) true;; *) test "$GCC" = yes;; esac; }; then | ||||
|         : | ||||
|       else | ||||
|         ld_shlibs=no | ||||
|       fi | ||||
|       ;; | ||||
|     dgux*) | ||||
|       hardcode_libdir_flag_spec='-L$libdir' | ||||
|       ;; | ||||
|     freebsd2.[01]*) | ||||
|       hardcode_direct=yes | ||||
|       hardcode_minus_L=yes | ||||
|       ;; | ||||
|     freebsd* | dragonfly*) | ||||
|       hardcode_libdir_flag_spec='-R$libdir' | ||||
|       hardcode_direct=yes | ||||
|       ;; | ||||
|     hpux9*) | ||||
|       hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' | ||||
|       hardcode_libdir_separator=: | ||||
|       hardcode_direct=yes | ||||
|       # hardcode_minus_L: Not really in the search PATH, | ||||
|       # but as the default location of the library. | ||||
|       hardcode_minus_L=yes | ||||
|       ;; | ||||
|     hpux10*) | ||||
|       if test "$with_gnu_ld" = no; then | ||||
|         hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' | ||||
|         hardcode_libdir_separator=: | ||||
|         hardcode_direct=yes | ||||
|         # hardcode_minus_L: Not really in the search PATH, | ||||
|         # but as the default location of the library. | ||||
|         hardcode_minus_L=yes | ||||
|       fi | ||||
|       ;; | ||||
|     hpux11*) | ||||
|       if test "$with_gnu_ld" = no; then | ||||
|         hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' | ||||
|         hardcode_libdir_separator=: | ||||
|         case $host_cpu in | ||||
|           hppa*64*|ia64*) | ||||
|             hardcode_direct=no | ||||
|             ;; | ||||
|           *) | ||||
|             hardcode_direct=yes | ||||
|             # hardcode_minus_L: Not really in the search PATH, | ||||
|             # but as the default location of the library. | ||||
|             hardcode_minus_L=yes | ||||
|             ;; | ||||
|         esac | ||||
|       fi | ||||
|       ;; | ||||
|     irix5* | irix6* | nonstopux*) | ||||
|       hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' | ||||
|       hardcode_libdir_separator=: | ||||
|       ;; | ||||
|     netbsd*) | ||||
|       hardcode_libdir_flag_spec='-R$libdir' | ||||
|       hardcode_direct=yes | ||||
|       ;; | ||||
|     newsos6) | ||||
|       hardcode_direct=yes | ||||
|       hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' | ||||
|       hardcode_libdir_separator=: | ||||
|       ;; | ||||
|     *nto* | *qnx*) | ||||
|       ;; | ||||
|     openbsd*) | ||||
|       if test -f /usr/libexec/ld.so; then | ||||
|         hardcode_direct=yes | ||||
|         if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then | ||||
|           hardcode_libdir_flag_spec='${wl}-rpath,$libdir' | ||||
|         else | ||||
|           case "$host_os" in | ||||
|             openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*) | ||||
|               hardcode_libdir_flag_spec='-R$libdir' | ||||
|               ;; | ||||
|             *) | ||||
|               hardcode_libdir_flag_spec='${wl}-rpath,$libdir' | ||||
|               ;; | ||||
|           esac | ||||
|         fi | ||||
|       else | ||||
|         ld_shlibs=no | ||||
|       fi | ||||
|       ;; | ||||
|     os2*) | ||||
|       hardcode_libdir_flag_spec='-L$libdir' | ||||
|       hardcode_minus_L=yes | ||||
|       ;; | ||||
|     osf3*) | ||||
|       hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' | ||||
|       hardcode_libdir_separator=: | ||||
|       ;; | ||||
|     osf4* | osf5*) | ||||
|       if test "$GCC" = yes; then | ||||
|         hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' | ||||
|       else | ||||
|         # Both cc and cxx compiler support -rpath directly | ||||
|         hardcode_libdir_flag_spec='-rpath $libdir' | ||||
|       fi | ||||
|       hardcode_libdir_separator=: | ||||
|       ;; | ||||
|     solaris*) | ||||
|       hardcode_libdir_flag_spec='-R$libdir' | ||||
|       ;; | ||||
|     sunos4*) | ||||
|       hardcode_libdir_flag_spec='-L$libdir' | ||||
|       hardcode_direct=yes | ||||
|       hardcode_minus_L=yes | ||||
|       ;; | ||||
|     sysv4) | ||||
|       case $host_vendor in | ||||
|         sni) | ||||
|           hardcode_direct=yes # is this really true??? | ||||
|           ;; | ||||
|         siemens) | ||||
|           hardcode_direct=no | ||||
|           ;; | ||||
|         motorola) | ||||
|           hardcode_direct=no #Motorola manual says yes, but my tests say they lie | ||||
|           ;; | ||||
|       esac | ||||
|       ;; | ||||
|     sysv4.3*) | ||||
|       ;; | ||||
|     sysv4*MP*) | ||||
|       if test -d /usr/nec; then | ||||
|         ld_shlibs=yes | ||||
|       fi | ||||
|       ;; | ||||
|     sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) | ||||
|       ;; | ||||
|     sysv5* | sco3.2v5* | sco5v6*) | ||||
|       hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-R,$libdir`' | ||||
|       hardcode_libdir_separator=':' | ||||
|       ;; | ||||
|     uts4*) | ||||
|       hardcode_libdir_flag_spec='-L$libdir' | ||||
|       ;; | ||||
|     *) | ||||
|       ld_shlibs=no | ||||
|       ;; | ||||
|   esac | ||||
| fi | ||||
| 
 | ||||
| # Check dynamic linker characteristics | ||||
| # Code taken from libtool.m4's _LT_SYS_DYNAMIC_LINKER. | ||||
| # Unlike libtool.m4, here we don't care about _all_ names of the library, but | ||||
| # only about the one the linker finds when passed -lNAME. This is the last | ||||
| # element of library_names_spec in libtool.m4, or possibly two of them if the | ||||
| # linker has special search rules. | ||||
| library_names_spec=      # the last element of library_names_spec in libtool.m4 | ||||
| libname_spec='lib$name' | ||||
| case "$host_os" in | ||||
|   aix3*) | ||||
|     library_names_spec='$libname.a' | ||||
|     ;; | ||||
|   aix[4-9]*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   amigaos*) | ||||
|     case "$host_cpu" in | ||||
|       powerpc*) | ||||
|         library_names_spec='$libname$shrext' ;; | ||||
|       m68k) | ||||
|         library_names_spec='$libname.a' ;; | ||||
|     esac | ||||
|     ;; | ||||
|   beos*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   bsdi[45]*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   cygwin* | mingw* | pw32* | cegcc*) | ||||
|     shrext=.dll | ||||
|     library_names_spec='$libname.dll.a $libname.lib' | ||||
|     ;; | ||||
|   darwin* | rhapsody*) | ||||
|     shrext=.dylib | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   dgux*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   freebsd[23].*) | ||||
|     library_names_spec='$libname$shrext$versuffix' | ||||
|     ;; | ||||
|   freebsd* | dragonfly*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   gnu*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   haiku*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   hpux9* | hpux10* | hpux11*) | ||||
|     case $host_cpu in | ||||
|       ia64*) | ||||
|         shrext=.so | ||||
|         ;; | ||||
|       hppa*64*) | ||||
|         shrext=.sl | ||||
|         ;; | ||||
|       *) | ||||
|         shrext=.sl | ||||
|         ;; | ||||
|     esac | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   interix[3-9]*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   irix5* | irix6* | nonstopux*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     case "$host_os" in | ||||
|       irix5* | nonstopux*) | ||||
|         libsuff= shlibsuff= | ||||
|         ;; | ||||
|       *) | ||||
|         case $LD in | ||||
|           *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= ;; | ||||
|           *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 ;; | ||||
|           *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 ;; | ||||
|           *) libsuff= shlibsuff= ;; | ||||
|         esac | ||||
|         ;; | ||||
|     esac | ||||
|     ;; | ||||
|   linux*oldld* | linux*aout* | linux*coff*) | ||||
|     ;; | ||||
|   linux* | k*bsd*-gnu | kopensolaris*-gnu) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   knetbsd*-gnu) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   netbsd*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   newsos6) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   *nto* | *qnx*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   openbsd*) | ||||
|     library_names_spec='$libname$shrext$versuffix' | ||||
|     ;; | ||||
|   os2*) | ||||
|     libname_spec='$name' | ||||
|     shrext=.dll | ||||
|     library_names_spec='$libname.a' | ||||
|     ;; | ||||
|   osf3* | osf4* | osf5*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   rdos*) | ||||
|     ;; | ||||
|   solaris*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   sunos4*) | ||||
|     library_names_spec='$libname$shrext$versuffix' | ||||
|     ;; | ||||
|   sysv4 | sysv4.3*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   sysv4*MP*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   tpf*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
|   uts4*) | ||||
|     library_names_spec='$libname$shrext' | ||||
|     ;; | ||||
| esac | ||||
| 
 | ||||
| sed_quote_subst='s/\(["`$\\]\)/\\\1/g' | ||||
| escaped_wl=`echo "X$wl" | sed -e 's/^X//' -e "$sed_quote_subst"` | ||||
| shlibext=`echo "$shrext" | sed -e 's,^\.,,'` | ||||
| escaped_libname_spec=`echo "X$libname_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` | ||||
| escaped_library_names_spec=`echo "X$library_names_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` | ||||
| escaped_hardcode_libdir_flag_spec=`echo "X$hardcode_libdir_flag_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` | ||||
| 
 | ||||
| LC_ALL=C sed -e 's/^\([a-zA-Z0-9_]*\)=/acl_cv_\1=/' <<EOF | ||||
| 
 | ||||
| # How to pass a linker flag through the compiler. | ||||
| wl="$escaped_wl" | ||||
| 
 | ||||
| # Static library suffix (normally "a"). | ||||
| libext="$libext" | ||||
| 
 | ||||
| # Shared library suffix (normally "so"). | ||||
| shlibext="$shlibext" | ||||
| 
 | ||||
| # Format of library name prefix. | ||||
| libname_spec="$escaped_libname_spec" | ||||
| 
 | ||||
| # Library names that the linker finds when passed -lNAME. | ||||
| library_names_spec="$escaped_library_names_spec" | ||||
| 
 | ||||
| # Flag to hardcode \$libdir into a binary during linking. | ||||
| # This must work even if \$libdir does not exist. | ||||
| hardcode_libdir_flag_spec="$escaped_hardcode_libdir_flag_spec" | ||||
| 
 | ||||
| # Whether we need a single -rpath flag with a separated argument. | ||||
| hardcode_libdir_separator="$hardcode_libdir_separator" | ||||
| 
 | ||||
| # Set to yes if using DIR/libNAME.so during linking hardcodes DIR into the | ||||
| # resulting binary. | ||||
| hardcode_direct="$hardcode_direct" | ||||
| 
 | ||||
| # Set to yes if using the -LDIR flag during linking hardcodes DIR into the | ||||
| # resulting binary. | ||||
| hardcode_minus_L="$hardcode_minus_L" | ||||
| 
 | ||||
| EOF | ||||
							
								
								
									
										1793
									
								
								third_party/make/build-aux/config.sub
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										1793
									
								
								third_party/make/build-aux/config.sub
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										791
									
								
								third_party/make/build-aux/depcomp
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										791
									
								
								third_party/make/build-aux/depcomp
									
										
									
									
										vendored
									
									
										Executable file
									
								
							|  | @ -0,0 +1,791 @@ | |||
| #! /bin/sh | ||||
| # depcomp - compile a program generating dependencies as side-effects | ||||
| 
 | ||||
| scriptversion=2018-03-07.03; # UTC | ||||
| 
 | ||||
| # Copyright (C) 1999-2019 Free Software Foundation, Inc. | ||||
| 
 | ||||
| # This program is free software; you can redistribute it and/or modify | ||||
| # it under the terms of the GNU General Public License as published by | ||||
| # the Free Software Foundation; either version 2, or (at your option) | ||||
| # any later version. | ||||
| 
 | ||||
| # This program is distributed in the hope that it will be useful, | ||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| # GNU General Public License for more details. | ||||
| 
 | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| # As a special exception to the GNU General Public License, if you | ||||
| # distribute this file as part of a program that contains a | ||||
| # configuration script generated by Autoconf, you may include it under | ||||
| # the same distribution terms that you use for the rest of that program. | ||||
| 
 | ||||
| # Originally written by Alexandre Oliva <oliva@dcc.unicamp.br>. | ||||
| 
 | ||||
| case $1 in | ||||
|   '') | ||||
|     echo "$0: No command.  Try '$0 --help' for more information." 1>&2 | ||||
|     exit 1; | ||||
|     ;; | ||||
|   -h | --h*) | ||||
|     cat <<\EOF | ||||
| Usage: depcomp [--help] [--version] PROGRAM [ARGS] | ||||
| 
 | ||||
| Run PROGRAMS ARGS to compile a file, generating dependencies | ||||
| as side-effects. | ||||
| 
 | ||||
| Environment variables: | ||||
|   depmode     Dependency tracking mode. | ||||
|   source      Source file read by 'PROGRAMS ARGS'. | ||||
|   object      Object file output by 'PROGRAMS ARGS'. | ||||
|   DEPDIR      directory where to store dependencies. | ||||
|   depfile     Dependency file to output. | ||||
|   tmpdepfile  Temporary file to use when outputting dependencies. | ||||
|   libtool     Whether libtool is used (yes/no). | ||||
| 
 | ||||
| Report bugs to <bug-automake@gnu.org>. | ||||
| EOF | ||||
|     exit $? | ||||
|     ;; | ||||
|   -v | --v*) | ||||
|     echo "depcomp $scriptversion" | ||||
|     exit $? | ||||
|     ;; | ||||
| esac | ||||
| 
 | ||||
| # Get the directory component of the given path, and save it in the | ||||
| # global variables '$dir'.  Note that this directory component will | ||||
| # be either empty or ending with a '/' character.  This is deliberate. | ||||
| set_dir_from () | ||||
| { | ||||
|   case $1 in | ||||
|     */*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;; | ||||
|       *) dir=;; | ||||
|   esac | ||||
| } | ||||
| 
 | ||||
| # Get the suffix-stripped basename of the given path, and save it the | ||||
| # global variable '$base'. | ||||
| set_base_from () | ||||
| { | ||||
|   base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'` | ||||
| } | ||||
| 
 | ||||
| # If no dependency file was actually created by the compiler invocation, | ||||
| # we still have to create a dummy depfile, to avoid errors with the | ||||
| # Makefile "include basename.Plo" scheme. | ||||
| make_dummy_depfile () | ||||
| { | ||||
|   echo "#dummy" > "$depfile" | ||||
| } | ||||
| 
 | ||||
| # Factor out some common post-processing of the generated depfile. | ||||
| # Requires the auxiliary global variable '$tmpdepfile' to be set. | ||||
| aix_post_process_depfile () | ||||
| { | ||||
|   # If the compiler actually managed to produce a dependency file, | ||||
|   # post-process it. | ||||
|   if test -f "$tmpdepfile"; then | ||||
|     # Each line is of the form 'foo.o: dependency.h'. | ||||
|     # Do two passes, one to just change these to | ||||
|     #   $object: dependency.h | ||||
|     # and one to simply output | ||||
|     #   dependency.h: | ||||
|     # which is needed to avoid the deleted-header problem. | ||||
|     { sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile" | ||||
|       sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile" | ||||
|     } > "$depfile" | ||||
|     rm -f "$tmpdepfile" | ||||
|   else | ||||
|     make_dummy_depfile | ||||
|   fi | ||||
| } | ||||
| 
 | ||||
| # A tabulation character. | ||||
| tab='	' | ||||
| # A newline character. | ||||
| nl=' | ||||
| ' | ||||
| # Character ranges might be problematic outside the C locale. | ||||
| # These definitions help. | ||||
| upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ | ||||
| lower=abcdefghijklmnopqrstuvwxyz | ||||
| digits=0123456789 | ||||
| alpha=${upper}${lower} | ||||
| 
 | ||||
| if test -z "$depmode" || test -z "$source" || test -z "$object"; then | ||||
|   echo "depcomp: Variables source, object and depmode must be set" 1>&2 | ||||
|   exit 1 | ||||
| fi | ||||
| 
 | ||||
| # Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. | ||||
| depfile=${depfile-`echo "$object" | | ||||
|   sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} | ||||
| tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} | ||||
| 
 | ||||
| rm -f "$tmpdepfile" | ||||
| 
 | ||||
| # Avoid interferences from the environment. | ||||
| gccflag= dashmflag= | ||||
| 
 | ||||
| # Some modes work just like other modes, but use different flags.  We | ||||
| # parameterize here, but still list the modes in the big case below, | ||||
| # to make depend.m4 easier to write.  Note that we *cannot* use a case | ||||
| # here, because this file can only contain one case statement. | ||||
| if test "$depmode" = hp; then | ||||
|   # HP compiler uses -M and no extra arg. | ||||
|   gccflag=-M | ||||
|   depmode=gcc | ||||
| fi | ||||
| 
 | ||||
| if test "$depmode" = dashXmstdout; then | ||||
|   # This is just like dashmstdout with a different argument. | ||||
|   dashmflag=-xM | ||||
|   depmode=dashmstdout | ||||
| fi | ||||
| 
 | ||||
| cygpath_u="cygpath -u -f -" | ||||
| if test "$depmode" = msvcmsys; then | ||||
|   # This is just like msvisualcpp but w/o cygpath translation. | ||||
|   # Just convert the backslash-escaped backslashes to single forward | ||||
|   # slashes to satisfy depend.m4 | ||||
|   cygpath_u='sed s,\\\\,/,g' | ||||
|   depmode=msvisualcpp | ||||
| fi | ||||
| 
 | ||||
| if test "$depmode" = msvc7msys; then | ||||
|   # This is just like msvc7 but w/o cygpath translation. | ||||
|   # Just convert the backslash-escaped backslashes to single forward | ||||
|   # slashes to satisfy depend.m4 | ||||
|   cygpath_u='sed s,\\\\,/,g' | ||||
|   depmode=msvc7 | ||||
| fi | ||||
| 
 | ||||
| if test "$depmode" = xlc; then | ||||
|   # IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information. | ||||
|   gccflag=-qmakedep=gcc,-MF | ||||
|   depmode=gcc | ||||
| fi | ||||
| 
 | ||||
| case "$depmode" in | ||||
| gcc3) | ||||
| ## gcc 3 implements dependency tracking that does exactly what | ||||
| ## we want.  Yay!  Note: for some reason libtool 1.4 doesn't like | ||||
| ## it if -MD -MP comes after the -MF stuff.  Hmm. | ||||
| ## Unfortunately, FreeBSD c89 acceptance of flags depends upon | ||||
| ## the command line argument order; so add the flags where they | ||||
| ## appear in depend2.am.  Note that the slowdown incurred here | ||||
| ## affects only configure: in makefiles, %FASTDEP% shortcuts this. | ||||
|   for arg | ||||
|   do | ||||
|     case $arg in | ||||
|     -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; | ||||
|     *)  set fnord "$@" "$arg" ;; | ||||
|     esac | ||||
|     shift # fnord | ||||
|     shift # $arg | ||||
|   done | ||||
|   "$@" | ||||
|   stat=$? | ||||
|   if test $stat -ne 0; then | ||||
|     rm -f "$tmpdepfile" | ||||
|     exit $stat | ||||
|   fi | ||||
|   mv "$tmpdepfile" "$depfile" | ||||
|   ;; | ||||
| 
 | ||||
| gcc) | ||||
| ## Note that this doesn't just cater to obsosete pre-3.x GCC compilers. | ||||
| ## but also to in-use compilers like IMB xlc/xlC and the HP C compiler. | ||||
| ## (see the conditional assignment to $gccflag above). | ||||
| ## There are various ways to get dependency output from gcc.  Here's | ||||
| ## why we pick this rather obscure method: | ||||
| ## - Don't want to use -MD because we'd like the dependencies to end | ||||
| ##   up in a subdir.  Having to rename by hand is ugly. | ||||
| ##   (We might end up doing this anyway to support other compilers.) | ||||
| ## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like | ||||
| ##   -MM, not -M (despite what the docs say).  Also, it might not be | ||||
| ##   supported by the other compilers which use the 'gcc' depmode. | ||||
| ## - Using -M directly means running the compiler twice (even worse | ||||
| ##   than renaming). | ||||
|   if test -z "$gccflag"; then | ||||
|     gccflag=-MD, | ||||
|   fi | ||||
|   "$@" -Wp,"$gccflag$tmpdepfile" | ||||
|   stat=$? | ||||
|   if test $stat -ne 0; then | ||||
|     rm -f "$tmpdepfile" | ||||
|     exit $stat | ||||
|   fi | ||||
|   rm -f "$depfile" | ||||
|   echo "$object : \\" > "$depfile" | ||||
|   # The second -e expression handles DOS-style file names with drive | ||||
|   # letters. | ||||
|   sed -e 's/^[^:]*: / /' \ | ||||
|       -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" | ||||
| ## This next piece of magic avoids the "deleted header file" problem. | ||||
| ## The problem is that when a header file which appears in a .P file | ||||
| ## is deleted, the dependency causes make to die (because there is | ||||
| ## typically no way to rebuild the header).  We avoid this by adding | ||||
| ## dummy dependencies for each header file.  Too bad gcc doesn't do | ||||
| ## this for us directly. | ||||
| ## Some versions of gcc put a space before the ':'.  On the theory | ||||
| ## that the space means something, we add a space to the output as | ||||
| ## well.  hp depmode also adds that space, but also prefixes the VPATH | ||||
| ## to the object.  Take care to not repeat it in the output. | ||||
| ## Some versions of the HPUX 10.20 sed can't process this invocation | ||||
| ## correctly.  Breaking it into two sed invocations is a workaround. | ||||
|   tr ' ' "$nl" < "$tmpdepfile" \ | ||||
|     | sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \ | ||||
|     | sed -e 's/$/ :/' >> "$depfile" | ||||
|   rm -f "$tmpdepfile" | ||||
|   ;; | ||||
| 
 | ||||
| hp) | ||||
|   # This case exists only to let depend.m4 do its work.  It works by | ||||
|   # looking at the text of this script.  This case will never be run, | ||||
|   # since it is checked for above. | ||||
|   exit 1 | ||||
|   ;; | ||||
| 
 | ||||
| sgi) | ||||
|   if test "$libtool" = yes; then | ||||
|     "$@" "-Wp,-MDupdate,$tmpdepfile" | ||||
|   else | ||||
|     "$@" -MDupdate "$tmpdepfile" | ||||
|   fi | ||||
|   stat=$? | ||||
|   if test $stat -ne 0; then | ||||
|     rm -f "$tmpdepfile" | ||||
|     exit $stat | ||||
|   fi | ||||
|   rm -f "$depfile" | ||||
| 
 | ||||
|   if test -f "$tmpdepfile"; then  # yes, the sourcefile depend on other files | ||||
|     echo "$object : \\" > "$depfile" | ||||
|     # Clip off the initial element (the dependent).  Don't try to be | ||||
|     # clever and replace this with sed code, as IRIX sed won't handle | ||||
|     # lines with more than a fixed number of characters (4096 in | ||||
|     # IRIX 6.2 sed, 8192 in IRIX 6.5).  We also remove comment lines; | ||||
|     # the IRIX cc adds comments like '#:fec' to the end of the | ||||
|     # dependency line. | ||||
|     tr ' ' "$nl" < "$tmpdepfile" \ | ||||
|       | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \ | ||||
|       | tr "$nl" ' ' >> "$depfile" | ||||
|     echo >> "$depfile" | ||||
|     # The second pass generates a dummy entry for each header file. | ||||
|     tr ' ' "$nl" < "$tmpdepfile" \ | ||||
|       | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ | ||||
|       >> "$depfile" | ||||
|   else | ||||
|     make_dummy_depfile | ||||
|   fi | ||||
|   rm -f "$tmpdepfile" | ||||
|   ;; | ||||
| 
 | ||||
| xlc) | ||||
|   # This case exists only to let depend.m4 do its work.  It works by | ||||
|   # looking at the text of this script.  This case will never be run, | ||||
|   # since it is checked for above. | ||||
|   exit 1 | ||||
|   ;; | ||||
| 
 | ||||
| aix) | ||||
|   # The C for AIX Compiler uses -M and outputs the dependencies | ||||
|   # in a .u file.  In older versions, this file always lives in the | ||||
|   # current directory.  Also, the AIX compiler puts '$object:' at the | ||||
|   # start of each line; $object doesn't have directory information. | ||||
|   # Version 6 uses the directory in both cases. | ||||
|   set_dir_from "$object" | ||||
|   set_base_from "$object" | ||||
|   if test "$libtool" = yes; then | ||||
|     tmpdepfile1=$dir$base.u | ||||
|     tmpdepfile2=$base.u | ||||
|     tmpdepfile3=$dir.libs/$base.u | ||||
|     "$@" -Wc,-M | ||||
|   else | ||||
|     tmpdepfile1=$dir$base.u | ||||
|     tmpdepfile2=$dir$base.u | ||||
|     tmpdepfile3=$dir$base.u | ||||
|     "$@" -M | ||||
|   fi | ||||
|   stat=$? | ||||
|   if test $stat -ne 0; then | ||||
|     rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" | ||||
|     exit $stat | ||||
|   fi | ||||
| 
 | ||||
|   for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" | ||||
|   do | ||||
|     test -f "$tmpdepfile" && break | ||||
|   done | ||||
|   aix_post_process_depfile | ||||
|   ;; | ||||
| 
 | ||||
| tcc) | ||||
|   # tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26 | ||||
|   # FIXME: That version still under development at the moment of writing. | ||||
|   #        Make that this statement remains true also for stable, released | ||||
|   #        versions. | ||||
|   # It will wrap lines (doesn't matter whether long or short) with a | ||||
|   # trailing '\', as in: | ||||
|   # | ||||
|   #   foo.o : \ | ||||
|   #    foo.c \ | ||||
|   #    foo.h \ | ||||
|   # | ||||
|   # It will put a trailing '\' even on the last line, and will use leading | ||||
|   # spaces rather than leading tabs (at least since its commit 0394caf7 | ||||
|   # "Emit spaces for -MD"). | ||||
|   "$@" -MD -MF "$tmpdepfile" | ||||
|   stat=$? | ||||
|   if test $stat -ne 0; then | ||||
|     rm -f "$tmpdepfile" | ||||
|     exit $stat | ||||
|   fi | ||||
|   rm -f "$depfile" | ||||
|   # Each non-empty line is of the form 'foo.o : \' or ' dep.h \'. | ||||
|   # We have to change lines of the first kind to '$object: \'. | ||||
|   sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile" | ||||
|   # And for each line of the second kind, we have to emit a 'dep.h:' | ||||
|   # dummy dependency, to avoid the deleted-header problem. | ||||
|   sed -n -e 's|^  *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile" | ||||
|   rm -f "$tmpdepfile" | ||||
|   ;; | ||||
| 
 | ||||
| ## The order of this option in the case statement is important, since the | ||||
| ## shell code in configure will try each of these formats in the order | ||||
| ## listed in this file.  A plain '-MD' option would be understood by many | ||||
| ## compilers, so we must ensure this comes after the gcc and icc options. | ||||
| pgcc) | ||||
|   # Portland's C compiler understands '-MD'. | ||||
|   # Will always output deps to 'file.d' where file is the root name of the | ||||
|   # source file under compilation, even if file resides in a subdirectory. | ||||
|   # The object file name does not affect the name of the '.d' file. | ||||
|   # pgcc 10.2 will output | ||||
|   #    foo.o: sub/foo.c sub/foo.h | ||||
|   # and will wrap long lines using '\' : | ||||
|   #    foo.o: sub/foo.c ... \ | ||||
|   #     sub/foo.h ... \ | ||||
|   #     ... | ||||
|   set_dir_from "$object" | ||||
|   # Use the source, not the object, to determine the base name, since | ||||
|   # that's sadly what pgcc will do too. | ||||
|   set_base_from "$source" | ||||
|   tmpdepfile=$base.d | ||||
| 
 | ||||
|   # For projects that build the same source file twice into different object | ||||
|   # files, the pgcc approach of using the *source* file root name can cause | ||||
|   # problems in parallel builds.  Use a locking strategy to avoid stomping on | ||||
|   # the same $tmpdepfile. | ||||
|   lockdir=$base.d-lock | ||||
|   trap " | ||||
|     echo '$0: caught signal, cleaning up...' >&2 | ||||
|     rmdir '$lockdir' | ||||
|     exit 1 | ||||
|   " 1 2 13 15 | ||||
|   numtries=100 | ||||
|   i=$numtries | ||||
|   while test $i -gt 0; do | ||||
|     # mkdir is a portable test-and-set. | ||||
|     if mkdir "$lockdir" 2>/dev/null; then | ||||
|       # This process acquired the lock. | ||||
|       "$@" -MD | ||||
|       stat=$? | ||||
|       # Release the lock. | ||||
|       rmdir "$lockdir" | ||||
|       break | ||||
|     else | ||||
|       # If the lock is being held by a different process, wait | ||||
|       # until the winning process is done or we timeout. | ||||
|       while test -d "$lockdir" && test $i -gt 0; do | ||||
|         sleep 1 | ||||
|         i=`expr $i - 1` | ||||
|       done | ||||
|     fi | ||||
|     i=`expr $i - 1` | ||||
|   done | ||||
|   trap - 1 2 13 15 | ||||
|   if test $i -le 0; then | ||||
|     echo "$0: failed to acquire lock after $numtries attempts" >&2 | ||||
|     echo "$0: check lockdir '$lockdir'" >&2 | ||||
|     exit 1 | ||||
|   fi | ||||
| 
 | ||||
|   if test $stat -ne 0; then | ||||
|     rm -f "$tmpdepfile" | ||||
|     exit $stat | ||||
|   fi | ||||
|   rm -f "$depfile" | ||||
|   # Each line is of the form `foo.o: dependent.h', | ||||
|   # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. | ||||
|   # Do two passes, one to just change these to | ||||
|   # `$object: dependent.h' and one to simply `dependent.h:'. | ||||
|   sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" | ||||
|   # Some versions of the HPUX 10.20 sed can't process this invocation | ||||
|   # correctly.  Breaking it into two sed invocations is a workaround. | ||||
|   sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \ | ||||
|     | sed -e 's/$/ :/' >> "$depfile" | ||||
|   rm -f "$tmpdepfile" | ||||
|   ;; | ||||
| 
 | ||||
| hp2) | ||||
|   # The "hp" stanza above does not work with aCC (C++) and HP's ia64 | ||||
|   # compilers, which have integrated preprocessors.  The correct option | ||||
|   # to use with these is +Maked; it writes dependencies to a file named | ||||
|   # 'foo.d', which lands next to the object file, wherever that | ||||
|   # happens to be. | ||||
|   # Much of this is similar to the tru64 case; see comments there. | ||||
|   set_dir_from  "$object" | ||||
|   set_base_from "$object" | ||||
|   if test "$libtool" = yes; then | ||||
|     tmpdepfile1=$dir$base.d | ||||
|     tmpdepfile2=$dir.libs/$base.d | ||||
|     "$@" -Wc,+Maked | ||||
|   else | ||||
|     tmpdepfile1=$dir$base.d | ||||
|     tmpdepfile2=$dir$base.d | ||||
|     "$@" +Maked | ||||
|   fi | ||||
|   stat=$? | ||||
|   if test $stat -ne 0; then | ||||
|      rm -f "$tmpdepfile1" "$tmpdepfile2" | ||||
|      exit $stat | ||||
|   fi | ||||
| 
 | ||||
|   for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" | ||||
|   do | ||||
|     test -f "$tmpdepfile" && break | ||||
|   done | ||||
|   if test -f "$tmpdepfile"; then | ||||
|     sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile" | ||||
|     # Add 'dependent.h:' lines. | ||||
|     sed -ne '2,${ | ||||
|                s/^ *// | ||||
|                s/ \\*$// | ||||
|                s/$/:/ | ||||
|                p | ||||
|              }' "$tmpdepfile" >> "$depfile" | ||||
|   else | ||||
|     make_dummy_depfile | ||||
|   fi | ||||
|   rm -f "$tmpdepfile" "$tmpdepfile2" | ||||
|   ;; | ||||
| 
 | ||||
| tru64) | ||||
|   # The Tru64 compiler uses -MD to generate dependencies as a side | ||||
|   # effect.  'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'. | ||||
|   # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put | ||||
|   # dependencies in 'foo.d' instead, so we check for that too. | ||||
|   # Subdirectories are respected. | ||||
|   set_dir_from  "$object" | ||||
|   set_base_from "$object" | ||||
| 
 | ||||
|   if test "$libtool" = yes; then | ||||
|     # Libtool generates 2 separate objects for the 2 libraries.  These | ||||
|     # two compilations output dependencies in $dir.libs/$base.o.d and | ||||
|     # in $dir$base.o.d.  We have to check for both files, because | ||||
|     # one of the two compilations can be disabled.  We should prefer | ||||
|     # $dir$base.o.d over $dir.libs/$base.o.d because the latter is | ||||
|     # automatically cleaned when .libs/ is deleted, while ignoring | ||||
|     # the former would cause a distcleancheck panic. | ||||
|     tmpdepfile1=$dir$base.o.d          # libtool 1.5 | ||||
|     tmpdepfile2=$dir.libs/$base.o.d    # Likewise. | ||||
|     tmpdepfile3=$dir.libs/$base.d      # Compaq CCC V6.2-504 | ||||
|     "$@" -Wc,-MD | ||||
|   else | ||||
|     tmpdepfile1=$dir$base.d | ||||
|     tmpdepfile2=$dir$base.d | ||||
|     tmpdepfile3=$dir$base.d | ||||
|     "$@" -MD | ||||
|   fi | ||||
| 
 | ||||
|   stat=$? | ||||
|   if test $stat -ne 0; then | ||||
|     rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" | ||||
|     exit $stat | ||||
|   fi | ||||
| 
 | ||||
|   for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" | ||||
|   do | ||||
|     test -f "$tmpdepfile" && break | ||||
|   done | ||||
|   # Same post-processing that is required for AIX mode. | ||||
|   aix_post_process_depfile | ||||
|   ;; | ||||
| 
 | ||||
| msvc7) | ||||
|   if test "$libtool" = yes; then | ||||
|     showIncludes=-Wc,-showIncludes | ||||
|   else | ||||
|     showIncludes=-showIncludes | ||||
|   fi | ||||
|   "$@" $showIncludes > "$tmpdepfile" | ||||
|   stat=$? | ||||
|   grep -v '^Note: including file: ' "$tmpdepfile" | ||||
|   if test $stat -ne 0; then | ||||
|     rm -f "$tmpdepfile" | ||||
|     exit $stat | ||||
|   fi | ||||
|   rm -f "$depfile" | ||||
|   echo "$object : \\" > "$depfile" | ||||
|   # The first sed program below extracts the file names and escapes | ||||
|   # backslashes for cygpath.  The second sed program outputs the file | ||||
|   # name when reading, but also accumulates all include files in the | ||||
|   # hold buffer in order to output them again at the end.  This only | ||||
|   # works with sed implementations that can handle large buffers. | ||||
|   sed < "$tmpdepfile" -n ' | ||||
| /^Note: including file:  *\(.*\)/ { | ||||
|   s//\1/ | ||||
|   s/\\/\\\\/g | ||||
|   p | ||||
| }' | $cygpath_u | sort -u | sed -n ' | ||||
| s/ /\\ /g | ||||
| s/\(.*\)/'"$tab"'\1 \\/p | ||||
| s/.\(.*\) \\/\1:/ | ||||
| H | ||||
| $ { | ||||
|   s/.*/'"$tab"'/ | ||||
|   G | ||||
|   p | ||||
| }' >> "$depfile" | ||||
|   echo >> "$depfile" # make sure the fragment doesn't end with a backslash | ||||
|   rm -f "$tmpdepfile" | ||||
|   ;; | ||||
| 
 | ||||
| msvc7msys) | ||||
|   # This case exists only to let depend.m4 do its work.  It works by | ||||
|   # looking at the text of this script.  This case will never be run, | ||||
|   # since it is checked for above. | ||||
|   exit 1 | ||||
|   ;; | ||||
| 
 | ||||
| #nosideeffect) | ||||
|   # This comment above is used by automake to tell side-effect | ||||
|   # dependency tracking mechanisms from slower ones. | ||||
| 
 | ||||
| dashmstdout) | ||||
|   # Important note: in order to support this mode, a compiler *must* | ||||
|   # always write the preprocessed file to stdout, regardless of -o. | ||||
|   "$@" || exit $? | ||||
| 
 | ||||
|   # Remove the call to Libtool. | ||||
|   if test "$libtool" = yes; then | ||||
|     while test "X$1" != 'X--mode=compile'; do | ||||
|       shift | ||||
|     done | ||||
|     shift | ||||
|   fi | ||||
| 
 | ||||
|   # Remove '-o $object'. | ||||
|   IFS=" " | ||||
|   for arg | ||||
|   do | ||||
|     case $arg in | ||||
|     -o) | ||||
|       shift | ||||
|       ;; | ||||
|     $object) | ||||
|       shift | ||||
|       ;; | ||||
|     *) | ||||
|       set fnord "$@" "$arg" | ||||
|       shift # fnord | ||||
|       shift # $arg | ||||
|       ;; | ||||
|     esac | ||||
|   done | ||||
| 
 | ||||
|   test -z "$dashmflag" && dashmflag=-M | ||||
|   # Require at least two characters before searching for ':' | ||||
|   # in the target name.  This is to cope with DOS-style filenames: | ||||
|   # a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise. | ||||
|   "$@" $dashmflag | | ||||
|     sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile" | ||||
|   rm -f "$depfile" | ||||
|   cat < "$tmpdepfile" > "$depfile" | ||||
|   # Some versions of the HPUX 10.20 sed can't process this sed invocation | ||||
|   # correctly.  Breaking it into two sed invocations is a workaround. | ||||
|   tr ' ' "$nl" < "$tmpdepfile" \ | ||||
|     | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | ||||
|     | sed -e 's/$/ :/' >> "$depfile" | ||||
|   rm -f "$tmpdepfile" | ||||
|   ;; | ||||
| 
 | ||||
| dashXmstdout) | ||||
|   # This case only exists to satisfy depend.m4.  It is never actually | ||||
|   # run, as this mode is specially recognized in the preamble. | ||||
|   exit 1 | ||||
|   ;; | ||||
| 
 | ||||
| makedepend) | ||||
|   "$@" || exit $? | ||||
|   # Remove any Libtool call | ||||
|   if test "$libtool" = yes; then | ||||
|     while test "X$1" != 'X--mode=compile'; do | ||||
|       shift | ||||
|     done | ||||
|     shift | ||||
|   fi | ||||
|   # X makedepend | ||||
|   shift | ||||
|   cleared=no eat=no | ||||
|   for arg | ||||
|   do | ||||
|     case $cleared in | ||||
|     no) | ||||
|       set ""; shift | ||||
|       cleared=yes ;; | ||||
|     esac | ||||
|     if test $eat = yes; then | ||||
|       eat=no | ||||
|       continue | ||||
|     fi | ||||
|     case "$arg" in | ||||
|     -D*|-I*) | ||||
|       set fnord "$@" "$arg"; shift ;; | ||||
|     # Strip any option that makedepend may not understand.  Remove | ||||
|     # the object too, otherwise makedepend will parse it as a source file. | ||||
|     -arch) | ||||
|       eat=yes ;; | ||||
|     -*|$object) | ||||
|       ;; | ||||
|     *) | ||||
|       set fnord "$@" "$arg"; shift ;; | ||||
|     esac | ||||
|   done | ||||
|   obj_suffix=`echo "$object" | sed 's/^.*\././'` | ||||
|   touch "$tmpdepfile" | ||||
|   ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" | ||||
|   rm -f "$depfile" | ||||
|   # makedepend may prepend the VPATH from the source file name to the object. | ||||
|   # No need to regex-escape $object, excess matching of '.' is harmless. | ||||
|   sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile" | ||||
|   # Some versions of the HPUX 10.20 sed can't process the last invocation | ||||
|   # correctly.  Breaking it into two sed invocations is a workaround. | ||||
|   sed '1,2d' "$tmpdepfile" \ | ||||
|     | tr ' ' "$nl" \ | ||||
|     | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | ||||
|     | sed -e 's/$/ :/' >> "$depfile" | ||||
|   rm -f "$tmpdepfile" "$tmpdepfile".bak | ||||
|   ;; | ||||
| 
 | ||||
| cpp) | ||||
|   # Important note: in order to support this mode, a compiler *must* | ||||
|   # always write the preprocessed file to stdout. | ||||
|   "$@" || exit $? | ||||
| 
 | ||||
|   # Remove the call to Libtool. | ||||
|   if test "$libtool" = yes; then | ||||
|     while test "X$1" != 'X--mode=compile'; do | ||||
|       shift | ||||
|     done | ||||
|     shift | ||||
|   fi | ||||
| 
 | ||||
|   # Remove '-o $object'. | ||||
|   IFS=" " | ||||
|   for arg | ||||
|   do | ||||
|     case $arg in | ||||
|     -o) | ||||
|       shift | ||||
|       ;; | ||||
|     $object) | ||||
|       shift | ||||
|       ;; | ||||
|     *) | ||||
|       set fnord "$@" "$arg" | ||||
|       shift # fnord | ||||
|       shift # $arg | ||||
|       ;; | ||||
|     esac | ||||
|   done | ||||
| 
 | ||||
|   "$@" -E \ | ||||
|     | sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ | ||||
|              -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ | ||||
|     | sed '$ s: \\$::' > "$tmpdepfile" | ||||
|   rm -f "$depfile" | ||||
|   echo "$object : \\" > "$depfile" | ||||
|   cat < "$tmpdepfile" >> "$depfile" | ||||
|   sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" | ||||
|   rm -f "$tmpdepfile" | ||||
|   ;; | ||||
| 
 | ||||
| msvisualcpp) | ||||
|   # Important note: in order to support this mode, a compiler *must* | ||||
|   # always write the preprocessed file to stdout. | ||||
|   "$@" || exit $? | ||||
| 
 | ||||
|   # Remove the call to Libtool. | ||||
|   if test "$libtool" = yes; then | ||||
|     while test "X$1" != 'X--mode=compile'; do | ||||
|       shift | ||||
|     done | ||||
|     shift | ||||
|   fi | ||||
| 
 | ||||
|   IFS=" " | ||||
|   for arg | ||||
|   do | ||||
|     case "$arg" in | ||||
|     -o) | ||||
|       shift | ||||
|       ;; | ||||
|     $object) | ||||
|       shift | ||||
|       ;; | ||||
|     "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") | ||||
|         set fnord "$@" | ||||
|         shift | ||||
|         shift | ||||
|         ;; | ||||
|     *) | ||||
|         set fnord "$@" "$arg" | ||||
|         shift | ||||
|         shift | ||||
|         ;; | ||||
|     esac | ||||
|   done | ||||
|   "$@" -E 2>/dev/null | | ||||
|   sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile" | ||||
|   rm -f "$depfile" | ||||
|   echo "$object : \\" > "$depfile" | ||||
|   sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile" | ||||
|   echo "$tab" >> "$depfile" | ||||
|   sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile" | ||||
|   rm -f "$tmpdepfile" | ||||
|   ;; | ||||
| 
 | ||||
| msvcmsys) | ||||
|   # This case exists only to let depend.m4 do its work.  It works by | ||||
|   # looking at the text of this script.  This case will never be run, | ||||
|   # since it is checked for above. | ||||
|   exit 1 | ||||
|   ;; | ||||
| 
 | ||||
| none) | ||||
|   exec "$@" | ||||
|   ;; | ||||
| 
 | ||||
| *) | ||||
|   echo "Unknown depmode $depmode" 1>&2 | ||||
|   exit 1 | ||||
|   ;; | ||||
| esac | ||||
| 
 | ||||
| exit 0 | ||||
| 
 | ||||
| # Local Variables: | ||||
| # mode: shell-script | ||||
| # sh-indentation: 2 | ||||
| # eval: (add-hook 'before-save-hook 'time-stamp) | ||||
| # time-stamp-start: "scriptversion=" | ||||
| # time-stamp-format: "%:y-%02m-%02d.%02H" | ||||
| # time-stamp-time-zone: "UTC0" | ||||
| # time-stamp-end: "; # UTC" | ||||
| # End: | ||||
							
								
								
									
										529
									
								
								third_party/make/build-aux/install-sh
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										529
									
								
								third_party/make/build-aux/install-sh
									
										
									
									
										vendored
									
									
										Executable file
									
								
							|  | @ -0,0 +1,529 @@ | |||
| #!/bin/sh | ||||
| # install - install a program, script, or datafile | ||||
| 
 | ||||
| scriptversion=2018-03-11.20; # UTC | ||||
| 
 | ||||
| # This originates from X11R5 (mit/util/scripts/install.sh), which was | ||||
| # later released in X11R6 (xc/config/util/install.sh) with the | ||||
| # following copyright and license. | ||||
| # | ||||
| # Copyright (C) 1994 X Consortium | ||||
| # | ||||
| # Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| # of this software and associated documentation files (the "Software"), to | ||||
| # deal in the Software without restriction, including without limitation the | ||||
| # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or | ||||
| # sell copies of the Software, and to permit persons to whom the Software is | ||||
| # furnished to do so, subject to the following conditions: | ||||
| # | ||||
| # The above copyright notice and this permission notice shall be included in | ||||
| # all copies or substantial portions of the Software. | ||||
| # | ||||
| # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE | ||||
| # X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN | ||||
| # AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- | ||||
| # TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
| # | ||||
| # Except as contained in this notice, the name of the X Consortium shall not | ||||
| # be used in advertising or otherwise to promote the sale, use or other deal- | ||||
| # ings in this Software without prior written authorization from the X Consor- | ||||
| # tium. | ||||
| # | ||||
| # | ||||
| # FSF changes to this file are in the public domain. | ||||
| # | ||||
| # Calling this script install-sh is preferred over install.sh, to prevent | ||||
| # 'make' implicit rules from creating a file called install from it | ||||
| # when there is no Makefile. | ||||
| # | ||||
| # This script is compatible with the BSD install script, but was written | ||||
| # from scratch. | ||||
| 
 | ||||
| tab='	' | ||||
| nl=' | ||||
| ' | ||||
| IFS=" $tab$nl" | ||||
| 
 | ||||
| # Set DOITPROG to "echo" to test this script. | ||||
| 
 | ||||
| doit=${DOITPROG-} | ||||
| doit_exec=${doit:-exec} | ||||
| 
 | ||||
| # Put in absolute file names if you don't have them in your path; | ||||
| # or use environment vars. | ||||
| 
 | ||||
| chgrpprog=${CHGRPPROG-chgrp} | ||||
| chmodprog=${CHMODPROG-chmod} | ||||
| chownprog=${CHOWNPROG-chown} | ||||
| cmpprog=${CMPPROG-cmp} | ||||
| cpprog=${CPPROG-cp} | ||||
| mkdirprog=${MKDIRPROG-mkdir} | ||||
| mvprog=${MVPROG-mv} | ||||
| rmprog=${RMPROG-rm} | ||||
| stripprog=${STRIPPROG-strip} | ||||
| 
 | ||||
| posix_mkdir= | ||||
| 
 | ||||
| # Desired mode of installed file. | ||||
| mode=0755 | ||||
| 
 | ||||
| chgrpcmd= | ||||
| chmodcmd=$chmodprog | ||||
| chowncmd= | ||||
| mvcmd=$mvprog | ||||
| rmcmd="$rmprog -f" | ||||
| stripcmd= | ||||
| 
 | ||||
| src= | ||||
| dst= | ||||
| dir_arg= | ||||
| dst_arg= | ||||
| 
 | ||||
| copy_on_change=false | ||||
| is_target_a_directory=possibly | ||||
| 
 | ||||
| usage="\ | ||||
| Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE | ||||
|    or: $0 [OPTION]... SRCFILES... DIRECTORY | ||||
|    or: $0 [OPTION]... -t DIRECTORY SRCFILES... | ||||
|    or: $0 [OPTION]... -d DIRECTORIES... | ||||
| 
 | ||||
| In the 1st form, copy SRCFILE to DSTFILE. | ||||
| In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. | ||||
| In the 4th, create DIRECTORIES. | ||||
| 
 | ||||
| Options: | ||||
|      --help     display this help and exit. | ||||
|      --version  display version info and exit. | ||||
| 
 | ||||
|   -c            (ignored) | ||||
|   -C            install only if different (preserve the last data modification time) | ||||
|   -d            create directories instead of installing files. | ||||
|   -g GROUP      $chgrpprog installed files to GROUP. | ||||
|   -m MODE       $chmodprog installed files to MODE. | ||||
|   -o USER       $chownprog installed files to USER. | ||||
|   -s            $stripprog installed files. | ||||
|   -t DIRECTORY  install into DIRECTORY. | ||||
|   -T            report an error if DSTFILE is a directory. | ||||
| 
 | ||||
| Environment variables override the default commands: | ||||
|   CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG | ||||
|   RMPROG STRIPPROG | ||||
| " | ||||
| 
 | ||||
| while test $# -ne 0; do | ||||
|   case $1 in | ||||
|     -c) ;; | ||||
| 
 | ||||
|     -C) copy_on_change=true;; | ||||
| 
 | ||||
|     -d) dir_arg=true;; | ||||
| 
 | ||||
|     -g) chgrpcmd="$chgrpprog $2" | ||||
|         shift;; | ||||
| 
 | ||||
|     --help) echo "$usage"; exit $?;; | ||||
| 
 | ||||
|     -m) mode=$2 | ||||
|         case $mode in | ||||
|           *' '* | *"$tab"* | *"$nl"* | *'*'* | *'?'* | *'['*) | ||||
|             echo "$0: invalid mode: $mode" >&2 | ||||
|             exit 1;; | ||||
|         esac | ||||
|         shift;; | ||||
| 
 | ||||
|     -o) chowncmd="$chownprog $2" | ||||
|         shift;; | ||||
| 
 | ||||
|     -s) stripcmd=$stripprog;; | ||||
| 
 | ||||
|     -t) | ||||
|         is_target_a_directory=always | ||||
|         dst_arg=$2 | ||||
|         # Protect names problematic for 'test' and other utilities. | ||||
|         case $dst_arg in | ||||
|           -* | [=\(\)!]) dst_arg=./$dst_arg;; | ||||
|         esac | ||||
|         shift;; | ||||
| 
 | ||||
|     -T) is_target_a_directory=never;; | ||||
| 
 | ||||
|     --version) echo "$0 $scriptversion"; exit $?;; | ||||
| 
 | ||||
|     --) shift | ||||
|         break;; | ||||
| 
 | ||||
|     -*) echo "$0: invalid option: $1" >&2 | ||||
|         exit 1;; | ||||
| 
 | ||||
|     *)  break;; | ||||
|   esac | ||||
|   shift | ||||
| done | ||||
| 
 | ||||
| # We allow the use of options -d and -T together, by making -d | ||||
| # take the precedence; this is for compatibility with GNU install. | ||||
| 
 | ||||
| if test -n "$dir_arg"; then | ||||
|   if test -n "$dst_arg"; then | ||||
|     echo "$0: target directory not allowed when installing a directory." >&2 | ||||
|     exit 1 | ||||
|   fi | ||||
| fi | ||||
| 
 | ||||
| if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then | ||||
|   # When -d is used, all remaining arguments are directories to create. | ||||
|   # When -t is used, the destination is already specified. | ||||
|   # Otherwise, the last argument is the destination.  Remove it from $@. | ||||
|   for arg | ||||
|   do | ||||
|     if test -n "$dst_arg"; then | ||||
|       # $@ is not empty: it contains at least $arg. | ||||
|       set fnord "$@" "$dst_arg" | ||||
|       shift # fnord | ||||
|     fi | ||||
|     shift # arg | ||||
|     dst_arg=$arg | ||||
|     # Protect names problematic for 'test' and other utilities. | ||||
|     case $dst_arg in | ||||
|       -* | [=\(\)!]) dst_arg=./$dst_arg;; | ||||
|     esac | ||||
|   done | ||||
| fi | ||||
| 
 | ||||
| if test $# -eq 0; then | ||||
|   if test -z "$dir_arg"; then | ||||
|     echo "$0: no input file specified." >&2 | ||||
|     exit 1 | ||||
|   fi | ||||
|   # It's OK to call 'install-sh -d' without argument. | ||||
|   # This can happen when creating conditional directories. | ||||
|   exit 0 | ||||
| fi | ||||
| 
 | ||||
| if test -z "$dir_arg"; then | ||||
|   if test $# -gt 1 || test "$is_target_a_directory" = always; then | ||||
|     if test ! -d "$dst_arg"; then | ||||
|       echo "$0: $dst_arg: Is not a directory." >&2 | ||||
|       exit 1 | ||||
|     fi | ||||
|   fi | ||||
| fi | ||||
| 
 | ||||
| if test -z "$dir_arg"; then | ||||
|   do_exit='(exit $ret); exit $ret' | ||||
|   trap "ret=129; $do_exit" 1 | ||||
|   trap "ret=130; $do_exit" 2 | ||||
|   trap "ret=141; $do_exit" 13 | ||||
|   trap "ret=143; $do_exit" 15 | ||||
| 
 | ||||
|   # Set umask so as not to create temps with too-generous modes. | ||||
|   # However, 'strip' requires both read and write access to temps. | ||||
|   case $mode in | ||||
|     # Optimize common cases. | ||||
|     *644) cp_umask=133;; | ||||
|     *755) cp_umask=22;; | ||||
| 
 | ||||
|     *[0-7]) | ||||
|       if test -z "$stripcmd"; then | ||||
|         u_plus_rw= | ||||
|       else | ||||
|         u_plus_rw='% 200' | ||||
|       fi | ||||
|       cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;; | ||||
|     *) | ||||
|       if test -z "$stripcmd"; then | ||||
|         u_plus_rw= | ||||
|       else | ||||
|         u_plus_rw=,u+rw | ||||
|       fi | ||||
|       cp_umask=$mode$u_plus_rw;; | ||||
|   esac | ||||
| fi | ||||
| 
 | ||||
| for src | ||||
| do | ||||
|   # Protect names problematic for 'test' and other utilities. | ||||
|   case $src in | ||||
|     -* | [=\(\)!]) src=./$src;; | ||||
|   esac | ||||
| 
 | ||||
|   if test -n "$dir_arg"; then | ||||
|     dst=$src | ||||
|     dstdir=$dst | ||||
|     test -d "$dstdir" | ||||
|     dstdir_status=$? | ||||
|   else | ||||
| 
 | ||||
|     # Waiting for this to be detected by the "$cpprog $src $dsttmp" command | ||||
|     # might cause directories to be created, which would be especially bad | ||||
|     # if $src (and thus $dsttmp) contains '*'. | ||||
|     if test ! -f "$src" && test ! -d "$src"; then | ||||
|       echo "$0: $src does not exist." >&2 | ||||
|       exit 1 | ||||
|     fi | ||||
| 
 | ||||
|     if test -z "$dst_arg"; then | ||||
|       echo "$0: no destination specified." >&2 | ||||
|       exit 1 | ||||
|     fi | ||||
|     dst=$dst_arg | ||||
| 
 | ||||
|     # If destination is a directory, append the input filename. | ||||
|     if test -d "$dst"; then | ||||
|       if test "$is_target_a_directory" = never; then | ||||
|         echo "$0: $dst_arg: Is a directory" >&2 | ||||
|         exit 1 | ||||
|       fi | ||||
|       dstdir=$dst | ||||
|       dstbase=`basename "$src"` | ||||
|       case $dst in | ||||
| 	*/) dst=$dst$dstbase;; | ||||
| 	*)  dst=$dst/$dstbase;; | ||||
|       esac | ||||
|       dstdir_status=0 | ||||
|     else | ||||
|       dstdir=`dirname "$dst"` | ||||
|       test -d "$dstdir" | ||||
|       dstdir_status=$? | ||||
|     fi | ||||
|   fi | ||||
| 
 | ||||
|   case $dstdir in | ||||
|     */) dstdirslash=$dstdir;; | ||||
|     *)  dstdirslash=$dstdir/;; | ||||
|   esac | ||||
| 
 | ||||
|   obsolete_mkdir_used=false | ||||
| 
 | ||||
|   if test $dstdir_status != 0; then | ||||
|     case $posix_mkdir in | ||||
|       '') | ||||
|         # Create intermediate dirs using mode 755 as modified by the umask. | ||||
|         # This is like FreeBSD 'install' as of 1997-10-28. | ||||
|         umask=`umask` | ||||
|         case $stripcmd.$umask in | ||||
|           # Optimize common cases. | ||||
|           *[2367][2367]) mkdir_umask=$umask;; | ||||
|           .*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;; | ||||
| 
 | ||||
|           *[0-7]) | ||||
|             mkdir_umask=`expr $umask + 22 \ | ||||
|               - $umask % 100 % 40 + $umask % 20 \ | ||||
|               - $umask % 10 % 4 + $umask % 2 | ||||
|             `;; | ||||
|           *) mkdir_umask=$umask,go-w;; | ||||
|         esac | ||||
| 
 | ||||
|         # With -d, create the new directory with the user-specified mode. | ||||
|         # Otherwise, rely on $mkdir_umask. | ||||
|         if test -n "$dir_arg"; then | ||||
|           mkdir_mode=-m$mode | ||||
|         else | ||||
|           mkdir_mode= | ||||
|         fi | ||||
| 
 | ||||
|         posix_mkdir=false | ||||
|         case $umask in | ||||
|           *[123567][0-7][0-7]) | ||||
|             # POSIX mkdir -p sets u+wx bits regardless of umask, which | ||||
|             # is incompatible with FreeBSD 'install' when (umask & 300) != 0. | ||||
|             ;; | ||||
|           *) | ||||
|             # Note that $RANDOM variable is not portable (e.g. dash);  Use it | ||||
|             # here however when possible just to lower collision chance. | ||||
|             tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$ | ||||
| 
 | ||||
|             trap 'ret=$?; rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null; exit $ret' 0 | ||||
| 
 | ||||
|             # Because "mkdir -p" follows existing symlinks and we likely work | ||||
|             # directly in world-writeable /tmp, make sure that the '$tmpdir' | ||||
|             # directory is successfully created first before we actually test | ||||
|             # 'mkdir -p' feature. | ||||
|             if (umask $mkdir_umask && | ||||
|                 $mkdirprog $mkdir_mode "$tmpdir" && | ||||
|                 exec $mkdirprog $mkdir_mode -p -- "$tmpdir/a/b") >/dev/null 2>&1 | ||||
|             then | ||||
|               if test -z "$dir_arg" || { | ||||
|                    # Check for POSIX incompatibilities with -m. | ||||
|                    # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or | ||||
|                    # other-writable bit of parent directory when it shouldn't. | ||||
|                    # FreeBSD 6.1 mkdir -m -p sets mode of existing directory. | ||||
|                    test_tmpdir="$tmpdir/a" | ||||
|                    ls_ld_tmpdir=`ls -ld "$test_tmpdir"` | ||||
|                    case $ls_ld_tmpdir in | ||||
|                      d????-?r-*) different_mode=700;; | ||||
|                      d????-?--*) different_mode=755;; | ||||
|                      *) false;; | ||||
|                    esac && | ||||
|                    $mkdirprog -m$different_mode -p -- "$test_tmpdir" && { | ||||
|                      ls_ld_tmpdir_1=`ls -ld "$test_tmpdir"` | ||||
|                      test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1" | ||||
|                    } | ||||
|                  } | ||||
|               then posix_mkdir=: | ||||
|               fi | ||||
|               rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" | ||||
|             else | ||||
|               # Remove any dirs left behind by ancient mkdir implementations. | ||||
|               rmdir ./$mkdir_mode ./-p ./-- "$tmpdir" 2>/dev/null | ||||
|             fi | ||||
|             trap '' 0;; | ||||
|         esac;; | ||||
|     esac | ||||
| 
 | ||||
|     if | ||||
|       $posix_mkdir && ( | ||||
|         umask $mkdir_umask && | ||||
|         $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir" | ||||
|       ) | ||||
|     then : | ||||
|     else | ||||
| 
 | ||||
|       # The umask is ridiculous, or mkdir does not conform to POSIX, | ||||
|       # or it failed possibly due to a race condition.  Create the | ||||
|       # directory the slow way, step by step, checking for races as we go. | ||||
| 
 | ||||
|       case $dstdir in | ||||
|         /*) prefix='/';; | ||||
|         [-=\(\)!]*) prefix='./';; | ||||
|         *)  prefix='';; | ||||
|       esac | ||||
| 
 | ||||
|       oIFS=$IFS | ||||
|       IFS=/ | ||||
|       set -f | ||||
|       set fnord $dstdir | ||||
|       shift | ||||
|       set +f | ||||
|       IFS=$oIFS | ||||
| 
 | ||||
|       prefixes= | ||||
| 
 | ||||
|       for d | ||||
|       do | ||||
|         test X"$d" = X && continue | ||||
| 
 | ||||
|         prefix=$prefix$d | ||||
|         if test -d "$prefix"; then | ||||
|           prefixes= | ||||
|         else | ||||
|           if $posix_mkdir; then | ||||
|             (umask=$mkdir_umask && | ||||
|              $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break | ||||
|             # Don't fail if two instances are running concurrently. | ||||
|             test -d "$prefix" || exit 1 | ||||
|           else | ||||
|             case $prefix in | ||||
|               *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;; | ||||
|               *) qprefix=$prefix;; | ||||
|             esac | ||||
|             prefixes="$prefixes '$qprefix'" | ||||
|           fi | ||||
|         fi | ||||
|         prefix=$prefix/ | ||||
|       done | ||||
| 
 | ||||
|       if test -n "$prefixes"; then | ||||
|         # Don't fail if two instances are running concurrently. | ||||
|         (umask $mkdir_umask && | ||||
|          eval "\$doit_exec \$mkdirprog $prefixes") || | ||||
|           test -d "$dstdir" || exit 1 | ||||
|         obsolete_mkdir_used=true | ||||
|       fi | ||||
|     fi | ||||
|   fi | ||||
| 
 | ||||
|   if test -n "$dir_arg"; then | ||||
|     { test -z "$chowncmd" || $doit $chowncmd "$dst"; } && | ||||
|     { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } && | ||||
|     { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false || | ||||
|       test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1 | ||||
|   else | ||||
| 
 | ||||
|     # Make a couple of temp file names in the proper directory. | ||||
|     dsttmp=${dstdirslash}_inst.$$_ | ||||
|     rmtmp=${dstdirslash}_rm.$$_ | ||||
| 
 | ||||
|     # Trap to clean up those temp files at exit. | ||||
|     trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 | ||||
| 
 | ||||
|     # Copy the file name to the temp name. | ||||
|     (umask $cp_umask && | ||||
|      { test -z "$stripcmd" || { | ||||
| 	 # Create $dsttmp read-write so that cp doesn't create it read-only, | ||||
| 	 # which would cause strip to fail. | ||||
| 	 if test -z "$doit"; then | ||||
| 	   : >"$dsttmp" # No need to fork-exec 'touch'. | ||||
| 	 else | ||||
| 	   $doit touch "$dsttmp" | ||||
| 	 fi | ||||
|        } | ||||
|      } && | ||||
|      $doit_exec $cpprog "$src" "$dsttmp") && | ||||
| 
 | ||||
|     # and set any options; do chmod last to preserve setuid bits. | ||||
|     # | ||||
|     # If any of these fail, we abort the whole thing.  If we want to | ||||
|     # ignore errors from any of these, just make sure not to ignore | ||||
|     # errors from the above "$doit $cpprog $src $dsttmp" command. | ||||
|     # | ||||
|     { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } && | ||||
|     { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } && | ||||
|     { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } && | ||||
|     { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } && | ||||
| 
 | ||||
|     # If -C, don't bother to copy if it wouldn't change the file. | ||||
|     if $copy_on_change && | ||||
|        old=`LC_ALL=C ls -dlL "$dst"     2>/dev/null` && | ||||
|        new=`LC_ALL=C ls -dlL "$dsttmp"  2>/dev/null` && | ||||
|        set -f && | ||||
|        set X $old && old=:$2:$4:$5:$6 && | ||||
|        set X $new && new=:$2:$4:$5:$6 && | ||||
|        set +f && | ||||
|        test "$old" = "$new" && | ||||
|        $cmpprog "$dst" "$dsttmp" >/dev/null 2>&1 | ||||
|     then | ||||
|       rm -f "$dsttmp" | ||||
|     else | ||||
|       # Rename the file to the real destination. | ||||
|       $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null || | ||||
| 
 | ||||
|       # The rename failed, perhaps because mv can't rename something else | ||||
|       # to itself, or perhaps because mv is so ancient that it does not | ||||
|       # support -f. | ||||
|       { | ||||
|         # Now remove or move aside any old file at destination location. | ||||
|         # We try this two ways since rm can't unlink itself on some | ||||
|         # systems and the destination file might be busy for other | ||||
|         # reasons.  In this case, the final cleanup might fail but the new | ||||
|         # file should still install successfully. | ||||
|         { | ||||
|           test ! -f "$dst" || | ||||
|           $doit $rmcmd -f "$dst" 2>/dev/null || | ||||
|           { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null && | ||||
|             { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; } | ||||
|           } || | ||||
|           { echo "$0: cannot unlink or rename $dst" >&2 | ||||
|             (exit 1); exit 1 | ||||
|           } | ||||
|         } && | ||||
| 
 | ||||
|         # Now rename the file to the real destination. | ||||
|         $doit $mvcmd "$dsttmp" "$dst" | ||||
|       } | ||||
|     fi || exit 1 | ||||
| 
 | ||||
|     trap '' 0 | ||||
|   fi | ||||
| done | ||||
| 
 | ||||
| # Local variables: | ||||
| # eval: (add-hook 'before-save-hook 'time-stamp) | ||||
| # time-stamp-start: "scriptversion=" | ||||
| # time-stamp-format: "%:y-%02m-%02d.%02H" | ||||
| # time-stamp-time-zone: "UTC0" | ||||
| # time-stamp-end: "; # UTC" | ||||
| # End: | ||||
							
								
								
									
										228
									
								
								third_party/make/build-aux/mdate-sh
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										228
									
								
								third_party/make/build-aux/mdate-sh
									
										
									
									
										vendored
									
									
										Executable file
									
								
							|  | @ -0,0 +1,228 @@ | |||
| #!/bin/sh | ||||
| # Get modification time of a file or directory and pretty-print it. | ||||
| 
 | ||||
| scriptversion=2018-03-07.03; # UTC | ||||
| 
 | ||||
| # Copyright (C) 1995-2019 Free Software Foundation, Inc. | ||||
| # written by Ulrich Drepper <drepper@gnu.ai.mit.edu>, June 1995 | ||||
| # | ||||
| # This program is free software; you can redistribute it and/or modify | ||||
| # it under the terms of the GNU General Public License as published by | ||||
| # the Free Software Foundation; either version 2, or (at your option) | ||||
| # any later version. | ||||
| # | ||||
| # This program is distributed in the hope that it will be useful, | ||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| # GNU General Public License for more details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| # As a special exception to the GNU General Public License, if you | ||||
| # distribute this file as part of a program that contains a | ||||
| # configuration script generated by Autoconf, you may include it under | ||||
| # the same distribution terms that you use for the rest of that program. | ||||
| 
 | ||||
| # This file is maintained in Automake, please report | ||||
| # bugs to <bug-automake@gnu.org> or send patches to | ||||
| # <automake-patches@gnu.org>. | ||||
| 
 | ||||
| if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then | ||||
|   emulate sh | ||||
|   NULLCMD=: | ||||
|   # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which | ||||
|   # is contrary to our usage.  Disable this feature. | ||||
|   alias -g '${1+"$@"}'='"$@"' | ||||
|   setopt NO_GLOB_SUBST | ||||
| fi | ||||
| 
 | ||||
| case $1 in | ||||
|   '') | ||||
|      echo "$0: No file.  Try '$0 --help' for more information." 1>&2 | ||||
|      exit 1; | ||||
|      ;; | ||||
|   -h | --h*) | ||||
|     cat <<\EOF | ||||
| Usage: mdate-sh [--help] [--version] FILE | ||||
| 
 | ||||
| Pretty-print the modification day of FILE, in the format: | ||||
| 1 January 1970 | ||||
| 
 | ||||
| Report bugs to <bug-automake@gnu.org>. | ||||
| EOF | ||||
|     exit $? | ||||
|     ;; | ||||
|   -v | --v*) | ||||
|     echo "mdate-sh $scriptversion" | ||||
|     exit $? | ||||
|     ;; | ||||
| esac | ||||
| 
 | ||||
| error () | ||||
| { | ||||
|   echo "$0: $1" >&2 | ||||
|   exit 1 | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| # Prevent date giving response in another language. | ||||
| LANG=C | ||||
| export LANG | ||||
| LC_ALL=C | ||||
| export LC_ALL | ||||
| LC_TIME=C | ||||
| export LC_TIME | ||||
| 
 | ||||
| # Use UTC to get reproducible result. | ||||
| TZ=UTC0 | ||||
| export TZ | ||||
| 
 | ||||
| # GNU ls changes its time format in response to the TIME_STYLE | ||||
| # variable.  Since we cannot assume 'unset' works, revert this | ||||
| # variable to its documented default. | ||||
| if test "${TIME_STYLE+set}" = set; then | ||||
|   TIME_STYLE=posix-long-iso | ||||
|   export TIME_STYLE | ||||
| fi | ||||
| 
 | ||||
| save_arg1=$1 | ||||
| 
 | ||||
| # Find out how to get the extended ls output of a file or directory. | ||||
| if ls -L /dev/null 1>/dev/null 2>&1; then | ||||
|   ls_command='ls -L -l -d' | ||||
| else | ||||
|   ls_command='ls -l -d' | ||||
| fi | ||||
| # Avoid user/group names that might have spaces, when possible. | ||||
| if ls -n /dev/null 1>/dev/null 2>&1; then | ||||
|   ls_command="$ls_command -n" | ||||
| fi | ||||
| 
 | ||||
| # A 'ls -l' line looks as follows on OS/2. | ||||
| #  drwxrwx---        0 Aug 11  2001 foo | ||||
| # This differs from Unix, which adds ownership information. | ||||
| #  drwxrwx---   2 root  root      4096 Aug 11  2001 foo | ||||
| # | ||||
| # To find the date, we split the line on spaces and iterate on words | ||||
| # until we find a month.  This cannot work with files whose owner is a | ||||
| # user named "Jan", or "Feb", etc.  However, it's unlikely that '/' | ||||
| # will be owned by a user whose name is a month.  So we first look at | ||||
| # the extended ls output of the root directory to decide how many | ||||
| # words should be skipped to get the date. | ||||
| 
 | ||||
| # On HPUX /bin/sh, "set" interprets "-rw-r--r--" as options, so the "x" below. | ||||
| set x`$ls_command /` | ||||
| 
 | ||||
| # Find which argument is the month. | ||||
| month= | ||||
| command= | ||||
| until test $month | ||||
| do | ||||
|   test $# -gt 0 || error "failed parsing '$ls_command /' output" | ||||
|   shift | ||||
|   # Add another shift to the command. | ||||
|   command="$command shift;" | ||||
|   case $1 in | ||||
|     Jan) month=January; nummonth=1;; | ||||
|     Feb) month=February; nummonth=2;; | ||||
|     Mar) month=March; nummonth=3;; | ||||
|     Apr) month=April; nummonth=4;; | ||||
|     May) month=May; nummonth=5;; | ||||
|     Jun) month=June; nummonth=6;; | ||||
|     Jul) month=July; nummonth=7;; | ||||
|     Aug) month=August; nummonth=8;; | ||||
|     Sep) month=September; nummonth=9;; | ||||
|     Oct) month=October; nummonth=10;; | ||||
|     Nov) month=November; nummonth=11;; | ||||
|     Dec) month=December; nummonth=12;; | ||||
|   esac | ||||
| done | ||||
| 
 | ||||
| test -n "$month" || error "failed parsing '$ls_command /' output" | ||||
| 
 | ||||
| # Get the extended ls output of the file or directory. | ||||
| set dummy x`eval "$ls_command \"\\\$save_arg1\""` | ||||
| 
 | ||||
| # Remove all preceding arguments | ||||
| eval $command | ||||
| 
 | ||||
| # Because of the dummy argument above, month is in $2. | ||||
| # | ||||
| # On a POSIX system, we should have | ||||
| # | ||||
| # $# = 5 | ||||
| # $1 = file size | ||||
| # $2 = month | ||||
| # $3 = day | ||||
| # $4 = year or time | ||||
| # $5 = filename | ||||
| # | ||||
| # On Darwin 7.7.0 and 7.6.0, we have | ||||
| # | ||||
| # $# = 4 | ||||
| # $1 = day | ||||
| # $2 = month | ||||
| # $3 = year or time | ||||
| # $4 = filename | ||||
| 
 | ||||
| # Get the month. | ||||
| case $2 in | ||||
|   Jan) month=January; nummonth=1;; | ||||
|   Feb) month=February; nummonth=2;; | ||||
|   Mar) month=March; nummonth=3;; | ||||
|   Apr) month=April; nummonth=4;; | ||||
|   May) month=May; nummonth=5;; | ||||
|   Jun) month=June; nummonth=6;; | ||||
|   Jul) month=July; nummonth=7;; | ||||
|   Aug) month=August; nummonth=8;; | ||||
|   Sep) month=September; nummonth=9;; | ||||
|   Oct) month=October; nummonth=10;; | ||||
|   Nov) month=November; nummonth=11;; | ||||
|   Dec) month=December; nummonth=12;; | ||||
| esac | ||||
| 
 | ||||
| case $3 in | ||||
|   ???*) day=$1;; | ||||
|   *) day=$3; shift;; | ||||
| esac | ||||
| 
 | ||||
| # Here we have to deal with the problem that the ls output gives either | ||||
| # the time of day or the year. | ||||
| case $3 in | ||||
|   *:*) set `date`; eval year=\$$# | ||||
|        case $2 in | ||||
| 	 Jan) nummonthtod=1;; | ||||
| 	 Feb) nummonthtod=2;; | ||||
| 	 Mar) nummonthtod=3;; | ||||
| 	 Apr) nummonthtod=4;; | ||||
| 	 May) nummonthtod=5;; | ||||
| 	 Jun) nummonthtod=6;; | ||||
| 	 Jul) nummonthtod=7;; | ||||
| 	 Aug) nummonthtod=8;; | ||||
| 	 Sep) nummonthtod=9;; | ||||
| 	 Oct) nummonthtod=10;; | ||||
| 	 Nov) nummonthtod=11;; | ||||
| 	 Dec) nummonthtod=12;; | ||||
|        esac | ||||
|        # For the first six month of the year the time notation can also | ||||
|        # be used for files modified in the last year. | ||||
|        if (expr $nummonth \> $nummonthtod) > /dev/null; | ||||
|        then | ||||
| 	 year=`expr $year - 1` | ||||
|        fi;; | ||||
|   *) year=$3;; | ||||
| esac | ||||
| 
 | ||||
| # The result. | ||||
| echo $day $month $year | ||||
| 
 | ||||
| # Local Variables: | ||||
| # mode: shell-script | ||||
| # sh-indentation: 2 | ||||
| # eval: (add-hook 'before-save-hook 'time-stamp) | ||||
| # time-stamp-start: "scriptversion=" | ||||
| # time-stamp-format: "%:y-%02m-%02d.%02H" | ||||
| # time-stamp-time-zone: "UTC0" | ||||
| # time-stamp-end: "; # UTC" | ||||
| # End: | ||||
							
								
								
									
										215
									
								
								third_party/make/build-aux/missing
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										215
									
								
								third_party/make/build-aux/missing
									
										
									
									
										vendored
									
									
										Executable file
									
								
							|  | @ -0,0 +1,215 @@ | |||
| #! /bin/sh | ||||
| # Common wrapper for a few potentially missing GNU programs. | ||||
| 
 | ||||
| scriptversion=2018-03-07.03; # UTC | ||||
| 
 | ||||
| # Copyright (C) 1996-2018 Free Software Foundation, Inc. | ||||
| # Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996. | ||||
| 
 | ||||
| # This program is free software; you can redistribute it and/or modify | ||||
| # it under the terms of the GNU General Public License as published by | ||||
| # the Free Software Foundation; either version 2, or (at your option) | ||||
| # any later version. | ||||
| 
 | ||||
| # This program is distributed in the hope that it will be useful, | ||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| # GNU General Public License for more details. | ||||
| 
 | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| # As a special exception to the GNU General Public License, if you | ||||
| # distribute this file as part of a program that contains a | ||||
| # configuration script generated by Autoconf, you may include it under | ||||
| # the same distribution terms that you use for the rest of that program. | ||||
| 
 | ||||
| if test $# -eq 0; then | ||||
|   echo 1>&2 "Try '$0 --help' for more information" | ||||
|   exit 1 | ||||
| fi | ||||
| 
 | ||||
| case $1 in | ||||
| 
 | ||||
|   --is-lightweight) | ||||
|     # Used by our autoconf macros to check whether the available missing | ||||
|     # script is modern enough. | ||||
|     exit 0 | ||||
|     ;; | ||||
| 
 | ||||
|   --run) | ||||
|     # Back-compat with the calling convention used by older automake. | ||||
|     shift | ||||
|     ;; | ||||
| 
 | ||||
|   -h|--h|--he|--hel|--help) | ||||
|     echo "\ | ||||
| $0 [OPTION]... PROGRAM [ARGUMENT]... | ||||
| 
 | ||||
| Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due | ||||
| to PROGRAM being missing or too old. | ||||
| 
 | ||||
| Options: | ||||
|   -h, --help      display this help and exit | ||||
|   -v, --version   output version information and exit | ||||
| 
 | ||||
| Supported PROGRAM values: | ||||
|   aclocal   autoconf  autoheader   autom4te  automake  makeinfo | ||||
|   bison     yacc      flex         lex       help2man | ||||
| 
 | ||||
| Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and | ||||
| 'g' are ignored when checking the name. | ||||
| 
 | ||||
| Send bug reports to <bug-automake@gnu.org>." | ||||
|     exit $? | ||||
|     ;; | ||||
| 
 | ||||
|   -v|--v|--ve|--ver|--vers|--versi|--versio|--version) | ||||
|     echo "missing $scriptversion (GNU Automake)" | ||||
|     exit $? | ||||
|     ;; | ||||
| 
 | ||||
|   -*) | ||||
|     echo 1>&2 "$0: unknown '$1' option" | ||||
|     echo 1>&2 "Try '$0 --help' for more information" | ||||
|     exit 1 | ||||
|     ;; | ||||
| 
 | ||||
| esac | ||||
| 
 | ||||
| # Run the given program, remember its exit status. | ||||
| "$@"; st=$? | ||||
| 
 | ||||
| # If it succeeded, we are done. | ||||
| test $st -eq 0 && exit 0 | ||||
| 
 | ||||
| # Also exit now if we it failed (or wasn't found), and '--version' was | ||||
| # passed; such an option is passed most likely to detect whether the | ||||
| # program is present and works. | ||||
| case $2 in --version|--help) exit $st;; esac | ||||
| 
 | ||||
| # Exit code 63 means version mismatch.  This often happens when the user | ||||
| # tries to use an ancient version of a tool on a file that requires a | ||||
| # minimum version. | ||||
| if test $st -eq 63; then | ||||
|   msg="probably too old" | ||||
| elif test $st -eq 127; then | ||||
|   # Program was missing. | ||||
|   msg="missing on your system" | ||||
| else | ||||
|   # Program was found and executed, but failed.  Give up. | ||||
|   exit $st | ||||
| fi | ||||
| 
 | ||||
| perl_URL=https://www.perl.org/ | ||||
| flex_URL=https://github.com/westes/flex | ||||
| gnu_software_URL=https://www.gnu.org/software | ||||
| 
 | ||||
| program_details () | ||||
| { | ||||
|   case $1 in | ||||
|     aclocal|automake) | ||||
|       echo "The '$1' program is part of the GNU Automake package:" | ||||
|       echo "<$gnu_software_URL/automake>" | ||||
|       echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:" | ||||
|       echo "<$gnu_software_URL/autoconf>" | ||||
|       echo "<$gnu_software_URL/m4/>" | ||||
|       echo "<$perl_URL>" | ||||
|       ;; | ||||
|     autoconf|autom4te|autoheader) | ||||
|       echo "The '$1' program is part of the GNU Autoconf package:" | ||||
|       echo "<$gnu_software_URL/autoconf/>" | ||||
|       echo "It also requires GNU m4 and Perl in order to run:" | ||||
|       echo "<$gnu_software_URL/m4/>" | ||||
|       echo "<$perl_URL>" | ||||
|       ;; | ||||
|   esac | ||||
| } | ||||
| 
 | ||||
| give_advice () | ||||
| { | ||||
|   # Normalize program name to check for. | ||||
|   normalized_program=`echo "$1" | sed ' | ||||
|     s/^gnu-//; t | ||||
|     s/^gnu//; t | ||||
|     s/^g//; t'` | ||||
| 
 | ||||
|   printf '%s\n' "'$1' is $msg." | ||||
| 
 | ||||
|   configure_deps="'configure.ac' or m4 files included by 'configure.ac'" | ||||
|   case $normalized_program in | ||||
|     autoconf*) | ||||
|       echo "You should only need it if you modified 'configure.ac'," | ||||
|       echo "or m4 files included by it." | ||||
|       program_details 'autoconf' | ||||
|       ;; | ||||
|     autoheader*) | ||||
|       echo "You should only need it if you modified 'acconfig.h' or" | ||||
|       echo "$configure_deps." | ||||
|       program_details 'autoheader' | ||||
|       ;; | ||||
|     automake*) | ||||
|       echo "You should only need it if you modified 'Makefile.am' or" | ||||
|       echo "$configure_deps." | ||||
|       program_details 'automake' | ||||
|       ;; | ||||
|     aclocal*) | ||||
|       echo "You should only need it if you modified 'acinclude.m4' or" | ||||
|       echo "$configure_deps." | ||||
|       program_details 'aclocal' | ||||
|       ;; | ||||
|    autom4te*) | ||||
|       echo "You might have modified some maintainer files that require" | ||||
|       echo "the 'autom4te' program to be rebuilt." | ||||
|       program_details 'autom4te' | ||||
|       ;; | ||||
|     bison*|yacc*) | ||||
|       echo "You should only need it if you modified a '.y' file." | ||||
|       echo "You may want to install the GNU Bison package:" | ||||
|       echo "<$gnu_software_URL/bison/>" | ||||
|       ;; | ||||
|     lex*|flex*) | ||||
|       echo "You should only need it if you modified a '.l' file." | ||||
|       echo "You may want to install the Fast Lexical Analyzer package:" | ||||
|       echo "<$flex_URL>" | ||||
|       ;; | ||||
|     help2man*) | ||||
|       echo "You should only need it if you modified a dependency" \ | ||||
|            "of a man page." | ||||
|       echo "You may want to install the GNU Help2man package:" | ||||
|       echo "<$gnu_software_URL/help2man/>" | ||||
|     ;; | ||||
|     makeinfo*) | ||||
|       echo "You should only need it if you modified a '.texi' file, or" | ||||
|       echo "any other file indirectly affecting the aspect of the manual." | ||||
|       echo "You might want to install the Texinfo package:" | ||||
|       echo "<$gnu_software_URL/texinfo/>" | ||||
|       echo "The spurious makeinfo call might also be the consequence of" | ||||
|       echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might" | ||||
|       echo "want to install GNU make:" | ||||
|       echo "<$gnu_software_URL/make/>" | ||||
|       ;; | ||||
|     *) | ||||
|       echo "You might have modified some files without having the proper" | ||||
|       echo "tools for further handling them.  Check the 'README' file, it" | ||||
|       echo "often tells you about the needed prerequisites for installing" | ||||
|       echo "this package.  You may also peek at any GNU archive site, in" | ||||
|       echo "case some other package contains this missing '$1' program." | ||||
|       ;; | ||||
|   esac | ||||
| } | ||||
| 
 | ||||
| give_advice "$1" | sed -e '1s/^/WARNING: /' \ | ||||
|                        -e '2,$s/^/         /' >&2 | ||||
| 
 | ||||
| # Propagate the correct exit status (expected to be 127 for a program | ||||
| # not found, 63 for a program that failed due to version mismatch). | ||||
| exit $st | ||||
| 
 | ||||
| # Local variables: | ||||
| # eval: (add-hook 'before-save-hook 'time-stamp) | ||||
| # time-stamp-start: "scriptversion=" | ||||
| # time-stamp-format: "%:y-%02m-%02d.%02H" | ||||
| # time-stamp-time-zone: "UTC0" | ||||
| # time-stamp-end: "; # UTC" | ||||
| # End: | ||||
							
								
								
									
										11620
									
								
								third_party/make/build-aux/texinfo.tex
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										11620
									
								
								third_party/make/build-aux/texinfo.tex
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										38
									
								
								third_party/make/build.cfg.in
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								third_party/make/build.cfg.in
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,38 @@ | |||
| # Configuration for building GNU Make in the absence of any 'make' program. | ||||
| # @configure_input@ | ||||
| 
 | ||||
| # Copyright (C) 1993-2020 Free Software Foundation, Inc. | ||||
| # This file is part of GNU Make. | ||||
| # | ||||
| # GNU Make is free software; you can redistribute it and/or modify it under | ||||
| # the terms of the GNU General Public License as published by the Free Software | ||||
| # Foundation; either version 3 of the License, or (at your option) any later | ||||
| # version. | ||||
| # | ||||
| # GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS | ||||
| # FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more | ||||
| # details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License along with | ||||
| # this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| # See Makefile.in for comments describing these variables. | ||||
| 
 | ||||
| top_srcdir='@top_srcdir@' | ||||
| 
 | ||||
| prefix='@prefix@' | ||||
| exec_prefix=`eval echo @exec_prefix@` | ||||
| 
 | ||||
| CC='@CC@' | ||||
| AR='@AR@' | ||||
| CFLAGS='@CFLAGS@ @GUILE_CFLAGS@' | ||||
| CPPFLAGS='@CPPFLAGS@' | ||||
| DEFS='@DEFS@' | ||||
| ARFLAGS='@ARFLAGS@' | ||||
| LDFLAGS='@AM_LDFLAGS@ @LDFLAGS@' | ||||
| ALLOCA='@ALLOCA@' | ||||
| LOADLIBES='@LIBS@ @GUILE_LIBS@ @LIBINTL@' | ||||
| REMOTE='@REMOTE@' | ||||
| OBJEXT='@OBJEXT@' | ||||
| EXEEXT='@EXEEXT@' | ||||
							
								
								
									
										149
									
								
								third_party/make/build.sh
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										149
									
								
								third_party/make/build.sh
									
										
									
									
										vendored
									
									
										Executable file
									
								
							|  | @ -0,0 +1,149 @@ | |||
| #!/bin/sh | ||||
| # Shell script to build GNU Make in the absence of any 'make' program. | ||||
| 
 | ||||
| # Copyright (C) 1993-2020 Free Software Foundation, Inc. | ||||
| # This file is part of GNU Make. | ||||
| # | ||||
| # GNU Make is free software; you can redistribute it and/or modify it under | ||||
| # the terms of the GNU General Public License as published by the Free Software | ||||
| # Foundation; either version 3 of the License, or (at your option) any later | ||||
| # version. | ||||
| # | ||||
| # GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS | ||||
| # FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more | ||||
| # details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License along with | ||||
| # this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| # Get configure-generated values | ||||
| . ./build.cfg | ||||
| 
 | ||||
| : ${OUTDIR:=.} | ||||
| OUTLIB="$OUTDIR/lib" | ||||
| 
 | ||||
| # Directory to find libraries in for '-lXXX'. | ||||
| libdir=$exec_prefix/lib | ||||
| # Directory to search by default for included makefiles. | ||||
| includedir=$prefix/include | ||||
| 
 | ||||
| localedir=$prefix/share/locale | ||||
| 
 | ||||
| defines="-DLOCALEDIR=\"$localedir\" -DLIBDIR=\"$libdir\" -DINCLUDEDIR=\"$includedir\"" | ||||
| 
 | ||||
| # Look up a make variable value. | ||||
| # It can handle simple recursion where variables are separate words. | ||||
| # Print the value to stdout. | ||||
| get_mk_var () | ||||
| { | ||||
|   file=$1 | ||||
|   var=$2 | ||||
| 
 | ||||
|   val= | ||||
|   v=$(sed -e :a -e '/\\$/N; s/\\\n//; ta' "$file" | sed -n "s=^ *$var *\= *==p") | ||||
|   for w in $v; do | ||||
|     case $w in | ||||
|       (\$[\(\{]*[\)\}]) w=${w#\$[\(\{]}; w=$(get_mk_var "$file" "${w%[\)\}]}") ;; | ||||
|     esac | ||||
|     val="${val:+$val }$w" | ||||
|   done | ||||
| 
 | ||||
|   printf '%s\n' "$val" | ||||
| } | ||||
| 
 | ||||
| # Compile source files.  Object files are put into $objs. | ||||
| compile () | ||||
| { | ||||
|   objs= | ||||
|   for ofile in "$@"; do | ||||
|     file="${ofile%.$OBJEXT}.c" | ||||
|     echo "compiling $file..." | ||||
|     of="$OUTDIR/$ofile" | ||||
|     mkdir -p "${of%/*}" | ||||
|     $CC $cflags $CPPFLAGS $CFLAGS -c -o "$of" "$top_srcdir/$file" | ||||
|     objs="${objs:+$objs }$of" | ||||
|   done | ||||
| } | ||||
| 
 | ||||
| # Use config.status to convert a .in file.  Output file is put into $out. | ||||
| # $out will be empty if no conversion was needed. | ||||
| convert () | ||||
| { | ||||
|   out= | ||||
|   base=$1 | ||||
|   var="GENERATE_$(echo $base | tr 'a-z./+' A-Z__X)" | ||||
| 
 | ||||
|   # Is this file disabled? | ||||
|   grep "${var}_FALSE\"]=\"\"" config.status >/dev/null && return | ||||
| 
 | ||||
|   # Not disabled, so create it | ||||
|   in="$top_srcdir/lib/$(echo ${base%.*}.in.${base##*.} | tr / _)" | ||||
|   out="$OUTLIB/$base" | ||||
|   mkdir -p "${out%/*}" | ||||
| 
 | ||||
|   # First perform the normal replacements, using config.status | ||||
|   sed -e 's|@GUARD_PREFIX@|GL|g' \ | ||||
|       -e 's/@GNULIB_UNISTD_H_GETOPT@/0/g' \ | ||||
|       "$in" > "${out}_" | ||||
|   ./config.status --file "${out}__:${out}_" | ||||
|   int="${out}__" | ||||
| 
 | ||||
|   # Then see if there any files we need to include.  Unfortunately there's no | ||||
|   # algorithmic conversion so we just have to hard-code it. | ||||
|   incls=$(sed -n 's/.*definitions* of \(_[^ $]*\).*/\1/p' "$in") | ||||
| 
 | ||||
|   for inc in $incls; do | ||||
|     case $inc in | ||||
|       (_GL_FUNCDECL_RPL) fn=$(get_mk_var lib/Makefile CXXDEFS_H) ;; | ||||
|       (_GL_ARG_NONNULL)  fn=$(get_mk_var lib/Makefile ARG_NONNULL_H) ;; | ||||
|       (_GL_WARN_ON_USE)  fn=$(get_mk_var lib/Makefile WARN_ON_USE_H) ;; | ||||
|       (_Noreturn)        fn=$(get_mk_var lib/Makefile _NORETURN_H) ;; | ||||
|       (*) echo "Unknown file replacement: $inc"; exit 1 ;; | ||||
|     esac | ||||
| 
 | ||||
|     fn="$top_srcdir/lib/${fn##*/}" | ||||
|     [ -f "$fn" ] || { echo "Missing file: $fn"; exit 1; } | ||||
| 
 | ||||
|     sed "/definitions* of $inc/r $fn" "$int" > "${int}_" | ||||
|     int=${int}_ | ||||
|   done | ||||
| 
 | ||||
|   # Done! | ||||
|   mv "$int" "$out" | ||||
| } | ||||
| 
 | ||||
| # Get source files provided from gnulib and convert to object files | ||||
| LIBOBJS= | ||||
| for lo in $( (get_mk_var lib/Makefile libgnu_a_OBJECTS; get_mk_var lib/Makefile libgnu_a_LIBADD) | sed "s=\$[\(\{]OBJEXT[\)\}]=$OBJEXT=g"); do | ||||
|   LIBOBJS="${LIBOBJS:+$LIBOBJS }lib/$lo" | ||||
| done | ||||
| 
 | ||||
| # Get object files from the Makefile | ||||
| OBJS=$(get_mk_var Makefile make_OBJECTS | sed "s=\$[\(\{]OBJEXT[\)\}]=$OBJEXT=g") | ||||
| 
 | ||||
| # Exit as soon as any command fails. | ||||
| set -e | ||||
| 
 | ||||
| # Generate gnulib header files that would normally be created by make | ||||
| for b in $(get_mk_var lib/Makefile BUILT_SOURCES); do | ||||
|     convert $b | ||||
| done | ||||
| 
 | ||||
| # Build the gnulib library | ||||
| cflags="$DEFS -I$OUTLIB -Ilib -I$top_srcdir/lib -I$OUTDIR/src -Isrc -I$top_srcdir/src" | ||||
| compile $LIBOBJS | ||||
| 
 | ||||
| echo "creating libgnu.a..." | ||||
| $AR $ARFLAGS "$OUTLIB"/libgnu.a $objs | ||||
| 
 | ||||
| # Compile the source files into those objects. | ||||
| cflags="$DEFS $defines -I$OUTDIR/src -Isrc -I$top_srcdir/src -I$OUTLIB -Ilib -I$top_srcdir/lib" | ||||
| compile $OBJS | ||||
| 
 | ||||
| # Link all the objects together. | ||||
| echo "linking make..." | ||||
| $CC $CFLAGS $LDFLAGS -L"$OUTLIB" $objs -lgnu $LOADLIBES -o "$OUTDIR/makenew$EXEEXT" | ||||
| mv -f "$OUTDIR/makenew$EXEEXT" "$OUTDIR/make$EXEEXT" | ||||
| 
 | ||||
| echo done. | ||||
							
								
								
									
										402
									
								
								third_party/make/build_w32.bat
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										402
									
								
								third_party/make/build_w32.bat
									
										
									
									
										vendored
									
									
										Executable file
									
								
							|  | @ -0,0 +1,402 @@ | |||
| @echo off | ||||
| :: Copyright (C) 1996-2020 Free Software Foundation, Inc. | ||||
| :: This file is part of GNU Make. | ||||
| :: | ||||
| :: GNU Make is free software; you can redistribute it and/or modify it under | ||||
| :: the terms of the GNU General Public License as published by the Free | ||||
| :: Software Foundation; either version 3 of the License, or (at your option) | ||||
| :: any later version. | ||||
| :: | ||||
| :: GNU Make is distributed in the hope that it will be useful, but WITHOUT | ||||
| :: ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||||
| :: FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for. | ||||
| :: more details. | ||||
| :: | ||||
| :: You should have received a copy of the GNU General Public License along | ||||
| :: with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| setlocal | ||||
| if not "%RECURSEME%"=="%~0" ( | ||||
|     set "RECURSEME=%~0" | ||||
|     %ComSpec% /s /c ""%~0" %*" | ||||
|     goto :EOF | ||||
| ) | ||||
| 
 | ||||
| call :Reset | ||||
| 
 | ||||
| if "%1" == "-h" goto Usage | ||||
| if "%1" == "--help" goto Usage | ||||
| 
 | ||||
| echo. | ||||
| echo Creating GNU Make for Windows 9X/NT/2K/XP/Vista/7/8/10 | ||||
| echo. | ||||
| 
 | ||||
| set MAKE=gnumake | ||||
| set GUILE=Y | ||||
| set COMPILER=cl.exe | ||||
| set O=obj | ||||
| set ARCH=x64 | ||||
| set DEBUG=N | ||||
| 
 | ||||
| if exist maintMakefile ( | ||||
|     set MAINT=Y | ||||
| ) else ( | ||||
|     set MAINT=N | ||||
| ) | ||||
| 
 | ||||
| :ParseSW | ||||
| if "%1" == "--debug" goto SetDebug | ||||
| if "%1" == "--without-guile" goto NoGuile | ||||
| if "%1" == "--x86" goto Set32Bit | ||||
| if "%1" == "gcc" goto SetCC | ||||
| if "%1" == "" goto DoneSW | ||||
| goto Usage | ||||
| 
 | ||||
| :SetDebug | ||||
| set DEBUG=Y | ||||
| echo - Building without compiler optimizations | ||||
| shift | ||||
| goto ParseSW | ||||
| 
 | ||||
| :NoGuile | ||||
| set GUILE=N | ||||
| echo - Building without Guile | ||||
| shift | ||||
| goto ParseSW | ||||
| 
 | ||||
| :Set32Bit | ||||
| set ARCH=x86 | ||||
| echo - Building 32bit GNU Make | ||||
| shift | ||||
| goto ParseSW | ||||
| 
 | ||||
| :SetCC | ||||
| set COMPILER=gcc | ||||
| set O=o | ||||
| echo - Building with GCC | ||||
| shift | ||||
| goto ParseSW | ||||
| 
 | ||||
| :DoneSW | ||||
| if "%MAINT%" == "Y" echo - Enabling maintainer mode | ||||
| 
 | ||||
| if "%COMPILER%" == "gcc" goto FindGcc | ||||
| 
 | ||||
| :: Find a compiler.  Visual Studio requires a lot of effort to locate :-/. | ||||
| %COMPILER% >nul 2>&1 | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| :: Visual Studio 17 and above provides the "vswhere" tool | ||||
| call :FindVswhere | ||||
| if ERRORLEVEL 1 goto LegacyVS | ||||
| 
 | ||||
| for /f "tokens=* usebackq" %%i in (`%VSWHERE% -latest -property installationPath`) do ( | ||||
|     set InstallPath=%%i | ||||
| ) | ||||
| set "VSVARS=%InstallPath%\VC\Auxiliary\Build\vcvarsall.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| :: No "vswhere" or it can't find a compiler.  Go old-school. | ||||
| :LegacyVS | ||||
| set "VSVARS=%VS150COMNTOOLS%\..\..\VC\vcvarsall.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| set "VSVARS=%VS140COMNTOOLS%\..\..\VC\vcvarsall.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| set "VSVARS=%VS120COMNTOOLS%\..\..\VC\vcvarsall.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| set "VSVARS=%VS110COMNTOOLS%\..\..\VC\vcvarsall.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| set "VSVARS=%VS100COMNTOOLS%\..\..\VC\vcvarsall.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| set "VSVARS=%VS90COMNTOOLS%\..\..\VC\vcvarsall.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| set "VSVARS=%VS80COMNTOOLS%\..\..\VC\vcvarsall.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| set "VSVARS=%VS71COMNTOOLS%\..\..\VC\vcvarsall.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| set "VSVARS=%VS70COMNTOOLS%\..\..\VC\vcvarsall.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| set "VSVARS=%V6TOOLS%\VC98\Bin\vcvars32.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| set "VSVARS=%V6TOOLS%\VC97\Bin\vcvars32.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| set "VSVARS=%V5TOOLS%\VC\Bin\vcvars32.bat" | ||||
| call :CheckMSVC | ||||
| if not ERRORLEVEL 1 goto FoundMSVC | ||||
| 
 | ||||
| :: We did not find anything--fail | ||||
| echo No MSVC compiler available. | ||||
| echo Please run vcvarsall.bat and/or configure your Path. | ||||
| exit 1 | ||||
| 
 | ||||
| :FoundMSVC | ||||
| set OUTDIR=.\WinRel | ||||
| set LNKOUT=./WinRel | ||||
| set "OPTS=/O2 /D NDEBUG" | ||||
| set LINKOPTS= | ||||
| if "%DEBUG%" == "Y" set OUTDIR=.\WinDebug | ||||
| if "%DEBUG%" == "Y" set LNKOUT=./WinDebug | ||||
| if "%DEBUG%" == "Y" set "OPTS=/Zi /Od /D _DEBUG" | ||||
| if "%DEBUG%" == "Y" set LINKOPTS=/DEBUG | ||||
| if "%MAINT%" == "Y" set "OPTS=%OPTS% /D MAKE_MAINTAINER_MODE" | ||||
| :: Show the compiler version that we found | ||||
| :: Unfortunately this also shows a "usage" note; I can't find anything better. | ||||
| echo. | ||||
| %COMPILER% | ||||
| goto Build | ||||
| 
 | ||||
| :FindGcc | ||||
| set OUTDIR=.\GccRel | ||||
| set LNKOUT=./GccRel | ||||
| set OPTS=-O2 | ||||
| if "%DEBUG%" == "Y" set OPTS=-O0 | ||||
| if "%DEBUG%" == "Y" set OUTDIR=.\GccDebug | ||||
| if "%DEBUG%" == "Y" set LNKOUT=./GccDebug | ||||
| if "%MAINT%" == "Y" set "OPTS=%OPTS% -DMAKE_MAINTAINER_MODE" | ||||
| :: Show the compiler version that we found | ||||
| echo. | ||||
| %COMPILER% --version | ||||
| if not ERRORLEVEL 1 goto Build | ||||
| echo No %COMPILER% found. | ||||
| exit 1 | ||||
| 
 | ||||
| :Build | ||||
| :: Clean the directory if it exists | ||||
| if exist %OUTDIR%\nul rmdir /S /Q %OUTDIR% | ||||
| 
 | ||||
| :: Recreate it | ||||
| mkdir %OUTDIR% | ||||
| mkdir %OUTDIR%\src | ||||
| mkdir %OUTDIR%\src\w32 | ||||
| mkdir %OUTDIR%\src\w32\compat | ||||
| mkdir %OUTDIR%\src\w32\subproc | ||||
| mkdir %OUTDIR%\lib | ||||
| 
 | ||||
| if "%GUILE%" == "Y" call :ChkGuile | ||||
| 
 | ||||
| echo. | ||||
| echo Compiling %OUTDIR% version | ||||
| 
 | ||||
| if exist src\config.h.W32.template call :ConfigSCM | ||||
| copy src\config.h.W32 %OUTDIR%\src\config.h | ||||
| 
 | ||||
| copy lib\glob.in.h %OUTDIR%\lib\glob.h | ||||
| copy lib\fnmatch.in.h %OUTDIR%\lib\fnmatch.h | ||||
| 
 | ||||
| if exist %OUTDIR%\link.sc del %OUTDIR%\link.sc | ||||
| 
 | ||||
| call :Compile src/ar | ||||
| call :Compile src/arscan | ||||
| call :Compile src/commands | ||||
| call :Compile src/default | ||||
| call :Compile src/dir | ||||
| call :Compile src/expand | ||||
| call :Compile src/file | ||||
| call :Compile src/function | ||||
| call :Compile src/getopt | ||||
| call :Compile src/getopt1 | ||||
| call :Compile src/guile GUILE | ||||
| call :Compile src/hash | ||||
| call :Compile src/implicit | ||||
| call :Compile src/job | ||||
| call :Compile src/load | ||||
| call :Compile src/loadapi | ||||
| call :Compile src/main GUILE | ||||
| call :Compile src/misc | ||||
| call :Compile src/output | ||||
| call :Compile src/read | ||||
| call :Compile src/remake | ||||
| call :Compile src/remote-stub | ||||
| call :Compile src/rule | ||||
| call :Compile src/signame | ||||
| call :Compile src/strcache | ||||
| call :Compile src/variable | ||||
| call :Compile src/version | ||||
| call :Compile src/vpath | ||||
| call :Compile src/w32/pathstuff | ||||
| call :Compile src/w32/w32os | ||||
| call :Compile src/w32/compat/posixfcn | ||||
| call :Compile src/w32/subproc/misc | ||||
| call :Compile src/w32/subproc/sub_proc | ||||
| call :Compile src/w32/subproc/w32err | ||||
| call :Compile lib/fnmatch | ||||
| call :Compile lib/glob | ||||
| call :Compile lib/getloadavg | ||||
| 
 | ||||
| if not "%COMPILER%" == "gcc" call :Compile src\w32\compat\dirent | ||||
| 
 | ||||
| call :Link | ||||
| 
 | ||||
| echo. | ||||
| if exist %OUTDIR%\%MAKE%.exe goto Success | ||||
| echo %OUTDIR% build FAILED! | ||||
| exit 1 | ||||
| 
 | ||||
| :Success | ||||
| echo %OUTDIR% build succeeded. | ||||
| if exist Basic.mk copy /Y Basic.mk Makefile | ||||
| if not exist tests\config-flags.pm copy /Y tests\config-flags.pm.W32 tests\config-flags.pm | ||||
| call :Reset | ||||
| goto :EOF | ||||
| 
 | ||||
| :: | ||||
| :: Subroutines | ||||
| :: | ||||
| 
 | ||||
| :Compile | ||||
| echo %LNKOUT%/%1.%O% >>%OUTDIR%\link.sc | ||||
| set EXTRAS= | ||||
| if "%2" == "GUILE" set "EXTRAS=%GUILECFLAGS%" | ||||
| if exist "%OUTDIR%\%1.%O%" del "%OUTDIR%\%1.%O%" | ||||
| if "%COMPILER%" == "gcc" goto GccCompile | ||||
| 
 | ||||
| :: MSVC Compile | ||||
| echo on | ||||
| %COMPILER% /nologo /MT /W4 /EHsc %OPTS% /I %OUTDIR%/src /I src /I %OUTDIR%/lib /I lib /I src/w32/include /D WINDOWS32 /D WIN32 /D _CONSOLE /D HAVE_CONFIG_H /FR%OUTDIR% /Fp%OUTDIR%\%MAKE%.pch /Fo%OUTDIR%\%1.%O% /Fd%OUTDIR%\%MAKE%.pdb %EXTRAS% /c %1.c | ||||
| @echo off | ||||
| goto CompileDone | ||||
| 
 | ||||
| :GccCompile | ||||
| :: GCC Compile | ||||
| echo on | ||||
| %COMPILER% -mthreads -Wall -std=gnu99 -gdwarf-2 -g3 %OPTS% -I%OUTDIR%/src -I./src -I%OUTDIR%/lib -I./lib -I./src/w32/include -DWINDOWS32 -DHAVE_CONFIG_H %EXTRAS% -o %OUTDIR%/%1.%O% -c %1.c | ||||
| @echo off | ||||
| 
 | ||||
| :CompileDone | ||||
| if not exist "%OUTDIR%\%1.%O%" exit 1 | ||||
| goto :EOF | ||||
| 
 | ||||
| :Link | ||||
| echo. | ||||
| echo Linking %LNKOUT%/%MAKE%.exe | ||||
| if "%COMPILER%" == "gcc" goto GccLink | ||||
| 
 | ||||
| :: MSVC Link | ||||
| echo %GUILELIBS% kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib >>%OUTDIR%\link.sc | ||||
| echo on | ||||
| link.exe /NOLOGO /SUBSYSTEM:console /PDB:%LNKOUT%\%MAKE%.pdb %LINKOPTS% /OUT:%LNKOUT%\%MAKE%.exe @%LNKOUT%\link.sc | ||||
| @echo off | ||||
| goto :EOF | ||||
| 
 | ||||
| :GccLink | ||||
| :: GCC Link | ||||
| echo on | ||||
| echo %GUILELIBS% -lkernel32 -luser32 -lgdi32 -lwinspool -lcomdlg32 -ladvapi32 -lshell32 -lole32 -loleaut32 -luuid -lodbc32 -lodbccp32 >>%OUTDIR%\link.sc | ||||
| %COMPILER% -mthreads -gdwarf-2 -g3 %OPTS% -o %LNKOUT%/%MAKE%.exe @%LNKOUT%/link.sc -Wl,--out-implib=%LNKOUT%/libgnumake-1.dll.a | ||||
| @echo off | ||||
| goto :EOF | ||||
| 
 | ||||
| :ConfigSCM | ||||
| echo Generating config from SCM templates | ||||
| sed -n "s/^AC_INIT(\[GNU make\],\[\([^]]\+\)\].*/s,%%VERSION%%,\1,g/p" configure.ac > %OUTDIR%\src\config.h.W32.sed | ||||
| echo s,%%PACKAGE%%,make,g >> %OUTDIR%\src\config.h.W32.sed | ||||
| sed -f %OUTDIR%\src\config.h.W32.sed src\config.h.W32.template > src\config.h.W32 | ||||
| echo static const char *const GUILE_module_defn = ^" \ > src\gmk-default.h | ||||
| sed -e "s/;.*//" -e "/^[ \t]*$/d" -e "s/\"/\\\\\"/g" -e "s/$/ \\\/" src\gmk-default.scm >> src\gmk-default.h | ||||
| echo ^";>> src\gmk-default.h | ||||
| goto :EOF | ||||
| 
 | ||||
| :ChkGuile | ||||
| :: Build with Guile is supported only on NT and later versions | ||||
| if not "%OS%" == "Windows_NT" goto NoGuile | ||||
| pkg-config --help > %OUTDIR%\guile.tmp 2> NUL | ||||
| if ERRORLEVEL 1 goto NoPkgCfg | ||||
| 
 | ||||
| echo Checking for Guile 2.0 | ||||
| if not "%COMPILER%" == "gcc" set PKGMSC=--msvc-syntax | ||||
| pkg-config --cflags --short-errors "guile-2.0" > %OUTDIR%\guile.tmp | ||||
| if not ERRORLEVEL 1 set /P GUILECFLAGS= < %OUTDIR%\guile.tmp | ||||
| 
 | ||||
| pkg-config --libs --static --short-errors %PKGMSC% "guile-2.0" > %OUTDIR%\guile.tmp | ||||
| if not ERRORLEVEL 1 set /P GUILELIBS= < %OUTDIR%\guile.tmp | ||||
| 
 | ||||
| if not "%GUILECFLAGS%" == "" goto GuileDone | ||||
| 
 | ||||
| echo Checking for Guile 1.8 | ||||
| pkg-config --cflags --short-errors "guile-1.8" > %OUTDIR%\guile.tmp | ||||
| if not ERRORLEVEL 1 set /P GUILECFLAGS= < %OUTDIR%\guile.tmp | ||||
| 
 | ||||
| pkg-config --libs --static --short-errors %PKGMSC% "guile-1.8" > %OUTDIR%\guile.tmp | ||||
| if not ERRORLEVEL 1 set /P GUILELIBS= < %OUTDIR%\guile.tmp | ||||
| 
 | ||||
| if not "%GUILECFLAGS%" == "" goto GuileDone | ||||
| 
 | ||||
| echo - No Guile found, building without Guile | ||||
| goto GuileDone | ||||
| 
 | ||||
| :NoPkgCfg | ||||
| echo - pkg-config not found, building without Guile | ||||
| 
 | ||||
| :GuileDone | ||||
| if "%GUILECFLAGS%" == "" goto :EOF | ||||
| 
 | ||||
| echo - Guile found: building with Guile | ||||
| set "GUILECFLAGS=%GUILECFLAGS% -DHAVE_GUILE" | ||||
| goto :EOF | ||||
| 
 | ||||
| :FindVswhere | ||||
| set VSWHERE=vswhere | ||||
| %VSWHERE% -help >nul 2>&1 | ||||
| if not ERRORLEVEL 1 exit /b 0 | ||||
| set "VSWHERE=C:\Program Files (x86)\Microsoft Visual Studio\Installer\vswhere" | ||||
| %VSWHERE% -help >nul 2>&1 | ||||
| if ERRORLEVEL 1 exit /b 1 | ||||
| goto :EOF | ||||
| 
 | ||||
| :CheckMSVC | ||||
| if not exist "%VSVARS%" exit /b 1 | ||||
| call "%VSVARS%" %ARCH% | ||||
| if ERRORLEVEL 1 exit /b 1 | ||||
| %COMPILER% >nul 2>&1 | ||||
| if ERRORLEVEL 1 exit /b 1 | ||||
| goto :EOF | ||||
| 
 | ||||
| :Usage | ||||
| echo Usage: %0 [options] [gcc] | ||||
| echo Options: | ||||
| echo.  --without-guile   Do not compile Guile support even if found | ||||
| echo.  --debug           Make a Debug build--default is Release | ||||
| echo.  --x86             Make a 32bit binary--default is 64bit | ||||
| echo.  --help            Display these instructions and exit | ||||
| goto :EOF | ||||
| 
 | ||||
| :Reset | ||||
| set ARCH= | ||||
| set COMPILER= | ||||
| set DEBUG= | ||||
| set GUILE= | ||||
| set GUILECFLAGS= | ||||
| set GUILELIBS= | ||||
| set LINKOPTS= | ||||
| set MAKE= | ||||
| set NOGUILE= | ||||
| set O= | ||||
| set OPTS= | ||||
| set OUTDIR= | ||||
| set LNKOUT= | ||||
| set PKGMSC= | ||||
| set VSVARS= | ||||
| goto :EOF | ||||
							
								
								
									
										95
									
								
								third_party/make/builddos.bat
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										95
									
								
								third_party/make/builddos.bat
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,95 @@ | |||
| @echo off | ||||
| rem Copyright (C) 1998-2020 Free Software Foundation, Inc. | ||||
| rem This file is part of GNU Make. | ||||
| rem | ||||
| rem GNU Make is free software; you can redistribute it and/or modify it under | ||||
| rem the terms of the GNU General Public License as published by the Free | ||||
| rem Software Foundation; either version 3 of the License, or (at your option) | ||||
| rem any later version. | ||||
| rem | ||||
| rem GNU Make is distributed in the hope that it will be useful, but WITHOUT | ||||
| rem ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||||
| rem FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for. | ||||
| rem more details. | ||||
| rem | ||||
| rem You should have received a copy of the GNU General Public License along | ||||
| rem with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| echo Building Make for MSDOS with DJGPP | ||||
| 
 | ||||
| rem The SmallEnv trick protects against too small environment block, | ||||
| rem in which case the values will be truncated and the whole thing | ||||
| rem goes awry.  COMMAND.COM will say "Out of environment space", but | ||||
| rem many people don't care, so we force them to care by refusing to go. | ||||
| 
 | ||||
| rem Where is the srcdir? | ||||
| set XSRC=. | ||||
| if not "%XSRC%"=="." goto SmallEnv | ||||
| if "%1%"=="" goto SrcDone | ||||
| if "%1%"=="." goto SrcDone | ||||
| set XSRC=%1 | ||||
| 
 | ||||
| if not "%XSRC%"=="%1" goto SmallEnv | ||||
| 
 | ||||
| :SrcDone | ||||
| 
 | ||||
| if not exist src mkdir src | ||||
| if not exist lib mkdir lib | ||||
| 
 | ||||
| copy /Y %XSRC%\src\configh.dos .\src\config.h | ||||
| 
 | ||||
| copy /Y %XSRC%\lib\glob.in.h .\lib\glob.h | ||||
| copy /Y %XSRC%\lib\fnmatch.in.h .\lib\fnmatch.h | ||||
| 
 | ||||
| rem Echo ON so they will see what is going on. | ||||
| @echo on | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/commands.c -o commands.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/output.c -o output.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/job.c -o job.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/dir.c -o dir.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/file.c -o file.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/misc.c -o misc.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/main.c -o main.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -DINCLUDEDIR=\"c:/djgpp/include\" -O2 -g %XSRC%/src/read.c -o read.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -DLIBDIR=\"c:/djgpp/lib\" -O2 -g %XSRC%/src/remake.c -o remake.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/rule.c -o rule.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/implicit.c -o implicit.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/default.c -o default.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/variable.c -o variable.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/expand.c -o eyxpand.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/function.c -o function.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/vpath.c -o vpath.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/hash.c -o hash.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/strcache.c -o strcache.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/version.c -o version.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/ar.c -o ar.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/arscan.c -o arscan.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/signame.c -o signame.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/remote-stub.c -o remote-stub.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/getopt.c -o getopt.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/src/getopt1.c -o getopt1.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/lib/glob.c -o lib/glob.o | ||||
| gcc -c -I./src -I%XSRC%/src -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/lib/fnmatch.c -o lib/fnmatch.o | ||||
| @echo off | ||||
| echo commands.o > respf.$$$ | ||||
| for %%f in (job output dir file misc main read remake rule implicit default variable) do echo %%f.o >> respf.$$$ | ||||
| for %%f in (expand function vpath hash strcache version ar arscan signame remote-stub getopt getopt1) do echo %%f.o >> respf.$$$ | ||||
| for %%f in (lib\glob lib\fnmatch) do echo %%f.o >> respf.$$$ | ||||
| rem gcc  -c -I./src -I%XSRC% -I./lib -I%XSRC%/lib -DHAVE_CONFIG_H -O2 -g %XSRC%/guile.c -o guile.o | ||||
| rem echo guile.o >> respf.$$$ | ||||
| @echo Linking... | ||||
| @echo on | ||||
| gcc -o make.exe @respf.$$$ | ||||
| @echo off | ||||
| if not exist make.exe echo Make.exe build failed... | ||||
| if exist make.exe echo make.exe is now built! | ||||
| if exist make.exe del respf.$$$ | ||||
| if exist make.exe copy /Y Basic.mk Makefile | ||||
| goto End | ||||
| 
 | ||||
| :SmallEnv | ||||
| echo Your environment is too small.  Please enlarge it and run me again. | ||||
| 
 | ||||
| :End | ||||
| set XRSC= | ||||
| @echo on | ||||
							
								
								
									
										19666
									
								
								third_party/make/configure
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										19666
									
								
								third_party/make/configure
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										538
									
								
								third_party/make/configure.ac
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										538
									
								
								third_party/make/configure.ac
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,538 @@ | |||
| # Process this file with autoconf to produce a configure script. | ||||
| # | ||||
| # Copyright (C) 1993-2020 Free Software Foundation, Inc. | ||||
| # This file is part of GNU Make. | ||||
| # | ||||
| # GNU Make is free software; you can redistribute it and/or modify it under | ||||
| # the terms of the GNU General Public License as published by the Free Software | ||||
| # Foundation; either version 3 of the License, or (at your option) any later | ||||
| # version. | ||||
| # | ||||
| # GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS | ||||
| # FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more | ||||
| # details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License along with | ||||
| # this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| AC_INIT([GNU make],[4.3],[bug-make@gnu.org]) | ||||
| 
 | ||||
| AC_PREREQ([2.69]) | ||||
| 
 | ||||
| # Autoconf setup | ||||
| AC_CONFIG_AUX_DIR([build-aux]) | ||||
| AC_CONFIG_SRCDIR([src/vpath.c]) | ||||
| AC_CONFIG_HEADERS([src/config.h]) | ||||
| 
 | ||||
| AC_CONFIG_LIBOBJ_DIR([lib]) | ||||
| 
 | ||||
| # Automake setup | ||||
| # We have to enable "foreign" because ChangeLog is auto-generated | ||||
| # Automake 1.15 and gnulib don't get along: gnulib has some strange error | ||||
| # in the way it handles getloadavg.c which causes make distcheck to fail. | ||||
| # http://lists.gnu.org/archive/html/bug-gnulib/2018-06/msg00024.html | ||||
| AM_INIT_AUTOMAKE([1.16.1 foreign -Werror -Wall]) | ||||
| 
 | ||||
| # Checks for programs. | ||||
| AC_USE_SYSTEM_EXTENSIONS | ||||
| AC_PROG_CC | ||||
| 
 | ||||
| # Configure gnulib | ||||
| gl_EARLY | ||||
| gl_INIT | ||||
| 
 | ||||
| AC_PROG_INSTALL | ||||
| AC_PROG_RANLIB | ||||
| AC_PROG_CPP | ||||
| AC_CHECK_PROG([AR], [ar], [ar], [ar]) | ||||
| # Perl is needed for the test suite (only) | ||||
| AC_CHECK_PROG([PERL], [perl], [perl], [perl]) | ||||
| 
 | ||||
| # Specialized system macros | ||||
| AC_CANONICAL_HOST | ||||
| AC_AIX | ||||
| AC_ISC_POSIX | ||||
| AC_MINIX | ||||
| AC_C_BIGENDIAN | ||||
| 
 | ||||
| # Enable gettext, in "external" mode. | ||||
| AM_GNU_GETTEXT_VERSION([0.19.4]) | ||||
| AM_GNU_GETTEXT([external]) | ||||
| 
 | ||||
| # This test must come as early as possible after the compiler configuration | ||||
| # tests, because the choice of the file model can (in principle) affect | ||||
| # whether functions and headers are available, whether they work, etc. | ||||
| AC_SYS_LARGEFILE | ||||
| 
 | ||||
| # Checks for libraries. | ||||
| AC_SEARCH_LIBS([getpwnam], [sun]) | ||||
| 
 | ||||
| # Checks for header files. | ||||
| AC_HEADER_STDC | ||||
| AC_HEADER_DIRENT | ||||
| AC_HEADER_STAT | ||||
| AC_HEADER_TIME | ||||
| AC_CHECK_HEADERS([stdlib.h locale.h unistd.h limits.h fcntl.h string.h \ | ||||
|                   memory.h sys/param.h sys/resource.h sys/time.h sys/timeb.h \ | ||||
|                   sys/select.h sys/file.h spawn.h]) | ||||
| 
 | ||||
| AM_PROG_CC_C_O | ||||
| AC_C_CONST | ||||
| AC_TYPE_SIGNAL | ||||
| AC_TYPE_UID_T | ||||
| AC_TYPE_PID_T | ||||
| AC_TYPE_OFF_T | ||||
| AC_TYPE_SIZE_T | ||||
| AC_TYPE_SSIZE_T | ||||
| AC_TYPE_UINTMAX_T | ||||
| 
 | ||||
| # Find out whether our struct stat returns nanosecond resolution timestamps. | ||||
| 
 | ||||
| AC_STRUCT_ST_MTIM_NSEC | ||||
| AC_CACHE_CHECK([whether to use high resolution file timestamps], | ||||
|                [make_cv_file_timestamp_hi_res], | ||||
| [ make_cv_file_timestamp_hi_res=no | ||||
|   AS_IF([test "$ac_cv_struct_st_mtim_nsec" != no], | ||||
|         [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[ | ||||
| #if HAVE_INTTYPES_H | ||||
| # include <inttypes.h> | ||||
| #endif]], | ||||
|                       [[char a[0x7fffffff < (uintmax_t)-1 >> 30 ? 1 : -1];]])], | ||||
|         [make_cv_file_timestamp_hi_res=yes]) | ||||
|   ])]) | ||||
| AS_IF([test "$make_cv_file_timestamp_hi_res" = yes], [val=1], [val=0]) | ||||
| AC_DEFINE_UNQUOTED([FILE_TIMESTAMP_HI_RES], [$val], | ||||
|                    [Use high resolution file timestamps if nonzero.]) | ||||
| 
 | ||||
| AS_IF([test "$make_cv_file_timestamp_hi_res" = yes], | ||||
| [ # Solaris 2.5.1 needs -lposix4 to get the clock_gettime function. | ||||
|   # Solaris 7 prefers the library name -lrt to the obsolescent name -lposix4. | ||||
|   AC_SEARCH_LIBS([clock_gettime], [rt posix4]) | ||||
|   AS_IF([test "$ac_cv_search_clock_gettime" != no], | ||||
|   [ AC_DEFINE([HAVE_CLOCK_GETTIME], [1], | ||||
|               [Define to 1 if you have the clock_gettime function.]) | ||||
|   ]) | ||||
| ]) | ||||
| 
 | ||||
| # Check for DOS-style pathnames. | ||||
| pds_AC_DOS_PATHS | ||||
| 
 | ||||
| # See if we have a standard version of gettimeofday().  Since actual | ||||
| # implementations can differ, just make sure we have the most common | ||||
| # one. | ||||
| AC_CACHE_CHECK([for standard gettimeofday], [ac_cv_func_gettimeofday], | ||||
|   [ac_cv_func_gettimeofday=no | ||||
|    AC_RUN_IFELSE([AC_LANG_SOURCE([[#include <sys/time.h> | ||||
|                   int main () | ||||
|                   { | ||||
|                     struct timeval t; t.tv_sec = -1; t.tv_usec = -1; | ||||
|                     return gettimeofday (&t, 0) != 0 | ||||
|                           || t.tv_sec < 0 || t.tv_usec < 0; | ||||
|                   }]])], | ||||
|                   [ac_cv_func_gettimeofday=yes], | ||||
|                   [ac_cv_func_gettimeofday=no], | ||||
|                   [ac_cv_func_gettimeofday="no (cross-compiling)"])]) | ||||
| AS_IF([test "$ac_cv_func_gettimeofday" = yes], | ||||
| [ AC_DEFINE([HAVE_GETTIMEOFDAY], [1], | ||||
|             [Define to 1 if you have a standard gettimeofday function]) | ||||
| ]) | ||||
| 
 | ||||
| AC_CHECK_FUNCS([strdup strndup memrchr umask mkstemp mktemp fdopen \ | ||||
|                 dup dup2 getcwd realpath sigsetmask sigaction \ | ||||
|                 getgroups seteuid setegid setlinebuf setreuid setregid \ | ||||
|                 getrlimit setrlimit setvbuf pipe strsignal \ | ||||
|                 lstat readlink atexit isatty ttyname pselect posix_spawn \ | ||||
|                 posix_spawnattr_setsigmask]) | ||||
| 
 | ||||
| # We need to check declarations, not just existence, because on Tru64 this | ||||
| # function is not declared without special flags, which themselves cause | ||||
| # other problems.  We'll just use our own. | ||||
| AC_CHECK_DECLS([bsd_signal], [], [], [[#define _GNU_SOURCE 1 | ||||
| #include <signal.h>]]) | ||||
| 
 | ||||
| AC_FUNC_FORK | ||||
| 
 | ||||
| AC_FUNC_SETVBUF_REVERSED | ||||
| 
 | ||||
| # Rumor has it that strcasecmp lives in -lresolv on some odd systems. | ||||
| # It doesn't hurt much to use our own if we can't find it so I don't | ||||
| # make the effort here. | ||||
| AC_CHECK_FUNCS([strcasecmp strncasecmp strcmpi strncmpi stricmp strnicmp]) | ||||
| 
 | ||||
| # strcoll() is used by the GNU glob library | ||||
| AC_FUNC_STRCOLL | ||||
| AC_FUNC_CLOSEDIR_VOID | ||||
| 
 | ||||
| # dir.c and our glob.c use dirent.d_type if available | ||||
| AC_STRUCT_DIRENT_D_TYPE | ||||
| 
 | ||||
| # See if the user wants to add (or not) GNU Guile support | ||||
| AC_ARG_WITH([guile], [AS_HELP_STRING([--with-guile], | ||||
|             [Support GNU Guile for embedded scripting])]) | ||||
| 
 | ||||
| # Annoyingly, each version of Guile comes with it's own PC file so we have to | ||||
| # specify them as individual packages.  Ugh. | ||||
| PKG_PROG_PKG_CONFIG | ||||
| 
 | ||||
| AS_IF([test "x$with_guile" != xno], | ||||
| [ guile_versions="3.0 2.2 2.0 1.8" | ||||
|   guile_version=no | ||||
|   have_guile=no | ||||
|   AC_MSG_CHECKING([for GNU Guile]) | ||||
|   for v in $guile_versions; do | ||||
|     PKG_CHECK_EXISTS([guile-$v], [guile_version=$v; have_guile=yes; break], []) | ||||
|   done | ||||
|   AC_MSG_RESULT([$guile_version]) | ||||
|   AS_IF([test "$have_guile" = yes], | ||||
|   [ PKG_CHECK_MODULES(GUILE, [guile-$guile_version]) | ||||
|     # Unfortunately Guile requires a C99 compiler but GNU make doesn't, so | ||||
|     # verify we can actually compile the header. | ||||
|     keep_CPPFLAGS="$CPPFLAGS" | ||||
|     CPPFLAGS="$CPPFLAGS $pkg_cv_GUILE_CFLAGS" | ||||
|     AC_CHECK_HEADER([libguile.h], | ||||
|                     [AC_DEFINE([HAVE_GUILE], [1], [Embed GNU Guile support])], | ||||
|                     [have_guile=no], | ||||
|                     [/* Avoid configuration error warnings. */]) | ||||
|     CPPFLAGS="$keep_CPPFLAGS" | ||||
|   ]) | ||||
| ]) | ||||
| 
 | ||||
| AM_CONDITIONAL([HAVE_GUILE], [test "$have_guile" = "yes"]) | ||||
| 
 | ||||
| AC_CHECK_DECLS([sys_siglist, _sys_siglist, __sys_siglist], , , | ||||
|   [AC_INCLUDES_DEFAULT | ||||
| #include <signal.h> | ||||
| /* NetBSD declares sys_siglist in unistd.h.  */ | ||||
| #if HAVE_UNISTD_H | ||||
| # include <unistd.h> | ||||
| #endif | ||||
| ]) | ||||
| 
 | ||||
| 
 | ||||
| # Check out the wait reality. | ||||
| AC_CHECK_HEADERS([sys/wait.h],[],[],[[#include <sys/types.h>]]) | ||||
| AC_CHECK_FUNCS([waitpid wait3]) | ||||
| AC_CACHE_CHECK([for union wait], [make_cv_union_wait], | ||||
| [ AC_LINK_IFELSE([AC_LANG_PROGRAM([[#include <sys/types.h> | ||||
| #include <sys/wait.h>]], | ||||
|      [[union wait status; int pid; pid = wait (&status); | ||||
| #ifdef WEXITSTATUS | ||||
| /* Some POSIXoid systems have both the new-style macros and the old | ||||
|    union wait type, and they do not work together.  If union wait | ||||
|    conflicts with WEXITSTATUS et al, we don't want to use it at all.  */ | ||||
|         if (WEXITSTATUS (status) != 0) pid = -1; | ||||
| #ifdef WTERMSIG | ||||
|         /* If we have WEXITSTATUS and WTERMSIG, just use them on ints.  */ | ||||
|         -- blow chunks here -- | ||||
| #endif | ||||
| #endif | ||||
| #ifdef HAVE_WAITPID | ||||
|         /* Make sure union wait works with waitpid.  */ | ||||
|         pid = waitpid (-1, &status, 0); | ||||
| #endif | ||||
|       ]])], | ||||
|     [make_cv_union_wait=yes], | ||||
|     [make_cv_union_wait=no]) | ||||
| ]) | ||||
| AS_IF([test "$make_cv_union_wait" = yes], | ||||
| [ AC_DEFINE([HAVE_UNION_WAIT], [1], | ||||
|             [Define to 1 if you have the 'union wait' type in <sys/wait.h>.]) | ||||
| ]) | ||||
| 
 | ||||
| 
 | ||||
| # If we're building on Windows/DOS/OS/2, add some support for DOS drive specs. | ||||
| AS_IF([test "$PATH_SEPARATOR" = ';'], | ||||
| [ AC_DEFINE([HAVE_DOS_PATHS], [1], | ||||
|             [Define to 1 if your system requires backslashes or drive specs in pathnames.]) | ||||
| ]) | ||||
| 
 | ||||
| # See if the user wants to use pmake's "customs" distributed build capability | ||||
| AC_SUBST([REMOTE]) REMOTE=stub | ||||
| use_customs=false | ||||
| AC_ARG_WITH([customs], | ||||
| [AC_HELP_STRING([--with-customs=DIR], | ||||
|                 [enable remote jobs via Customs--see README.customs])], | ||||
| [ AS_CASE([$withval], [n|no], [:], | ||||
|     [make_cppflags="$CPPFLAGS" | ||||
|      AS_CASE([$withval], | ||||
|              [y|ye|yes], [:], | ||||
|              [CPPFLAGS="$CPPFLAGS -I$with_customs/include/customs" | ||||
|               make_ldflags="$LDFLAGS -L$with_customs/lib"]) | ||||
|      CF_NETLIBS | ||||
|      AC_CHECK_HEADER([customs.h], | ||||
|                      [use_customs=true | ||||
|                       REMOTE=cstms | ||||
|                       LIBS="$LIBS -lcustoms" LDFLAGS="$make_ldflags"], | ||||
|                      [with_customs=no | ||||
|                       CPPFLAGS="$make_cppflags" make_badcust=yes]) | ||||
|     ]) | ||||
| ]) | ||||
| 
 | ||||
| # Tell automake about this, so it can include the right .c files. | ||||
| AM_CONDITIONAL([USE_CUSTOMS], [test "$use_customs" = true]) | ||||
| 
 | ||||
| # See if the user asked to handle case insensitive file systems. | ||||
| AH_TEMPLATE([HAVE_CASE_INSENSITIVE_FS], [Use case insensitive file names]) | ||||
| AC_ARG_ENABLE([case-insensitive-file-system], | ||||
|   AC_HELP_STRING([--enable-case-insensitive-file-system], | ||||
|                  [assume file systems are case insensitive]), | ||||
|   [AS_IF([test "$enableval" = yes], [AC_DEFINE([HAVE_CASE_INSENSITIVE_FS])])]) | ||||
| 
 | ||||
| # See if we can handle the job server feature, and if the user wants it. | ||||
| AC_ARG_ENABLE([job-server], | ||||
|   AC_HELP_STRING([--disable-job-server], | ||||
|                  [disallow recursive make communication during -jN]), | ||||
|   [make_cv_job_server="$enableval" user_job_server="$enableval"], | ||||
|   [make_cv_job_server="yes"]) | ||||
| 
 | ||||
| AS_IF([test "$ac_cv_func_waitpid" = no && test "$ac_cv_func_wait3" = no], | ||||
|       [has_wait_nohang=no], | ||||
|       [has_wait_nohang=yes]) | ||||
| 
 | ||||
| AC_CACHE_CHECK([for SA_RESTART], [make_cv_sa_restart], [ | ||||
|   AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <signal.h>]], | ||||
|       [[return SA_RESTART;]])], | ||||
|     [make_cv_sa_restart=yes], | ||||
|     [make_cv_sa_restart=no])]) | ||||
| 
 | ||||
| AS_IF([test "$make_cv_sa_restart" != no], | ||||
| [ AC_DEFINE([HAVE_SA_RESTART], [1], | ||||
|      [Define to 1 if <signal.h> defines the SA_RESTART constant.]) | ||||
| ]) | ||||
| 
 | ||||
| # Only allow jobserver on systems that support it | ||||
| AS_CASE([/$ac_cv_func_pipe/$ac_cv_func_sigaction/$make_cv_sa_restart/$has_wait_nohang/], | ||||
|   [*/no/*], [make_cv_job_server=no]) | ||||
| 
 | ||||
| # Also supported on OS2 and MinGW | ||||
| AS_CASE([$host_os], [os2*|mingw*], [make_cv_job_server=yes]) | ||||
| 
 | ||||
| # If we support it and the user didn't disable it, build with jobserver | ||||
| AS_CASE([/$make_cv_job_server/$user_job_server/], | ||||
|   [*/no/*], [: no jobserver], | ||||
|   [AC_DEFINE(MAKE_JOBSERVER, 1, | ||||
|              [Define to 1 to enable job server support in GNU make.]) | ||||
|   ]) | ||||
| 
 | ||||
| # If dl*() functions are supported we can enable the load operation | ||||
| AC_CHECK_DECLS([dlopen, dlsym, dlerror], [], [], | ||||
|   [[#include <dlfcn.h>]]) | ||||
| 
 | ||||
| AC_ARG_ENABLE([load], | ||||
|   AC_HELP_STRING([--disable-load], | ||||
|                  [disable support for the 'load' operation]), | ||||
|   [make_cv_load="$enableval" user_load="$enableval"], | ||||
|   [make_cv_load="yes"]) | ||||
| 
 | ||||
| AS_CASE([/$ac_cv_have_decl_dlopen/$ac_cv_have_decl_dlsym/$ac_cv_have_decl_dlerror/], | ||||
|   [*/no/*], [make_cv_load=no]) | ||||
| 
 | ||||
| # We might need -ldl | ||||
| AS_IF([test "$make_cv_load" = yes], [ | ||||
|   AC_SEARCH_LIBS([dlopen], [dl], [], [make_cv_load=]) | ||||
|   ]) | ||||
| 
 | ||||
| AS_CASE([/$make_cv_load/$user_load/], | ||||
|   [*/no/*], [make_cv_load=no], | ||||
|   [AC_DEFINE(MAKE_LOAD, 1, | ||||
|              [Define to 1 to enable 'load' support in GNU make.]) | ||||
|   ]) | ||||
| 
 | ||||
| # If we want load support, we might need to link with export-dynamic. | ||||
| # See if we can figure it out.  Unfortunately this is very difficult. | ||||
| # For example passing -rdynamic to the SunPRO linker gives a warning | ||||
| # but succeeds and creates a shared object, not an executable! | ||||
| AS_IF([test "$make_cv_load" = yes], [ | ||||
|   AC_MSG_CHECKING([If the linker accepts -Wl,--export-dynamic]) | ||||
|   old_LDFLAGS="$LDFLAGS" | ||||
|   LDFLAGS="$LDFLAGS -Wl,--export-dynamic" | ||||
|   AC_LINK_IFELSE([AC_LANG_SOURCE([int main(){}])], | ||||
|     [AC_MSG_RESULT([yes]) | ||||
|      AC_SUBST([AM_LDFLAGS], [-Wl,--export-dynamic])], | ||||
|     [AC_MSG_RESULT([no]) | ||||
|      AC_MSG_CHECKING([If the linker accepts -rdynamic]) | ||||
|      LDFLAGS="$old_LDFLAGS -rdynamic" | ||||
|      AC_LINK_IFELSE([AC_LANG_SOURCE([int main(){}])], | ||||
|        [AC_MSG_RESULT([yes]) | ||||
|         AC_SUBST([AM_LDFLAGS], [-rdynamic])], | ||||
|        [AC_MSG_RESULT([no])]) | ||||
|    ]) | ||||
|   LDFLAGS="$old_LDFLAGS" | ||||
| ]) | ||||
| 
 | ||||
| # if we have both lstat() and readlink() then we can support symlink | ||||
| # timechecks. | ||||
| AS_IF([test "$ac_cv_func_lstat" = yes && test "$ac_cv_func_readlink" = yes], | ||||
|   [ AC_DEFINE([MAKE_SYMLINKS], [1], | ||||
|               [Define to 1 to enable symbolic link timestamp checking.]) | ||||
| ]) | ||||
| 
 | ||||
| # Use posix_spawn if we have support and the user didn't disable it | ||||
| 
 | ||||
| AC_ARG_ENABLE([posix-spawn], | ||||
|   AC_HELP_STRING([--disable-posix-spawn], | ||||
|                  [disable support for posix_spawn()]), | ||||
|   [make_cv_posix_spawn="$enableval" user_posix_spawn="$enableval"], | ||||
|   [make_cv_posix_spawn="yes"]) | ||||
| 
 | ||||
| AS_CASE([/$ac_cv_header_spawn/$ac_cv_func_posix_spawn/], | ||||
|   [*/no/*], [make_cv_posix_spawn=no]) | ||||
| 
 | ||||
| AS_IF([test "$make_cv_posix_spawn" = yes], | ||||
|   AC_CACHE_CHECK([for posix_spawn that fails synchronously], | ||||
|     [make_cv_synchronous_posix_spawn], | ||||
|     [make_cv_synchronous_posix_spawn=no | ||||
|      AC_RUN_IFELSE([AC_LANG_SOURCE([[ | ||||
|        #include <spawn.h> | ||||
|        #include <string.h> | ||||
| 
 | ||||
|        extern char **environ; | ||||
| 
 | ||||
|        int main() { | ||||
|          char* path = strdup("./non-existent"); | ||||
|          char *argv[[2]]; | ||||
|          argv[[0]] = path; | ||||
|          argv[[1]] =  0; | ||||
|          return posix_spawn(0, path, 0, 0, argv, environ); | ||||
|        }]])], | ||||
|        [make_cv_synchronous_posix_spawn=no], | ||||
|        [make_cv_synchronous_posix_spawn=yes], | ||||
|        [make_cv_synchronous_posix_spawn="no (cross-compiling)"])])) | ||||
| 
 | ||||
| AS_CASE([/$user_posix_spawn/$make_cv_posix_spawn/$make_cv_synchronous_posix_spawn/], | ||||
|   [*/no/*], [make_cv_posix_spawn=no], | ||||
|   [AC_DEFINE(USE_POSIX_SPAWN, 1, [Define to 1 to use posix_spawn().]) | ||||
|   ]) | ||||
| 
 | ||||
| # Find the SCCS commands, so we can include them in our default rules. | ||||
| 
 | ||||
| AC_CACHE_CHECK([for location of SCCS get command], [make_cv_path_sccs_get], [ | ||||
|   AS_IF([test -f /usr/sccs/get], | ||||
|         [make_cv_path_sccs_get=/usr/sccs/get], | ||||
|         [make_cv_path_sccs_get=get]) | ||||
| ]) | ||||
| AC_DEFINE_UNQUOTED([SCCS_GET], ["$make_cv_path_sccs_get"], | ||||
|                    [Define to the name of the SCCS 'get' command.]) | ||||
| 
 | ||||
| ac_clean_files="$ac_clean_files s.conftest conftoast" # Remove these later. | ||||
| AS_IF([(/usr/sccs/admin -n s.conftest || admin -n s.conftest) >/dev/null 2>&1 && | ||||
|    test -f s.conftest], | ||||
| [ # We successfully created an SCCS file. | ||||
|   AC_CACHE_CHECK([if SCCS get command understands -G], [make_cv_sys_get_minus_G], | ||||
|     [AS_IF([$make_cv_path_sccs_get -Gconftoast s.conftest >/dev/null 2>&1 && | ||||
|             test -f conftoast], | ||||
|            [make_cv_sys_get_minus_G=yes], | ||||
|            [make_cv_sys_get_minus_G=no]) | ||||
|     ]) | ||||
|   AS_IF([test "$make_cv_sys_get_minus_G" = yes], | ||||
|     [AC_DEFINE([SCCS_GET_MINUS_G], [1], | ||||
|      [Define to 1 if the SCCS 'get' command understands the '-G<file>' option.]) | ||||
|     ]) | ||||
| ]) | ||||
| rm -f s.conftest conftoast | ||||
| 
 | ||||
| # Let the makefile know what our build host is | ||||
| 
 | ||||
| AC_DEFINE_UNQUOTED([MAKE_HOST],["$host"],[Build host information.]) | ||||
| MAKE_HOST="$host" | ||||
| AC_SUBST([MAKE_HOST]) | ||||
| 
 | ||||
| w32_target_env=no | ||||
| AM_CONDITIONAL([WINDOWSENV], [false]) | ||||
| 
 | ||||
| AS_CASE([$host], | ||||
|   [*-*-mingw32], | ||||
|    [AM_CONDITIONAL([WINDOWSENV], [true]) | ||||
|     w32_target_env=yes | ||||
|     AC_DEFINE([WINDOWS32], [1], [Use platform specific coding]) | ||||
|     AC_DEFINE([HAVE_DOS_PATHS], [1], [Use platform specific coding]) | ||||
|   ]) | ||||
| 
 | ||||
| AC_DEFINE_UNQUOTED([PATH_SEPARATOR_CHAR],['$PATH_SEPARATOR'], | ||||
|         [Define to the character that separates directories in PATH.]) | ||||
| 
 | ||||
| # Include the Maintainer's Makefile section, if it's here. | ||||
| 
 | ||||
| MAINT_MAKEFILE=/dev/null | ||||
| AS_IF([test -r "$srcdir/maintMakefile"], | ||||
| [ MAINT_MAKEFILE="$srcdir/maintMakefile" | ||||
| ]) | ||||
| AC_SUBST_FILE([MAINT_MAKEFILE]) | ||||
| 
 | ||||
| # Allow building with dmalloc | ||||
| AM_WITH_DMALLOC | ||||
| 
 | ||||
| # Forcibly disable SET_MAKE.  If it's set it breaks things like the test | ||||
| # scripts, etc. | ||||
| SET_MAKE= | ||||
| 
 | ||||
| # Sanity check and inform the user of what we found | ||||
| 
 | ||||
| AS_IF([test "x$make_badcust" = xyes], [ | ||||
| echo | ||||
| echo "WARNING: --with-customs specified but no customs.h could be found;" | ||||
| echo "         disabling Customs support." | ||||
| echo | ||||
| ]) | ||||
| 
 | ||||
| AS_CASE([$with_customs], | ||||
| [""|n|no|y|ye|yes], [:], | ||||
| [AS_IF([test -f "$with_customs/lib/libcustoms.a"], [:], | ||||
| [ echo | ||||
|   echo "WARNING: '$with_customs/lib' does not appear to contain the" | ||||
|   echo "         Customs library.  You must build and install Customs" | ||||
|   echo "         before compiling GNU make." | ||||
|   echo | ||||
| ])]) | ||||
| 
 | ||||
| AS_IF([test "x$has_wait_nohang" = xno], | ||||
| [ echo | ||||
|   echo "WARNING: Your system has neither waitpid() nor wait3()." | ||||
|   echo "         Without one of these, signal handling is unreliable." | ||||
|   echo "         You should be aware that running GNU make with -j" | ||||
|   echo "         could result in erratic behavior." | ||||
|   echo | ||||
| ]) | ||||
| 
 | ||||
| AS_IF([test "x$make_cv_job_server" = xno && test "x$user_job_server" = xyes], | ||||
| [ echo | ||||
|   echo "WARNING: Make job server requires a POSIX-ish system that" | ||||
|   echo "         supports the pipe(), sigaction(), and either" | ||||
|   echo "         waitpid() or wait3() functions.  Your system doesn't" | ||||
|   echo "         appear to provide one or more of those." | ||||
|   echo "         Disabling job server support." | ||||
|   echo | ||||
| ]) | ||||
| 
 | ||||
| AS_IF([test "x$make_cv_load" = xno && test "x$user_load" = xyes], | ||||
| [ echo | ||||
|   echo "WARNING: 'load' support requires a POSIX-ish system that" | ||||
|   echo "         supports the dlopen(), dlsym(), and dlerror() functions." | ||||
|   echo "         Your system doesn't appear to provide one or more of these." | ||||
|   echo "         Disabling 'load' support." | ||||
|   echo | ||||
| ]) | ||||
| 
 | ||||
| AS_IF([test "x$make_cv_posix_spawn" = xno && test "x$user_posix_spawn" = xyes], | ||||
| [ echo | ||||
|   echo "WARNING: posix_spawn() is not supported on this system." | ||||
|   echo | ||||
| ]) | ||||
| 
 | ||||
| # Specify what files are to be created. | ||||
| AC_CONFIG_FILES([Makefile build.cfg lib/Makefile po/Makefile.in doc/Makefile \ | ||||
|                  tests/config-flags.pm]) | ||||
| # We don't need this: the standard automake output suffices for POSIX systems. | ||||
| #mk/Posix.mk | ||||
| 
 | ||||
| # OK, do it! | ||||
| 
 | ||||
| AC_OUTPUT | ||||
| 
 | ||||
| dnl Local Variables: | ||||
| dnl comment-start: "dnl " | ||||
| dnl comment-end: "" | ||||
| dnl comment-start-skip: "\\bdnl\\b\\s *" | ||||
| dnl compile-command: "make configure config.h.in" | ||||
| dnl End: | ||||
							
								
								
									
										24
									
								
								third_party/make/doc/Makefile.am
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								third_party/make/doc/Makefile.am
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,24 @@ | |||
| # -*-Makefile-*-, or close enough | ||||
| # Copyright (C) 2000-2020 Free Software Foundation, Inc. | ||||
| # This file is part of GNU Make. | ||||
| # | ||||
| # GNU Make is free software; you can redistribute it and/or modify it under | ||||
| # the terms of the GNU General Public License as published by the Free Software | ||||
| # Foundation; either version 3 of the License, or (at your option) any later | ||||
| # version. | ||||
| # | ||||
| # GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS | ||||
| # FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more | ||||
| # details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License along with | ||||
| # this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| TEXI2HTML = texi2html | ||||
| TEXI2HTML_FLAGS = -split_chapter | ||||
| 
 | ||||
| info_TEXINFOS =	make.texi | ||||
| make_TEXINFOS = fdl.texi make-stds.texi | ||||
| 
 | ||||
| CLEANFILES = make*.html | ||||
							
								
								
									
										1324
									
								
								third_party/make/doc/Makefile.in
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1324
									
								
								third_party/make/doc/Makefile.in
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										505
									
								
								third_party/make/doc/fdl.texi
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										505
									
								
								third_party/make/doc/fdl.texi
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,505 @@ | |||
| @c The GNU Free Documentation License. | ||||
| @center Version 1.3, 3 November 2008 | ||||
| 
 | ||||
| @c This file is intended to be included within another document, | ||||
| @c hence no sectioning command or @node. | ||||
| 
 | ||||
| @display | ||||
| Copyright @copyright{} 2000, 2001, 2002, 2007, 2008 Free Software Foundation, Inc. | ||||
| @uref{https://fsf.org/} | ||||
| 
 | ||||
| Everyone is permitted to copy and distribute verbatim copies | ||||
| of this license document, but changing it is not allowed. | ||||
| @end display | ||||
| 
 | ||||
| @enumerate 0 | ||||
| @item | ||||
| PREAMBLE | ||||
| 
 | ||||
| The purpose of this License is to make a manual, textbook, or other | ||||
| functional and useful document @dfn{free} in the sense of freedom: to | ||||
| assure everyone the effective freedom to copy and redistribute it, | ||||
| with or without modifying it, either commercially or noncommercially. | ||||
| Secondarily, this License preserves for the author and publisher a way | ||||
| to get credit for their work, while not being considered responsible | ||||
| for modifications made by others. | ||||
| 
 | ||||
| This License is a kind of ``copyleft'', which means that derivative | ||||
| works of the document must themselves be free in the same sense.  It | ||||
| complements the GNU General Public License, which is a copyleft | ||||
| license designed for free software. | ||||
| 
 | ||||
| We have designed this License in order to use it for manuals for free | ||||
| software, because free software needs free documentation: a free | ||||
| program should come with manuals providing the same freedoms that the | ||||
| software does.  But this License is not limited to software manuals; | ||||
| it can be used for any textual work, regardless of subject matter or | ||||
| whether it is published as a printed book.  We recommend this License | ||||
| principally for works whose purpose is instruction or reference. | ||||
| 
 | ||||
| @item | ||||
| APPLICABILITY AND DEFINITIONS | ||||
| 
 | ||||
| This License applies to any manual or other work, in any medium, that | ||||
| contains a notice placed by the copyright holder saying it can be | ||||
| distributed under the terms of this License.  Such a notice grants a | ||||
| world-wide, royalty-free license, unlimited in duration, to use that | ||||
| work under the conditions stated herein.  The ``Document'', below, | ||||
| refers to any such manual or work.  Any member of the public is a | ||||
| licensee, and is addressed as ``you''.  You accept the license if you | ||||
| copy, modify or distribute the work in a way requiring permission | ||||
| under copyright law. | ||||
| 
 | ||||
| A ``Modified Version'' of the Document means any work containing the | ||||
| Document or a portion of it, either copied verbatim, or with | ||||
| modifications and/or translated into another language. | ||||
| 
 | ||||
| A ``Secondary Section'' is a named appendix or a front-matter section | ||||
| of the Document that deals exclusively with the relationship of the | ||||
| publishers or authors of the Document to the Document's overall | ||||
| subject (or to related matters) and contains nothing that could fall | ||||
| directly within that overall subject.  (Thus, if the Document is in | ||||
| part a textbook of mathematics, a Secondary Section may not explain | ||||
| any mathematics.)  The relationship could be a matter of historical | ||||
| connection with the subject or with related matters, or of legal, | ||||
| commercial, philosophical, ethical or political position regarding | ||||
| them. | ||||
| 
 | ||||
| The ``Invariant Sections'' are certain Secondary Sections whose titles | ||||
| are designated, as being those of Invariant Sections, in the notice | ||||
| that says that the Document is released under this License.  If a | ||||
| section does not fit the above definition of Secondary then it is not | ||||
| allowed to be designated as Invariant.  The Document may contain zero | ||||
| Invariant Sections.  If the Document does not identify any Invariant | ||||
| Sections then there are none. | ||||
| 
 | ||||
| The ``Cover Texts'' are certain short passages of text that are listed, | ||||
| as Front-Cover Texts or Back-Cover Texts, in the notice that says that | ||||
| the Document is released under this License.  A Front-Cover Text may | ||||
| be at most 5 words, and a Back-Cover Text may be at most 25 words. | ||||
| 
 | ||||
| A ``Transparent'' copy of the Document means a machine-readable copy, | ||||
| represented in a format whose specification is available to the | ||||
| general public, that is suitable for revising the document | ||||
| straightforwardly with generic text editors or (for images composed of | ||||
| pixels) generic paint programs or (for drawings) some widely available | ||||
| drawing editor, and that is suitable for input to text formatters or | ||||
| for automatic translation to a variety of formats suitable for input | ||||
| to text formatters.  A copy made in an otherwise Transparent file | ||||
| format whose markup, or absence of markup, has been arranged to thwart | ||||
| or discourage subsequent modification by readers is not Transparent. | ||||
| An image format is not Transparent if used for any substantial amount | ||||
| of text.  A copy that is not ``Transparent'' is called ``Opaque''. | ||||
| 
 | ||||
| Examples of suitable formats for Transparent copies include plain | ||||
| ASCII without markup, Texinfo input format, La@TeX{} input | ||||
| format, SGML or XML using a publicly available | ||||
| DTD, and standard-conforming simple HTML, | ||||
| PostScript or PDF designed for human modification.  Examples | ||||
| of transparent image formats include PNG, XCF and | ||||
| JPG@.  Opaque formats include proprietary formats that can be | ||||
| read and edited only by proprietary word processors, SGML or | ||||
| XML for which the DTD and/or processing tools are | ||||
| not generally available, and the machine-generated HTML, | ||||
| PostScript or PDF produced by some word processors for | ||||
| output purposes only. | ||||
| 
 | ||||
| The ``Title Page'' means, for a printed book, the title page itself, | ||||
| plus such following pages as are needed to hold, legibly, the material | ||||
| this License requires to appear in the title page.  For works in | ||||
| formats which do not have any title page as such, ``Title Page'' means | ||||
| the text near the most prominent appearance of the work's title, | ||||
| preceding the beginning of the body of the text. | ||||
| 
 | ||||
| The ``publisher'' means any person or entity that distributes copies | ||||
| of the Document to the public. | ||||
| 
 | ||||
| A section ``Entitled XYZ'' means a named subunit of the Document whose | ||||
| title either is precisely XYZ or contains XYZ in parentheses following | ||||
| text that translates XYZ in another language.  (Here XYZ stands for a | ||||
| specific section name mentioned below, such as ``Acknowledgements'', | ||||
| ``Dedications'', ``Endorsements'', or ``History''.)  To ``Preserve the Title'' | ||||
| of such a section when you modify the Document means that it remains a | ||||
| section ``Entitled XYZ'' according to this definition. | ||||
| 
 | ||||
| The Document may include Warranty Disclaimers next to the notice which | ||||
| states that this License applies to the Document.  These Warranty | ||||
| Disclaimers are considered to be included by reference in this | ||||
| License, but only as regards disclaiming warranties: any other | ||||
| implication that these Warranty Disclaimers may have is void and has | ||||
| no effect on the meaning of this License. | ||||
| 
 | ||||
| @item | ||||
| VERBATIM COPYING | ||||
| 
 | ||||
| You may copy and distribute the Document in any medium, either | ||||
| commercially or noncommercially, provided that this License, the | ||||
| copyright notices, and the license notice saying this License applies | ||||
| to the Document are reproduced in all copies, and that you add no other | ||||
| conditions whatsoever to those of this License.  You may not use | ||||
| technical measures to obstruct or control the reading or further | ||||
| copying of the copies you make or distribute.  However, you may accept | ||||
| compensation in exchange for copies.  If you distribute a large enough | ||||
| number of copies you must also follow the conditions in section 3. | ||||
| 
 | ||||
| You may also lend copies, under the same conditions stated above, and | ||||
| you may publicly display copies. | ||||
| 
 | ||||
| @item | ||||
| COPYING IN QUANTITY | ||||
| 
 | ||||
| If you publish printed copies (or copies in media that commonly have | ||||
| printed covers) of the Document, numbering more than 100, and the | ||||
| Document's license notice requires Cover Texts, you must enclose the | ||||
| copies in covers that carry, clearly and legibly, all these Cover | ||||
| Texts: Front-Cover Texts on the front cover, and Back-Cover Texts on | ||||
| the back cover.  Both covers must also clearly and legibly identify | ||||
| you as the publisher of these copies.  The front cover must present | ||||
| the full title with all words of the title equally prominent and | ||||
| visible.  You may add other material on the covers in addition. | ||||
| Copying with changes limited to the covers, as long as they preserve | ||||
| the title of the Document and satisfy these conditions, can be treated | ||||
| as verbatim copying in other respects. | ||||
| 
 | ||||
| If the required texts for either cover are too voluminous to fit | ||||
| legibly, you should put the first ones listed (as many as fit | ||||
| reasonably) on the actual cover, and continue the rest onto adjacent | ||||
| pages. | ||||
| 
 | ||||
| If you publish or distribute Opaque copies of the Document numbering | ||||
| more than 100, you must either include a machine-readable Transparent | ||||
| copy along with each Opaque copy, or state in or with each Opaque copy | ||||
| a computer-network location from which the general network-using | ||||
| public has access to download using public-standard network protocols | ||||
| a complete Transparent copy of the Document, free of added material. | ||||
| If you use the latter option, you must take reasonably prudent steps, | ||||
| when you begin distribution of Opaque copies in quantity, to ensure | ||||
| that this Transparent copy will remain thus accessible at the stated | ||||
| location until at least one year after the last time you distribute an | ||||
| Opaque copy (directly or through your agents or retailers) of that | ||||
| edition to the public. | ||||
| 
 | ||||
| It is requested, but not required, that you contact the authors of the | ||||
| Document well before redistributing any large number of copies, to give | ||||
| them a chance to provide you with an updated version of the Document. | ||||
| 
 | ||||
| @item | ||||
| MODIFICATIONS | ||||
| 
 | ||||
| You may copy and distribute a Modified Version of the Document under | ||||
| the conditions of sections 2 and 3 above, provided that you release | ||||
| the Modified Version under precisely this License, with the Modified | ||||
| Version filling the role of the Document, thus licensing distribution | ||||
| and modification of the Modified Version to whoever possesses a copy | ||||
| of it.  In addition, you must do these things in the Modified Version: | ||||
| 
 | ||||
| @enumerate A | ||||
| @item | ||||
| Use in the Title Page (and on the covers, if any) a title distinct | ||||
| from that of the Document, and from those of previous versions | ||||
| (which should, if there were any, be listed in the History section | ||||
| of the Document).  You may use the same title as a previous version | ||||
| if the original publisher of that version gives permission. | ||||
| 
 | ||||
| @item | ||||
| List on the Title Page, as authors, one or more persons or entities | ||||
| responsible for authorship of the modifications in the Modified | ||||
| Version, together with at least five of the principal authors of the | ||||
| Document (all of its principal authors, if it has fewer than five), | ||||
| unless they release you from this requirement. | ||||
| 
 | ||||
| @item | ||||
| State on the Title page the name of the publisher of the | ||||
| Modified Version, as the publisher. | ||||
| 
 | ||||
| @item | ||||
| Preserve all the copyright notices of the Document. | ||||
| 
 | ||||
| @item | ||||
| Add an appropriate copyright notice for your modifications | ||||
| adjacent to the other copyright notices. | ||||
| 
 | ||||
| @item | ||||
| Include, immediately after the copyright notices, a license notice | ||||
| giving the public permission to use the Modified Version under the | ||||
| terms of this License, in the form shown in the Addendum below. | ||||
| 
 | ||||
| @item | ||||
| Preserve in that license notice the full lists of Invariant Sections | ||||
| and required Cover Texts given in the Document's license notice. | ||||
| 
 | ||||
| @item | ||||
| Include an unaltered copy of this License. | ||||
| 
 | ||||
| @item | ||||
| Preserve the section Entitled ``History'', Preserve its Title, and add | ||||
| to it an item stating at least the title, year, new authors, and | ||||
| publisher of the Modified Version as given on the Title Page.  If | ||||
| there is no section Entitled ``History'' in the Document, create one | ||||
| stating the title, year, authors, and publisher of the Document as | ||||
| given on its Title Page, then add an item describing the Modified | ||||
| Version as stated in the previous sentence. | ||||
| 
 | ||||
| @item | ||||
| Preserve the network location, if any, given in the Document for | ||||
| public access to a Transparent copy of the Document, and likewise | ||||
| the network locations given in the Document for previous versions | ||||
| it was based on.  These may be placed in the ``History'' section. | ||||
| You may omit a network location for a work that was published at | ||||
| least four years before the Document itself, or if the original | ||||
| publisher of the version it refers to gives permission. | ||||
| 
 | ||||
| @item | ||||
| For any section Entitled ``Acknowledgements'' or ``Dedications'', Preserve | ||||
| the Title of the section, and preserve in the section all the | ||||
| substance and tone of each of the contributor acknowledgements and/or | ||||
| dedications given therein. | ||||
| 
 | ||||
| @item | ||||
| Preserve all the Invariant Sections of the Document, | ||||
| unaltered in their text and in their titles.  Section numbers | ||||
| or the equivalent are not considered part of the section titles. | ||||
| 
 | ||||
| @item | ||||
| Delete any section Entitled ``Endorsements''.  Such a section | ||||
| may not be included in the Modified Version. | ||||
| 
 | ||||
| @item | ||||
| Do not retitle any existing section to be Entitled ``Endorsements'' or | ||||
| to conflict in title with any Invariant Section. | ||||
| 
 | ||||
| @item | ||||
| Preserve any Warranty Disclaimers. | ||||
| @end enumerate | ||||
| 
 | ||||
| If the Modified Version includes new front-matter sections or | ||||
| appendices that qualify as Secondary Sections and contain no material | ||||
| copied from the Document, you may at your option designate some or all | ||||
| of these sections as invariant.  To do this, add their titles to the | ||||
| list of Invariant Sections in the Modified Version's license notice. | ||||
| These titles must be distinct from any other section titles. | ||||
| 
 | ||||
| You may add a section Entitled ``Endorsements'', provided it contains | ||||
| nothing but endorsements of your Modified Version by various | ||||
| parties---for example, statements of peer review or that the text has | ||||
| been approved by an organization as the authoritative definition of a | ||||
| standard. | ||||
| 
 | ||||
| You may add a passage of up to five words as a Front-Cover Text, and a | ||||
| passage of up to 25 words as a Back-Cover Text, to the end of the list | ||||
| of Cover Texts in the Modified Version.  Only one passage of | ||||
| Front-Cover Text and one of Back-Cover Text may be added by (or | ||||
| through arrangements made by) any one entity.  If the Document already | ||||
| includes a cover text for the same cover, previously added by you or | ||||
| by arrangement made by the same entity you are acting on behalf of, | ||||
| you may not add another; but you may replace the old one, on explicit | ||||
| permission from the previous publisher that added the old one. | ||||
| 
 | ||||
| The author(s) and publisher(s) of the Document do not by this License | ||||
| give permission to use their names for publicity for or to assert or | ||||
| imply endorsement of any Modified Version. | ||||
| 
 | ||||
| @item | ||||
| COMBINING DOCUMENTS | ||||
| 
 | ||||
| You may combine the Document with other documents released under this | ||||
| License, under the terms defined in section 4 above for modified | ||||
| versions, provided that you include in the combination all of the | ||||
| Invariant Sections of all of the original documents, unmodified, and | ||||
| list them all as Invariant Sections of your combined work in its | ||||
| license notice, and that you preserve all their Warranty Disclaimers. | ||||
| 
 | ||||
| The combined work need only contain one copy of this License, and | ||||
| multiple identical Invariant Sections may be replaced with a single | ||||
| copy.  If there are multiple Invariant Sections with the same name but | ||||
| different contents, make the title of each such section unique by | ||||
| adding at the end of it, in parentheses, the name of the original | ||||
| author or publisher of that section if known, or else a unique number. | ||||
| Make the same adjustment to the section titles in the list of | ||||
| Invariant Sections in the license notice of the combined work. | ||||
| 
 | ||||
| In the combination, you must combine any sections Entitled ``History'' | ||||
| in the various original documents, forming one section Entitled | ||||
| ``History''; likewise combine any sections Entitled ``Acknowledgements'', | ||||
| and any sections Entitled ``Dedications''.  You must delete all | ||||
| sections Entitled ``Endorsements.'' | ||||
| 
 | ||||
| @item | ||||
| COLLECTIONS OF DOCUMENTS | ||||
| 
 | ||||
| You may make a collection consisting of the Document and other documents | ||||
| released under this License, and replace the individual copies of this | ||||
| License in the various documents with a single copy that is included in | ||||
| the collection, provided that you follow the rules of this License for | ||||
| verbatim copying of each of the documents in all other respects. | ||||
| 
 | ||||
| You may extract a single document from such a collection, and distribute | ||||
| it individually under this License, provided you insert a copy of this | ||||
| License into the extracted document, and follow this License in all | ||||
| other respects regarding verbatim copying of that document. | ||||
| 
 | ||||
| @item | ||||
| AGGREGATION WITH INDEPENDENT WORKS | ||||
| 
 | ||||
| A compilation of the Document or its derivatives with other separate | ||||
| and independent documents or works, in or on a volume of a storage or | ||||
| distribution medium, is called an ``aggregate'' if the copyright | ||||
| resulting from the compilation is not used to limit the legal rights | ||||
| of the compilation's users beyond what the individual works permit. | ||||
| When the Document is included in an aggregate, this License does not | ||||
| apply to the other works in the aggregate which are not themselves | ||||
| derivative works of the Document. | ||||
| 
 | ||||
| If the Cover Text requirement of section 3 is applicable to these | ||||
| copies of the Document, then if the Document is less than one half of | ||||
| the entire aggregate, the Document's Cover Texts may be placed on | ||||
| covers that bracket the Document within the aggregate, or the | ||||
| electronic equivalent of covers if the Document is in electronic form. | ||||
| Otherwise they must appear on printed covers that bracket the whole | ||||
| aggregate. | ||||
| 
 | ||||
| @item | ||||
| TRANSLATION | ||||
| 
 | ||||
| Translation is considered a kind of modification, so you may | ||||
| distribute translations of the Document under the terms of section 4. | ||||
| Replacing Invariant Sections with translations requires special | ||||
| permission from their copyright holders, but you may include | ||||
| translations of some or all Invariant Sections in addition to the | ||||
| original versions of these Invariant Sections.  You may include a | ||||
| translation of this License, and all the license notices in the | ||||
| Document, and any Warranty Disclaimers, provided that you also include | ||||
| the original English version of this License and the original versions | ||||
| of those notices and disclaimers.  In case of a disagreement between | ||||
| the translation and the original version of this License or a notice | ||||
| or disclaimer, the original version will prevail. | ||||
| 
 | ||||
| If a section in the Document is Entitled ``Acknowledgements'', | ||||
| ``Dedications'', or ``History'', the requirement (section 4) to Preserve | ||||
| its Title (section 1) will typically require changing the actual | ||||
| title. | ||||
| 
 | ||||
| @item | ||||
| TERMINATION | ||||
| 
 | ||||
| You may not copy, modify, sublicense, or distribute the Document | ||||
| except as expressly provided under this License.  Any attempt | ||||
| otherwise to copy, modify, sublicense, or distribute it is void, and | ||||
| will automatically terminate your rights under this License. | ||||
| 
 | ||||
| However, if you cease all violation of this License, then your license | ||||
| from a particular copyright holder is reinstated (a) provisionally, | ||||
| unless and until the copyright holder explicitly and finally | ||||
| terminates your license, and (b) permanently, if the copyright holder | ||||
| fails to notify you of the violation by some reasonable means prior to | ||||
| 60 days after the cessation. | ||||
| 
 | ||||
| Moreover, your license from a particular copyright holder is | ||||
| reinstated permanently if the copyright holder notifies you of the | ||||
| violation by some reasonable means, this is the first time you have | ||||
| received notice of violation of this License (for any work) from that | ||||
| copyright holder, and you cure the violation prior to 30 days after | ||||
| your receipt of the notice. | ||||
| 
 | ||||
| Termination of your rights under this section does not terminate the | ||||
| licenses of parties who have received copies or rights from you under | ||||
| this License.  If your rights have been terminated and not permanently | ||||
| reinstated, receipt of a copy of some or all of the same material does | ||||
| not give you any rights to use it. | ||||
| 
 | ||||
| @item | ||||
| FUTURE REVISIONS OF THIS LICENSE | ||||
| 
 | ||||
| The Free Software Foundation may publish new, revised versions | ||||
| of the GNU Free Documentation License from time to time.  Such new | ||||
| versions will be similar in spirit to the present version, but may | ||||
| differ in detail to address new problems or concerns.  See | ||||
| @uref{https://www.gnu.org/copyleft/}. | ||||
| 
 | ||||
| Each version of the License is given a distinguishing version number. | ||||
| If the Document specifies that a particular numbered version of this | ||||
| License ``or any later version'' applies to it, you have the option of | ||||
| following the terms and conditions either of that specified version or | ||||
| of any later version that has been published (not as a draft) by the | ||||
| Free Software Foundation.  If the Document does not specify a version | ||||
| number of this License, you may choose any version ever published (not | ||||
| as a draft) by the Free Software Foundation.  If the Document | ||||
| specifies that a proxy can decide which future versions of this | ||||
| License can be used, that proxy's public statement of acceptance of a | ||||
| version permanently authorizes you to choose that version for the | ||||
| Document. | ||||
| 
 | ||||
| @item | ||||
| RELICENSING | ||||
| 
 | ||||
| ``Massive Multiauthor Collaboration Site'' (or ``MMC Site'') means any | ||||
| World Wide Web server that publishes copyrightable works and also | ||||
| provides prominent facilities for anybody to edit those works.  A | ||||
| public wiki that anybody can edit is an example of such a server.  A | ||||
| ``Massive Multiauthor Collaboration'' (or ``MMC'') contained in the | ||||
| site means any set of copyrightable works thus published on the MMC | ||||
| site. | ||||
| 
 | ||||
| ``CC-BY-SA'' means the Creative Commons Attribution-Share Alike 3.0 | ||||
| license published by Creative Commons Corporation, a not-for-profit | ||||
| corporation with a principal place of business in San Francisco, | ||||
| California, as well as future copyleft versions of that license | ||||
| published by that same organization. | ||||
| 
 | ||||
| ``Incorporate'' means to publish or republish a Document, in whole or | ||||
| in part, as part of another Document. | ||||
| 
 | ||||
| An MMC is ``eligible for relicensing'' if it is licensed under this | ||||
| License, and if all works that were first published under this License | ||||
| somewhere other than this MMC, and subsequently incorporated in whole | ||||
| or in part into the MMC, (1) had no cover texts or invariant sections, | ||||
| and (2) were thus incorporated prior to November 1, 2008. | ||||
| 
 | ||||
| The operator of an MMC Site may republish an MMC contained in the site | ||||
| under CC-BY-SA on the same site at any time before August 1, 2009, | ||||
| provided the MMC is eligible for relicensing. | ||||
| 
 | ||||
| @end enumerate | ||||
| 
 | ||||
| @page | ||||
| @heading ADDENDUM: How to use this License for your documents | ||||
| 
 | ||||
| To use this License in a document you have written, include a copy of | ||||
| the License in the document and put the following copyright and | ||||
| license notices just after the title page: | ||||
| 
 | ||||
| @smallexample | ||||
| @group | ||||
|   Copyright (C)  @var{year}  @var{your name}. | ||||
|   Permission is granted to copy, distribute and/or modify this document | ||||
|   under the terms of the GNU Free Documentation License, Version 1.3 | ||||
|   or any later version published by the Free Software Foundation; | ||||
|   with no Invariant Sections, no Front-Cover Texts, and no Back-Cover | ||||
|   Texts.  A copy of the license is included in the section entitled ``GNU | ||||
|   Free Documentation License''. | ||||
| @end group | ||||
| @end smallexample | ||||
| 
 | ||||
| If you have Invariant Sections, Front-Cover Texts and Back-Cover Texts, | ||||
| replace the ``with@dots{}Texts.''@: line with this: | ||||
| 
 | ||||
| @smallexample | ||||
| @group | ||||
|     with the Invariant Sections being @var{list their titles}, with | ||||
|     the Front-Cover Texts being @var{list}, and with the Back-Cover Texts | ||||
|     being @var{list}. | ||||
| @end group | ||||
| @end smallexample | ||||
| 
 | ||||
| If you have Invariant Sections without Cover Texts, or some other | ||||
| combination of the three, merge those two alternatives to suit the | ||||
| situation. | ||||
| 
 | ||||
| If your document contains nontrivial examples of program code, we | ||||
| recommend releasing these examples in parallel under your choice of | ||||
| free software license, such as the GNU General Public License, | ||||
| to permit their use in free software. | ||||
| 
 | ||||
| @c Local Variables: | ||||
| @c ispell-local-pdict: "ispell-dict" | ||||
| @c End: | ||||
							
								
								
									
										1173
									
								
								third_party/make/doc/make-stds.texi
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1173
									
								
								third_party/make/doc/make-stds.texi
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										379
									
								
								third_party/make/doc/make.1
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										379
									
								
								third_party/make/doc/make.1
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,379 @@ | |||
| .TH MAKE 1 "28 February 2016" "GNU" "User Commands" | ||||
| .SH NAME | ||||
| make \- GNU make utility to maintain groups of programs | ||||
| .SH SYNOPSIS | ||||
| .B make | ||||
| [\fIOPTION\fR]... [\fITARGET\fR]... | ||||
| .SH DESCRIPTION | ||||
| .LP | ||||
| The | ||||
| .I make | ||||
| utility will determine automatically which pieces of a large program need to | ||||
| be recompiled, and issue the commands to recompile them.  The manual describes | ||||
| the GNU implementation of | ||||
| .BR make , | ||||
| which was written by Richard Stallman and Roland McGrath, and is currently | ||||
| maintained by Paul Smith.  Our examples show C programs, since they are very | ||||
| common, but you can use | ||||
| .B make | ||||
| with any programming language whose compiler can be run with a shell command. | ||||
| In fact, | ||||
| .B make | ||||
| is not limited to programs.  You can use it to describe any task where some | ||||
| files must be updated automatically from others whenever the others change. | ||||
| .LP | ||||
| To prepare to use | ||||
| .BR make , | ||||
| you must write a file called the | ||||
| .I makefile | ||||
| that describes the relationships among files in your program, and the states | ||||
| the commands for updating each file.  In a program, typically the executable | ||||
| file is updated from object files, which are in turn made by compiling source | ||||
| files. | ||||
| .LP | ||||
| Once a suitable makefile exists, each time you change some source files, | ||||
| this simple shell command: | ||||
| .sp 1 | ||||
| .RS | ||||
| .B make | ||||
| .RE | ||||
| .sp 1 | ||||
| suffices to perform all necessary recompilations. | ||||
| The | ||||
| .B make | ||||
| program uses the makefile description and the last-modification times of the | ||||
| files to decide which of the files need to be updated.  For each of those | ||||
| files, it issues the commands recorded in the makefile. | ||||
| .LP | ||||
| .B make | ||||
| executes commands in the | ||||
| .I makefile | ||||
| to update one or more target | ||||
| .IR names , | ||||
| where | ||||
| .I name | ||||
| is typically a program. | ||||
| If no | ||||
| .B \-f | ||||
| option is present, | ||||
| .B make | ||||
| will look for the makefiles | ||||
| .IR GNUmakefile , | ||||
| .IR makefile , | ||||
| and | ||||
| .IR Makefile , | ||||
| in that order. | ||||
| .LP | ||||
| Normally you should call your makefile either | ||||
| .I makefile | ||||
| or | ||||
| .IR Makefile . | ||||
| (We recommend | ||||
| .I Makefile | ||||
| because it appears prominently near the beginning of a directory | ||||
| listing, right near other important files such as | ||||
| .IR  README .) | ||||
| The first name checked, | ||||
| .IR GNUmakefile , | ||||
| is not recommended for most makefiles.  You should use this name if you have a | ||||
| makefile that is specific to GNU | ||||
| .BR make , | ||||
| and will not be understood by other versions of | ||||
| .BR make . | ||||
| If | ||||
| .I makefile | ||||
| is '\-', the standard input is read. | ||||
| .LP | ||||
| .B make | ||||
| updates a target if it depends on prerequisite files | ||||
| that have been modified since the target was last modified, | ||||
| or if the target does not exist. | ||||
| .SH OPTIONS | ||||
| .sp 1 | ||||
| .TP 0.5i | ||||
| \fB\-b\fR, \fB\-m\fR | ||||
| These options are ignored for compatibility with other versions of | ||||
| .BR make . | ||||
| .TP 0.5i | ||||
| \fB\-B\fR, \fB\-\-always\-make\fR | ||||
| Unconditionally make all targets. | ||||
| .TP 0.5i | ||||
| \fB\-C\fR \fIdir\fR, \fB\-\-directory\fR=\fIdir\fR | ||||
| Change to directory | ||||
| .I dir | ||||
| before reading the makefiles or doing anything else. | ||||
| If multiple | ||||
| .B \-C | ||||
| options are specified, each is interpreted relative to the | ||||
| previous one: | ||||
| .BR "\-C " / | ||||
| .BR "\-C " etc | ||||
| is equivalent to | ||||
| .BR "\-C " /etc. | ||||
| This is typically used with recursive invocations of | ||||
| .BR make . | ||||
| .TP 0.5i | ||||
| .B \-d | ||||
| Print debugging information in addition to normal processing. | ||||
| The debugging information says which files are being considered for | ||||
| remaking, which file-times are being compared and with what results, | ||||
| which files actually need to be remade, which implicit rules are | ||||
| considered and which are applied---everything interesting about how | ||||
| .B make | ||||
| decides what to do. | ||||
| .TP 0.5i | ||||
| .BI \-\-debug "[=FLAGS]" | ||||
| Print debugging information in addition to normal processing. | ||||
| If the | ||||
| .I FLAGS | ||||
| are omitted, then the behavior is the same as if | ||||
| .B \-d | ||||
| was specified. | ||||
| .I FLAGS | ||||
| may be | ||||
| .I a | ||||
| for all debugging output (same as using | ||||
| .BR \-d ), | ||||
| .I b | ||||
| for basic debugging, | ||||
| .I v | ||||
| for more verbose basic debugging, | ||||
| .I i | ||||
| for showing implicit rules, | ||||
| .I j | ||||
| for details on invocation of commands, and | ||||
| .I m | ||||
| for debugging while remaking makefiles.  Use | ||||
| .I n | ||||
| to disable all previous debugging flags. | ||||
| .TP 0.5i | ||||
| \fB\-e\fR, \fB\-\-environment\-overrides\fR | ||||
| Give variables taken from the environment precedence over variables | ||||
| from makefiles. | ||||
| .TP 0.5i | ||||
| \fB\-E\fR \fIstring\fR, \fB\-\-eval\fR \fIstring\fR | ||||
| Interpret \fIstring\fR using the \fBeval\fR function, before parsing any | ||||
| makefiles. | ||||
| .TP 0.5i | ||||
| \fB\-f\fR \fIfile\fR, \fB\-\-file\fR=\fIfile\fR, \fB\-\-makefile\fR=\fIFILE\fR | ||||
| Use | ||||
| .I file | ||||
| as a makefile. | ||||
| .TP 0.5i | ||||
| \fB\-i\fR, \fB\-\-ignore\-errors\fR | ||||
| Ignore all errors in commands executed to remake files. | ||||
| .TP 0.5i | ||||
| \fB\-I\fR \fIdir\fR, \fB\-\-include\-dir\fR=\fIdir\fR | ||||
| Specifies a directory | ||||
| .I dir | ||||
| to search for included makefiles. | ||||
| If several | ||||
| .B \-I | ||||
| options are used to specify several directories, the directories are | ||||
| searched in the order specified. | ||||
| Unlike the arguments to other flags of | ||||
| .BR make , | ||||
| directories given with | ||||
| .B \-I | ||||
| flags may come directly after the flag: | ||||
| .BI \-I dir | ||||
| is allowed, as well as | ||||
| .B \-I | ||||
| .IR dir . | ||||
| This syntax is allowed for compatibility with the C | ||||
| preprocessor's | ||||
| .B \-I | ||||
| flag. | ||||
| .TP 0.5i | ||||
| \fB\-j\fR [\fIjobs\fR], \fB\-\-jobs\fR[=\fIjobs\fR] | ||||
| Specifies the number of | ||||
| .I jobs | ||||
| (commands) to run simultaneously. | ||||
| If there is more than one | ||||
| .B \-j | ||||
| option, the last one is effective. | ||||
| If the | ||||
| .B \-j | ||||
| option is given without an argument, | ||||
| .BR make | ||||
| will not limit the number of jobs that can run simultaneously. | ||||
| .TP 0.5i | ||||
| \fB\-k\fR, \fB\-\-keep\-going\fR | ||||
| Continue as much as possible after an error. | ||||
| While the target that failed, and those that depend on it, cannot | ||||
| be remade, the other dependencies of these targets can be processed | ||||
| all the same. | ||||
| .TP 0.5i | ||||
| \fB\-l\fR [\fIload\fR], \fB\-\-load\-average\fR[=\fIload\fR] | ||||
| Specifies that no new jobs (commands) should be started if there are | ||||
| others jobs running and the load average is at least | ||||
| .I load | ||||
| (a floating-point number). | ||||
| With no argument, removes a previous load limit. | ||||
| .TP 0.5i | ||||
| \fB\-L\fR, \fB\-\-check\-symlink\-times\fR | ||||
| Use the latest mtime between symlinks and target. | ||||
| .TP 0.5i | ||||
| \fB\-n\fR, \fB\-\-just\-print\fR, \fB\-\-dry\-run\fR, \fB\-\-recon\fR | ||||
| Print the commands that would be executed, but do not execute them (except in | ||||
| certain circumstances). | ||||
| .TP 0.5i | ||||
| \fB\-o\fR \fIfile\fR, \fB\-\-old\-file\fR=\fIfile\fR, \fB\-\-assume\-old\fR=\fIfile\fR | ||||
| Do not remake the file | ||||
| .I file | ||||
| even if it is older than its dependencies, and do not remake anything | ||||
| on account of changes in | ||||
| .IR file . | ||||
| Essentially the file is treated as very old and its rules are ignored. | ||||
| .TP 0.5i | ||||
| \fB\-O\fR[\fItype\fR], \fB\-\-output\-sync\fR[=\fItype\fR] | ||||
| When running multiple jobs in parallel with \fB-j\fR, ensure the output of | ||||
| each job is collected together rather than interspersed with output from | ||||
| other jobs.  If | ||||
| .I type | ||||
| is not specified or is | ||||
| .B target | ||||
| the output from the entire recipe for each target is grouped together.  If | ||||
| .I type | ||||
| is | ||||
| .B line | ||||
| the output from each command line within a recipe is grouped together. | ||||
| If | ||||
| .I type | ||||
| is | ||||
| .B recurse | ||||
| output from an entire recursive make is grouped together.  If | ||||
| .I type | ||||
| is | ||||
| .B none | ||||
| output synchronization is disabled. | ||||
| .TP 0.5i | ||||
| \fB\-p\fR, \fB\-\-print\-data\-base\fR | ||||
| Print the data base (rules and variable values) that results from | ||||
| reading the makefiles; then execute as usual or as otherwise | ||||
| specified. | ||||
| This also prints the version information given by the | ||||
| .B \-v | ||||
| switch (see below). | ||||
| To print the data base without trying to remake any files, use | ||||
| .IR "make \-p \-f/dev/null" . | ||||
| .TP 0.5i | ||||
| \fB\-q\fR, \fB\-\-question\fR | ||||
| ``Question mode''. | ||||
| Do not run any commands, or print anything; just return an exit status | ||||
| that is zero if the specified targets are already up to date, nonzero | ||||
| otherwise. | ||||
| .TP 0.5i | ||||
| \fB\-r\fR, \fB\-\-no\-builtin\-rules\fR | ||||
| Eliminate use of the built\-in implicit rules. | ||||
| Also clear out the default list of suffixes for suffix rules. | ||||
| .TP 0.5i | ||||
| \fB\-R\fR, \fB\-\-no\-builtin\-variables\fR | ||||
| Don't define any built\-in variables. | ||||
| .TP 0.5i | ||||
| \fB\-s\fR, \fB\-\-silent\fR, \fB\-\-quiet\fR | ||||
| Silent operation; do not print the commands as they are executed. | ||||
| .TP 0.5i | ||||
| .B \-\-no\-silent | ||||
| Cancel the effect of the \fB\-s\fR option. | ||||
| .TP 0.5i | ||||
| \fB\-S\fR, \fB\-\-no\-keep\-going\fR, \fB\-\-stop\fR | ||||
| Cancel the effect of the | ||||
| .B \-k | ||||
| option. | ||||
| .TP 0.5i | ||||
| \fB\-t\fR, \fB\-\-touch\fR | ||||
| Touch files (mark them up to date without really changing them) | ||||
| instead of running their commands. | ||||
| This is used to pretend that the commands were done, in order to fool | ||||
| future invocations of | ||||
| .BR make . | ||||
| .TP 0.5i | ||||
| .B \-\-trace | ||||
| Information about the disposition of each target is printed (why the target is | ||||
| being rebuilt and what commands are run to rebuild it). | ||||
| .TP 0.5i | ||||
| \fB\-v\fR, \fB\-\-version\fR | ||||
| Print the version of the | ||||
| .B make | ||||
| program plus a copyright, a list of authors and a notice that there | ||||
| is no warranty. | ||||
| .TP 0.5i | ||||
| \fB\-w\fR, \fB\-\-print\-directory\fR | ||||
| Print a message containing the working directory | ||||
| before and after other processing. | ||||
| This may be useful for tracking down errors from complicated nests of | ||||
| recursive | ||||
| .B make | ||||
| commands. | ||||
| .TP 0.5i | ||||
| .B \-\-no\-print\-directory | ||||
| Turn off | ||||
| .BR \-w , | ||||
| even if it was turned on implicitly. | ||||
| .TP 0.5i | ||||
| \fB\-W\fR \fIfile\fR, \fB\-\-what\-if\fR=\fIfile\fR, \fB\-\-new\-file\fR=\fIfile\fR, \fB\-\-assume\-new\fR=\fIfile\fR | ||||
| Pretend that the target | ||||
| .I file | ||||
| has just been modified. | ||||
| When used with the | ||||
| .B \-n | ||||
| flag, this shows you what would happen if you were to modify that file. | ||||
| Without | ||||
| .BR \-n , | ||||
| it is almost the same as running a | ||||
| .I touch | ||||
| command on the given file before running | ||||
| .BR make , | ||||
| except that the modification time is changed only in the imagination of | ||||
| .BR make . | ||||
| .TP 0.5i | ||||
| .B \-\-warn\-undefined\-variables | ||||
| Warn when an undefined variable is referenced. | ||||
| .SH "EXIT STATUS" | ||||
| GNU | ||||
| .B make | ||||
| exits with a status of zero if all makefiles were successfully parsed | ||||
| and no targets that were built failed.  A status of one will be returned | ||||
| if the | ||||
| .B \-q | ||||
| flag was used and | ||||
| .B make | ||||
| determines that a target needs to be rebuilt.  A status of two will be | ||||
| returned if any errors were encountered. | ||||
| .SH "SEE ALSO" | ||||
| The full documentation for | ||||
| .B make | ||||
| is maintained as a Texinfo manual.  If the | ||||
| .B info | ||||
| and | ||||
| .B make | ||||
| programs are properly installed at your site, the command | ||||
| .IP | ||||
| .B info make | ||||
| .PP | ||||
| should give you access to the complete manual. | ||||
| .SH BUGS | ||||
| See the chapter ``Problems and Bugs'' in | ||||
| .IR "The GNU Make Manual" . | ||||
| .SH AUTHOR | ||||
| This manual page contributed by Dennis Morse of Stanford University. | ||||
| Further updates contributed by Mike Frysinger.  It has been reworked by Roland | ||||
| McGrath.  Maintained by Paul Smith. | ||||
| .SH "COPYRIGHT" | ||||
| Copyright \(co 1992-1993, 1996-2020 Free Software Foundation, Inc. | ||||
| This file is part of | ||||
| .IR "GNU make" . | ||||
| .LP | ||||
| GNU Make is free software; you can redistribute it and/or modify it under the | ||||
| terms of the GNU General Public License as published by the Free Software | ||||
| Foundation; either version 3 of the License, or (at your option) any later | ||||
| version. | ||||
| .LP | ||||
| GNU Make is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
| WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR | ||||
| A PARTICULAR PURPOSE.  See the GNU General Public License for more details. | ||||
| .LP | ||||
| You should have received a copy of the GNU General Public License along with | ||||
| this program.  If not, see | ||||
| .IR http://www.gnu.org/licenses/ . | ||||
							
								
								
									
										207
									
								
								third_party/make/doc/make.info
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										207
									
								
								third_party/make/doc/make.info
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,207 @@ | |||
| This is make.info, produced by makeinfo version 6.6 from make.texi. | ||||
| 
 | ||||
| This file documents the GNU 'make' utility, which determines | ||||
| automatically which pieces of a large program need to be recompiled, and | ||||
| issues the commands to recompile them. | ||||
| 
 | ||||
|    This is Edition 0.75, last updated 19 January 2020, of 'The GNU Make | ||||
| Manual', for GNU 'make' version 4.3. | ||||
| 
 | ||||
|    Copyright (C) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, | ||||
| 1997, 1998, 1999, 2000, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, | ||||
| 2010, 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019, 2020 Free | ||||
| Software Foundation, Inc. | ||||
| 
 | ||||
|      Permission is granted to copy, distribute and/or modify this | ||||
|      document under the terms of the GNU Free Documentation License, | ||||
|      Version 1.3 or any later version published by the Free Software | ||||
|      Foundation; with no Invariant Sections, with the Front-Cover Texts | ||||
|      being "A GNU Manual," and with the Back-Cover Texts as in (a) | ||||
|      below.  A copy of the license is included in the section entitled | ||||
|      "GNU Free Documentation License." | ||||
| 
 | ||||
|      (a) The FSF's Back-Cover Text is: "You have the freedom to copy and | ||||
|      modify this GNU manual.  Buying copies from the FSF supports it in | ||||
|      developing GNU and promoting software freedom." | ||||
| INFO-DIR-SECTION Software development | ||||
| START-INFO-DIR-ENTRY | ||||
| * Make: (make).            Remake files automatically. | ||||
| END-INFO-DIR-ENTRY | ||||
| 
 | ||||
|  | ||||
| Indirect: | ||||
| make.info-1: 1379 | ||||
| make.info-2: 301593 | ||||
|  | ||||
| Tag Table: | ||||
| (Indirect) | ||||
| Node: Top1379 | ||||
| Node: Overview16646 | ||||
| Node: Preparing17659 | ||||
| Node: Reading18627 | ||||
| Node: Bugs19554 | ||||
| Node: Introduction21383 | ||||
| Node: Rule Introduction22976 | ||||
| Node: Simple Makefile24909 | ||||
| Node: How Make Works28645 | ||||
| Node: Variables Simplify31294 | ||||
| Node: make Deduces33500 | ||||
| Node: Combine By Prerequisite35233 | ||||
| Node: Cleanup36262 | ||||
| Node: Makefiles37680 | ||||
| Node: Makefile Contents38575 | ||||
| Node: Splitting Lines41748 | ||||
| Node: Makefile Names44231 | ||||
| Node: Include45838 | ||||
| Ref: Include-Footnote-149582 | ||||
| Node: MAKEFILES Variable49716 | ||||
| Node: Remaking Makefiles51257 | ||||
| Node: Overriding Makefiles55587 | ||||
| Node: Reading Makefiles57615 | ||||
| Node: Parsing Makefiles61057 | ||||
| Node: Secondary Expansion62915 | ||||
| Node: Rules70363 | ||||
| Node: Rule Example73036 | ||||
| Node: Rule Syntax73884 | ||||
| Node: Prerequisite Types76479 | ||||
| Node: Wildcards79346 | ||||
| Node: Wildcard Examples81065 | ||||
| Node: Wildcard Pitfall82415 | ||||
| Node: Wildcard Function84204 | ||||
| Node: Directory Search85988 | ||||
| Node: General Search87123 | ||||
| Node: Selective Search88830 | ||||
| Node: Search Algorithm91820 | ||||
| Node: Recipes/Search94338 | ||||
| Node: Implicit/Search95661 | ||||
| Node: Libraries/Search96603 | ||||
| Node: Phony Targets98574 | ||||
| Node: Force Targets103411 | ||||
| Node: Empty Targets104448 | ||||
| Node: Special Targets105750 | ||||
| Node: Multiple Targets113550 | ||||
| Node: Multiple Rules117783 | ||||
| Node: Static Pattern120001 | ||||
| Node: Static Usage120653 | ||||
| Node: Static versus Implicit124372 | ||||
| Node: Double-Colon126112 | ||||
| Node: Automatic Prerequisites127872 | ||||
| Node: Recipes132133 | ||||
| Node: Recipe Syntax133305 | ||||
| Node: Splitting Recipe Lines135420 | ||||
| Node: Variables in Recipes138573 | ||||
| Node: Echoing139899 | ||||
| Node: Execution141111 | ||||
| Ref: Execution-Footnote-1142524 | ||||
| Node: One Shell142669 | ||||
| Node: Choosing the Shell145987 | ||||
| Node: Parallel150131 | ||||
| Node: Parallel Output152800 | ||||
| Node: Parallel Input157227 | ||||
| Node: Errors158346 | ||||
| Node: Interrupts161981 | ||||
| Node: Recursion164342 | ||||
| Node: MAKE Variable166439 | ||||
| Node: Variables/Recursion168682 | ||||
| Node: Options/Recursion174127 | ||||
| Node: -w Option180133 | ||||
| Node: Canned Recipes181128 | ||||
| Node: Empty Recipes184111 | ||||
| Node: Using Variables185551 | ||||
| Node: Reference188979 | ||||
| Node: Flavors190789 | ||||
| Node: Advanced196768 | ||||
| Node: Substitution Refs197273 | ||||
| Node: Computed Names198875 | ||||
| Node: Values203423 | ||||
| Node: Setting204340 | ||||
| Node: Appending207379 | ||||
| Node: Override Directive211350 | ||||
| Node: Multi-Line212977 | ||||
| Node: Undefine Directive215840 | ||||
| Node: Environment216929 | ||||
| Node: Target-specific219181 | ||||
| Node: Pattern-specific222208 | ||||
| Node: Suppressing Inheritance224055 | ||||
| Node: Special Variables225508 | ||||
| Node: Conditionals233749 | ||||
| Node: Conditional Example234462 | ||||
| Node: Conditional Syntax237025 | ||||
| Node: Testing Flags242785 | ||||
| Node: Functions243886 | ||||
| Node: Syntax of Functions245446 | ||||
| Node: Text Functions247780 | ||||
| Node: File Name Functions256341 | ||||
| Node: Conditional Functions261567 | ||||
| Node: Foreach Function263943 | ||||
| Node: File Function267156 | ||||
| Node: Call Function269713 | ||||
| Node: Value Function272598 | ||||
| Node: Eval Function274035 | ||||
| Node: Origin Function276311 | ||||
| Node: Flavor Function279537 | ||||
| Node: Make Control Functions280581 | ||||
| Node: Shell Function282267 | ||||
| Node: Guile Function284026 | ||||
| Node: Running284776 | ||||
| Node: Makefile Arguments286757 | ||||
| Node: Goals287473 | ||||
| Node: Instead of Execution292212 | ||||
| Node: Avoiding Compilation295927 | ||||
| Node: Overriding297902 | ||||
| Node: Testing301593 | ||||
| Node: Options Summary303477 | ||||
| Node: Implicit Rules315181 | ||||
| Node: Using Implicit317318 | ||||
| Node: Catalogue of Rules320837 | ||||
| Node: Implicit Variables330181 | ||||
| Node: Chained Rules335254 | ||||
| Node: Pattern Rules339475 | ||||
| Node: Pattern Intro341009 | ||||
| Node: Pattern Examples343160 | ||||
| Node: Automatic Variables344967 | ||||
| Node: Pattern Match352342 | ||||
| Node: Match-Anything Rules355665 | ||||
| Node: Canceling Rules359586 | ||||
| Node: Last Resort360300 | ||||
| Node: Suffix Rules362129 | ||||
| Node: Implicit Rule Search365863 | ||||
| Node: Archives369414 | ||||
| Node: Archive Members370119 | ||||
| Node: Archive Update371729 | ||||
| Node: Archive Symbols373640 | ||||
| Node: Archive Pitfalls374873 | ||||
| Node: Archive Suffix Rules375595 | ||||
| Node: Extending make377143 | ||||
| Node: Guile Integration378288 | ||||
| Node: Guile Types379516 | ||||
| Node: Guile Interface381936 | ||||
| Node: Guile Example383222 | ||||
| Node: Loading Objects385413 | ||||
| Node: load Directive386903 | ||||
| Node: Remaking Loaded Objects389657 | ||||
| Node: Loaded Object API390291 | ||||
| Node: Loaded Object Example397053 | ||||
| Node: Integrating make399300 | ||||
| Node: Job Slots400051 | ||||
| Node: POSIX Jobserver403483 | ||||
| Node: Windows Jobserver405951 | ||||
| Node: Terminal Output407304 | ||||
| Node: Features409693 | ||||
| Node: Missing418862 | ||||
| Node: Makefile Conventions422590 | ||||
| Node: Makefile Basics423569 | ||||
| Node: Utilities in Makefiles426736 | ||||
| Node: Command Variables429235 | ||||
| Node: DESTDIR432475 | ||||
| Node: Directory Variables434642 | ||||
| Node: Standard Targets449999 | ||||
| Node: Install Command Categories464105 | ||||
| Node: Quick Reference468631 | ||||
| Node: Error Messages481345 | ||||
| Node: Complex Makefile490140 | ||||
| Node: GNU Free Documentation License498758 | ||||
| Node: Concept Index523916 | ||||
| Node: Name Index596081 | ||||
|  | ||||
| End Tag Table | ||||
							
								
								
									
										7224
									
								
								third_party/make/doc/make.info-1
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7224
									
								
								third_party/make/doc/make.info-1
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										6463
									
								
								third_party/make/doc/make.info-2
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										6463
									
								
								third_party/make/doc/make.info-2
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										13061
									
								
								third_party/make/doc/make.texi
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										13061
									
								
								third_party/make/doc/make.texi
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										4
									
								
								third_party/make/doc/stamp-vti
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								third_party/make/doc/stamp-vti
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,4 @@ | |||
| @set UPDATED 19 January 2020 | ||||
| @set UPDATED-MONTH January 2020 | ||||
| @set EDITION 4.3 | ||||
| @set VERSION 4.3 | ||||
							
								
								
									
										4
									
								
								third_party/make/doc/version.texi
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								third_party/make/doc/version.texi
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,4 @@ | |||
| @set UPDATED 19 January 2020 | ||||
| @set UPDATED-MONTH January 2020 | ||||
| @set EDITION 4.3 | ||||
| @set VERSION 4.3 | ||||
							
								
								
									
										1169
									
								
								third_party/make/lib/Makefile.am
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1169
									
								
								third_party/make/lib/Makefile.am
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										2118
									
								
								third_party/make/lib/Makefile.in
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2118
									
								
								third_party/make/lib/Makefile.in
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										40
									
								
								third_party/make/lib/_Noreturn.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								third_party/make/lib/_Noreturn.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,40 @@ | |||
| /* A C macro for declaring that a function does not return.
 | ||||
|    Copyright (C) 2011-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify it | ||||
|    under the terms of the GNU General Public License as published | ||||
|    by the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
|    General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _Noreturn | ||||
| # if (defined __cplusplus \ | ||||
|       && ((201103 <= __cplusplus && !(__GNUC__ == 4 && __GNUC_MINOR__ == 7)) \ | ||||
|           || (defined _MSC_VER && 1900 <= _MSC_VER)) \ | ||||
|       && 0) | ||||
|     /* [[noreturn]] is not practically usable, because with it the syntax
 | ||||
|          extern _Noreturn void func (...); | ||||
|        would not be valid; such a declaration would only be valid with 'extern' | ||||
|        and '_Noreturn' swapped, or without the 'extern' keyword.  However, some | ||||
|        AIX system header files and several gnulib header files use precisely | ||||
|        this syntax with 'extern'.  */ | ||||
| #  define _Noreturn [[noreturn]] | ||||
| # elif ((!defined __cplusplus || defined __clang__)                     \ | ||||
|         && (201112 <= (defined __STDC_VERSION__ ? __STDC_VERSION__ : 0)  \ | ||||
|             || 4 < __GNUC__ + (7 <= __GNUC_MINOR__))) | ||||
|    /* _Noreturn works as-is.  */ | ||||
| # elif 2 < __GNUC__ + (8 <= __GNUC_MINOR__) || 0x5110 <= __SUNPRO_C | ||||
| #  define _Noreturn __attribute__ ((__noreturn__)) | ||||
| # elif 1200 <= (defined _MSC_VER ? _MSC_VER : 0) | ||||
| #  define _Noreturn __declspec (noreturn) | ||||
| # else | ||||
| #  define _Noreturn | ||||
| # endif | ||||
| #endif | ||||
							
								
								
									
										31
									
								
								third_party/make/lib/access.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								third_party/make/lib/access.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,31 @@ | |||
| /* Test the access rights of a file.
 | ||||
|    Copyright (C) 2019-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include <unistd.h> | ||||
| 
 | ||||
| #include <fcntl.h> | ||||
| #include <io.h> | ||||
| 
 | ||||
| int | ||||
| access (const char *file, int mode) | ||||
| { | ||||
|   if ((mode & X_OK) != 0) | ||||
|     mode = (mode & ~X_OK) | R_OK; | ||||
|   return _access (file, mode); | ||||
| } | ||||
							
								
								
									
										478
									
								
								third_party/make/lib/alloca.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										478
									
								
								third_party/make/lib/alloca.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,478 @@ | |||
| /* alloca.c -- allocate automatically reclaimed memory
 | ||||
|    (Mostly) portable public-domain implementation -- D A Gwyn | ||||
| 
 | ||||
|    This implementation of the PWB library alloca function, | ||||
|    which is used to allocate space off the run-time stack so | ||||
|    that it is automatically reclaimed upon procedure exit, | ||||
|    was inspired by discussions with J. Q. Johnson of Cornell. | ||||
|    J.Otto Tennant <jot@cray.com> contributed the Cray support. | ||||
| 
 | ||||
|    There are some preprocessor constants that can | ||||
|    be defined when compiling for your specific system, for | ||||
|    improved efficiency; however, the defaults should be okay. | ||||
| 
 | ||||
|    The general concept of this implementation is to keep | ||||
|    track of all alloca-allocated blocks, and reclaim any | ||||
|    that are found to be deeper in the stack than the current | ||||
|    invocation.  This heuristic does not reclaim storage as | ||||
|    soon as it becomes invalid, but it will do so eventually. | ||||
| 
 | ||||
|    As a special case, alloca(0) reclaims storage without | ||||
|    allocating any.  It is a good idea to use alloca(0) in | ||||
|    your main control loop, etc. to force garbage collection.  */ | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| #include <alloca.h> | ||||
| 
 | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| #ifdef emacs | ||||
| # include "lisp.h" | ||||
| # include "blockinput.h" | ||||
| # ifdef EMACS_FREE | ||||
| #  undef free | ||||
| #  define free EMACS_FREE | ||||
| # endif | ||||
| #else | ||||
| # define memory_full() abort () | ||||
| #endif | ||||
| 
 | ||||
| /* If compiling with GCC 2, this file's not needed.  */ | ||||
| #if !defined (__GNUC__) || __GNUC__ < 2 | ||||
| 
 | ||||
| /* If someone has defined alloca as a macro,
 | ||||
|    there must be some other way alloca is supposed to work.  */ | ||||
| # ifndef alloca | ||||
| 
 | ||||
| #  ifdef emacs | ||||
| #   ifdef static | ||||
| /* actually, only want this if static is defined as ""
 | ||||
|    -- this is for usg, in which emacs must undefine static | ||||
|    in order to make unexec workable | ||||
|    */ | ||||
| #    ifndef STACK_DIRECTION | ||||
| you | ||||
| lose | ||||
| -- must know STACK_DIRECTION at compile-time | ||||
| /* Using #error here is not wise since this file should work for
 | ||||
|    old and obscure compilers.  */ | ||||
| #    endif /* STACK_DIRECTION undefined */ | ||||
| #   endif /* static */ | ||||
| #  endif /* emacs */ | ||||
| 
 | ||||
| /* If your stack is a linked list of frames, you have to
 | ||||
|    provide an "address metric" ADDRESS_FUNCTION macro.  */ | ||||
| 
 | ||||
| #  if defined (CRAY) && defined (CRAY_STACKSEG_END) | ||||
| long i00afunc (); | ||||
| #   define ADDRESS_FUNCTION(arg) (char *) i00afunc (&(arg)) | ||||
| #  else | ||||
| #   define ADDRESS_FUNCTION(arg) &(arg) | ||||
| #  endif | ||||
| 
 | ||||
| /* Define STACK_DIRECTION if you know the direction of stack
 | ||||
|    growth for your system; otherwise it will be automatically | ||||
|    deduced at run-time. | ||||
| 
 | ||||
|    STACK_DIRECTION > 0 => grows toward higher addresses | ||||
|    STACK_DIRECTION < 0 => grows toward lower addresses | ||||
|    STACK_DIRECTION = 0 => direction of growth unknown  */ | ||||
| 
 | ||||
| #  ifndef STACK_DIRECTION | ||||
| #   define STACK_DIRECTION      0       /* Direction unknown.  */ | ||||
| #  endif | ||||
| 
 | ||||
| #  if STACK_DIRECTION != 0 | ||||
| 
 | ||||
| #   define STACK_DIR    STACK_DIRECTION /* Known at compile-time.  */ | ||||
| 
 | ||||
| #  else /* STACK_DIRECTION == 0; need run-time code.  */ | ||||
| 
 | ||||
| static int stack_dir;           /* 1 or -1 once known.  */ | ||||
| #   define STACK_DIR    stack_dir | ||||
| 
 | ||||
| static int | ||||
| find_stack_direction (int *addr, int depth) | ||||
| { | ||||
|   int dir, dummy = 0; | ||||
|   if (! addr) | ||||
|     addr = &dummy; | ||||
|   *addr = addr < &dummy ? 1 : addr == &dummy ? 0 : -1; | ||||
|   dir = depth ? find_stack_direction (addr, depth - 1) : 0; | ||||
|   return dir + dummy; | ||||
| } | ||||
| 
 | ||||
| #  endif /* STACK_DIRECTION == 0 */ | ||||
| 
 | ||||
| /* An "alloca header" is used to:
 | ||||
|    (a) chain together all alloca'ed blocks; | ||||
|    (b) keep track of stack depth. | ||||
| 
 | ||||
|    It is very important that sizeof(header) agree with malloc | ||||
|    alignment chunk size.  The following default should work okay.  */ | ||||
| 
 | ||||
| #  ifndef       ALIGN_SIZE | ||||
| #   define ALIGN_SIZE   sizeof(double) | ||||
| #  endif | ||||
| 
 | ||||
| typedef union hdr | ||||
| { | ||||
|   char align[ALIGN_SIZE];       /* To force sizeof(header).  */ | ||||
|   struct | ||||
|     { | ||||
|       union hdr *next;          /* For chaining headers.  */ | ||||
|       char *deep;               /* For stack depth measure.  */ | ||||
|     } h; | ||||
| } header; | ||||
| 
 | ||||
| static header *last_alloca_header = NULL;       /* -> last alloca header.  */ | ||||
| 
 | ||||
| /* Return a pointer to at least SIZE bytes of storage,
 | ||||
|    which will be automatically reclaimed upon exit from | ||||
|    the procedure that called alloca.  Originally, this space | ||||
|    was supposed to be taken from the current stack frame of the | ||||
|    caller, but that method cannot be made to work for some | ||||
|    implementations of C, for example under Gould's UTX/32.  */ | ||||
| 
 | ||||
| void * | ||||
| alloca (size_t size) | ||||
| { | ||||
|   auto char probe;              /* Probes stack depth: */ | ||||
|   register char *depth = ADDRESS_FUNCTION (probe); | ||||
| 
 | ||||
| #  if STACK_DIRECTION == 0 | ||||
|   if (STACK_DIR == 0)           /* Unknown growth direction.  */ | ||||
|     STACK_DIR = find_stack_direction (NULL, (size & 1) + 20); | ||||
| #  endif | ||||
| 
 | ||||
|   /* Reclaim garbage, defined as all alloca'd storage that
 | ||||
|      was allocated from deeper in the stack than currently.  */ | ||||
| 
 | ||||
|   { | ||||
|     register header *hp;        /* Traverses linked list.  */ | ||||
| 
 | ||||
| #  ifdef emacs | ||||
|     BLOCK_INPUT; | ||||
| #  endif | ||||
| 
 | ||||
|     for (hp = last_alloca_header; hp != NULL;) | ||||
|       if ((STACK_DIR > 0 && hp->h.deep > depth) | ||||
|           || (STACK_DIR < 0 && hp->h.deep < depth)) | ||||
|         { | ||||
|           register header *np = hp->h.next; | ||||
| 
 | ||||
|           free (hp);            /* Collect garbage.  */ | ||||
| 
 | ||||
|           hp = np;              /* -> next header.  */ | ||||
|         } | ||||
|       else | ||||
|         break;                  /* Rest are not deeper.  */ | ||||
| 
 | ||||
|     last_alloca_header = hp;    /* -> last valid storage.  */ | ||||
| 
 | ||||
| #  ifdef emacs | ||||
|     UNBLOCK_INPUT; | ||||
| #  endif | ||||
|   } | ||||
| 
 | ||||
|   if (size == 0) | ||||
|     return NULL;                /* No allocation required.  */ | ||||
| 
 | ||||
|   /* Allocate combined header + user data storage.  */ | ||||
| 
 | ||||
|   { | ||||
|     /* Address of header.  */ | ||||
|     register header *new; | ||||
| 
 | ||||
|     size_t combined_size = sizeof (header) + size; | ||||
|     if (combined_size < sizeof (header)) | ||||
|       memory_full (); | ||||
| 
 | ||||
|     new = malloc (combined_size); | ||||
| 
 | ||||
|     if (! new) | ||||
|       memory_full (); | ||||
| 
 | ||||
|     new->h.next = last_alloca_header; | ||||
|     new->h.deep = depth; | ||||
| 
 | ||||
|     last_alloca_header = new; | ||||
| 
 | ||||
|     /* User storage begins just after header.  */ | ||||
| 
 | ||||
|     return (void *) (new + 1); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| #  if defined (CRAY) && defined (CRAY_STACKSEG_END) | ||||
| 
 | ||||
| #   ifdef DEBUG_I00AFUNC | ||||
| #    include <stdio.h> | ||||
| #   endif | ||||
| 
 | ||||
| #   ifndef CRAY_STACK | ||||
| #    define CRAY_STACK | ||||
| #    ifndef CRAY2 | ||||
| /* Stack structures for CRAY-1, CRAY X-MP, and CRAY Y-MP */ | ||||
| struct stack_control_header | ||||
|   { | ||||
|     long shgrow:32;             /* Number of times stack has grown.  */ | ||||
|     long shaseg:32;             /* Size of increments to stack.  */ | ||||
|     long shhwm:32;              /* High water mark of stack.  */ | ||||
|     long shsize:32;             /* Current size of stack (all segments).  */ | ||||
|   }; | ||||
| 
 | ||||
| /* The stack segment linkage control information occurs at
 | ||||
|    the high-address end of a stack segment.  (The stack | ||||
|    grows from low addresses to high addresses.)  The initial | ||||
|    part of the stack segment linkage control information is | ||||
|    0200 (octal) words.  This provides for register storage | ||||
|    for the routine which overflows the stack.  */ | ||||
| 
 | ||||
| struct stack_segment_linkage | ||||
|   { | ||||
|     long ss[0200];              /* 0200 overflow words.  */ | ||||
|     long sssize:32;             /* Number of words in this segment.  */ | ||||
|     long ssbase:32;             /* Offset to stack base.  */ | ||||
|     long:32; | ||||
|     long sspseg:32;             /* Offset to linkage control of previous
 | ||||
|                                    segment of stack.  */ | ||||
|     long:32; | ||||
|     long sstcpt:32;             /* Pointer to task common address block.  */ | ||||
|     long sscsnm;                /* Private control structure number for
 | ||||
|                                    microtasking.  */ | ||||
|     long ssusr1;                /* Reserved for user.  */ | ||||
|     long ssusr2;                /* Reserved for user.  */ | ||||
|     long sstpid;                /* Process ID for pid based multi-tasking.  */ | ||||
|     long ssgvup;                /* Pointer to multitasking thread giveup.  */ | ||||
|     long sscray[7];             /* Reserved for Cray Research.  */ | ||||
|     long ssa0; | ||||
|     long ssa1; | ||||
|     long ssa2; | ||||
|     long ssa3; | ||||
|     long ssa4; | ||||
|     long ssa5; | ||||
|     long ssa6; | ||||
|     long ssa7; | ||||
|     long sss0; | ||||
|     long sss1; | ||||
|     long sss2; | ||||
|     long sss3; | ||||
|     long sss4; | ||||
|     long sss5; | ||||
|     long sss6; | ||||
|     long sss7; | ||||
|   }; | ||||
| 
 | ||||
| #    else /* CRAY2 */ | ||||
| /* The following structure defines the vector of words
 | ||||
|    returned by the STKSTAT library routine.  */ | ||||
| struct stk_stat | ||||
|   { | ||||
|     long now;                   /* Current total stack size.  */ | ||||
|     long maxc;                  /* Amount of contiguous space which would
 | ||||
|                                    be required to satisfy the maximum | ||||
|                                    stack demand to date.  */ | ||||
|     long high_water;            /* Stack high-water mark.  */ | ||||
|     long overflows;             /* Number of stack overflow ($STKOFEN) calls.  */ | ||||
|     long hits;                  /* Number of internal buffer hits.  */ | ||||
|     long extends;               /* Number of block extensions.  */ | ||||
|     long stko_mallocs;          /* Block allocations by $STKOFEN.  */ | ||||
|     long underflows;            /* Number of stack underflow calls ($STKRETN).  */ | ||||
|     long stko_free;             /* Number of deallocations by $STKRETN.  */ | ||||
|     long stkm_free;             /* Number of deallocations by $STKMRET.  */ | ||||
|     long segments;              /* Current number of stack segments.  */ | ||||
|     long maxs;                  /* Maximum number of stack segments so far.  */ | ||||
|     long pad_size;              /* Stack pad size.  */ | ||||
|     long current_address;       /* Current stack segment address.  */ | ||||
|     long current_size;          /* Current stack segment size.  This
 | ||||
|                                    number is actually corrupted by STKSTAT to | ||||
|                                    include the fifteen word trailer area.  */ | ||||
|     long initial_address;       /* Address of initial segment.  */ | ||||
|     long initial_size;          /* Size of initial segment.  */ | ||||
|   }; | ||||
| 
 | ||||
| /* The following structure describes the data structure which trails
 | ||||
|    any stack segment.  I think that the description in 'asdef' is | ||||
|    out of date.  I only describe the parts that I am sure about.  */ | ||||
| 
 | ||||
| struct stk_trailer | ||||
|   { | ||||
|     long this_address;          /* Address of this block.  */ | ||||
|     long this_size;             /* Size of this block (does not include
 | ||||
|                                    this trailer).  */ | ||||
|     long unknown2; | ||||
|     long unknown3; | ||||
|     long link;                  /* Address of trailer block of previous
 | ||||
|                                    segment.  */ | ||||
|     long unknown5; | ||||
|     long unknown6; | ||||
|     long unknown7; | ||||
|     long unknown8; | ||||
|     long unknown9; | ||||
|     long unknown10; | ||||
|     long unknown11; | ||||
|     long unknown12; | ||||
|     long unknown13; | ||||
|     long unknown14; | ||||
|   }; | ||||
| 
 | ||||
| #    endif /* CRAY2 */ | ||||
| #   endif /* not CRAY_STACK */ | ||||
| 
 | ||||
| #   ifdef CRAY2 | ||||
| /* Determine a "stack measure" for an arbitrary ADDRESS.
 | ||||
|    I doubt that "lint" will like this much.  */ | ||||
| 
 | ||||
| static long | ||||
| i00afunc (long *address) | ||||
| { | ||||
|   struct stk_stat status; | ||||
|   struct stk_trailer *trailer; | ||||
|   long *block, size; | ||||
|   long result = 0; | ||||
| 
 | ||||
|   /* We want to iterate through all of the segments.  The first
 | ||||
|      step is to get the stack status structure.  We could do this | ||||
|      more quickly and more directly, perhaps, by referencing the | ||||
|      $LM00 common block, but I know that this works.  */ | ||||
| 
 | ||||
|   STKSTAT (&status); | ||||
| 
 | ||||
|   /* Set up the iteration.  */ | ||||
| 
 | ||||
|   trailer = (struct stk_trailer *) (status.current_address | ||||
|                                     + status.current_size | ||||
|                                     - 15); | ||||
| 
 | ||||
|   /* There must be at least one stack segment.  Therefore it is
 | ||||
|      a fatal error if "trailer" is null.  */ | ||||
| 
 | ||||
|   if (trailer == NULL) | ||||
|     abort (); | ||||
| 
 | ||||
|   /* Discard segments that do not contain our argument address.  */ | ||||
| 
 | ||||
|   while (trailer != NULL) | ||||
|     { | ||||
|       block = (long *) trailer->this_address; | ||||
|       size = trailer->this_size; | ||||
|       if (block == NULL || size == 0) | ||||
|         abort (); | ||||
|       trailer = (struct stk_trailer *) trailer->link; | ||||
|       if ((block <= address) && (address < (block + size))) | ||||
|         break; | ||||
|     } | ||||
| 
 | ||||
|   /* Set the result to the offset in this segment and add the sizes
 | ||||
|      of all predecessor segments.  */ | ||||
| 
 | ||||
|   result = address - block; | ||||
| 
 | ||||
|   if (trailer == NULL) | ||||
|     { | ||||
|       return result; | ||||
|     } | ||||
| 
 | ||||
|   do | ||||
|     { | ||||
|       if (trailer->this_size <= 0) | ||||
|         abort (); | ||||
|       result += trailer->this_size; | ||||
|       trailer = (struct stk_trailer *) trailer->link; | ||||
|     } | ||||
|   while (trailer != NULL); | ||||
| 
 | ||||
|   /* We are done.  Note that if you present a bogus address (one
 | ||||
|      not in any segment), you will get a different number back, formed | ||||
|      from subtracting the address of the first block.  This is probably | ||||
|      not what you want.  */ | ||||
| 
 | ||||
|   return (result); | ||||
| } | ||||
| 
 | ||||
| #   else /* not CRAY2 */ | ||||
| /* Stack address function for a CRAY-1, CRAY X-MP, or CRAY Y-MP.
 | ||||
|    Determine the number of the cell within the stack, | ||||
|    given the address of the cell.  The purpose of this | ||||
|    routine is to linearize, in some sense, stack addresses | ||||
|    for alloca.  */ | ||||
| 
 | ||||
| static long | ||||
| i00afunc (long address) | ||||
| { | ||||
|   long stkl = 0; | ||||
| 
 | ||||
|   long size, pseg, this_segment, stack; | ||||
|   long result = 0; | ||||
| 
 | ||||
|   struct stack_segment_linkage *ssptr; | ||||
| 
 | ||||
|   /* Register B67 contains the address of the end of the
 | ||||
|      current stack segment.  If you (as a subprogram) store | ||||
|      your registers on the stack and find that you are past | ||||
|      the contents of B67, you have overflowed the segment. | ||||
| 
 | ||||
|      B67 also points to the stack segment linkage control | ||||
|      area, which is what we are really interested in.  */ | ||||
| 
 | ||||
|   stkl = CRAY_STACKSEG_END (); | ||||
|   ssptr = (struct stack_segment_linkage *) stkl; | ||||
| 
 | ||||
|   /* If one subtracts 'size' from the end of the segment,
 | ||||
|      one has the address of the first word of the segment. | ||||
| 
 | ||||
|      If this is not the first segment, 'pseg' will be | ||||
|      nonzero.  */ | ||||
| 
 | ||||
|   pseg = ssptr->sspseg; | ||||
|   size = ssptr->sssize; | ||||
| 
 | ||||
|   this_segment = stkl - size; | ||||
| 
 | ||||
|   /* It is possible that calling this routine itself caused
 | ||||
|      a stack overflow.  Discard stack segments which do not | ||||
|      contain the target address.  */ | ||||
| 
 | ||||
|   while (!(this_segment <= address && address <= stkl)) | ||||
|     { | ||||
| #    ifdef DEBUG_I00AFUNC | ||||
|       fprintf (stderr, "%011o %011o %011o\n", this_segment, address, stkl); | ||||
| #    endif | ||||
|       if (pseg == 0) | ||||
|         break; | ||||
|       stkl = stkl - pseg; | ||||
|       ssptr = (struct stack_segment_linkage *) stkl; | ||||
|       size = ssptr->sssize; | ||||
|       pseg = ssptr->sspseg; | ||||
|       this_segment = stkl - size; | ||||
|     } | ||||
| 
 | ||||
|   result = address - this_segment; | ||||
| 
 | ||||
|   /* If you subtract pseg from the current end of the stack,
 | ||||
|      you get the address of the previous stack segment's end. | ||||
|      This seems a little convoluted to me, but I'll bet you save | ||||
|      a cycle somewhere.  */ | ||||
| 
 | ||||
|   while (pseg != 0) | ||||
|     { | ||||
| #    ifdef DEBUG_I00AFUNC | ||||
|       fprintf (stderr, "%011o %011o\n", pseg, size); | ||||
| #    endif | ||||
|       stkl = stkl - pseg; | ||||
|       ssptr = (struct stack_segment_linkage *) stkl; | ||||
|       size = ssptr->sssize; | ||||
|       pseg = ssptr->sspseg; | ||||
|       result += size; | ||||
|     } | ||||
|   return (result); | ||||
| } | ||||
| 
 | ||||
| #   endif /* not CRAY2 */ | ||||
| #  endif /* CRAY */ | ||||
| 
 | ||||
| # endif /* no alloca */ | ||||
| #endif /* not GCC 2 */ | ||||
							
								
								
									
										71
									
								
								third_party/make/lib/alloca.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								third_party/make/lib/alloca.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,71 @@ | |||
| /* Memory allocation on the stack.
 | ||||
| 
 | ||||
|    Copyright (C) 1995, 1999, 2001-2004, 2006-2020 Free Software Foundation, | ||||
|    Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify it | ||||
|    under the terms of the GNU General Public License as published | ||||
|    by the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
|    General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public | ||||
|    License along with this program; if not, see | ||||
|    <https://www.gnu.org/licenses/>.
 | ||||
|   */ | ||||
| 
 | ||||
| /* Avoid using the symbol _ALLOCA_H here, as Bison assumes _ALLOCA_H
 | ||||
|    means there is a real alloca function.  */ | ||||
| #ifndef _GL_ALLOCA_H | ||||
| #define _GL_ALLOCA_H | ||||
| 
 | ||||
| /* alloca (N) returns a pointer to N bytes of memory
 | ||||
|    allocated on the stack, which will last until the function returns. | ||||
|    Use of alloca should be avoided: | ||||
|      - inside arguments of function calls - undefined behaviour, | ||||
|      - in inline functions - the allocation may actually last until the | ||||
|        calling function returns, | ||||
|      - for huge N (say, N >= 65536) - you never know how large (or small) | ||||
|        the stack is, and when the stack cannot fulfill the memory allocation | ||||
|        request, the program just crashes. | ||||
|  */ | ||||
| 
 | ||||
| #ifndef alloca | ||||
| # ifdef __GNUC__ | ||||
|    /* Some version of mingw have an <alloca.h> that causes trouble when
 | ||||
|       included after 'alloca' gets defined as a macro.  As a workaround, include | ||||
|       this <alloca.h> first and define 'alloca' as a macro afterwards.  */ | ||||
| #  if (defined _WIN32 && ! defined __CYGWIN__) && @HAVE_ALLOCA_H@ | ||||
| #   include_next <alloca.h> | ||||
| #  endif | ||||
| #  define alloca __builtin_alloca | ||||
| # elif defined _AIX | ||||
| #  define alloca __alloca | ||||
| # elif defined _MSC_VER | ||||
| #  include <malloc.h> | ||||
| #  define alloca _alloca | ||||
| # elif defined __DECC && defined __VMS | ||||
| #  define alloca __ALLOCA | ||||
| # elif defined __TANDEM && defined _TNS_E_TARGET | ||||
| #  ifdef  __cplusplus | ||||
| extern "C" | ||||
| #  endif | ||||
| void *_alloca (unsigned short); | ||||
| #  pragma intrinsic (_alloca) | ||||
| #  define alloca _alloca | ||||
| # elif defined __MVS__ | ||||
| #  include <stdlib.h> | ||||
| # else | ||||
| #  include <stddef.h> | ||||
| #  ifdef  __cplusplus | ||||
| extern "C" | ||||
| #  endif | ||||
| void *alloca (size_t); | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| #endif /* _GL_ALLOCA_H */ | ||||
							
								
								
									
										26
									
								
								third_party/make/lib/arg-nonnull.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								third_party/make/lib/arg-nonnull.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,26 @@ | |||
| /* A C macro for declaring that specific arguments must not be NULL.
 | ||||
|    Copyright (C) 2009-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify it | ||||
|    under the terms of the GNU General Public License as published | ||||
|    by the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
|    General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| /* _GL_ARG_NONNULL((n,...,m)) tells the compiler and static analyzer tools
 | ||||
|    that the values passed as arguments n, ..., m must be non-NULL pointers. | ||||
|    n = 1 stands for the first argument, n = 2 for the second argument etc.  */ | ||||
| #ifndef _GL_ARG_NONNULL | ||||
| # if (__GNUC__ == 3 && __GNUC_MINOR__ >= 3) || __GNUC__ > 3 | ||||
| #  define _GL_ARG_NONNULL(params) __attribute__ ((__nonnull__ params)) | ||||
| # else | ||||
| #  define _GL_ARG_NONNULL(params) | ||||
| # endif | ||||
| #endif | ||||
							
								
								
									
										75
									
								
								third_party/make/lib/basename-lgpl.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								third_party/make/lib/basename-lgpl.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,75 @@ | |||
| /* basename.c -- return the last element in a file name
 | ||||
| 
 | ||||
|    Copyright (C) 1990, 1998-2001, 2003-2006, 2009-2020 Free Software | ||||
|    Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| #include "dirname.h" | ||||
| 
 | ||||
| #include <string.h> | ||||
| 
 | ||||
| /* Return the address of the last file name component of NAME.  If
 | ||||
|    NAME has no relative file name components because it is a file | ||||
|    system root, return the empty string.  */ | ||||
| 
 | ||||
| char * | ||||
| last_component (char const *name) | ||||
| { | ||||
|   char const *base = name + FILE_SYSTEM_PREFIX_LEN (name); | ||||
|   char const *p; | ||||
|   bool saw_slash = false; | ||||
| 
 | ||||
|   while (ISSLASH (*base)) | ||||
|     base++; | ||||
| 
 | ||||
|   for (p = base; *p; p++) | ||||
|     { | ||||
|       if (ISSLASH (*p)) | ||||
|         saw_slash = true; | ||||
|       else if (saw_slash) | ||||
|         { | ||||
|           base = p; | ||||
|           saw_slash = false; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|   return (char *) base; | ||||
| } | ||||
| 
 | ||||
| /* Return the length of the basename NAME.  Typically NAME is the
 | ||||
|    value returned by base_name or last_component.  Act like strlen | ||||
|    (NAME), except omit all trailing slashes.  */ | ||||
| 
 | ||||
| size_t | ||||
| base_len (char const *name) | ||||
| { | ||||
|   size_t len; | ||||
|   size_t prefix_len = FILE_SYSTEM_PREFIX_LEN (name); | ||||
| 
 | ||||
|   for (len = strlen (name);  1 < len && ISSLASH (name[len - 1]);  len--) | ||||
|     continue; | ||||
| 
 | ||||
|   if (DOUBLE_SLASH_IS_DISTINCT_ROOT && len == 1 | ||||
|       && ISSLASH (name[0]) && ISSLASH (name[1]) && ! name[2]) | ||||
|     return 2; | ||||
| 
 | ||||
|   if (FILE_SYSTEM_DRIVE_PREFIX_CAN_BE_RELATIVE && prefix_len | ||||
|       && len == prefix_len && ISSLASH (name[prefix_len])) | ||||
|     return prefix_len + 1; | ||||
| 
 | ||||
|   return len; | ||||
| } | ||||
							
								
								
									
										316
									
								
								third_party/make/lib/c++defs.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										316
									
								
								third_party/make/lib/c++defs.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,316 @@ | |||
| /* C++ compatible function declaration macros.
 | ||||
|    Copyright (C) 2010-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify it | ||||
|    under the terms of the GNU General Public License as published | ||||
|    by the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
|    General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _GL_CXXDEFS_H | ||||
| #define _GL_CXXDEFS_H | ||||
| 
 | ||||
| /* Begin/end the GNULIB_NAMESPACE namespace.  */ | ||||
| #if defined __cplusplus && defined GNULIB_NAMESPACE | ||||
| # define _GL_BEGIN_NAMESPACE namespace GNULIB_NAMESPACE { | ||||
| # define _GL_END_NAMESPACE } | ||||
| #else | ||||
| # define _GL_BEGIN_NAMESPACE | ||||
| # define _GL_END_NAMESPACE | ||||
| #endif | ||||
| 
 | ||||
| /* The three most frequent use cases of these macros are:
 | ||||
| 
 | ||||
|    * For providing a substitute for a function that is missing on some | ||||
|      platforms, but is declared and works fine on the platforms on which | ||||
|      it exists: | ||||
| 
 | ||||
|        #if @GNULIB_FOO@ | ||||
|        # if !@HAVE_FOO@ | ||||
|        _GL_FUNCDECL_SYS (foo, ...); | ||||
|        # endif | ||||
|        _GL_CXXALIAS_SYS (foo, ...); | ||||
|        _GL_CXXALIASWARN (foo); | ||||
|        #elif defined GNULIB_POSIXCHECK | ||||
|        ... | ||||
|        #endif | ||||
| 
 | ||||
|    * For providing a replacement for a function that exists on all platforms, | ||||
|      but is broken/insufficient and needs to be replaced on some platforms: | ||||
| 
 | ||||
|        #if @GNULIB_FOO@ | ||||
|        # if @REPLACE_FOO@ | ||||
|        #  if !(defined __cplusplus && defined GNULIB_NAMESPACE) | ||||
|        #   undef foo | ||||
|        #   define foo rpl_foo | ||||
|        #  endif | ||||
|        _GL_FUNCDECL_RPL (foo, ...); | ||||
|        _GL_CXXALIAS_RPL (foo, ...); | ||||
|        # else | ||||
|        _GL_CXXALIAS_SYS (foo, ...); | ||||
|        # endif | ||||
|        _GL_CXXALIASWARN (foo); | ||||
|        #elif defined GNULIB_POSIXCHECK | ||||
|        ... | ||||
|        #endif | ||||
| 
 | ||||
|    * For providing a replacement for a function that exists on some platforms | ||||
|      but is broken/insufficient and needs to be replaced on some of them and | ||||
|      is additionally either missing or undeclared on some other platforms: | ||||
| 
 | ||||
|        #if @GNULIB_FOO@ | ||||
|        # if @REPLACE_FOO@ | ||||
|        #  if !(defined __cplusplus && defined GNULIB_NAMESPACE) | ||||
|        #   undef foo | ||||
|        #   define foo rpl_foo | ||||
|        #  endif | ||||
|        _GL_FUNCDECL_RPL (foo, ...); | ||||
|        _GL_CXXALIAS_RPL (foo, ...); | ||||
|        # else | ||||
|        #  if !@HAVE_FOO@   or   if !@HAVE_DECL_FOO@ | ||||
|        _GL_FUNCDECL_SYS (foo, ...); | ||||
|        #  endif | ||||
|        _GL_CXXALIAS_SYS (foo, ...); | ||||
|        # endif | ||||
|        _GL_CXXALIASWARN (foo); | ||||
|        #elif defined GNULIB_POSIXCHECK | ||||
|        ... | ||||
|        #endif | ||||
| */ | ||||
| 
 | ||||
| /* _GL_EXTERN_C declaration;
 | ||||
|    performs the declaration with C linkage.  */ | ||||
| #if defined __cplusplus | ||||
| # define _GL_EXTERN_C extern "C" | ||||
| #else | ||||
| # define _GL_EXTERN_C extern | ||||
| #endif | ||||
| 
 | ||||
| /* _GL_FUNCDECL_RPL (func, rettype, parameters_and_attributes);
 | ||||
|    declares a replacement function, named rpl_func, with the given prototype, | ||||
|    consisting of return type, parameters, and attributes. | ||||
|    Example: | ||||
|      _GL_FUNCDECL_RPL (open, int, (const char *filename, int flags, ...) | ||||
|                                   _GL_ARG_NONNULL ((1))); | ||||
|  */ | ||||
| #define _GL_FUNCDECL_RPL(func,rettype,parameters_and_attributes) \ | ||||
|   _GL_FUNCDECL_RPL_1 (rpl_##func, rettype, parameters_and_attributes) | ||||
| #define _GL_FUNCDECL_RPL_1(rpl_func,rettype,parameters_and_attributes) \ | ||||
|   _GL_EXTERN_C rettype rpl_func parameters_and_attributes | ||||
| 
 | ||||
| /* _GL_FUNCDECL_SYS (func, rettype, parameters_and_attributes);
 | ||||
|    declares the system function, named func, with the given prototype, | ||||
|    consisting of return type, parameters, and attributes. | ||||
|    Example: | ||||
|      _GL_FUNCDECL_SYS (open, int, (const char *filename, int flags, ...) | ||||
|                                   _GL_ARG_NONNULL ((1))); | ||||
|  */ | ||||
| #define _GL_FUNCDECL_SYS(func,rettype,parameters_and_attributes) \ | ||||
|   _GL_EXTERN_C rettype func parameters_and_attributes | ||||
| 
 | ||||
| /* _GL_CXXALIAS_RPL (func, rettype, parameters);
 | ||||
|    declares a C++ alias called GNULIB_NAMESPACE::func | ||||
|    that redirects to rpl_func, if GNULIB_NAMESPACE is defined. | ||||
|    Example: | ||||
|      _GL_CXXALIAS_RPL (open, int, (const char *filename, int flags, ...)); | ||||
| 
 | ||||
|    Wrapping rpl_func in an object with an inline conversion operator | ||||
|    avoids a reference to rpl_func unless GNULIB_NAMESPACE::func is | ||||
|    actually used in the program.  */ | ||||
| #define _GL_CXXALIAS_RPL(func,rettype,parameters) \ | ||||
|   _GL_CXXALIAS_RPL_1 (func, rpl_##func, rettype, parameters) | ||||
| #if defined __cplusplus && defined GNULIB_NAMESPACE | ||||
| # define _GL_CXXALIAS_RPL_1(func,rpl_func,rettype,parameters) \ | ||||
|     namespace GNULIB_NAMESPACE                                \ | ||||
|     {                                                         \ | ||||
|       static const struct _gl_ ## func ## _wrapper            \ | ||||
|       {                                                       \ | ||||
|         typedef rettype (*type) parameters;                   \ | ||||
|                                                               \ | ||||
|         inline operator type () const                         \ | ||||
|         {                                                     \ | ||||
|           return ::rpl_func;                                  \ | ||||
|         }                                                     \ | ||||
|       } func = {};                                            \ | ||||
|     }                                                         \ | ||||
|     _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| #else | ||||
| # define _GL_CXXALIAS_RPL_1(func,rpl_func,rettype,parameters) \ | ||||
|     _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| #endif | ||||
| 
 | ||||
| /* _GL_CXXALIAS_RPL_CAST_1 (func, rpl_func, rettype, parameters);
 | ||||
|    is like  _GL_CXXALIAS_RPL_1 (func, rpl_func, rettype, parameters); | ||||
|    except that the C function rpl_func may have a slightly different | ||||
|    declaration.  A cast is used to silence the "invalid conversion" error | ||||
|    that would otherwise occur.  */ | ||||
| #if defined __cplusplus && defined GNULIB_NAMESPACE | ||||
| # define _GL_CXXALIAS_RPL_CAST_1(func,rpl_func,rettype,parameters) \ | ||||
|     namespace GNULIB_NAMESPACE                                     \ | ||||
|     {                                                              \ | ||||
|       static const struct _gl_ ## func ## _wrapper                 \ | ||||
|       {                                                            \ | ||||
|         typedef rettype (*type) parameters;                        \ | ||||
|                                                                    \ | ||||
|         inline operator type () const                              \ | ||||
|         {                                                          \ | ||||
|           return reinterpret_cast<type>(::rpl_func);               \ | ||||
|         }                                                          \ | ||||
|       } func = {};                                                 \ | ||||
|     }                                                              \ | ||||
|     _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| #else | ||||
| # define _GL_CXXALIAS_RPL_CAST_1(func,rpl_func,rettype,parameters) \ | ||||
|     _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| #endif | ||||
| 
 | ||||
| /* _GL_CXXALIAS_SYS (func, rettype, parameters);
 | ||||
|    declares a C++ alias called GNULIB_NAMESPACE::func | ||||
|    that redirects to the system provided function func, if GNULIB_NAMESPACE | ||||
|    is defined. | ||||
|    Example: | ||||
|      _GL_CXXALIAS_SYS (open, int, (const char *filename, int flags, ...)); | ||||
| 
 | ||||
|    Wrapping func in an object with an inline conversion operator | ||||
|    avoids a reference to func unless GNULIB_NAMESPACE::func is | ||||
|    actually used in the program.  */ | ||||
| #if defined __cplusplus && defined GNULIB_NAMESPACE | ||||
| # define _GL_CXXALIAS_SYS(func,rettype,parameters)            \ | ||||
|     namespace GNULIB_NAMESPACE                                \ | ||||
|     {                                                         \ | ||||
|       static const struct _gl_ ## func ## _wrapper            \ | ||||
|       {                                                       \ | ||||
|         typedef rettype (*type) parameters;                   \ | ||||
|                                                               \ | ||||
|         inline operator type () const                         \ | ||||
|         {                                                     \ | ||||
|           return ::func;                                      \ | ||||
|         }                                                     \ | ||||
|       } func = {};                                            \ | ||||
|     }                                                         \ | ||||
|     _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| #else | ||||
| # define _GL_CXXALIAS_SYS(func,rettype,parameters) \ | ||||
|     _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| #endif | ||||
| 
 | ||||
| /* _GL_CXXALIAS_SYS_CAST (func, rettype, parameters);
 | ||||
|    is like  _GL_CXXALIAS_SYS (func, rettype, parameters); | ||||
|    except that the C function func may have a slightly different declaration. | ||||
|    A cast is used to silence the "invalid conversion" error that would | ||||
|    otherwise occur.  */ | ||||
| #if defined __cplusplus && defined GNULIB_NAMESPACE | ||||
| # define _GL_CXXALIAS_SYS_CAST(func,rettype,parameters) \ | ||||
|     namespace GNULIB_NAMESPACE                          \ | ||||
|     {                                                   \ | ||||
|       static const struct _gl_ ## func ## _wrapper      \ | ||||
|       {                                                 \ | ||||
|         typedef rettype (*type) parameters;             \ | ||||
|                                                         \ | ||||
|         inline operator type () const                   \ | ||||
|         {                                               \ | ||||
|           return reinterpret_cast<type>(::func);        \ | ||||
|         }                                               \ | ||||
|       } func = {};                                      \ | ||||
|     }                                                   \ | ||||
|     _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| #else | ||||
| # define _GL_CXXALIAS_SYS_CAST(func,rettype,parameters) \ | ||||
|     _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| #endif | ||||
| 
 | ||||
| /* _GL_CXXALIAS_SYS_CAST2 (func, rettype, parameters, rettype2, parameters2);
 | ||||
|    is like  _GL_CXXALIAS_SYS (func, rettype, parameters); | ||||
|    except that the C function is picked among a set of overloaded functions, | ||||
|    namely the one with rettype2 and parameters2.  Two consecutive casts | ||||
|    are used to silence the "cannot find a match" and "invalid conversion" | ||||
|    errors that would otherwise occur.  */ | ||||
| #if defined __cplusplus && defined GNULIB_NAMESPACE | ||||
|   /* The outer cast must be a reinterpret_cast.
 | ||||
|      The inner cast: When the function is defined as a set of overloaded | ||||
|      functions, it works as a static_cast<>, choosing the designated variant. | ||||
|      When the function is defined as a single variant, it works as a | ||||
|      reinterpret_cast<>. The parenthesized cast syntax works both ways.  */ | ||||
| # define _GL_CXXALIAS_SYS_CAST2(func,rettype,parameters,rettype2,parameters2) \ | ||||
|     namespace GNULIB_NAMESPACE                                                \ | ||||
|     {                                                                         \ | ||||
|       static const struct _gl_ ## func ## _wrapper                            \ | ||||
|       {                                                                       \ | ||||
|         typedef rettype (*type) parameters;                                   \ | ||||
|                                                                               \ | ||||
|         inline operator type () const                                         \ | ||||
|         {                                                                     \ | ||||
|           return reinterpret_cast<type>((rettype2 (*) parameters2)(::func));  \ | ||||
|         }                                                                     \ | ||||
|       } func = {};                                                            \ | ||||
|     }                                                                         \ | ||||
|     _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| #else | ||||
| # define _GL_CXXALIAS_SYS_CAST2(func,rettype,parameters,rettype2,parameters2) \ | ||||
|     _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| #endif | ||||
| 
 | ||||
| /* _GL_CXXALIASWARN (func);
 | ||||
|    causes a warning to be emitted when ::func is used but not when | ||||
|    GNULIB_NAMESPACE::func is used.  func must be defined without overloaded | ||||
|    variants.  */ | ||||
| #if defined __cplusplus && defined GNULIB_NAMESPACE | ||||
| # define _GL_CXXALIASWARN(func) \ | ||||
|    _GL_CXXALIASWARN_1 (func, GNULIB_NAMESPACE) | ||||
| # define _GL_CXXALIASWARN_1(func,namespace) \ | ||||
|    _GL_CXXALIASWARN_2 (func, namespace) | ||||
| /* To work around GCC bug <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=43881>,
 | ||||
|    we enable the warning only when not optimizing.  */ | ||||
| # if !__OPTIMIZE__ | ||||
| #  define _GL_CXXALIASWARN_2(func,namespace) \ | ||||
|     _GL_WARN_ON_USE (func, \ | ||||
|                      "The symbol ::" #func " refers to the system function. " \ | ||||
|                      "Use " #namespace "::" #func " instead.") | ||||
| # elif __GNUC__ >= 3 && GNULIB_STRICT_CHECKING | ||||
| #  define _GL_CXXALIASWARN_2(func,namespace) \ | ||||
|      extern __typeof__ (func) func | ||||
| # else | ||||
| #  define _GL_CXXALIASWARN_2(func,namespace) \ | ||||
|      _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| # endif | ||||
| #else | ||||
| # define _GL_CXXALIASWARN(func) \ | ||||
|     _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| #endif | ||||
| 
 | ||||
| /* _GL_CXXALIASWARN1 (func, rettype, parameters_and_attributes);
 | ||||
|    causes a warning to be emitted when the given overloaded variant of ::func | ||||
|    is used but not when GNULIB_NAMESPACE::func is used.  */ | ||||
| #if defined __cplusplus && defined GNULIB_NAMESPACE | ||||
| # define _GL_CXXALIASWARN1(func,rettype,parameters_and_attributes) \ | ||||
|    _GL_CXXALIASWARN1_1 (func, rettype, parameters_and_attributes, \ | ||||
|                         GNULIB_NAMESPACE) | ||||
| # define _GL_CXXALIASWARN1_1(func,rettype,parameters_and_attributes,namespace) \ | ||||
|    _GL_CXXALIASWARN1_2 (func, rettype, parameters_and_attributes, namespace) | ||||
| /* To work around GCC bug <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=43881>,
 | ||||
|    we enable the warning only when not optimizing.  */ | ||||
| # if !__OPTIMIZE__ | ||||
| #  define _GL_CXXALIASWARN1_2(func,rettype,parameters_and_attributes,namespace) \ | ||||
|     _GL_WARN_ON_USE_CXX (func, rettype, parameters_and_attributes, \ | ||||
|                          "The symbol ::" #func " refers to the system function. " \ | ||||
|                          "Use " #namespace "::" #func " instead.") | ||||
| # elif __GNUC__ >= 3 && GNULIB_STRICT_CHECKING | ||||
| #  define _GL_CXXALIASWARN1_2(func,rettype,parameters_and_attributes,namespace) \ | ||||
|      extern __typeof__ (func) func | ||||
| # else | ||||
| #  define _GL_CXXALIASWARN1_2(func,rettype,parameters_and_attributes,namespace) \ | ||||
|      _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| # endif | ||||
| #else | ||||
| # define _GL_CXXALIASWARN1(func,rettype,parameters_and_attributes) \ | ||||
|     _GL_EXTERN_C int _gl_cxxalias_dummy | ||||
| #endif | ||||
| 
 | ||||
| #endif /* _GL_CXXDEFS_H */ | ||||
							
								
								
									
										71
									
								
								third_party/make/lib/close.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								third_party/make/lib/close.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,71 @@ | |||
| /* close replacement.
 | ||||
|    Copyright (C) 2008-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include <unistd.h> | ||||
| 
 | ||||
| #include <errno.h> | ||||
| 
 | ||||
| #include "fd-hook.h" | ||||
| #if HAVE_MSVC_INVALID_PARAMETER_HANDLER | ||||
| # include "msvc-inval.h" | ||||
| #endif | ||||
| 
 | ||||
| #undef close | ||||
| 
 | ||||
| #if HAVE_MSVC_INVALID_PARAMETER_HANDLER | ||||
| static int | ||||
| close_nothrow (int fd) | ||||
| { | ||||
|   int result; | ||||
| 
 | ||||
|   TRY_MSVC_INVAL | ||||
|     { | ||||
|       result = close (fd); | ||||
|     } | ||||
|   CATCH_MSVC_INVAL | ||||
|     { | ||||
|       result = -1; | ||||
|       errno = EBADF; | ||||
|     } | ||||
|   DONE_MSVC_INVAL; | ||||
| 
 | ||||
|   return result; | ||||
| } | ||||
| #else | ||||
| # define close_nothrow close | ||||
| #endif | ||||
| 
 | ||||
| /* Override close() to call into other gnulib modules.  */ | ||||
| 
 | ||||
| int | ||||
| rpl_close (int fd) | ||||
| { | ||||
| #if WINDOWS_SOCKETS | ||||
|   int retval = execute_all_close_hooks (close_nothrow, fd); | ||||
| #else | ||||
|   int retval = close_nothrow (fd); | ||||
| #endif | ||||
| 
 | ||||
| #if REPLACE_FCHDIR | ||||
|   if (retval >= 0) | ||||
|     _gl_unregister_fd (fd); | ||||
| #endif | ||||
| 
 | ||||
|   return retval; | ||||
| } | ||||
							
								
								
									
										73
									
								
								third_party/make/lib/concat-filename.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								third_party/make/lib/concat-filename.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,73 @@ | |||
| /* Construct a full filename from a directory and a relative filename.
 | ||||
|    Copyright (C) 2001-2004, 2006-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify it | ||||
|    under the terms of the GNU General Public License as published by the | ||||
|    Free Software Foundation; either version 3 of the License, or any | ||||
|    later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| /* Written by Bruno Haible <haible@clisp.cons.org>.  */ | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include "concat-filename.h" | ||||
| 
 | ||||
| #include <errno.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| #include "filename.h" | ||||
| 
 | ||||
| /* Concatenate a directory filename, a relative filename and an optional
 | ||||
|    suffix.  The directory may end with the directory separator.  The second | ||||
|    argument may not start with the directory separator (it is relative). | ||||
|    Return a freshly allocated filename.  Return NULL and set errno | ||||
|    upon memory allocation failure.  */ | ||||
| char * | ||||
| concatenated_filename (const char *directory, const char *filename, | ||||
|                        const char *suffix) | ||||
| { | ||||
|   char *result; | ||||
|   char *p; | ||||
| 
 | ||||
|   if (strcmp (directory, ".") == 0) | ||||
|     { | ||||
|       /* No need to prepend the directory.  */ | ||||
|       result = (char *) malloc (strlen (filename) | ||||
|                                 + (suffix != NULL ? strlen (suffix) : 0) | ||||
|                                 + 1); | ||||
|       if (result == NULL) | ||||
|         return NULL; /* errno is set here */ | ||||
|       p = result; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       size_t directory_len = strlen (directory); | ||||
|       int need_slash = | ||||
|         (directory_len > FILE_SYSTEM_PREFIX_LEN (directory) | ||||
|          && !ISSLASH (directory[directory_len - 1])); | ||||
|       result = (char *) malloc (directory_len + need_slash | ||||
|                                 + strlen (filename) | ||||
|                                 + (suffix != NULL ? strlen (suffix) : 0) | ||||
|                                 + 1); | ||||
|       if (result == NULL) | ||||
|         return NULL; /* errno is set here */ | ||||
|       memcpy (result, directory, directory_len); | ||||
|       p = result + directory_len; | ||||
|       if (need_slash) | ||||
|         *p++ = '/'; | ||||
|     } | ||||
|   p = stpcpy (p, filename); | ||||
|   if (suffix != NULL) | ||||
|     stpcpy (p, suffix); | ||||
|   return result; | ||||
| } | ||||
							
								
								
									
										41
									
								
								third_party/make/lib/concat-filename.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								third_party/make/lib/concat-filename.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,41 @@ | |||
| /* Construct a full filename from a directory and a relative filename.
 | ||||
|    Copyright (C) 2001-2004, 2007-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _CONCAT_FILENAME_H | ||||
| #define _CONCAT_FILENAME_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| /* Concatenate a directory filename, a relative filename and an optional
 | ||||
|    suffix.  Return a freshly allocated filename.  Return NULL and set errno | ||||
|    upon memory allocation failure.  */ | ||||
| extern char *concatenated_filename (const char *directory, | ||||
|                                     const char *filename, const char *suffix); | ||||
| 
 | ||||
| /* Concatenate a directory filename, a relative filename and an optional
 | ||||
|    suffix.  Return a freshly allocated filename.  */ | ||||
| extern char *xconcatenated_filename (const char *directory, | ||||
|                                      const char *filename, const char *suffix); | ||||
| 
 | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* _CONCAT_FILENAME_H */ | ||||
							
								
								
									
										86
									
								
								third_party/make/lib/dirname-lgpl.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								third_party/make/lib/dirname-lgpl.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,86 @@ | |||
| /* dirname.c -- return all but the last element in a file name
 | ||||
| 
 | ||||
|    Copyright (C) 1990, 1998, 2000-2001, 2003-2006, 2009-2020 Free Software | ||||
|    Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| #include "dirname.h" | ||||
| 
 | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| /* Return the length of the prefix of FILE that will be used by
 | ||||
|    dir_name.  If FILE is in the working directory, this returns zero | ||||
|    even though 'dir_name (FILE)' will return ".".  Works properly even | ||||
|    if there are trailing slashes (by effectively ignoring them).  */ | ||||
| 
 | ||||
| size_t | ||||
| dir_len (char const *file) | ||||
| { | ||||
|   size_t prefix_length = FILE_SYSTEM_PREFIX_LEN (file); | ||||
|   size_t length; | ||||
| 
 | ||||
|   /* Advance prefix_length beyond important leading slashes.  */ | ||||
|   prefix_length += (prefix_length != 0 | ||||
|                     ? (FILE_SYSTEM_DRIVE_PREFIX_CAN_BE_RELATIVE | ||||
|                        && ISSLASH (file[prefix_length])) | ||||
|                     : (ISSLASH (file[0]) | ||||
|                        ? ((DOUBLE_SLASH_IS_DISTINCT_ROOT | ||||
|                            && ISSLASH (file[1]) && ! ISSLASH (file[2]) | ||||
|                            ? 2 : 1)) | ||||
|                        : 0)); | ||||
| 
 | ||||
|   /* Strip the basename and any redundant slashes before it.  */ | ||||
|   for (length = last_component (file) - file; | ||||
|        prefix_length < length; length--) | ||||
|     if (! ISSLASH (file[length - 1])) | ||||
|       break; | ||||
|   return length; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /* In general, we can't use the builtin 'dirname' function if available,
 | ||||
|    since it has different meanings in different environments. | ||||
|    In some environments the builtin 'dirname' modifies its argument. | ||||
| 
 | ||||
|    Return the leading directories part of FILE, allocated with malloc. | ||||
|    Works properly even if there are trailing slashes (by effectively | ||||
|    ignoring them).  Return NULL on failure. | ||||
| 
 | ||||
|    If lstat (FILE) would succeed, then { chdir (dir_name (FILE)); | ||||
|    lstat (base_name (FILE)); } will access the same file.  Likewise, | ||||
|    if the sequence { chdir (dir_name (FILE)); | ||||
|    rename (base_name (FILE), "foo"); } succeeds, you have renamed FILE | ||||
|    to "foo" in the same directory FILE was in.  */ | ||||
| 
 | ||||
| char * | ||||
| mdir_name (char const *file) | ||||
| { | ||||
|   size_t length = dir_len (file); | ||||
|   bool append_dot = (length == 0 | ||||
|                      || (FILE_SYSTEM_DRIVE_PREFIX_CAN_BE_RELATIVE | ||||
|                          && length == FILE_SYSTEM_PREFIX_LEN (file) | ||||
|                          && file[2] != '\0' && ! ISSLASH (file[2]))); | ||||
|   char *dir = malloc (length + append_dot + 1); | ||||
|   if (!dir) | ||||
|     return NULL; | ||||
|   memcpy (dir, file, length); | ||||
|   if (append_dot) | ||||
|     dir[length++] = '.'; | ||||
|   dir[length] = '\0'; | ||||
|   return dir; | ||||
| } | ||||
							
								
								
									
										54
									
								
								third_party/make/lib/dirname.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								third_party/make/lib/dirname.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,54 @@ | |||
| /*  Take file names apart into directory and base names.
 | ||||
| 
 | ||||
|     Copyright (C) 1998, 2001, 2003-2006, 2009-2020 Free Software Foundation, | ||||
|     Inc. | ||||
| 
 | ||||
|     This program is free software: you can redistribute it and/or modify | ||||
|     it under the terms of the GNU General Public License as published by | ||||
|     the Free Software Foundation; either version 3 of the License, or | ||||
|     (at your option) any later version. | ||||
| 
 | ||||
|     This program is distributed in the hope that it will be useful, | ||||
|     but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|     GNU General Public License for more details. | ||||
| 
 | ||||
|     You should have received a copy of the GNU General Public License | ||||
|     along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef DIRNAME_H_ | ||||
| # define DIRNAME_H_ 1 | ||||
| 
 | ||||
| # include <stdbool.h> | ||||
| # include <stddef.h> | ||||
| # include "dosname.h" | ||||
| 
 | ||||
| # ifndef DIRECTORY_SEPARATOR | ||||
| #  define DIRECTORY_SEPARATOR '/' | ||||
| # endif | ||||
| 
 | ||||
| # ifndef DOUBLE_SLASH_IS_DISTINCT_ROOT | ||||
| #  define DOUBLE_SLASH_IS_DISTINCT_ROOT 0 | ||||
| # endif | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| # if GNULIB_DIRNAME | ||||
| char *base_name (char const *file) _GL_ATTRIBUTE_MALLOC; | ||||
| char *dir_name (char const *file); | ||||
| # endif | ||||
| 
 | ||||
| char *mdir_name (char const *file); | ||||
| size_t base_len (char const *file) _GL_ATTRIBUTE_PURE; | ||||
| size_t dir_len (char const *file) _GL_ATTRIBUTE_PURE; | ||||
| char *last_component (char const *file) _GL_ATTRIBUTE_PURE; | ||||
| 
 | ||||
| bool strip_trailing_slashes (char *file); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } /* extern "C" */ | ||||
| #endif | ||||
| 
 | ||||
| #endif /* not DIRNAME_H_ */ | ||||
							
								
								
									
										52
									
								
								third_party/make/lib/dosname.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								third_party/make/lib/dosname.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,52 @@ | |||
| /* File names on MS-DOS/Windows systems.
 | ||||
| 
 | ||||
|    Copyright (C) 2000-2001, 2004-2006, 2009-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.
 | ||||
| 
 | ||||
|    From Paul Eggert and Jim Meyering.  */ | ||||
| 
 | ||||
| #ifndef _DOSNAME_H | ||||
| #define _DOSNAME_H | ||||
| 
 | ||||
| #if (defined _WIN32 || defined __CYGWIN__ \ | ||||
|      || defined __EMX__ || defined __MSDOS__ || defined __DJGPP__) | ||||
|    /* This internal macro assumes ASCII, but all hosts that support drive
 | ||||
|       letters use ASCII.  */ | ||||
| # define _IS_DRIVE_LETTER(C) (((unsigned int) (C) | ('a' - 'A')) - 'a'  \ | ||||
|                               <= 'z' - 'a') | ||||
| # define FILE_SYSTEM_PREFIX_LEN(Filename) \ | ||||
|           (_IS_DRIVE_LETTER ((Filename)[0]) && (Filename)[1] == ':' ? 2 : 0) | ||||
| # ifndef __CYGWIN__ | ||||
| #  define FILE_SYSTEM_DRIVE_PREFIX_CAN_BE_RELATIVE 1 | ||||
| # endif | ||||
| # define ISSLASH(C) ((C) == '/' || (C) == '\\') | ||||
| #else | ||||
| # define FILE_SYSTEM_PREFIX_LEN(Filename) 0 | ||||
| # define ISSLASH(C) ((C) == '/') | ||||
| #endif | ||||
| 
 | ||||
| #ifndef FILE_SYSTEM_DRIVE_PREFIX_CAN_BE_RELATIVE | ||||
| # define FILE_SYSTEM_DRIVE_PREFIX_CAN_BE_RELATIVE 0 | ||||
| #endif | ||||
| 
 | ||||
| #if FILE_SYSTEM_DRIVE_PREFIX_CAN_BE_RELATIVE | ||||
| #  define IS_ABSOLUTE_FILE_NAME(F) ISSLASH ((F)[FILE_SYSTEM_PREFIX_LEN (F)]) | ||||
| # else | ||||
| #  define IS_ABSOLUTE_FILE_NAME(F)                              \ | ||||
|      (ISSLASH ((F)[0]) || FILE_SYSTEM_PREFIX_LEN (F) != 0) | ||||
| #endif | ||||
| #define IS_RELATIVE_FILE_NAME(F) (! IS_ABSOLUTE_FILE_NAME (F)) | ||||
| 
 | ||||
| #endif /* DOSNAME_H_ */ | ||||
							
								
								
									
										235
									
								
								third_party/make/lib/dup2.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										235
									
								
								third_party/make/lib/dup2.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,235 @@ | |||
| /* Duplicate an open file descriptor to a specified file descriptor.
 | ||||
| 
 | ||||
|    Copyright (C) 1999, 2004-2007, 2009-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| /* written by Paul Eggert */ | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include <unistd.h> | ||||
| 
 | ||||
| #include <errno.h> | ||||
| #include <fcntl.h> | ||||
| 
 | ||||
| #if HAVE_DUP2 | ||||
| 
 | ||||
| # undef dup2 | ||||
| 
 | ||||
| # if defined _WIN32 && ! defined __CYGWIN__ | ||||
| 
 | ||||
| /* Get declarations of the native Windows API functions.  */ | ||||
| #  define WIN32_LEAN_AND_MEAN | ||||
| #  include <windows.h> | ||||
| 
 | ||||
| #  if HAVE_MSVC_INVALID_PARAMETER_HANDLER | ||||
| #   include "msvc-inval.h" | ||||
| #  endif | ||||
| 
 | ||||
| /* Get _get_osfhandle.  */ | ||||
| #  if GNULIB_MSVC_NOTHROW | ||||
| #   include "msvc-nothrow.h" | ||||
| #  else | ||||
| #   include <io.h> | ||||
| #  endif | ||||
| 
 | ||||
| #  if HAVE_MSVC_INVALID_PARAMETER_HANDLER | ||||
| static int | ||||
| dup2_nothrow (int fd, int desired_fd) | ||||
| { | ||||
|   int result; | ||||
| 
 | ||||
|   TRY_MSVC_INVAL | ||||
|     { | ||||
|       result = dup2 (fd, desired_fd); | ||||
|     } | ||||
|   CATCH_MSVC_INVAL | ||||
|     { | ||||
|       errno = EBADF; | ||||
|       result = -1; | ||||
|     } | ||||
|   DONE_MSVC_INVAL; | ||||
| 
 | ||||
|   return result; | ||||
| } | ||||
| #  else | ||||
| #   define dup2_nothrow dup2 | ||||
| #  endif | ||||
| 
 | ||||
| static int | ||||
| ms_windows_dup2 (int fd, int desired_fd) | ||||
| { | ||||
|   int result; | ||||
| 
 | ||||
|   /* If fd is closed, mingw hangs on dup2 (fd, fd).  If fd is open,
 | ||||
|      dup2 (fd, fd) returns 0, but all further attempts to use fd in | ||||
|      future dup2 calls will hang.  */ | ||||
|   if (fd == desired_fd) | ||||
|     { | ||||
|       if ((HANDLE) _get_osfhandle (fd) == INVALID_HANDLE_VALUE) | ||||
|         { | ||||
|           errno = EBADF; | ||||
|           return -1; | ||||
|         } | ||||
|       return fd; | ||||
|     } | ||||
| 
 | ||||
|   /* Wine 1.0.1 return 0 when desired_fd is negative but not -1:
 | ||||
|      https://bugs.winehq.org/show_bug.cgi?id=21289 */
 | ||||
|   if (desired_fd < 0) | ||||
|     { | ||||
|       errno = EBADF; | ||||
|       return -1; | ||||
|     } | ||||
| 
 | ||||
|   result = dup2_nothrow (fd, desired_fd); | ||||
| 
 | ||||
|   if (result == 0) | ||||
|     result = desired_fd; | ||||
| 
 | ||||
|   return result; | ||||
| } | ||||
| 
 | ||||
| #  define dup2 ms_windows_dup2 | ||||
| 
 | ||||
| # elif defined __KLIBC__ | ||||
| 
 | ||||
| #  include <InnoTekLIBC/backend.h> | ||||
| 
 | ||||
| static int | ||||
| klibc_dup2dirfd (int fd, int desired_fd) | ||||
| { | ||||
|   int tempfd; | ||||
|   int dupfd; | ||||
| 
 | ||||
|   tempfd = open ("NUL", O_RDONLY); | ||||
|   if (tempfd == -1) | ||||
|     return -1; | ||||
| 
 | ||||
|   if (tempfd == desired_fd) | ||||
|     { | ||||
|       close (tempfd); | ||||
| 
 | ||||
|       char path[_MAX_PATH]; | ||||
|       if (__libc_Back_ioFHToPath (fd, path, sizeof (path))) | ||||
|         return -1; | ||||
| 
 | ||||
|       return open(path, O_RDONLY); | ||||
|     } | ||||
| 
 | ||||
|   dupfd = klibc_dup2dirfd (fd, desired_fd); | ||||
| 
 | ||||
|   close (tempfd); | ||||
| 
 | ||||
|   return dupfd; | ||||
| } | ||||
| 
 | ||||
| static int | ||||
| klibc_dup2 (int fd, int desired_fd) | ||||
| { | ||||
|   int dupfd; | ||||
|   struct stat sbuf; | ||||
| 
 | ||||
|   dupfd = dup2 (fd, desired_fd); | ||||
|   if (dupfd == -1 && errno == ENOTSUP \ | ||||
|       && !fstat (fd, &sbuf) && S_ISDIR (sbuf.st_mode)) | ||||
|     { | ||||
|       close (desired_fd); | ||||
| 
 | ||||
|       return klibc_dup2dirfd (fd, desired_fd); | ||||
|     } | ||||
| 
 | ||||
|   return dupfd; | ||||
| } | ||||
| 
 | ||||
| #  define dup2 klibc_dup2 | ||||
| # endif | ||||
| 
 | ||||
| int | ||||
| rpl_dup2 (int fd, int desired_fd) | ||||
| { | ||||
|   int result; | ||||
| 
 | ||||
| # ifdef F_GETFL | ||||
|   /* On Linux kernels 2.6.26-2.6.29, dup2 (fd, fd) returns -EBADF.
 | ||||
|      On Cygwin 1.5.x, dup2 (1, 1) returns 0. | ||||
|      On Cygwin 1.7.17, dup2 (1, -1) dumps core. | ||||
|      On Cygwin 1.7.25, dup2 (1, 256) can dump core. | ||||
|      On Haiku, dup2 (fd, fd) mistakenly clears FD_CLOEXEC.  */ | ||||
| #  if HAVE_SETDTABLESIZE | ||||
|   setdtablesize (desired_fd + 1); | ||||
| #  endif | ||||
|   if (desired_fd < 0) | ||||
|     fd = desired_fd; | ||||
|   if (fd == desired_fd) | ||||
|     return fcntl (fd, F_GETFL) == -1 ? -1 : fd; | ||||
| # endif | ||||
| 
 | ||||
|   result = dup2 (fd, desired_fd); | ||||
| 
 | ||||
|   /* Correct an errno value on FreeBSD 6.1 and Cygwin 1.5.x.  */ | ||||
|   if (result == -1 && errno == EMFILE) | ||||
|     errno = EBADF; | ||||
| # if REPLACE_FCHDIR | ||||
|   if (fd != desired_fd && result != -1) | ||||
|     result = _gl_register_dup (fd, result); | ||||
| # endif | ||||
|   return result; | ||||
| } | ||||
| 
 | ||||
| #else /* !HAVE_DUP2 */ | ||||
| 
 | ||||
| /* On older platforms, dup2 did not exist.  */ | ||||
| 
 | ||||
| # ifndef F_DUPFD | ||||
| static int | ||||
| dupfd (int fd, int desired_fd) | ||||
| { | ||||
|   int duplicated_fd = dup (fd); | ||||
|   if (duplicated_fd < 0 || duplicated_fd == desired_fd) | ||||
|     return duplicated_fd; | ||||
|   else | ||||
|     { | ||||
|       int r = dupfd (fd, desired_fd); | ||||
|       int e = errno; | ||||
|       close (duplicated_fd); | ||||
|       errno = e; | ||||
|       return r; | ||||
|     } | ||||
| } | ||||
| # endif | ||||
| 
 | ||||
| int | ||||
| dup2 (int fd, int desired_fd) | ||||
| { | ||||
|   int result = fcntl (fd, F_GETFL) < 0 ? -1 : fd; | ||||
|   if (result == -1 || fd == desired_fd) | ||||
|     return result; | ||||
|   close (desired_fd); | ||||
| # ifdef F_DUPFD | ||||
|   result = fcntl (fd, F_DUPFD, desired_fd); | ||||
| #  if REPLACE_FCHDIR | ||||
|   if (0 <= result) | ||||
|     result = _gl_register_dup (fd, result); | ||||
| #  endif | ||||
| # else | ||||
|   result = dupfd (fd, desired_fd); | ||||
| # endif | ||||
|   if (result == -1 && (errno == EMFILE || errno == EINVAL)) | ||||
|     errno = EBADF; | ||||
|   return result; | ||||
| } | ||||
| #endif /* !HAVE_DUP2 */ | ||||
							
								
								
									
										279
									
								
								third_party/make/lib/errno.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										279
									
								
								third_party/make/lib/errno.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,279 @@ | |||
| /* A POSIX-like <errno.h>.
 | ||||
| 
 | ||||
|    Copyright (C) 2008-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program; if not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _@GUARD_PREFIX@_ERRNO_H | ||||
| 
 | ||||
| #if __GNUC__ >= 3 | ||||
| @PRAGMA_SYSTEM_HEADER@ | ||||
| #endif | ||||
| @PRAGMA_COLUMNS@ | ||||
| 
 | ||||
| /* The include_next requires a split double-inclusion guard.  */ | ||||
| #@INCLUDE_NEXT@ @NEXT_ERRNO_H@ | ||||
| 
 | ||||
| #ifndef _@GUARD_PREFIX@_ERRNO_H | ||||
| #define _@GUARD_PREFIX@_ERRNO_H | ||||
| 
 | ||||
| 
 | ||||
| /* On native Windows platforms, many macros are not defined.  */ | ||||
| # if defined _WIN32 && ! defined __CYGWIN__ | ||||
| 
 | ||||
| /* These are the same values as defined by MSVC 10, for interoperability.  */ | ||||
| 
 | ||||
| #  ifndef ENOMSG | ||||
| #   define ENOMSG    122 | ||||
| #   define GNULIB_defined_ENOMSG 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef EIDRM | ||||
| #   define EIDRM     111 | ||||
| #   define GNULIB_defined_EIDRM 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef ENOLINK | ||||
| #   define ENOLINK   121 | ||||
| #   define GNULIB_defined_ENOLINK 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef EPROTO | ||||
| #   define EPROTO    134 | ||||
| #   define GNULIB_defined_EPROTO 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef EBADMSG | ||||
| #   define EBADMSG   104 | ||||
| #   define GNULIB_defined_EBADMSG 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef EOVERFLOW | ||||
| #   define EOVERFLOW 132 | ||||
| #   define GNULIB_defined_EOVERFLOW 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef ENOTSUP | ||||
| #   define ENOTSUP   129 | ||||
| #   define GNULIB_defined_ENOTSUP 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef ENETRESET | ||||
| #   define ENETRESET 117 | ||||
| #   define GNULIB_defined_ENETRESET 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef ECONNABORTED | ||||
| #   define ECONNABORTED 106 | ||||
| #   define GNULIB_defined_ECONNABORTED 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef ECANCELED | ||||
| #   define ECANCELED 105 | ||||
| #   define GNULIB_defined_ECANCELED 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef EOWNERDEAD | ||||
| #   define EOWNERDEAD 133 | ||||
| #   define GNULIB_defined_EOWNERDEAD 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef ENOTRECOVERABLE | ||||
| #   define ENOTRECOVERABLE 127 | ||||
| #   define GNULIB_defined_ENOTRECOVERABLE 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef EINPROGRESS | ||||
| #   define EINPROGRESS     112 | ||||
| #   define EALREADY        103 | ||||
| #   define ENOTSOCK        128 | ||||
| #   define EDESTADDRREQ    109 | ||||
| #   define EMSGSIZE        115 | ||||
| #   define EPROTOTYPE      136 | ||||
| #   define ENOPROTOOPT     123 | ||||
| #   define EPROTONOSUPPORT 135 | ||||
| #   define EOPNOTSUPP      130 | ||||
| #   define EAFNOSUPPORT    102 | ||||
| #   define EADDRINUSE      100 | ||||
| #   define EADDRNOTAVAIL   101 | ||||
| #   define ENETDOWN        116 | ||||
| #   define ENETUNREACH     118 | ||||
| #   define ECONNRESET      108 | ||||
| #   define ENOBUFS         119 | ||||
| #   define EISCONN         113 | ||||
| #   define ENOTCONN        126 | ||||
| #   define ETIMEDOUT       138 | ||||
| #   define ECONNREFUSED    107 | ||||
| #   define ELOOP           114 | ||||
| #   define EHOSTUNREACH    110 | ||||
| #   define EWOULDBLOCK     140 | ||||
| #   define GNULIB_defined_ESOCK 1 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef ETXTBSY | ||||
| #   define ETXTBSY         139 | ||||
| #   define ENODATA         120  /* not required by POSIX */ | ||||
| #   define ENOSR           124  /* not required by POSIX */ | ||||
| #   define ENOSTR          125  /* not required by POSIX */ | ||||
| #   define ETIME           137  /* not required by POSIX */ | ||||
| #   define EOTHER          131  /* not required by POSIX */ | ||||
| #   define GNULIB_defined_ESTREAMS 1 | ||||
| #  endif | ||||
| 
 | ||||
| /* These are intentionally the same values as the WSA* error numbers, defined
 | ||||
|    in <winsock2.h>.  */ | ||||
| #  define ESOCKTNOSUPPORT 10044  /* not required by POSIX */ | ||||
| #  define EPFNOSUPPORT    10046  /* not required by POSIX */ | ||||
| #  define ESHUTDOWN       10058  /* not required by POSIX */ | ||||
| #  define ETOOMANYREFS    10059  /* not required by POSIX */ | ||||
| #  define EHOSTDOWN       10064  /* not required by POSIX */ | ||||
| #  define EPROCLIM        10067  /* not required by POSIX */ | ||||
| #  define EUSERS          10068  /* not required by POSIX */ | ||||
| #  define EDQUOT          10069 | ||||
| #  define ESTALE          10070 | ||||
| #  define EREMOTE         10071  /* not required by POSIX */ | ||||
| #  define GNULIB_defined_EWINSOCK 1 | ||||
| 
 | ||||
| # endif | ||||
| 
 | ||||
| 
 | ||||
| /* On OSF/1 5.1, when _XOPEN_SOURCE_EXTENDED is not defined, the macros
 | ||||
|    EMULTIHOP, ENOLINK, EOVERFLOW are not defined.  */ | ||||
| # if @EMULTIHOP_HIDDEN@ | ||||
| #  define EMULTIHOP @EMULTIHOP_VALUE@ | ||||
| #  define GNULIB_defined_EMULTIHOP 1 | ||||
| # endif | ||||
| # if @ENOLINK_HIDDEN@ | ||||
| #  define ENOLINK   @ENOLINK_VALUE@ | ||||
| #  define GNULIB_defined_ENOLINK 1 | ||||
| # endif | ||||
| # if @EOVERFLOW_HIDDEN@ | ||||
| #  define EOVERFLOW @EOVERFLOW_VALUE@ | ||||
| #  define GNULIB_defined_EOVERFLOW 1 | ||||
| # endif | ||||
| 
 | ||||
| 
 | ||||
| /* On OpenBSD 4.0 and on native Windows, the macros ENOMSG, EIDRM, ENOLINK,
 | ||||
|    EPROTO, EMULTIHOP, EBADMSG, EOVERFLOW, ENOTSUP, ECANCELED are not defined. | ||||
|    Likewise, on NonStop Kernel, EDQUOT is not defined. | ||||
|    Define them here.  Values >= 2000 seem safe to use: Solaris ESTALE = 151, | ||||
|    HP-UX EWOULDBLOCK = 246, IRIX EDQUOT = 1133. | ||||
| 
 | ||||
|    Note: When one of these systems defines some of these macros some day, | ||||
|    binaries will have to be recompiled so that they recognizes the new | ||||
|    errno values from the system.  */ | ||||
| 
 | ||||
| # ifndef ENOMSG | ||||
| #  define ENOMSG    2000 | ||||
| #  define GNULIB_defined_ENOMSG 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef EIDRM | ||||
| #  define EIDRM     2001 | ||||
| #  define GNULIB_defined_EIDRM 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef ENOLINK | ||||
| #  define ENOLINK   2002 | ||||
| #  define GNULIB_defined_ENOLINK 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef EPROTO | ||||
| #  define EPROTO    2003 | ||||
| #  define GNULIB_defined_EPROTO 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef EMULTIHOP | ||||
| #  define EMULTIHOP 2004 | ||||
| #  define GNULIB_defined_EMULTIHOP 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef EBADMSG | ||||
| #  define EBADMSG   2005 | ||||
| #  define GNULIB_defined_EBADMSG 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef EOVERFLOW | ||||
| #  define EOVERFLOW 2006 | ||||
| #  define GNULIB_defined_EOVERFLOW 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef ENOTSUP | ||||
| #  define ENOTSUP   2007 | ||||
| #  define GNULIB_defined_ENOTSUP 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef ENETRESET | ||||
| #  define ENETRESET 2011 | ||||
| #  define GNULIB_defined_ENETRESET 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef ECONNABORTED | ||||
| #  define ECONNABORTED 2012 | ||||
| #  define GNULIB_defined_ECONNABORTED 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef ESTALE | ||||
| #  define ESTALE    2009 | ||||
| #  define GNULIB_defined_ESTALE 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef EDQUOT | ||||
| #  define EDQUOT 2010 | ||||
| #  define GNULIB_defined_EDQUOT 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef ECANCELED | ||||
| #  define ECANCELED 2008 | ||||
| #  define GNULIB_defined_ECANCELED 1 | ||||
| # endif | ||||
| 
 | ||||
| /* On many platforms, the macros EOWNERDEAD and ENOTRECOVERABLE are not
 | ||||
|    defined.  */ | ||||
| 
 | ||||
| # ifndef EOWNERDEAD | ||||
| #  if defined __sun | ||||
|     /* Use the same values as defined for Solaris >= 8, for
 | ||||
|        interoperability.  */ | ||||
| #   define EOWNERDEAD      58 | ||||
| #   define ENOTRECOVERABLE 59 | ||||
| #  elif defined _WIN32 && ! defined __CYGWIN__ | ||||
|     /* We have a conflict here: pthreads-win32 defines these values
 | ||||
|        differently than MSVC 10.  It's hairy to decide which one to use.  */ | ||||
| #   if defined __MINGW32__ && !defined USE_WINDOWS_THREADS | ||||
|      /* Use the same values as defined by pthreads-win32, for
 | ||||
|         interoperability.  */ | ||||
| #    define EOWNERDEAD      43 | ||||
| #    define ENOTRECOVERABLE 44 | ||||
| #   else | ||||
|      /* Use the same values as defined by MSVC 10, for
 | ||||
|         interoperability.  */ | ||||
| #    define EOWNERDEAD      133 | ||||
| #    define ENOTRECOVERABLE 127 | ||||
| #   endif | ||||
| #  else | ||||
| #   define EOWNERDEAD      2013 | ||||
| #   define ENOTRECOVERABLE 2014 | ||||
| #  endif | ||||
| #  define GNULIB_defined_EOWNERDEAD 1 | ||||
| #  define GNULIB_defined_ENOTRECOVERABLE 1 | ||||
| # endif | ||||
| 
 | ||||
| # ifndef EILSEQ | ||||
| #  define EILSEQ 2015 | ||||
| #  define GNULIB_defined_EILSEQ 1 | ||||
| # endif | ||||
| 
 | ||||
| #endif /* _@GUARD_PREFIX@_ERRNO_H */ | ||||
| #endif /* _@GUARD_PREFIX@_ERRNO_H */ | ||||
							
								
								
									
										411
									
								
								third_party/make/lib/error.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										411
									
								
								third_party/make/lib/error.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,411 @@ | |||
| /* Error handler for noninteractive utilities
 | ||||
|    Copyright (C) 1990-1998, 2000-2007, 2009-2020 Free Software Foundation, Inc. | ||||
|    This file is part of the GNU C Library. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| /* Written by David MacKenzie <djm@gnu.ai.mit.edu>.  */ | ||||
| 
 | ||||
| #if !_LIBC | ||||
| # include <config.h> | ||||
| #endif | ||||
| 
 | ||||
| #include "error.h" | ||||
| 
 | ||||
| #include <stdarg.h> | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| #if !_LIBC && ENABLE_NLS | ||||
| # include "gettext.h" | ||||
| # define _(msgid) gettext (msgid) | ||||
| #endif | ||||
| 
 | ||||
| #ifdef _LIBC | ||||
| # include <libintl.h> | ||||
| # include <stdbool.h> | ||||
| # include <stdint.h> | ||||
| # include <wchar.h> | ||||
| # define mbsrtowcs __mbsrtowcs | ||||
| # define USE_UNLOCKED_IO 0 | ||||
| # define _GL_ATTRIBUTE_FORMAT_PRINTF(a, b) | ||||
| # define _GL_ARG_NONNULL(a) | ||||
| #else | ||||
| # include "getprogname.h" | ||||
| #endif | ||||
| 
 | ||||
| #if USE_UNLOCKED_IO | ||||
| # include "unlocked-io.h" | ||||
| #endif | ||||
| 
 | ||||
| #ifndef _ | ||||
| # define _(String) String | ||||
| #endif | ||||
| 
 | ||||
| /* If NULL, error will flush stdout, then print on stderr the program
 | ||||
|    name, a colon and a space.  Otherwise, error will call this | ||||
|    function without parameters instead.  */ | ||||
| void (*error_print_progname) (void); | ||||
| 
 | ||||
| /* This variable is incremented each time 'error' is called.  */ | ||||
| unsigned int error_message_count; | ||||
| 
 | ||||
| #ifdef _LIBC | ||||
| /* In the GNU C library, there is a predefined variable for this.  */ | ||||
| 
 | ||||
| # define program_name program_invocation_name | ||||
| # include <errno.h> | ||||
| # include <limits.h> | ||||
| # include <libio/libioP.h> | ||||
| 
 | ||||
| /* In GNU libc we want do not want to use the common name 'error' directly.
 | ||||
|    Instead make it a weak alias.  */ | ||||
| extern void __error (int status, int errnum, const char *message, ...) | ||||
|      __attribute__ ((__format__ (__printf__, 3, 4))); | ||||
| extern void __error_at_line (int status, int errnum, const char *file_name, | ||||
|                              unsigned int line_number, const char *message, | ||||
|                              ...) | ||||
|      __attribute__ ((__format__ (__printf__, 5, 6))); | ||||
| # define error __error | ||||
| # define error_at_line __error_at_line | ||||
| 
 | ||||
| # include <libio/iolibio.h> | ||||
| # define fflush(s) _IO_fflush (s) | ||||
| # undef putc | ||||
| # define putc(c, fp) _IO_putc (c, fp) | ||||
| 
 | ||||
| # include <bits/libc-lock.h> | ||||
| 
 | ||||
| #else /* not _LIBC */ | ||||
| 
 | ||||
| # include <fcntl.h> | ||||
| # include <unistd.h> | ||||
| 
 | ||||
| # if defined _WIN32 && ! defined __CYGWIN__ | ||||
| /* Get declarations of the native Windows API functions.  */ | ||||
| #  define WIN32_LEAN_AND_MEAN | ||||
| #  include <windows.h> | ||||
| /* Get _get_osfhandle.  */ | ||||
| #  if GNULIB_MSVC_NOTHROW | ||||
| #   include "msvc-nothrow.h" | ||||
| #  else | ||||
| #   include <io.h> | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
| /* The gnulib override of fcntl is not needed in this file.  */ | ||||
| # undef fcntl | ||||
| 
 | ||||
| # if !(GNULIB_STRERROR_R_POSIX || HAVE_DECL_STRERROR_R) | ||||
| #  ifndef HAVE_DECL_STRERROR_R | ||||
| "this configure-time declaration test was not run" | ||||
| #  endif | ||||
| #  if STRERROR_R_CHAR_P | ||||
| char *strerror_r (int errnum, char *buf, size_t buflen); | ||||
| #  else | ||||
| int strerror_r (int errnum, char *buf, size_t buflen); | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
| # define program_name getprogname () | ||||
| 
 | ||||
| # if GNULIB_STRERROR_R_POSIX || HAVE_STRERROR_R || defined strerror_r | ||||
| #  define __strerror_r strerror_r | ||||
| # endif /* GNULIB_STRERROR_R_POSIX || HAVE_STRERROR_R || defined strerror_r */ | ||||
| #endif  /* not _LIBC */ | ||||
| 
 | ||||
| #if !_LIBC | ||||
| /* Return non-zero if FD is open.  */ | ||||
| static int | ||||
| is_open (int fd) | ||||
| { | ||||
| # if defined _WIN32 && ! defined __CYGWIN__ | ||||
|   /* On native Windows: The initial state of unassigned standard file
 | ||||
|      descriptors is that they are open but point to an INVALID_HANDLE_VALUE. | ||||
|      There is no fcntl, and the gnulib replacement fcntl does not support | ||||
|      F_GETFL.  */ | ||||
|   return (HANDLE) _get_osfhandle (fd) != INVALID_HANDLE_VALUE; | ||||
| # else | ||||
| #  ifndef F_GETFL | ||||
| #   error Please port fcntl to your platform | ||||
| #  endif | ||||
|   return 0 <= fcntl (fd, F_GETFL); | ||||
| # endif | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| static void | ||||
| flush_stdout (void) | ||||
| { | ||||
| #if !_LIBC | ||||
|   int stdout_fd; | ||||
| 
 | ||||
| # if GNULIB_FREOPEN_SAFER | ||||
|   /* Use of gnulib's freopen-safer module normally ensures that
 | ||||
|        fileno (stdout) == 1 | ||||
|      whenever stdout is open.  */ | ||||
|   stdout_fd = STDOUT_FILENO; | ||||
| # else | ||||
|   /* POSIX states that fileno (stdout) after fclose is unspecified.  But in
 | ||||
|      practice it is not a problem, because stdout is statically allocated and | ||||
|      the fd of a FILE stream is stored as a field in its allocated memory.  */ | ||||
|   stdout_fd = fileno (stdout); | ||||
| # endif | ||||
|   /* POSIX states that fflush (stdout) after fclose is unspecified; it
 | ||||
|      is safe in glibc, but not on all other platforms.  fflush (NULL) | ||||
|      is always defined, but too draconian.  */ | ||||
|   if (0 <= stdout_fd && is_open (stdout_fd)) | ||||
| #endif | ||||
|     fflush (stdout); | ||||
| } | ||||
| 
 | ||||
| static void | ||||
| print_errno_message (int errnum) | ||||
| { | ||||
|   char const *s; | ||||
| 
 | ||||
| #if _LIBC || GNULIB_STRERROR_R_POSIX || defined HAVE_STRERROR_R | ||||
|   char errbuf[1024]; | ||||
| # if _LIBC || (!GNULIB_STRERROR_R_POSIX && STRERROR_R_CHAR_P) | ||||
|   s = __strerror_r (errnum, errbuf, sizeof errbuf); | ||||
| # else | ||||
|   if (__strerror_r (errnum, errbuf, sizeof errbuf) == 0) | ||||
|     s = errbuf; | ||||
|   else | ||||
|     s = 0; | ||||
| # endif | ||||
| #else | ||||
|   s = strerror (errnum); | ||||
| #endif | ||||
| 
 | ||||
| #if !_LIBC | ||||
|   if (! s) | ||||
|     s = _("Unknown system error"); | ||||
| #endif | ||||
| 
 | ||||
| #if _LIBC | ||||
|   __fxprintf (NULL, ": %s", s); | ||||
| #else | ||||
|   fprintf (stderr, ": %s", s); | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| static void _GL_ATTRIBUTE_FORMAT_PRINTF (3, 0) _GL_ARG_NONNULL ((3)) | ||||
| error_tail (int status, int errnum, const char *message, va_list args) | ||||
| { | ||||
| #if _LIBC | ||||
|   if (_IO_fwide (stderr, 0) > 0) | ||||
|     { | ||||
|       size_t len = strlen (message) + 1; | ||||
|       wchar_t *wmessage = NULL; | ||||
|       mbstate_t st; | ||||
|       size_t res; | ||||
|       const char *tmp; | ||||
|       bool use_malloc = false; | ||||
| 
 | ||||
|       while (1) | ||||
|         { | ||||
|           if (__libc_use_alloca (len * sizeof (wchar_t))) | ||||
|             wmessage = (wchar_t *) alloca (len * sizeof (wchar_t)); | ||||
|           else | ||||
|             { | ||||
|               if (!use_malloc) | ||||
|                 wmessage = NULL; | ||||
| 
 | ||||
|               wchar_t *p = (wchar_t *) realloc (wmessage, | ||||
|                                                 len * sizeof (wchar_t)); | ||||
|               if (p == NULL) | ||||
|                 { | ||||
|                   free (wmessage); | ||||
|                   fputws_unlocked (L"out of memory\n", stderr); | ||||
|                   return; | ||||
|                 } | ||||
|               wmessage = p; | ||||
|               use_malloc = true; | ||||
|             } | ||||
| 
 | ||||
|           memset (&st, '\0', sizeof (st)); | ||||
|           tmp = message; | ||||
| 
 | ||||
|           res = mbsrtowcs (wmessage, &tmp, len, &st); | ||||
|           if (res != len) | ||||
|             break; | ||||
| 
 | ||||
|           if (__builtin_expect (len >= SIZE_MAX / sizeof (wchar_t) / 2, 0)) | ||||
|             { | ||||
|               /* This really should not happen if everything is fine.  */ | ||||
|               res = (size_t) -1; | ||||
|               break; | ||||
|             } | ||||
| 
 | ||||
|           len *= 2; | ||||
|         } | ||||
| 
 | ||||
|       if (res == (size_t) -1) | ||||
|         { | ||||
|           /* The string cannot be converted.  */ | ||||
|           if (use_malloc) | ||||
|             { | ||||
|               free (wmessage); | ||||
|               use_malloc = false; | ||||
|             } | ||||
|           wmessage = (wchar_t *) L"???"; | ||||
|         } | ||||
| 
 | ||||
|       __vfwprintf (stderr, wmessage, args); | ||||
| 
 | ||||
|       if (use_malloc) | ||||
|         free (wmessage); | ||||
|     } | ||||
|   else | ||||
| #endif | ||||
|     vfprintf (stderr, message, args); | ||||
| 
 | ||||
|   ++error_message_count; | ||||
|   if (errnum) | ||||
|     print_errno_message (errnum); | ||||
| #if _LIBC | ||||
|   __fxprintf (NULL, "\n"); | ||||
| #else | ||||
|   putc ('\n', stderr); | ||||
| #endif | ||||
|   fflush (stderr); | ||||
|   if (status) | ||||
|     exit (status); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /* Print the program name and error message MESSAGE, which is a printf-style
 | ||||
|    format string with optional args. | ||||
|    If ERRNUM is nonzero, print its corresponding system error message. | ||||
|    Exit with status STATUS if it is nonzero.  */ | ||||
| void | ||||
| error (int status, int errnum, const char *message, ...) | ||||
| { | ||||
|   va_list args; | ||||
| 
 | ||||
| #if defined _LIBC && defined __libc_ptf_call | ||||
|   /* We do not want this call to be cut short by a thread
 | ||||
|      cancellation.  Therefore disable cancellation for now.  */ | ||||
|   int state = PTHREAD_CANCEL_ENABLE; | ||||
|   __libc_ptf_call (pthread_setcancelstate, (PTHREAD_CANCEL_DISABLE, &state), | ||||
|                    0); | ||||
| #endif | ||||
| 
 | ||||
|   flush_stdout (); | ||||
| #ifdef _LIBC | ||||
|   _IO_flockfile (stderr); | ||||
| #endif | ||||
|   if (error_print_progname) | ||||
|     (*error_print_progname) (); | ||||
|   else | ||||
|     { | ||||
| #if _LIBC | ||||
|       __fxprintf (NULL, "%s: ", program_name); | ||||
| #else | ||||
|       fprintf (stderr, "%s: ", program_name); | ||||
| #endif | ||||
|     } | ||||
| 
 | ||||
|   va_start (args, message); | ||||
|   error_tail (status, errnum, message, args); | ||||
|   va_end (args); | ||||
| 
 | ||||
| #ifdef _LIBC | ||||
|   _IO_funlockfile (stderr); | ||||
| # ifdef __libc_ptf_call | ||||
|   __libc_ptf_call (pthread_setcancelstate, (state, NULL), 0); | ||||
| # endif | ||||
| #endif | ||||
| } | ||||
|  | ||||
| /* Sometimes we want to have at most one error per line.  This
 | ||||
|    variable controls whether this mode is selected or not.  */ | ||||
| int error_one_per_line; | ||||
| 
 | ||||
| void | ||||
| error_at_line (int status, int errnum, const char *file_name, | ||||
|                unsigned int line_number, const char *message, ...) | ||||
| { | ||||
|   va_list args; | ||||
| 
 | ||||
|   if (error_one_per_line) | ||||
|     { | ||||
|       static const char *old_file_name; | ||||
|       static unsigned int old_line_number; | ||||
| 
 | ||||
|       if (old_line_number == line_number | ||||
|           && (file_name == old_file_name | ||||
|               || (old_file_name != NULL | ||||
|                   && file_name != NULL | ||||
|                   && strcmp (old_file_name, file_name) == 0))) | ||||
| 
 | ||||
|         /* Simply return and print nothing.  */ | ||||
|         return; | ||||
| 
 | ||||
|       old_file_name = file_name; | ||||
|       old_line_number = line_number; | ||||
|     } | ||||
| 
 | ||||
| #if defined _LIBC && defined __libc_ptf_call | ||||
|   /* We do not want this call to be cut short by a thread
 | ||||
|      cancellation.  Therefore disable cancellation for now.  */ | ||||
|   int state = PTHREAD_CANCEL_ENABLE; | ||||
|   __libc_ptf_call (pthread_setcancelstate, (PTHREAD_CANCEL_DISABLE, &state), | ||||
|                    0); | ||||
| #endif | ||||
| 
 | ||||
|   flush_stdout (); | ||||
| #ifdef _LIBC | ||||
|   _IO_flockfile (stderr); | ||||
| #endif | ||||
|   if (error_print_progname) | ||||
|     (*error_print_progname) (); | ||||
|   else | ||||
|     { | ||||
| #if _LIBC | ||||
|       __fxprintf (NULL, "%s:", program_name); | ||||
| #else | ||||
|       fprintf (stderr, "%s:", program_name); | ||||
| #endif | ||||
|     } | ||||
| 
 | ||||
| #if _LIBC | ||||
|   __fxprintf (NULL, file_name != NULL ? "%s:%u: " : " ", | ||||
|               file_name, line_number); | ||||
| #else | ||||
|   fprintf (stderr, file_name != NULL ? "%s:%u: " : " ", | ||||
|            file_name, line_number); | ||||
| #endif | ||||
| 
 | ||||
|   va_start (args, message); | ||||
|   error_tail (status, errnum, message, args); | ||||
|   va_end (args); | ||||
| 
 | ||||
| #ifdef _LIBC | ||||
|   _IO_funlockfile (stderr); | ||||
| # ifdef __libc_ptf_call | ||||
|   __libc_ptf_call (pthread_setcancelstate, (state, NULL), 0); | ||||
| # endif | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| #ifdef _LIBC | ||||
| /* Make the weak alias.  */ | ||||
| # undef error | ||||
| # undef error_at_line | ||||
| weak_alias (__error, error) | ||||
| weak_alias (__error_at_line, error_at_line) | ||||
| #endif | ||||
							
								
								
									
										75
									
								
								third_party/make/lib/error.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								third_party/make/lib/error.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,75 @@ | |||
| /* Declaration for error-reporting function
 | ||||
|    Copyright (C) 1995-1997, 2003, 2006, 2008-2020 Free Software Foundation, | ||||
|    Inc. | ||||
|    This file is part of the GNU C Library. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _ERROR_H | ||||
| #define _ERROR_H 1 | ||||
| 
 | ||||
| /* The __attribute__ feature is available in gcc versions 2.5 and later.
 | ||||
|    The __-protected variants of the attributes 'format' and 'printf' are | ||||
|    accepted by gcc versions 2.6.4 (effectively 2.7) and later. | ||||
|    We enable _GL_ATTRIBUTE_FORMAT only if these are supported too, because | ||||
|    gnulib and libintl do '#define printf __printf__' when they override | ||||
|    the 'printf' function.  */ | ||||
| #if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 7) | ||||
| # define _GL_ATTRIBUTE_FORMAT(spec) __attribute__ ((__format__ spec)) | ||||
| #else | ||||
| # define _GL_ATTRIBUTE_FORMAT(spec) /* empty */ | ||||
| #endif | ||||
| 
 | ||||
| /* On mingw, the flavor of printf depends on whether the extensions module
 | ||||
|  * is in use; the check for <stdio.h> determines the witness macro.  */ | ||||
| #ifndef _GL_ATTRIBUTE_SPEC_PRINTF | ||||
| # if GNULIB_PRINTF_ATTRIBUTE_FLAVOR_GNU | ||||
| #  define _GL_ATTRIBUTE_SPEC_PRINTF __gnu_printf__ | ||||
| # else | ||||
| #  define _GL_ATTRIBUTE_SPEC_PRINTF __printf__ | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Print a message with 'fprintf (stderr, FORMAT, ...)';
 | ||||
|    if ERRNUM is nonzero, follow it with ": " and strerror (ERRNUM). | ||||
|    If STATUS is nonzero, terminate the program with 'exit (STATUS)'.  */ | ||||
| 
 | ||||
| extern void error (int __status, int __errnum, const char *__format, ...) | ||||
|      _GL_ATTRIBUTE_FORMAT ((_GL_ATTRIBUTE_SPEC_PRINTF, 3, 4)); | ||||
| 
 | ||||
| extern void error_at_line (int __status, int __errnum, const char *__fname, | ||||
|                            unsigned int __lineno, const char *__format, ...) | ||||
|      _GL_ATTRIBUTE_FORMAT ((_GL_ATTRIBUTE_SPEC_PRINTF, 5, 6)); | ||||
| 
 | ||||
| /* If NULL, error will flush stdout, then print on stderr the program
 | ||||
|    name, a colon and a space.  Otherwise, error will call this | ||||
|    function without parameters instead.  */ | ||||
| extern void (*error_print_progname) (void); | ||||
| 
 | ||||
| /* This variable is incremented each time 'error' is called.  */ | ||||
| extern unsigned int error_message_count; | ||||
| 
 | ||||
| /* Sometimes we want to have at most one error per line.  This
 | ||||
|    variable controls whether this mode is selected or not.  */ | ||||
| extern int error_one_per_line; | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* error.h */ | ||||
							
								
								
									
										24
									
								
								third_party/make/lib/exitfail.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								third_party/make/lib/exitfail.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,24 @@ | |||
| /* Failure exit status
 | ||||
| 
 | ||||
|    Copyright (C) 2002-2003, 2005-2007, 2009-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| #include "exitfail.h" | ||||
| 
 | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| int volatile exit_failure = EXIT_FAILURE; | ||||
							
								
								
									
										18
									
								
								third_party/make/lib/exitfail.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								third_party/make/lib/exitfail.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,18 @@ | |||
| /* Failure exit status
 | ||||
| 
 | ||||
|    Copyright (C) 2002, 2009-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| extern int volatile exit_failure; | ||||
							
								
								
									
										627
									
								
								third_party/make/lib/fcntl.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										627
									
								
								third_party/make/lib/fcntl.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,627 @@ | |||
| /* Provide file descriptor control.
 | ||||
| 
 | ||||
|    Copyright (C) 2009-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| /* Written by Eric Blake <ebb9@byu.net>.  */ | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include <fcntl.h> | ||||
| 
 | ||||
| #include <errno.h> | ||||
| #include <limits.h> | ||||
| #include <stdarg.h> | ||||
| #include <stdlib.h> | ||||
| #include <unistd.h> | ||||
| 
 | ||||
| #ifdef __KLIBC__ | ||||
| # define INCL_DOS | ||||
| # include <os2.h> | ||||
| #endif | ||||
| 
 | ||||
| #if defined _WIN32 && ! defined __CYGWIN__ | ||||
| /* Get declarations of the native Windows API functions.  */ | ||||
| # define WIN32_LEAN_AND_MEAN | ||||
| # include <windows.h> | ||||
| 
 | ||||
| /* Get _get_osfhandle.  */ | ||||
| # if GNULIB_MSVC_NOTHROW | ||||
| #  include "msvc-nothrow.h" | ||||
| # else | ||||
| #  include <io.h> | ||||
| # endif | ||||
| 
 | ||||
| /* Upper bound on getdtablesize().  See lib/getdtablesize.c.  */ | ||||
| # define OPEN_MAX_MAX 0x10000 | ||||
| 
 | ||||
| /* Duplicate OLDFD into the first available slot of at least NEWFD,
 | ||||
|    which must be positive, with FLAGS determining whether the duplicate | ||||
|    will be inheritable.  */ | ||||
| static int | ||||
| dupfd (int oldfd, int newfd, int flags) | ||||
| { | ||||
|   /* Mingw has no way to create an arbitrary fd.  Iterate until all
 | ||||
|      file descriptors less than newfd are filled up.  */ | ||||
|   HANDLE curr_process = GetCurrentProcess (); | ||||
|   HANDLE old_handle = (HANDLE) _get_osfhandle (oldfd); | ||||
|   unsigned char fds_to_close[OPEN_MAX_MAX / CHAR_BIT]; | ||||
|   unsigned int fds_to_close_bound = 0; | ||||
|   int result; | ||||
|   BOOL inherit = flags & O_CLOEXEC ? FALSE : TRUE; | ||||
|   int mode; | ||||
| 
 | ||||
|   if (newfd < 0 || getdtablesize () <= newfd) | ||||
|     { | ||||
|       errno = EINVAL; | ||||
|       return -1; | ||||
|     } | ||||
|   if (old_handle == INVALID_HANDLE_VALUE | ||||
|       || (mode = setmode (oldfd, O_BINARY)) == -1) | ||||
|     { | ||||
|       /* oldfd is not open, or is an unassigned standard file
 | ||||
|          descriptor.  */ | ||||
|       errno = EBADF; | ||||
|       return -1; | ||||
|     } | ||||
|   setmode (oldfd, mode); | ||||
|   flags |= mode; | ||||
| 
 | ||||
|   for (;;) | ||||
|     { | ||||
|       HANDLE new_handle; | ||||
|       int duplicated_fd; | ||||
|       unsigned int index; | ||||
| 
 | ||||
|       if (!DuplicateHandle (curr_process,           /* SourceProcessHandle */ | ||||
|                             old_handle,             /* SourceHandle */ | ||||
|                             curr_process,           /* TargetProcessHandle */ | ||||
|                             (PHANDLE) &new_handle,  /* TargetHandle */ | ||||
|                             (DWORD) 0,              /* DesiredAccess */ | ||||
|                             inherit,                /* InheritHandle */ | ||||
|                             DUPLICATE_SAME_ACCESS)) /* Options */ | ||||
|         { | ||||
|           switch (GetLastError ()) | ||||
|             { | ||||
|               case ERROR_TOO_MANY_OPEN_FILES: | ||||
|                 errno = EMFILE; | ||||
|                 break; | ||||
|               case ERROR_INVALID_HANDLE: | ||||
|               case ERROR_INVALID_TARGET_HANDLE: | ||||
|               case ERROR_DIRECT_ACCESS_HANDLE: | ||||
|                 errno = EBADF; | ||||
|                 break; | ||||
|               case ERROR_INVALID_PARAMETER: | ||||
|               case ERROR_INVALID_FUNCTION: | ||||
|               case ERROR_INVALID_ACCESS: | ||||
|                 errno = EINVAL; | ||||
|                 break; | ||||
|               default: | ||||
|                 errno = EACCES; | ||||
|                 break; | ||||
|             } | ||||
|           result = -1; | ||||
|           break; | ||||
|         } | ||||
|       duplicated_fd = _open_osfhandle ((intptr_t) new_handle, flags); | ||||
|       if (duplicated_fd < 0) | ||||
|         { | ||||
|           CloseHandle (new_handle); | ||||
|           result = -1; | ||||
|           break; | ||||
|         } | ||||
|       if (newfd <= duplicated_fd) | ||||
|         { | ||||
|           result = duplicated_fd; | ||||
|           break; | ||||
|         } | ||||
| 
 | ||||
|       /* Set the bit duplicated_fd in fds_to_close[].  */ | ||||
|       index = (unsigned int) duplicated_fd / CHAR_BIT; | ||||
|       if (fds_to_close_bound <= index) | ||||
|         { | ||||
|           if (sizeof fds_to_close <= index) | ||||
|             /* Need to increase OPEN_MAX_MAX.  */ | ||||
|             abort (); | ||||
|           memset (fds_to_close + fds_to_close_bound, '\0', | ||||
|                   index + 1 - fds_to_close_bound); | ||||
|           fds_to_close_bound = index + 1; | ||||
|         } | ||||
|       fds_to_close[index] |= 1 << ((unsigned int) duplicated_fd % CHAR_BIT); | ||||
|     } | ||||
| 
 | ||||
|   /* Close the previous fds that turned out to be too small.  */ | ||||
|   { | ||||
|     int saved_errno = errno; | ||||
|     unsigned int duplicated_fd; | ||||
| 
 | ||||
|     for (duplicated_fd = 0; | ||||
|          duplicated_fd < fds_to_close_bound * CHAR_BIT; | ||||
|          duplicated_fd++) | ||||
|       if ((fds_to_close[duplicated_fd / CHAR_BIT] | ||||
|            >> (duplicated_fd % CHAR_BIT)) | ||||
|           & 1) | ||||
|         close (duplicated_fd); | ||||
| 
 | ||||
|     errno = saved_errno; | ||||
|   } | ||||
| 
 | ||||
| # if REPLACE_FCHDIR | ||||
|   if (0 <= result) | ||||
|     result = _gl_register_dup (oldfd, result); | ||||
| # endif | ||||
|   return result; | ||||
| } | ||||
| #endif /* W32 */ | ||||
| 
 | ||||
| /* Forward declarations, because we '#undef fcntl' in the middle of this
 | ||||
|    compilation unit.  */ | ||||
| /* Our implementation of fcntl (fd, F_DUPFD, target).  */ | ||||
| static int rpl_fcntl_DUPFD (int fd, int target); | ||||
| /* Our implementation of fcntl (fd, F_DUPFD_CLOEXEC, target).  */ | ||||
| static int rpl_fcntl_DUPFD_CLOEXEC (int fd, int target); | ||||
| #ifdef __KLIBC__ | ||||
| /* Adds support for fcntl on directories.  */ | ||||
| static int klibc_fcntl (int fd, int action, /* arg */...); | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| /* Perform the specified ACTION on the file descriptor FD, possibly
 | ||||
|    using the argument ARG further described below.  This replacement | ||||
|    handles the following actions, and forwards all others on to the | ||||
|    native fcntl.  An unrecognized ACTION returns -1 with errno set to | ||||
|    EINVAL. | ||||
| 
 | ||||
|    F_DUPFD - duplicate FD, with int ARG being the minimum target fd. | ||||
|    If successful, return the duplicate, which will be inheritable; | ||||
|    otherwise return -1 and set errno. | ||||
| 
 | ||||
|    F_DUPFD_CLOEXEC - duplicate FD, with int ARG being the minimum | ||||
|    target fd.  If successful, return the duplicate, which will not be | ||||
|    inheritable; otherwise return -1 and set errno. | ||||
| 
 | ||||
|    F_GETFD - ARG need not be present.  If successful, return a | ||||
|    non-negative value containing the descriptor flags of FD (only | ||||
|    FD_CLOEXEC is portable, but other flags may be present); otherwise | ||||
|    return -1 and set errno.  */ | ||||
| 
 | ||||
| int | ||||
| fcntl (int fd, int action, /* arg */...) | ||||
| #undef fcntl | ||||
| #ifdef __KLIBC__ | ||||
| # define fcntl klibc_fcntl | ||||
| #endif | ||||
| { | ||||
|   va_list arg; | ||||
|   int result = -1; | ||||
|   va_start (arg, action); | ||||
|   switch (action) | ||||
|     { | ||||
|     case F_DUPFD: | ||||
|       { | ||||
|         int target = va_arg (arg, int); | ||||
|         result = rpl_fcntl_DUPFD (fd, target); | ||||
|         break; | ||||
|       } | ||||
| 
 | ||||
|     case F_DUPFD_CLOEXEC: | ||||
|       { | ||||
|         int target = va_arg (arg, int); | ||||
|         result = rpl_fcntl_DUPFD_CLOEXEC (fd, target); | ||||
|         break; | ||||
|       } | ||||
| 
 | ||||
| #if !HAVE_FCNTL | ||||
|     case F_GETFD: | ||||
|       { | ||||
| # if defined _WIN32 && ! defined __CYGWIN__ | ||||
|         HANDLE handle = (HANDLE) _get_osfhandle (fd); | ||||
|         DWORD flags; | ||||
|         if (handle == INVALID_HANDLE_VALUE | ||||
|             || GetHandleInformation (handle, &flags) == 0) | ||||
|           errno = EBADF; | ||||
|         else | ||||
|           result = (flags & HANDLE_FLAG_INHERIT) ? 0 : FD_CLOEXEC; | ||||
| # else /* !W32 */ | ||||
|         /* Use dup2 to reject invalid file descriptors.  No way to
 | ||||
|            access this information, so punt.  */ | ||||
|         if (0 <= dup2 (fd, fd)) | ||||
|           result = 0; | ||||
| # endif /* !W32 */ | ||||
|         break; | ||||
|       } /* F_GETFD */ | ||||
| #endif /* !HAVE_FCNTL */ | ||||
| 
 | ||||
|       /* Implementing F_SETFD on mingw is not trivial - there is no
 | ||||
|          API for changing the O_NOINHERIT bit on an fd, and merely | ||||
|          changing the HANDLE_FLAG_INHERIT bit on the underlying handle | ||||
|          can lead to odd state.  It may be possible by duplicating the | ||||
|          handle, using _open_osfhandle with the right flags, then | ||||
|          using dup2 to move the duplicate onto the original, but that | ||||
|          is not supported for now.  */ | ||||
| 
 | ||||
|     default: | ||||
|       { | ||||
| #if HAVE_FCNTL | ||||
|         switch (action) | ||||
|           { | ||||
|           #ifdef F_BARRIERFSYNC                  /* macOS */ | ||||
|           case F_BARRIERFSYNC: | ||||
|           #endif | ||||
|           #ifdef F_CHKCLEAN                      /* macOS */ | ||||
|           case F_CHKCLEAN: | ||||
|           #endif | ||||
|           #ifdef F_CLOSEM                        /* NetBSD, HP-UX */ | ||||
|           case F_CLOSEM: | ||||
|           #endif | ||||
|           #ifdef F_FLUSH_DATA                    /* macOS */ | ||||
|           case F_FLUSH_DATA: | ||||
|           #endif | ||||
|           #ifdef F_FREEZE_FS                     /* macOS */ | ||||
|           case F_FREEZE_FS: | ||||
|           #endif | ||||
|           #ifdef F_FULLFSYNC                     /* macOS */ | ||||
|           case F_FULLFSYNC: | ||||
|           #endif | ||||
|           #ifdef F_GETCONFINED                   /* macOS */ | ||||
|           case F_GETCONFINED: | ||||
|           #endif | ||||
|           #ifdef F_GETDEFAULTPROTLEVEL           /* macOS */ | ||||
|           case F_GETDEFAULTPROTLEVEL: | ||||
|           #endif | ||||
|           #ifdef F_GETFD                         /* POSIX */ | ||||
|           case F_GETFD: | ||||
|           #endif | ||||
|           #ifdef F_GETFL                         /* POSIX */ | ||||
|           case F_GETFL: | ||||
|           #endif | ||||
|           #ifdef F_GETLEASE                      /* Linux */ | ||||
|           case F_GETLEASE: | ||||
|           #endif | ||||
|           #ifdef F_GETNOSIGPIPE                  /* macOS */ | ||||
|           case F_GETNOSIGPIPE: | ||||
|           #endif | ||||
|           #ifdef F_GETOWN                        /* POSIX */ | ||||
|           case F_GETOWN: | ||||
|           #endif | ||||
|           #ifdef F_GETPIPE_SZ                    /* Linux */ | ||||
|           case F_GETPIPE_SZ: | ||||
|           #endif | ||||
|           #ifdef F_GETPROTECTIONCLASS            /* macOS */ | ||||
|           case F_GETPROTECTIONCLASS: | ||||
|           #endif | ||||
|           #ifdef F_GETPROTECTIONLEVEL            /* macOS */ | ||||
|           case F_GETPROTECTIONLEVEL: | ||||
|           #endif | ||||
|           #ifdef F_GET_SEALS                     /* Linux */ | ||||
|           case F_GET_SEALS: | ||||
|           #endif | ||||
|           #ifdef F_GETSIG                        /* Linux */ | ||||
|           case F_GETSIG: | ||||
|           #endif | ||||
|           #ifdef F_MAXFD                         /* NetBSD */ | ||||
|           case F_MAXFD: | ||||
|           #endif | ||||
|           #ifdef F_RECYCLE                       /* macOS */ | ||||
|           case F_RECYCLE: | ||||
|           #endif | ||||
|           #ifdef F_SETFIFOENH                    /* HP-UX */ | ||||
|           case F_SETFIFOENH: | ||||
|           #endif | ||||
|           #ifdef F_THAW_FS                       /* macOS */ | ||||
|           case F_THAW_FS: | ||||
|           #endif | ||||
|             /* These actions take no argument.  */ | ||||
|             result = fcntl (fd, action); | ||||
|             break; | ||||
| 
 | ||||
|           #ifdef F_ADD_SEALS                     /* Linux */ | ||||
|           case F_ADD_SEALS: | ||||
|           #endif | ||||
|           #ifdef F_BADFD                         /* Solaris */ | ||||
|           case F_BADFD: | ||||
|           #endif | ||||
|           #ifdef F_CHECK_OPENEVT                 /* macOS */ | ||||
|           case F_CHECK_OPENEVT: | ||||
|           #endif | ||||
|           #ifdef F_DUP2FD                        /* FreeBSD, AIX, Solaris */ | ||||
|           case F_DUP2FD: | ||||
|           #endif | ||||
|           #ifdef F_DUP2FD_CLOEXEC                /* FreeBSD, Solaris */ | ||||
|           case F_DUP2FD_CLOEXEC: | ||||
|           #endif | ||||
|           #ifdef F_DUP2FD_CLOFORK                /* Solaris */ | ||||
|           case F_DUP2FD_CLOFORK: | ||||
|           #endif | ||||
|           #ifdef F_DUPFD                         /* POSIX */ | ||||
|           case F_DUPFD: | ||||
|           #endif | ||||
|           #ifdef F_DUPFD_CLOEXEC                 /* POSIX */ | ||||
|           case F_DUPFD_CLOEXEC: | ||||
|           #endif | ||||
|           #ifdef F_DUPFD_CLOFORK                 /* Solaris */ | ||||
|           case F_DUPFD_CLOFORK: | ||||
|           #endif | ||||
|           #ifdef F_GETXFL                        /* Solaris */ | ||||
|           case F_GETXFL: | ||||
|           #endif | ||||
|           #ifdef F_GLOBAL_NOCACHE                /* macOS */ | ||||
|           case F_GLOBAL_NOCACHE: | ||||
|           #endif | ||||
|           #ifdef F_MAKECOMPRESSED                /* macOS */ | ||||
|           case F_MAKECOMPRESSED: | ||||
|           #endif | ||||
|           #ifdef F_MOVEDATAEXTENTS               /* macOS */ | ||||
|           case F_MOVEDATAEXTENTS: | ||||
|           #endif | ||||
|           #ifdef F_NOCACHE                       /* macOS */ | ||||
|           case F_NOCACHE: | ||||
|           #endif | ||||
|           #ifdef F_NODIRECT                      /* macOS */ | ||||
|           case F_NODIRECT: | ||||
|           #endif | ||||
|           #ifdef F_NOTIFY                        /* Linux */ | ||||
|           case F_NOTIFY: | ||||
|           #endif | ||||
|           #ifdef F_OPLKACK                       /* IRIX */ | ||||
|           case F_OPLKACK: | ||||
|           #endif | ||||
|           #ifdef F_OPLKREG                       /* IRIX */ | ||||
|           case F_OPLKREG: | ||||
|           #endif | ||||
|           #ifdef F_RDAHEAD                       /* macOS */ | ||||
|           case F_RDAHEAD: | ||||
|           #endif | ||||
|           #ifdef F_SETBACKINGSTORE               /* macOS */ | ||||
|           case F_SETBACKINGSTORE: | ||||
|           #endif | ||||
|           #ifdef F_SETCONFINED                   /* macOS */ | ||||
|           case F_SETCONFINED: | ||||
|           #endif | ||||
|           #ifdef F_SETFD                         /* POSIX */ | ||||
|           case F_SETFD: | ||||
|           #endif | ||||
|           #ifdef F_SETFL                         /* POSIX */ | ||||
|           case F_SETFL: | ||||
|           #endif | ||||
|           #ifdef F_SETLEASE                      /* Linux */ | ||||
|           case F_SETLEASE: | ||||
|           #endif | ||||
|           #ifdef F_SETNOSIGPIPE                  /* macOS */ | ||||
|           case F_SETNOSIGPIPE: | ||||
|           #endif | ||||
|           #ifdef F_SETOWN                        /* POSIX */ | ||||
|           case F_SETOWN: | ||||
|           #endif | ||||
|           #ifdef F_SETPIPE_SZ                    /* Linux */ | ||||
|           case F_SETPIPE_SZ: | ||||
|           #endif | ||||
|           #ifdef F_SETPROTECTIONCLASS            /* macOS */ | ||||
|           case F_SETPROTECTIONCLASS: | ||||
|           #endif | ||||
|           #ifdef F_SETSIG                        /* Linux */ | ||||
|           case F_SETSIG: | ||||
|           #endif | ||||
|           #ifdef F_SINGLE_WRITER                 /* macOS */ | ||||
|           case F_SINGLE_WRITER: | ||||
|           #endif | ||||
|             /* These actions take an 'int' argument.  */ | ||||
|             { | ||||
|               int x = va_arg (arg, int); | ||||
|               result = fcntl (fd, action, x); | ||||
|             } | ||||
|             break; | ||||
| 
 | ||||
|           default: | ||||
|             /* Other actions take a pointer argument.  */ | ||||
|             { | ||||
|               void *p = va_arg (arg, void *); | ||||
|               result = fcntl (fd, action, p); | ||||
|             } | ||||
|             break; | ||||
|           } | ||||
| #else | ||||
|         errno = EINVAL; | ||||
| #endif | ||||
|         break; | ||||
|       } | ||||
|     } | ||||
|   va_end (arg); | ||||
|   return result; | ||||
| } | ||||
| 
 | ||||
| static int | ||||
| rpl_fcntl_DUPFD (int fd, int target) | ||||
| { | ||||
|   int result; | ||||
| #if !HAVE_FCNTL | ||||
|   result = dupfd (fd, target, 0); | ||||
| #elif FCNTL_DUPFD_BUGGY || REPLACE_FCHDIR | ||||
|   /* Detect invalid target; needed for cygwin 1.5.x.  */ | ||||
|   if (target < 0 || getdtablesize () <= target) | ||||
|     { | ||||
|       result = -1; | ||||
|       errno = EINVAL; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       /* Haiku alpha 2 loses fd flags on original.  */ | ||||
|       int flags = fcntl (fd, F_GETFD); | ||||
|       if (flags < 0) | ||||
|         result = -1; | ||||
|       else | ||||
|         { | ||||
|           result = fcntl (fd, F_DUPFD, target); | ||||
|           if (0 <= result && fcntl (fd, F_SETFD, flags) == -1) | ||||
|             { | ||||
|               int saved_errno = errno; | ||||
|               close (result); | ||||
|               result = -1; | ||||
|               errno = saved_errno; | ||||
|             } | ||||
| # if REPLACE_FCHDIR | ||||
|           if (0 <= result) | ||||
|             result = _gl_register_dup (fd, result); | ||||
| # endif | ||||
|         } | ||||
|     } | ||||
| #else | ||||
|   result = fcntl (fd, F_DUPFD, target); | ||||
| #endif | ||||
|   return result; | ||||
| } | ||||
| 
 | ||||
| static int | ||||
| rpl_fcntl_DUPFD_CLOEXEC (int fd, int target) | ||||
| { | ||||
|   int result; | ||||
| #if !HAVE_FCNTL | ||||
|   result = dupfd (fd, target, O_CLOEXEC); | ||||
| #else /* HAVE_FCNTL */ | ||||
| # if defined __HAIKU__ | ||||
|   /* On Haiku, the system fcntl (fd, F_DUPFD_CLOEXEC, target) sets
 | ||||
|      the FD_CLOEXEC flag on fd, not on target.  Therefore avoid the | ||||
|      system fcntl in this case.  */ | ||||
| #  define have_dupfd_cloexec -1 | ||||
| # else | ||||
|   /* Try the system call first, if the headers claim it exists
 | ||||
|      (that is, if GNULIB_defined_F_DUPFD_CLOEXEC is 0), since we | ||||
|      may be running with a glibc that has the macro but with an | ||||
|      older kernel that does not support it.  Cache the | ||||
|      information on whether the system call really works, but | ||||
|      avoid caching failure if the corresponding F_DUPFD fails | ||||
|      for any reason.  0 = unknown, 1 = yes, -1 = no.  */ | ||||
|   static int have_dupfd_cloexec = GNULIB_defined_F_DUPFD_CLOEXEC ? -1 : 0; | ||||
|   if (0 <= have_dupfd_cloexec) | ||||
|     { | ||||
|       result = fcntl (fd, F_DUPFD_CLOEXEC, target); | ||||
|       if (0 <= result || errno != EINVAL) | ||||
|         { | ||||
|           have_dupfd_cloexec = 1; | ||||
| #  if REPLACE_FCHDIR | ||||
|           if (0 <= result) | ||||
|             result = _gl_register_dup (fd, result); | ||||
| #  endif | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           result = rpl_fcntl_DUPFD (fd, target); | ||||
|           if (result >= 0) | ||||
|             have_dupfd_cloexec = -1; | ||||
|         } | ||||
|     } | ||||
|   else | ||||
| # endif | ||||
|     result = rpl_fcntl_DUPFD (fd, target); | ||||
|   if (0 <= result && have_dupfd_cloexec == -1) | ||||
|     { | ||||
|       int flags = fcntl (result, F_GETFD); | ||||
|       if (flags < 0 || fcntl (result, F_SETFD, flags | FD_CLOEXEC) == -1) | ||||
|         { | ||||
|           int saved_errno = errno; | ||||
|           close (result); | ||||
|           errno = saved_errno; | ||||
|           result = -1; | ||||
|         } | ||||
|     } | ||||
| #endif /* HAVE_FCNTL */ | ||||
|   return result; | ||||
| } | ||||
| 
 | ||||
| #undef fcntl | ||||
| 
 | ||||
| #ifdef __KLIBC__ | ||||
| 
 | ||||
| static int | ||||
| klibc_fcntl (int fd, int action, /* arg */...) | ||||
| { | ||||
|   va_list arg_ptr; | ||||
|   int arg; | ||||
|   struct stat sbuf; | ||||
|   int result; | ||||
| 
 | ||||
|   va_start (arg_ptr, action); | ||||
|   arg = va_arg (arg_ptr, int); | ||||
|   result = fcntl (fd, action, arg); | ||||
|   /* EPERM for F_DUPFD, ENOTSUP for others */ | ||||
|   if (result == -1 && (errno == EPERM || errno == ENOTSUP) | ||||
|       && !fstat (fd, &sbuf) && S_ISDIR (sbuf.st_mode)) | ||||
|     { | ||||
|       ULONG ulMode; | ||||
| 
 | ||||
|       switch (action) | ||||
|         { | ||||
|         case F_DUPFD: | ||||
|           /* Find available fd */ | ||||
|           while (fcntl (arg, F_GETFL) != -1 || errno != EBADF) | ||||
|             arg++; | ||||
| 
 | ||||
|           result = dup2 (fd, arg); | ||||
|           break; | ||||
| 
 | ||||
|         /* Using underlying APIs is right ? */ | ||||
|         case F_GETFD: | ||||
|           if (DosQueryFHState (fd, &ulMode)) | ||||
|             break; | ||||
| 
 | ||||
|           result = (ulMode & OPEN_FLAGS_NOINHERIT) ? FD_CLOEXEC : 0; | ||||
|           break; | ||||
| 
 | ||||
|         case F_SETFD: | ||||
|           if (arg & ~FD_CLOEXEC) | ||||
|             break; | ||||
| 
 | ||||
|           if (DosQueryFHState (fd, &ulMode)) | ||||
|             break; | ||||
| 
 | ||||
|           if (arg & FD_CLOEXEC) | ||||
|             ulMode |= OPEN_FLAGS_NOINHERIT; | ||||
|           else | ||||
|             ulMode &= ~OPEN_FLAGS_NOINHERIT; | ||||
| 
 | ||||
|           /* Filter supported flags.  */ | ||||
|           ulMode &= (OPEN_FLAGS_WRITE_THROUGH | OPEN_FLAGS_FAIL_ON_ERROR | ||||
|                      | OPEN_FLAGS_NO_CACHE | OPEN_FLAGS_NOINHERIT); | ||||
| 
 | ||||
|           if (DosSetFHState (fd, ulMode)) | ||||
|             break; | ||||
| 
 | ||||
|           result = 0; | ||||
|           break; | ||||
| 
 | ||||
|         case F_GETFL: | ||||
|           result = 0; | ||||
|           break; | ||||
| 
 | ||||
|         case F_SETFL: | ||||
|           if (arg != 0) | ||||
|             break; | ||||
| 
 | ||||
|           result = 0; | ||||
|           break; | ||||
| 
 | ||||
|         default: | ||||
|           errno = EINVAL; | ||||
|           break; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|   va_end (arg_ptr); | ||||
| 
 | ||||
|   return result; | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
							
								
								
									
										392
									
								
								third_party/make/lib/fcntl.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										392
									
								
								third_party/make/lib/fcntl.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,392 @@ | |||
| /* Like <fcntl.h>, but with non-working flags defined to 0.
 | ||||
| 
 | ||||
|    Copyright (C) 2006-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| /* written by Paul Eggert */ | ||||
| 
 | ||||
| #if __GNUC__ >= 3 | ||||
| @PRAGMA_SYSTEM_HEADER@ | ||||
| #endif | ||||
| @PRAGMA_COLUMNS@ | ||||
| 
 | ||||
| #if defined __need_system_fcntl_h | ||||
| /* Special invocation convention.  */ | ||||
| 
 | ||||
| /* Needed before <sys/stat.h>.
 | ||||
|    May also define off_t to a 64-bit type on native Windows.  */ | ||||
| #include <sys/types.h> | ||||
| /* On some systems other than glibc, <sys/stat.h> is a prerequisite of
 | ||||
|    <fcntl.h>.  On glibc systems, we would like to avoid namespace pollution. | ||||
|    But on glibc systems, <fcntl.h> includes <sys/stat.h> inside an | ||||
|    extern "C" { ... } block, which leads to errors in C++ mode with the | ||||
|    overridden <sys/stat.h> from gnulib.  These errors are known to be gone | ||||
|    with g++ version >= 4.3.  */ | ||||
| #if !(defined __GLIBC__ || defined __UCLIBC__) || (defined __cplusplus && defined GNULIB_NAMESPACE && (defined __ICC || !(__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 3)))) | ||||
| # include <sys/stat.h> | ||||
| #endif | ||||
| #@INCLUDE_NEXT@ @NEXT_FCNTL_H@ | ||||
| 
 | ||||
| /* Native Windows platforms declare open(), creat() in <io.h>.  */ | ||||
| #if (@GNULIB_CREAT@ || @GNULIB_OPEN@ || defined GNULIB_POSIXCHECK) \ | ||||
|     && (defined _WIN32 && ! defined __CYGWIN__) | ||||
| # include <io.h> | ||||
| #endif | ||||
| 
 | ||||
| #else | ||||
| /* Normal invocation convention.  */ | ||||
| 
 | ||||
| #ifndef _@GUARD_PREFIX@_FCNTL_H | ||||
| 
 | ||||
| /* Needed before <sys/stat.h>.
 | ||||
|    May also define off_t to a 64-bit type on native Windows.  */ | ||||
| #include <sys/types.h> | ||||
| /* On some systems other than glibc, <sys/stat.h> is a prerequisite of
 | ||||
|    <fcntl.h>.  On glibc systems, we would like to avoid namespace pollution. | ||||
|    But on glibc systems, <fcntl.h> includes <sys/stat.h> inside an | ||||
|    extern "C" { ... } block, which leads to errors in C++ mode with the | ||||
|    overridden <sys/stat.h> from gnulib.  These errors are known to be gone | ||||
|    with g++ version >= 4.3.  */ | ||||
| #if !(defined __GLIBC__ || defined __UCLIBC__) || (defined __cplusplus && defined GNULIB_NAMESPACE && (defined __ICC || !(__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 3)))) | ||||
| # include <sys/stat.h> | ||||
| #endif | ||||
| /* The include_next requires a split double-inclusion guard.  */ | ||||
| #@INCLUDE_NEXT@ @NEXT_FCNTL_H@ | ||||
| 
 | ||||
| /* Native Windows platforms declare open(), creat() in <io.h>.  */ | ||||
| #if (@GNULIB_CREAT@ || @GNULIB_OPEN@ || defined GNULIB_POSIXCHECK) \ | ||||
|     && (defined _WIN32 && ! defined __CYGWIN__) | ||||
| # include <io.h> | ||||
| #endif | ||||
| 
 | ||||
| #ifndef _@GUARD_PREFIX@_FCNTL_H | ||||
| #define _@GUARD_PREFIX@_FCNTL_H | ||||
| 
 | ||||
| #ifndef __GLIBC__ /* Avoid namespace pollution on glibc systems.  */ | ||||
| # include <unistd.h> | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| /* The definitions of _GL_FUNCDECL_RPL etc. are copied here.  */ | ||||
| 
 | ||||
| /* The definition of _GL_ARG_NONNULL is copied here.  */ | ||||
| 
 | ||||
| /* The definition of _GL_WARN_ON_USE is copied here.  */ | ||||
| 
 | ||||
| 
 | ||||
| /* Declare overridden functions.  */ | ||||
| 
 | ||||
| #if @GNULIB_CREAT@ | ||||
| # if @REPLACE_CREAT@ | ||||
| #  if !(defined __cplusplus && defined GNULIB_NAMESPACE) | ||||
| #   undef creat | ||||
| #   define creat rpl_creat | ||||
| #  endif | ||||
| _GL_FUNCDECL_RPL (creat, int, (const char *filename, mode_t mode) | ||||
|                              _GL_ARG_NONNULL ((1))); | ||||
| _GL_CXXALIAS_RPL (creat, int, (const char *filename, mode_t mode)); | ||||
| # else | ||||
| _GL_CXXALIAS_SYS (creat, int, (const char *filename, mode_t mode)); | ||||
| # endif | ||||
| _GL_CXXALIASWARN (creat); | ||||
| #elif defined GNULIB_POSIXCHECK | ||||
| # undef creat | ||||
| /* Assume creat is always declared.  */ | ||||
| _GL_WARN_ON_USE (creat, "creat is not always POSIX compliant - " | ||||
|                  "use gnulib module creat for portability"); | ||||
| #endif | ||||
| 
 | ||||
| #if @GNULIB_FCNTL@ | ||||
| # if @REPLACE_FCNTL@ | ||||
| #  if !(defined __cplusplus && defined GNULIB_NAMESPACE) | ||||
| #   undef fcntl | ||||
| #   define fcntl rpl_fcntl | ||||
| #  endif | ||||
| _GL_FUNCDECL_RPL (fcntl, int, (int fd, int action, ...)); | ||||
| _GL_CXXALIAS_RPL (fcntl, int, (int fd, int action, ...)); | ||||
| # else | ||||
| #  if !@HAVE_FCNTL@ | ||||
| _GL_FUNCDECL_SYS (fcntl, int, (int fd, int action, ...)); | ||||
| #  endif | ||||
| _GL_CXXALIAS_SYS (fcntl, int, (int fd, int action, ...)); | ||||
| # endif | ||||
| _GL_CXXALIASWARN (fcntl); | ||||
| #elif defined GNULIB_POSIXCHECK | ||||
| # undef fcntl | ||||
| # if HAVE_RAW_DECL_FCNTL | ||||
| _GL_WARN_ON_USE (fcntl, "fcntl is not always POSIX compliant - " | ||||
|                  "use gnulib module fcntl for portability"); | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| #if @GNULIB_OPEN@ | ||||
| # if @REPLACE_OPEN@ | ||||
| #  if !(defined __cplusplus && defined GNULIB_NAMESPACE) | ||||
| #   undef open | ||||
| #   define open rpl_open | ||||
| #  endif | ||||
| _GL_FUNCDECL_RPL (open, int, (const char *filename, int flags, ...) | ||||
|                              _GL_ARG_NONNULL ((1))); | ||||
| _GL_CXXALIAS_RPL (open, int, (const char *filename, int flags, ...)); | ||||
| # else | ||||
| _GL_CXXALIAS_SYS (open, int, (const char *filename, int flags, ...)); | ||||
| # endif | ||||
| /* On HP-UX 11, in C++ mode, open() is defined as an inline function with a
 | ||||
|    default argument.  _GL_CXXALIASWARN does not work in this case.  */ | ||||
| # if !defined __hpux | ||||
| _GL_CXXALIASWARN (open); | ||||
| # endif | ||||
| #elif defined GNULIB_POSIXCHECK | ||||
| # undef open | ||||
| /* Assume open is always declared.  */ | ||||
| _GL_WARN_ON_USE (open, "open is not always POSIX compliant - " | ||||
|                  "use gnulib module open for portability"); | ||||
| #endif | ||||
| 
 | ||||
| #if @GNULIB_OPENAT@ | ||||
| # if @REPLACE_OPENAT@ | ||||
| #  if !(defined __cplusplus && defined GNULIB_NAMESPACE) | ||||
| #   undef openat | ||||
| #   define openat rpl_openat | ||||
| #  endif | ||||
| _GL_FUNCDECL_RPL (openat, int, | ||||
|                   (int fd, char const *file, int flags, /* mode_t mode */ ...) | ||||
|                   _GL_ARG_NONNULL ((2))); | ||||
| _GL_CXXALIAS_RPL (openat, int, | ||||
|                   (int fd, char const *file, int flags, /* mode_t mode */ ...)); | ||||
| # else | ||||
| #  if !@HAVE_OPENAT@ | ||||
| _GL_FUNCDECL_SYS (openat, int, | ||||
|                   (int fd, char const *file, int flags, /* mode_t mode */ ...) | ||||
|                   _GL_ARG_NONNULL ((2))); | ||||
| #  endif | ||||
| _GL_CXXALIAS_SYS (openat, int, | ||||
|                   (int fd, char const *file, int flags, /* mode_t mode */ ...)); | ||||
| # endif | ||||
| _GL_CXXALIASWARN (openat); | ||||
| #elif defined GNULIB_POSIXCHECK | ||||
| # undef openat | ||||
| # if HAVE_RAW_DECL_OPENAT | ||||
| _GL_WARN_ON_USE (openat, "openat is not portable - " | ||||
|                  "use gnulib module openat for portability"); | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| /* Fix up the FD_* macros, only known to be missing on mingw.  */ | ||||
| 
 | ||||
| #ifndef FD_CLOEXEC | ||||
| # define FD_CLOEXEC 1 | ||||
| #endif | ||||
| 
 | ||||
| /* Fix up the supported F_* macros.  Intentionally leave other F_*
 | ||||
|    macros undefined.  Only known to be missing on mingw.  */ | ||||
| 
 | ||||
| #ifndef F_DUPFD_CLOEXEC | ||||
| # define F_DUPFD_CLOEXEC 0x40000000 | ||||
| /* Witness variable: 1 if gnulib defined F_DUPFD_CLOEXEC, 0 otherwise.  */ | ||||
| # define GNULIB_defined_F_DUPFD_CLOEXEC 1 | ||||
| #else | ||||
| # define GNULIB_defined_F_DUPFD_CLOEXEC 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef F_DUPFD | ||||
| # define F_DUPFD 1 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef F_GETFD | ||||
| # define F_GETFD 2 | ||||
| #endif | ||||
| 
 | ||||
| /* Fix up the O_* macros.  */ | ||||
| 
 | ||||
| /* AIX 7.1 with XL C 12.1 defines O_CLOEXEC, O_NOFOLLOW, and O_TTY_INIT
 | ||||
|    to values outside 'int' range, so omit these misdefinitions. | ||||
|    But avoid namespace pollution on non-AIX systems.  */ | ||||
| #ifdef _AIX | ||||
| # include <limits.h> | ||||
| # if defined O_CLOEXEC && ! (INT_MIN <= O_CLOEXEC && O_CLOEXEC <= INT_MAX) | ||||
| #  undef O_CLOEXEC | ||||
| # endif | ||||
| # if defined O_NOFOLLOW && ! (INT_MIN <= O_NOFOLLOW && O_NOFOLLOW <= INT_MAX) | ||||
| #  undef O_NOFOLLOW | ||||
| # endif | ||||
| # if defined O_TTY_INIT && ! (INT_MIN <= O_TTY_INIT && O_TTY_INIT <= INT_MAX) | ||||
| #  undef O_TTY_INIT | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| #if !defined O_DIRECT && defined O_DIRECTIO | ||||
| /* Tru64 spells it 'O_DIRECTIO'.  */ | ||||
| # define O_DIRECT O_DIRECTIO | ||||
| #endif | ||||
| 
 | ||||
| #if !defined O_CLOEXEC && defined O_NOINHERIT | ||||
| /* Mingw spells it 'O_NOINHERIT'.  */ | ||||
| # define O_CLOEXEC O_NOINHERIT | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_CLOEXEC | ||||
| # define O_CLOEXEC 0x40000000 /* Try to not collide with system O_* flags.  */ | ||||
| # define GNULIB_defined_O_CLOEXEC 1 | ||||
| #else | ||||
| # define GNULIB_defined_O_CLOEXEC 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_DIRECT | ||||
| # define O_DIRECT 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_DIRECTORY | ||||
| # define O_DIRECTORY 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_DSYNC | ||||
| # define O_DSYNC 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_EXEC | ||||
| # define O_EXEC O_RDONLY /* This is often close enough in older systems.  */ | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_IGNORE_CTTY | ||||
| # define O_IGNORE_CTTY 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_NDELAY | ||||
| # define O_NDELAY 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_NOATIME | ||||
| # define O_NOATIME 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_NONBLOCK | ||||
| # define O_NONBLOCK O_NDELAY | ||||
| #endif | ||||
| 
 | ||||
| /* If the gnulib module 'nonblocking' is in use, guarantee a working non-zero
 | ||||
|    value of O_NONBLOCK.  Otherwise, O_NONBLOCK is defined (above) to O_NDELAY | ||||
|    or to 0 as fallback.  */ | ||||
| #if @GNULIB_NONBLOCKING@ | ||||
| # if O_NONBLOCK | ||||
| #  define GNULIB_defined_O_NONBLOCK 0 | ||||
| # else | ||||
| #  define GNULIB_defined_O_NONBLOCK 1 | ||||
| #  undef O_NONBLOCK | ||||
| #  define O_NONBLOCK 0x40000000 | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_NOCTTY | ||||
| # define O_NOCTTY 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_NOFOLLOW | ||||
| # define O_NOFOLLOW 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_NOLINK | ||||
| # define O_NOLINK 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_NOLINKS | ||||
| # define O_NOLINKS 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_NOTRANS | ||||
| # define O_NOTRANS 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_RSYNC | ||||
| # define O_RSYNC 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_SEARCH | ||||
| # define O_SEARCH O_RDONLY /* This is often close enough in older systems.  */ | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_SYNC | ||||
| # define O_SYNC 0 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_TTY_INIT | ||||
| # define O_TTY_INIT 0 | ||||
| #endif | ||||
| 
 | ||||
| #if ~O_ACCMODE & (O_RDONLY | O_WRONLY | O_RDWR | O_EXEC | O_SEARCH) | ||||
| # undef O_ACCMODE | ||||
| # define O_ACCMODE (O_RDONLY | O_WRONLY | O_RDWR | O_EXEC | O_SEARCH) | ||||
| #endif | ||||
| 
 | ||||
| /* For systems that distinguish between text and binary I/O.
 | ||||
|    O_BINARY is usually declared in fcntl.h  */ | ||||
| #if !defined O_BINARY && defined _O_BINARY | ||||
|   /* For MSC-compatible compilers.  */ | ||||
| # define O_BINARY _O_BINARY | ||||
| # define O_TEXT _O_TEXT | ||||
| #endif | ||||
| 
 | ||||
| #if defined __BEOS__ || defined __HAIKU__ | ||||
|   /* BeOS 5 and Haiku have O_BINARY and O_TEXT, but they have no effect.  */ | ||||
| # undef O_BINARY | ||||
| # undef O_TEXT | ||||
| #endif | ||||
| 
 | ||||
| #ifndef O_BINARY | ||||
| # define O_BINARY 0 | ||||
| # define O_TEXT 0 | ||||
| #endif | ||||
| 
 | ||||
| /* Fix up the AT_* macros.  */ | ||||
| 
 | ||||
| /* Work around a bug in Solaris 9 and 10: AT_FDCWD is positive.  Its
 | ||||
|    value exceeds INT_MAX, so its use as an int doesn't conform to the | ||||
|    C standard, and GCC and Sun C complain in some cases.  If the bug | ||||
|    is present, undef AT_FDCWD here, so it can be redefined below.  */ | ||||
| #if 0 < AT_FDCWD && AT_FDCWD == 0xffd19553
 | ||||
| # undef AT_FDCWD | ||||
| #endif | ||||
| 
 | ||||
| /* Use the same bit pattern as Solaris 9, but with the proper
 | ||||
|    signedness.  The bit pattern is important, in case this actually is | ||||
|    Solaris with the above workaround.  */ | ||||
| #ifndef AT_FDCWD | ||||
| # define AT_FDCWD (-3041965) | ||||
| #endif | ||||
| 
 | ||||
| /* Use the same values as Solaris 9.  This shouldn't matter, but
 | ||||
|    there's no real reason to differ.  */ | ||||
| #ifndef AT_SYMLINK_NOFOLLOW | ||||
| # define AT_SYMLINK_NOFOLLOW 4096 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef AT_REMOVEDIR | ||||
| # define AT_REMOVEDIR 1 | ||||
| #endif | ||||
| 
 | ||||
| /* Solaris 9 lacks these two, so just pick unique values.  */ | ||||
| #ifndef AT_SYMLINK_FOLLOW | ||||
| # define AT_SYMLINK_FOLLOW 2 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef AT_EACCESS | ||||
| # define AT_EACCESS 4 | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| #endif /* _@GUARD_PREFIX@_FCNTL_H */ | ||||
| #endif /* _@GUARD_PREFIX@_FCNTL_H */ | ||||
| #endif | ||||
							
								
								
									
										116
									
								
								third_party/make/lib/fd-hook.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								third_party/make/lib/fd-hook.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,116 @@ | |||
| /* Hook for making file descriptor functions close(), ioctl() extensible.
 | ||||
|    Copyright (C) 2009-2020 Free Software Foundation, Inc. | ||||
|    Written by Bruno Haible <bruno@clisp.org>, 2009. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify it | ||||
|    under the terms of the GNU General Public License as published | ||||
|    by the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
|    General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include "fd-hook.h" | ||||
| 
 | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| /* Currently, this entire code is only needed for the handling of sockets
 | ||||
|    on native Windows platforms.  */ | ||||
| #if WINDOWS_SOCKETS | ||||
| 
 | ||||
| /* The first and last link in the doubly linked list.
 | ||||
|    Initially the list is empty.  */ | ||||
| static struct fd_hook anchor = { &anchor, &anchor, NULL, NULL }; | ||||
| 
 | ||||
| int | ||||
| execute_close_hooks (const struct fd_hook *remaining_list, gl_close_fn primary, | ||||
|                      int fd) | ||||
| { | ||||
|   if (remaining_list == &anchor) | ||||
|     /* End of list reached.  */ | ||||
|     return primary (fd); | ||||
|   else | ||||
|     return remaining_list->private_close_fn (remaining_list->private_next, | ||||
|                                              primary, fd); | ||||
| } | ||||
| 
 | ||||
| int | ||||
| execute_all_close_hooks (gl_close_fn primary, int fd) | ||||
| { | ||||
|   return execute_close_hooks (anchor.private_next, primary, fd); | ||||
| } | ||||
| 
 | ||||
| int | ||||
| execute_ioctl_hooks (const struct fd_hook *remaining_list, gl_ioctl_fn primary, | ||||
|                      int fd, int request, void *arg) | ||||
| { | ||||
|   if (remaining_list == &anchor) | ||||
|     /* End of list reached.  */ | ||||
|     return primary (fd, request, arg); | ||||
|   else | ||||
|     return remaining_list->private_ioctl_fn (remaining_list->private_next, | ||||
|                                              primary, fd, request, arg); | ||||
| } | ||||
| 
 | ||||
| int | ||||
| execute_all_ioctl_hooks (gl_ioctl_fn primary, | ||||
|                          int fd, int request, void *arg) | ||||
| { | ||||
|   return execute_ioctl_hooks (anchor.private_next, primary, fd, request, arg); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| register_fd_hook (close_hook_fn close_hook, ioctl_hook_fn ioctl_hook, struct fd_hook *link) | ||||
| { | ||||
|   if (close_hook == NULL) | ||||
|     close_hook = execute_close_hooks; | ||||
|   if (ioctl_hook == NULL) | ||||
|     ioctl_hook = execute_ioctl_hooks; | ||||
| 
 | ||||
|   if (link->private_next == NULL && link->private_prev == NULL) | ||||
|     { | ||||
|       /* Add the link to the doubly linked list.  */ | ||||
|       link->private_next = anchor.private_next; | ||||
|       link->private_prev = &anchor; | ||||
|       link->private_close_fn = close_hook; | ||||
|       link->private_ioctl_fn = ioctl_hook; | ||||
|       anchor.private_next->private_prev = link; | ||||
|       anchor.private_next = link; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       /* The link is already in use.  */ | ||||
|       if (link->private_close_fn != close_hook | ||||
|           || link->private_ioctl_fn != ioctl_hook) | ||||
|         abort (); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void | ||||
| unregister_fd_hook (struct fd_hook *link) | ||||
| { | ||||
|   struct fd_hook *next = link->private_next; | ||||
|   struct fd_hook *prev = link->private_prev; | ||||
| 
 | ||||
|   if (next != NULL && prev != NULL) | ||||
|     { | ||||
|       /* The link is in use.  Remove it from the doubly linked list.  */ | ||||
|       prev->private_next = next; | ||||
|       next->private_prev = prev; | ||||
|       /* Clear the link, to mark it unused.  */ | ||||
|       link->private_next = NULL; | ||||
|       link->private_prev = NULL; | ||||
|       link->private_close_fn = NULL; | ||||
|       link->private_ioctl_fn = NULL; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
							
								
								
									
										119
									
								
								third_party/make/lib/fd-hook.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										119
									
								
								third_party/make/lib/fd-hook.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,119 @@ | |||
| /* Hook for making file descriptor functions close(), ioctl() extensible.
 | ||||
|    Copyright (C) 2009-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify it | ||||
|    under the terms of the GNU General Public License as published | ||||
|    by the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
|    General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| 
 | ||||
| #ifndef FD_HOOK_H | ||||
| #define FD_HOOK_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| /* Currently, this entire code is only needed for the handling of sockets
 | ||||
|    on native Windows platforms.  */ | ||||
| #if WINDOWS_SOCKETS | ||||
| 
 | ||||
| 
 | ||||
| /* Type of function that closes FD.  */ | ||||
| typedef int (*gl_close_fn) (int fd); | ||||
| 
 | ||||
| /* Type of function that applies a control request to FD.  */ | ||||
| typedef int (*gl_ioctl_fn) (int fd, int request, void *arg); | ||||
| 
 | ||||
| /* An element of the list of file descriptor hooks.
 | ||||
|    In CLOS (Common Lisp Object System) speak, it consists of an "around" | ||||
|    method for the close() function and an "around" method for the ioctl() | ||||
|    function. | ||||
|    The fields of this structure are considered private.  */ | ||||
| struct fd_hook | ||||
| { | ||||
|   /* Doubly linked list.  */ | ||||
|   struct fd_hook *private_next; | ||||
|   struct fd_hook *private_prev; | ||||
|   /* Function that treats the types of FD that it knows about and calls
 | ||||
|      execute_close_hooks (REMAINING_LIST, PRIMARY, FD) as a fallback.  */ | ||||
|   int (*private_close_fn) (const struct fd_hook *remaining_list, | ||||
|                            gl_close_fn primary, | ||||
|                            int fd); | ||||
|   /* Function that treats the types of FD that it knows about and calls
 | ||||
|      execute_ioctl_hooks (REMAINING_LIST, PRIMARY, FD, REQUEST, ARG) as a | ||||
|      fallback.  */ | ||||
|   int (*private_ioctl_fn) (const struct fd_hook *remaining_list, | ||||
|                            gl_ioctl_fn primary, | ||||
|                            int fd, int request, void *arg); | ||||
| }; | ||||
| 
 | ||||
| /* This type of function closes FD, applying special knowledge for the FD
 | ||||
|    types it knows about, and calls | ||||
|    execute_close_hooks (REMAINING_LIST, PRIMARY, FD) | ||||
|    for the other FD types. | ||||
|    In CLOS speak, REMAINING_LIST is the remaining list of "around" methods, | ||||
|    and PRIMARY is the "primary" method for close().  */ | ||||
| typedef int (*close_hook_fn) (const struct fd_hook *remaining_list, | ||||
|                               gl_close_fn primary, | ||||
|                               int fd); | ||||
| 
 | ||||
| /* Execute the close hooks in REMAINING_LIST, with PRIMARY as "primary" method.
 | ||||
|    Return 0 or -1, like close() would do.  */ | ||||
| extern int execute_close_hooks (const struct fd_hook *remaining_list, | ||||
|                                 gl_close_fn primary, | ||||
|                                 int fd); | ||||
| 
 | ||||
| /* Execute all close hooks, with PRIMARY as "primary" method.
 | ||||
|    Return 0 or -1, like close() would do.  */ | ||||
| extern int execute_all_close_hooks (gl_close_fn primary, int fd); | ||||
| 
 | ||||
| /* This type of function applies a control request to FD, applying special
 | ||||
|    knowledge for the FD types it knows about, and calls | ||||
|    execute_ioctl_hooks (REMAINING_LIST, PRIMARY, FD, REQUEST, ARG) | ||||
|    for the other FD types. | ||||
|    In CLOS speak, REMAINING_LIST is the remaining list of "around" methods, | ||||
|    and PRIMARY is the "primary" method for ioctl().  */ | ||||
| typedef int (*ioctl_hook_fn) (const struct fd_hook *remaining_list, | ||||
|                               gl_ioctl_fn primary, | ||||
|                               int fd, int request, void *arg); | ||||
| 
 | ||||
| /* Execute the ioctl hooks in REMAINING_LIST, with PRIMARY as "primary" method.
 | ||||
|    Return 0 or -1, like ioctl() would do.  */ | ||||
| extern int execute_ioctl_hooks (const struct fd_hook *remaining_list, | ||||
|                                 gl_ioctl_fn primary, | ||||
|                                 int fd, int request, void *arg); | ||||
| 
 | ||||
| /* Execute all ioctl hooks, with PRIMARY as "primary" method.
 | ||||
|    Return 0 or -1, like ioctl() would do.  */ | ||||
| extern int execute_all_ioctl_hooks (gl_ioctl_fn primary, | ||||
|                                     int fd, int request, void *arg); | ||||
| 
 | ||||
| /* Add a function pair to the list of file descriptor hooks.
 | ||||
|    CLOSE_HOOK and IOCTL_HOOK may be NULL, indicating no change. | ||||
|    The LINK variable points to a piece of memory which is guaranteed to be | ||||
|    accessible until the corresponding call to unregister_fd_hook.  */ | ||||
| extern void register_fd_hook (close_hook_fn close_hook, ioctl_hook_fn ioctl_hook, | ||||
|                               struct fd_hook *link); | ||||
| 
 | ||||
| /* Removes a hook from the list of file descriptor hooks.  */ | ||||
| extern void unregister_fd_hook (struct fd_hook *link); | ||||
| 
 | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* FD_HOOK_H */ | ||||
							
								
								
									
										54
									
								
								third_party/make/lib/filename.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								third_party/make/lib/filename.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,54 @@ | |||
| /* Basic filename support macros.
 | ||||
|    Copyright (C) 2001-2004, 2007-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _FILENAME_H | ||||
| #define _FILENAME_H | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| /* Pathname support.
 | ||||
|    ISSLASH(C)           tests whether C is a directory separator character. | ||||
|    IS_ABSOLUTE_PATH(P)  tests whether P is an absolute path.  If it is not, | ||||
|                         it may be concatenated to a directory pathname. | ||||
|    IS_PATH_WITH_DIR(P)  tests whether P contains a directory specification. | ||||
|  */ | ||||
| #if defined _WIN32 || defined __CYGWIN__ || defined __EMX__ || defined __DJGPP__ | ||||
|   /* Native Windows, Cygwin, OS/2, DOS */ | ||||
| # define ISSLASH(C) ((C) == '/' || (C) == '\\') | ||||
| # define HAS_DEVICE(P) \ | ||||
|     ((((P)[0] >= 'A' && (P)[0] <= 'Z') || ((P)[0] >= 'a' && (P)[0] <= 'z')) \ | ||||
|      && (P)[1] == ':') | ||||
| # define IS_ABSOLUTE_PATH(P) (ISSLASH ((P)[0]) || HAS_DEVICE (P)) | ||||
| # define IS_PATH_WITH_DIR(P) \ | ||||
|     (strchr (P, '/') != NULL || strchr (P, '\\') != NULL || HAS_DEVICE (P)) | ||||
| # define FILE_SYSTEM_PREFIX_LEN(P) (HAS_DEVICE (P) ? 2 : 0) | ||||
| #else | ||||
|   /* Unix */ | ||||
| # define ISSLASH(C) ((C) == '/') | ||||
| # define IS_ABSOLUTE_PATH(P) ISSLASH ((P)[0]) | ||||
| # define IS_PATH_WITH_DIR(P) (strchr (P, '/') != NULL) | ||||
| # define FILE_SYSTEM_PREFIX_LEN(P) 0 | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* _FILENAME_H */ | ||||
							
								
								
									
										251
									
								
								third_party/make/lib/findprog-in.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										251
									
								
								third_party/make/lib/findprog-in.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,251 @@ | |||
| /* Locating a program in a given path.
 | ||||
|    Copyright (C) 2001-2004, 2006-2020 Free Software Foundation, Inc. | ||||
|    Written by Bruno Haible <haible@clisp.cons.org>, 2001, 2019. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include "findprog.h" | ||||
| 
 | ||||
| #include <errno.h> | ||||
| #include <stdbool.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include <unistd.h> | ||||
| 
 | ||||
| #include "filename.h" | ||||
| #include "concat-filename.h" | ||||
| #include "xalloc.h" | ||||
| 
 | ||||
| #if (defined _WIN32 && !defined __CYGWIN__) || defined __EMX__ || defined __DJGPP__ | ||||
|   /* Native Windows, OS/2, DOS */ | ||||
| # define NATIVE_SLASH '\\' | ||||
| #else | ||||
|   /* Unix */ | ||||
| # define NATIVE_SLASH '/' | ||||
| #endif | ||||
| 
 | ||||
| /* Separator in PATH like lists of pathnames.  */ | ||||
| #if (defined _WIN32 && !defined __CYGWIN__) || defined __EMX__ || defined __DJGPP__ | ||||
|   /* Native Windows, OS/2, DOS */ | ||||
| # define PATH_SEPARATOR ';' | ||||
| #else | ||||
|   /* Unix */ | ||||
| # define PATH_SEPARATOR ':' | ||||
| #endif | ||||
| 
 | ||||
| /* The list of suffixes that the execlp/execvp function tries when searching
 | ||||
|    for the program.  */ | ||||
| static const char * const suffixes[] = | ||||
|   { | ||||
|     #if defined _WIN32 && !defined __CYGWIN__ /* Native Windows */ | ||||
|     "", ".com", ".exe", ".bat", ".cmd" | ||||
|     /* Note: Files without any suffix are not considered executable.  */ | ||||
|     /* Note: The cmd.exe program does a different lookup: It searches according
 | ||||
|        to the PATHEXT environment variable. | ||||
|        See <https://stackoverflow.com/questions/7839150/>.
 | ||||
|        Also, it executes files ending .bat and .cmd directly without letting the | ||||
|        kernel interpret the program file.  */ | ||||
|     #elif defined __CYGWIN__ | ||||
|     "", ".exe", ".com" | ||||
|     #elif defined __EMX__ | ||||
|     "", ".exe" | ||||
|     #elif defined __DJGPP__ | ||||
|     "", ".com", ".exe", ".bat" | ||||
|     #else /* Unix */ | ||||
|     "" | ||||
|     #endif | ||||
|   }; | ||||
| 
 | ||||
| const char * | ||||
| find_in_given_path (const char *progname, const char *path, | ||||
|                     bool optimize_for_exec) | ||||
| { | ||||
|   { | ||||
|     bool has_slash = false; | ||||
|     { | ||||
|       const char *p; | ||||
| 
 | ||||
|       for (p = progname; *p != '\0'; p++) | ||||
|         if (ISSLASH (*p)) | ||||
|           { | ||||
|             has_slash = true; | ||||
|             break; | ||||
|           } | ||||
|     } | ||||
|     if (has_slash) | ||||
|       { | ||||
|         /* If progname contains a slash, it is either absolute or relative to
 | ||||
|            the current directory.  PATH is not used.  */ | ||||
|         if (optimize_for_exec) | ||||
|           /* The execl/execv/execlp/execvp functions will try the various
 | ||||
|              suffixes anyway and fail if no executable is found.  */ | ||||
|           return progname; | ||||
|         else | ||||
|           { | ||||
|             /* Try the various suffixes and see whether one of the files
 | ||||
|                with such a suffix is actually executable.  */ | ||||
|             int failure_errno; | ||||
|             size_t i; | ||||
|             #if defined _WIN32 && !defined __CYGWIN__ /* Native Windows */ | ||||
|             const char *progbasename; | ||||
| 
 | ||||
|             { | ||||
|               const char *p; | ||||
| 
 | ||||
|               progbasename = progname; | ||||
|               for (p = progname; *p != '\0'; p++) | ||||
|                 if (ISSLASH (*p)) | ||||
|                   progbasename = p + 1; | ||||
|             } | ||||
|             #endif | ||||
| 
 | ||||
|             /* Try all platform-dependent suffixes.  */ | ||||
|             failure_errno = ENOENT; | ||||
|             for (i = 0; i < sizeof (suffixes) / sizeof (suffixes[0]); i++) | ||||
|               { | ||||
|                 const char *suffix = suffixes[i]; | ||||
| 
 | ||||
|                 #if defined _WIN32 && !defined __CYGWIN__ /* Native Windows */ | ||||
|                 /* File names without a '.' are not considered executable, and
 | ||||
|                    for file names with a '.' no additional suffix is tried.  */ | ||||
|                 if ((*suffix != '\0') != (strchr (progbasename, '.') != NULL)) | ||||
|                 #endif | ||||
|                   { | ||||
|                     /* Concatenate progname and suffix.  */ | ||||
|                     char *progpathname = | ||||
|                       xconcatenated_filename ("", progname, suffix); | ||||
| 
 | ||||
|                     /* On systems which have the eaccess() system call, let's
 | ||||
|                        use it.  On other systems, let's hope that this program | ||||
|                        is not installed setuid or setgid, so that it is ok to | ||||
|                        call access() despite its design flaw.  */ | ||||
|                     if (eaccess (progpathname, X_OK) == 0) | ||||
|                       { | ||||
|                         /* Found!  */ | ||||
|                         if (strcmp (progpathname, progname) == 0) | ||||
|                           { | ||||
|                             free (progpathname); | ||||
|                             return progname; | ||||
|                           } | ||||
|                         else | ||||
|                           return progpathname; | ||||
|                       } | ||||
| 
 | ||||
|                     if (errno != ENOENT) | ||||
|                       failure_errno = errno; | ||||
| 
 | ||||
|                     free (progpathname); | ||||
|                   } | ||||
|               } | ||||
| 
 | ||||
|             errno = failure_errno; | ||||
|             return NULL; | ||||
|           } | ||||
|       } | ||||
|   } | ||||
| 
 | ||||
|   if (path == NULL) | ||||
|     /* If PATH is not set, the default search path is implementation dependent.
 | ||||
|        In practice, it is treated like an empty PATH.  */ | ||||
|     path = ""; | ||||
| 
 | ||||
|   { | ||||
|     int failure_errno; | ||||
|     /* Make a copy, to prepare for destructive modifications.  */ | ||||
|     char *path_copy = xstrdup (path); | ||||
|     char *path_rest; | ||||
|     char *cp; | ||||
| 
 | ||||
|     failure_errno = ENOENT; | ||||
|     for (path_rest = path_copy; ; path_rest = cp + 1) | ||||
|       { | ||||
|         const char *dir; | ||||
|         bool last; | ||||
|         size_t i; | ||||
| 
 | ||||
|         /* Extract next directory in PATH.  */ | ||||
|         dir = path_rest; | ||||
|         for (cp = path_rest; *cp != '\0' && *cp != PATH_SEPARATOR; cp++) | ||||
|           ; | ||||
|         last = (*cp == '\0'); | ||||
|         *cp = '\0'; | ||||
| 
 | ||||
|         /* Empty PATH components designate the current directory.  */ | ||||
|         if (dir == cp) | ||||
|           dir = "."; | ||||
| 
 | ||||
|         /* Try all platform-dependent suffixes.  */ | ||||
|         for (i = 0; i < sizeof (suffixes) / sizeof (suffixes[0]); i++) | ||||
|           { | ||||
|             const char *suffix = suffixes[i]; | ||||
| 
 | ||||
|             #if defined _WIN32 && !defined __CYGWIN__ /* Native Windows */ | ||||
|             /* File names without a '.' are not considered executable, and
 | ||||
|                for file names with a '.' no additional suffix is tried.  */ | ||||
|             if ((*suffix != '\0') != (strchr (progname, '.') != NULL)) | ||||
|             #endif | ||||
|               { | ||||
|                 /* Concatenate dir, progname, and suffix.  */ | ||||
|                 char *progpathname = | ||||
|                   xconcatenated_filename (dir, progname, suffix); | ||||
| 
 | ||||
|                 /* On systems which have the eaccess() system call, let's
 | ||||
|                    use it.  On other systems, let's hope that this program | ||||
|                    is not installed setuid or setgid, so that it is ok to | ||||
|                    call access() despite its design flaw.  */ | ||||
|                 if (eaccess (progpathname, X_OK) == 0) | ||||
|                   { | ||||
|                     /* Found!  */ | ||||
|                     if (strcmp (progpathname, progname) == 0) | ||||
|                       { | ||||
|                         free (progpathname); | ||||
| 
 | ||||
|                         /* Add the "./" prefix for real, that
 | ||||
|                            xconcatenated_filename() optimized away.  This | ||||
|                            avoids a second PATH search when the caller uses | ||||
|                            execl/execv/execlp/execvp.  */ | ||||
|                         progpathname = | ||||
|                           XNMALLOC (2 + strlen (progname) + 1, char); | ||||
|                         progpathname[0] = '.'; | ||||
|                         progpathname[1] = NATIVE_SLASH; | ||||
|                         memcpy (progpathname + 2, progname, | ||||
|                                 strlen (progname) + 1); | ||||
|                       } | ||||
| 
 | ||||
|                     free (path_copy); | ||||
|                     return progpathname; | ||||
|                   } | ||||
| 
 | ||||
|                 if (errno != ENOENT) | ||||
|                   failure_errno = errno; | ||||
| 
 | ||||
|                 free (progpathname); | ||||
|               } | ||||
|           } | ||||
| 
 | ||||
|         if (last) | ||||
|           break; | ||||
|       } | ||||
| 
 | ||||
|     /* Not found in PATH.  */ | ||||
|     free (path_copy); | ||||
| 
 | ||||
|     errno = failure_errno; | ||||
|     return NULL; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										71
									
								
								third_party/make/lib/findprog.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								third_party/make/lib/findprog.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,71 @@ | |||
| /* Locating a program in PATH.
 | ||||
|    Copyright (C) 2001-2003, 2009-2020 Free Software Foundation, Inc. | ||||
|    Written by Bruno Haible <haible@clisp.cons.org>, 2001. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _FINDPROG_H | ||||
| #define _FINDPROG_H | ||||
| 
 | ||||
| #include <stdbool.h> | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| /* Looks up a program in the PATH.
 | ||||
|    Attempts to determine the pathname that would be called by execlp/execvp | ||||
|    of PROGNAME.  If successful, it returns a pathname containing a slash | ||||
|    (either absolute or relative to the current directory).  Otherwise, it | ||||
|    returns PROGNAME unmodified. | ||||
|    Because of the latter case, callers should use execlp/execvp, not | ||||
|    execl/execv on the returned pathname. | ||||
|    The returned string is freshly malloc()ed if it is != PROGNAME.  */ | ||||
| extern const char *find_in_path (const char *progname); | ||||
| 
 | ||||
| /* Looks up a program in the given PATH-like string.
 | ||||
| 
 | ||||
|    The PATH argument consists of a list of directories, separated by ':' or | ||||
|    (on native Windows) by ';'.  An empty PATH element designates the current | ||||
|    directory.  A null PATH is equivalent to an empty PATH, that is, to the | ||||
|    singleton list that contains only the current directory. | ||||
| 
 | ||||
|    Determines the pathname that would be called by execlp/execvp of PROGNAME. | ||||
|    - If successful, it returns a pathname containing a slash (either absolute | ||||
|      or relative to the current directory).  The returned string can be used | ||||
|      with either execl/execv or execlp/execvp.  It is freshly malloc()ed if it | ||||
|      is != PROGNAME. | ||||
|    - Otherwise, it sets errno and returns NULL. | ||||
|      Specific errno values include: | ||||
|        - ENOENT: means that the program's file was not found. | ||||
|        - EACCES: means that the program's file cannot be accessed (due to some | ||||
|          issue with one of the ancestor directories) or lacks the execute | ||||
|          permissions. | ||||
|    If OPTIMIZE_FOR_EXEC is true, the function saves some work, under the | ||||
|    assumption that the resulting pathname will not be accessed directly, | ||||
|    only through execl/execv or execlp/execvp. | ||||
| 
 | ||||
|    Here, a "slash" means: | ||||
|      - On POSIX systems excluding Cygwin: a '/', | ||||
|      - On Windows, OS/2, DOS platforms: a '/' or '\'. */ | ||||
| extern const char *find_in_given_path (const char *progname, const char *path, | ||||
|                                        bool optimize_for_exec); | ||||
| 
 | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* _FINDPROG_H */ | ||||
							
								
								
									
										489
									
								
								third_party/make/lib/fnmatch.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										489
									
								
								third_party/make/lib/fnmatch.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,489 @@ | |||
| /* Copyright (C) 1991, 1992, 1993, 1996, 1997, 1998, 1999 Free Software
 | ||||
| Foundation, Inc. | ||||
| This file is part of the GNU C Library. | ||||
| 
 | ||||
| This library is free software; you can redistribute it and/or | ||||
| modify it under the terms of the GNU Library General Public License as | ||||
| published by the Free Software Foundation; either version 2 of the | ||||
| License, or (at your option) any later version. | ||||
| 
 | ||||
| This library is distributed in the hope that it will be useful, | ||||
| but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
| Library General Public License for more details. | ||||
| 
 | ||||
| You should have received a copy of the GNU Library General Public License | ||||
| along with this library; see the file COPYING.LIB.  If not, write to the Free | ||||
| Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 | ||||
| USA.  */ | ||||
| 
 | ||||
| #if HAVE_CONFIG_H | ||||
| # include <config.h> | ||||
| #endif | ||||
| 
 | ||||
| /* Enable GNU extensions in fnmatch.h.  */ | ||||
| #ifndef _GNU_SOURCE | ||||
| # define _GNU_SOURCE	1 | ||||
| #endif | ||||
| 
 | ||||
| #include <errno.h> | ||||
| #include <fnmatch.h> | ||||
| #include <ctype.h> | ||||
| 
 | ||||
| #if HAVE_STRING_H || defined _LIBC | ||||
| # include <string.h> | ||||
| #else | ||||
| # include <strings.h> | ||||
| #endif | ||||
| 
 | ||||
| #if defined STDC_HEADERS || defined _LIBC | ||||
| # include <stdlib.h> | ||||
| #endif | ||||
| 
 | ||||
| /* For platform which support the ISO C amendement 1 functionality we
 | ||||
|    support user defined character classes.  */ | ||||
| #if defined _LIBC || (defined HAVE_WCTYPE_H && defined HAVE_WCHAR_H) | ||||
| /* Solaris 2.5 has a bug: <wchar.h> must be included before <wctype.h>.  */ | ||||
| # include <wchar.h> | ||||
| # include <wctype.h> | ||||
| #endif | ||||
| 
 | ||||
| /* Comment out all this code if we are using the GNU C Library, and are not
 | ||||
|    actually compiling the library itself.  This code is part of the GNU C | ||||
|    Library, but also included in many other GNU distributions.  Compiling | ||||
|    and linking in this code is a waste when using the GNU C library | ||||
|    (especially if it is a shared library).  Rather than having every GNU | ||||
|    program understand `configure --with-gnu-libc' and omit the object files, | ||||
|    it is simpler to just do this in the source for each such file.  */ | ||||
| 
 | ||||
| #if defined _LIBC || !defined __GNU_LIBRARY__ | ||||
| 
 | ||||
| 
 | ||||
| # if defined STDC_HEADERS || !defined isascii | ||||
| #  define ISASCII(c) 1 | ||||
| # else | ||||
| #  define ISASCII(c) isascii(c) | ||||
| # endif | ||||
| 
 | ||||
| # ifdef isblank | ||||
| #  define ISBLANK(c) (ISASCII (c) && isblank (c)) | ||||
| # else | ||||
| #  define ISBLANK(c) ((c) == ' ' || (c) == '\t') | ||||
| # endif | ||||
| # ifdef isgraph | ||||
| #  define ISGRAPH(c) (ISASCII (c) && isgraph (c)) | ||||
| # else | ||||
| #  define ISGRAPH(c) (ISASCII (c) && isprint (c) && !isspace (c)) | ||||
| # endif | ||||
| 
 | ||||
| # define ISPRINT(c) (ISASCII (c) && isprint (c)) | ||||
| # define ISDIGIT(c) (ISASCII (c) && isdigit (c)) | ||||
| # define ISALNUM(c) (ISASCII (c) && isalnum (c)) | ||||
| # define ISALPHA(c) (ISASCII (c) && isalpha (c)) | ||||
| # define ISCNTRL(c) (ISASCII (c) && iscntrl (c)) | ||||
| # define ISLOWER(c) (ISASCII (c) && islower (c)) | ||||
| # define ISPUNCT(c) (ISASCII (c) && ispunct (c)) | ||||
| # define ISSPACE(c) (ISASCII (c) && isspace (c)) | ||||
| # define ISUPPER(c) (ISASCII (c) && isupper (c)) | ||||
| # define ISXDIGIT(c) (ISASCII (c) && isxdigit (c)) | ||||
| 
 | ||||
| # define STREQ(s1, s2) ((strcmp (s1, s2) == 0)) | ||||
| 
 | ||||
| # if defined _LIBC || (defined HAVE_WCTYPE_H && defined HAVE_WCHAR_H) | ||||
| /* The GNU C library provides support for user-defined character classes
 | ||||
|    and the functions from ISO C amendement 1.  */ | ||||
| #  ifdef CHARCLASS_NAME_MAX | ||||
| #   define CHAR_CLASS_MAX_LENGTH CHARCLASS_NAME_MAX | ||||
| #  else | ||||
| /* This shouldn't happen but some implementation might still have this
 | ||||
|    problem.  Use a reasonable default value.  */ | ||||
| #   define CHAR_CLASS_MAX_LENGTH 256 | ||||
| #  endif | ||||
| 
 | ||||
| #  ifdef _LIBC | ||||
| #   define IS_CHAR_CLASS(string) __wctype (string) | ||||
| #  else | ||||
| #   define IS_CHAR_CLASS(string) wctype (string) | ||||
| #  endif | ||||
| # else | ||||
| #  define CHAR_CLASS_MAX_LENGTH  6 /* Namely, `xdigit'.  */ | ||||
| 
 | ||||
| #  define IS_CHAR_CLASS(string)						      \ | ||||
|    (STREQ (string, "alpha") || STREQ (string, "upper")			      \ | ||||
|     || STREQ (string, "lower") || STREQ (string, "digit")		      \ | ||||
|     || STREQ (string, "alnum") || STREQ (string, "xdigit")		      \ | ||||
|     || STREQ (string, "space") || STREQ (string, "print")		      \ | ||||
|     || STREQ (string, "punct") || STREQ (string, "graph")		      \ | ||||
|     || STREQ (string, "cntrl") || STREQ (string, "blank")) | ||||
| # endif | ||||
| 
 | ||||
| /* Avoid depending on library functions or files
 | ||||
|    whose names are inconsistent.  */ | ||||
| 
 | ||||
| # if !defined _LIBC && !defined getenv | ||||
| extern char *getenv (); | ||||
| # endif | ||||
| 
 | ||||
| # ifndef errno | ||||
| extern int errno; | ||||
| # endif | ||||
| 
 | ||||
| /* This function doesn't exist on most systems.  */ | ||||
| 
 | ||||
| # if !defined HAVE___STRCHRNUL && !defined _LIBC | ||||
| static char * | ||||
| __strchrnul (s, c) | ||||
|      const char *s; | ||||
|      int c; | ||||
| { | ||||
|   char *result = strchr (s, c); | ||||
|   if (result == NULL) | ||||
|     result = strchr (s, '\0'); | ||||
|   return result; | ||||
| } | ||||
| # endif | ||||
| 
 | ||||
| # ifndef internal_function | ||||
| /* Inside GNU libc we mark some function in a special way.  In other
 | ||||
|    environments simply ignore the marking.  */ | ||||
| #  define internal_function | ||||
| # endif | ||||
| 
 | ||||
| /* Match STRING against the filename pattern PATTERN, returning zero if
 | ||||
|    it matches, nonzero if not.  */ | ||||
| static int internal_fnmatch __P ((const char *pattern, const char *string, | ||||
| 				  int no_leading_period, int flags)) | ||||
|      internal_function; | ||||
| static int | ||||
| internal_function | ||||
| internal_fnmatch (pattern, string, no_leading_period, flags) | ||||
|      const char *pattern; | ||||
|      const char *string; | ||||
|      int no_leading_period; | ||||
|      int flags; | ||||
| { | ||||
|   register const char *p = pattern, *n = string; | ||||
|   register unsigned char c; | ||||
| 
 | ||||
| /* Note that this evaluates C many times.  */ | ||||
| # ifdef _LIBC | ||||
| #  define FOLD(c) ((flags & FNM_CASEFOLD) ? tolower (c) : (c)) | ||||
| # else | ||||
| #  define FOLD(c) ((flags & FNM_CASEFOLD) && ISUPPER (c) ? tolower (c) : (c)) | ||||
| # endif | ||||
| 
 | ||||
|   while ((c = *p++) != '\0') | ||||
|     { | ||||
|       c = FOLD (c); | ||||
| 
 | ||||
|       switch (c) | ||||
| 	{ | ||||
| 	case '?': | ||||
| 	  if (*n == '\0') | ||||
| 	    return FNM_NOMATCH; | ||||
| 	  else if (*n == '/' && (flags & FNM_FILE_NAME)) | ||||
| 	    return FNM_NOMATCH; | ||||
| 	  else if (*n == '.' && no_leading_period | ||||
| 		   && (n == string | ||||
| 		       || (n[-1] == '/' && (flags & FNM_FILE_NAME)))) | ||||
| 	    return FNM_NOMATCH; | ||||
| 	  break; | ||||
| 
 | ||||
| 	case '\\': | ||||
| 	  if (!(flags & FNM_NOESCAPE)) | ||||
| 	    { | ||||
| 	      c = *p++; | ||||
| 	      if (c == '\0') | ||||
| 		/* Trailing \ loses.  */ | ||||
| 		return FNM_NOMATCH; | ||||
| 	      c = FOLD (c); | ||||
| 	    } | ||||
| 	  if (FOLD ((unsigned char) *n) != c) | ||||
| 	    return FNM_NOMATCH; | ||||
| 	  break; | ||||
| 
 | ||||
| 	case '*': | ||||
| 	  if (*n == '.' && no_leading_period | ||||
| 	      && (n == string | ||||
| 		  || (n[-1] == '/' && (flags & FNM_FILE_NAME)))) | ||||
| 	    return FNM_NOMATCH; | ||||
| 
 | ||||
| 	  for (c = *p++; c == '?' || c == '*'; c = *p++) | ||||
| 	    { | ||||
| 	      if (*n == '/' && (flags & FNM_FILE_NAME)) | ||||
| 		/* A slash does not match a wildcard under FNM_FILE_NAME.  */ | ||||
| 		return FNM_NOMATCH; | ||||
| 	      else if (c == '?') | ||||
| 		{ | ||||
| 		  /* A ? needs to match one character.  */ | ||||
| 		  if (*n == '\0') | ||||
| 		    /* There isn't another character; no match.  */ | ||||
| 		    return FNM_NOMATCH; | ||||
| 		  else | ||||
| 		    /* One character of the string is consumed in matching
 | ||||
| 		       this ? wildcard, so *??? won't match if there are | ||||
| 		       less than three characters.  */ | ||||
| 		    ++n; | ||||
| 		} | ||||
| 	    } | ||||
| 
 | ||||
| 	  if (c == '\0') | ||||
| 	    /* The wildcard(s) is/are the last element of the pattern.
 | ||||
| 	       If the name is a file name and contains another slash | ||||
| 	       this does mean it cannot match.  */ | ||||
| 	    return ((flags & FNM_FILE_NAME) && strchr (n, '/') != NULL | ||||
| 		    ? FNM_NOMATCH : 0); | ||||
| 	  else | ||||
| 	    { | ||||
| 	      const char *endp; | ||||
| 
 | ||||
| 	      endp = __strchrnul (n, (flags & FNM_FILE_NAME) ? '/' : '\0'); | ||||
| 
 | ||||
| 	      if (c == '[') | ||||
| 		{ | ||||
| 		  int flags2 = ((flags & FNM_FILE_NAME) | ||||
| 				? flags : (flags & ~FNM_PERIOD)); | ||||
| 
 | ||||
| 		  for (--p; n < endp; ++n) | ||||
| 		    if (internal_fnmatch (p, n, | ||||
| 					  (no_leading_period | ||||
| 					   && (n == string | ||||
| 					       || (n[-1] == '/' | ||||
| 						   && (flags | ||||
| 						       & FNM_FILE_NAME)))), | ||||
| 					  flags2) | ||||
| 			== 0) | ||||
| 		      return 0; | ||||
| 		} | ||||
| 	      else if (c == '/' && (flags & FNM_FILE_NAME)) | ||||
| 		{ | ||||
| 		  while (*n != '\0' && *n != '/') | ||||
| 		    ++n; | ||||
| 		  if (*n == '/' | ||||
| 		      && (internal_fnmatch (p, n + 1, flags & FNM_PERIOD, | ||||
| 					    flags) == 0)) | ||||
| 		    return 0; | ||||
| 		} | ||||
| 	      else | ||||
| 		{ | ||||
| 		  int flags2 = ((flags & FNM_FILE_NAME) | ||||
| 				? flags : (flags & ~FNM_PERIOD)); | ||||
| 
 | ||||
| 		  if (c == '\\' && !(flags & FNM_NOESCAPE)) | ||||
| 		    c = *p; | ||||
| 		  c = FOLD (c); | ||||
| 		  for (--p; n < endp; ++n) | ||||
| 		    if (FOLD ((unsigned char) *n) == c | ||||
| 			&& (internal_fnmatch (p, n, | ||||
| 					      (no_leading_period | ||||
| 					       && (n == string | ||||
| 						   || (n[-1] == '/' | ||||
| 						       && (flags | ||||
| 							   & FNM_FILE_NAME)))), | ||||
| 					      flags2) == 0)) | ||||
| 		      return 0; | ||||
| 		} | ||||
| 	    } | ||||
| 
 | ||||
| 	  /* If we come here no match is possible with the wildcard.  */ | ||||
| 	  return FNM_NOMATCH; | ||||
| 
 | ||||
| 	case '[': | ||||
| 	  { | ||||
| 	    /* Nonzero if the sense of the character class is inverted.  */ | ||||
| 	    static int posixly_correct; | ||||
| 	    register int not; | ||||
| 	    char cold; | ||||
| 
 | ||||
| 	    if (posixly_correct == 0) | ||||
| 	      posixly_correct = getenv ("POSIXLY_CORRECT") != NULL ? 1 : -1; | ||||
| 
 | ||||
| 	    if (*n == '\0') | ||||
| 	      return FNM_NOMATCH; | ||||
| 
 | ||||
| 	    if (*n == '.' && no_leading_period && (n == string | ||||
| 						   || (n[-1] == '/' | ||||
| 						       && (flags | ||||
| 							   & FNM_FILE_NAME)))) | ||||
| 	      return FNM_NOMATCH; | ||||
| 
 | ||||
| 	    if (*n == '/' && (flags & FNM_FILE_NAME)) | ||||
| 	      /* `/' cannot be matched.  */ | ||||
| 	      return FNM_NOMATCH; | ||||
| 
 | ||||
| 	    not = (*p == '!' || (posixly_correct < 0 && *p == '^')); | ||||
| 	    if (not) | ||||
| 	      ++p; | ||||
| 
 | ||||
| 	    c = *p++; | ||||
| 	    for (;;) | ||||
| 	      { | ||||
| 		unsigned char fn = FOLD ((unsigned char) *n); | ||||
| 
 | ||||
| 		if (!(flags & FNM_NOESCAPE) && c == '\\') | ||||
| 		  { | ||||
| 		    if (*p == '\0') | ||||
| 		      return FNM_NOMATCH; | ||||
| 		    c = FOLD ((unsigned char) *p); | ||||
| 		    ++p; | ||||
| 
 | ||||
| 		    if (c == fn) | ||||
| 		      goto matched; | ||||
| 		  } | ||||
| 		else if (c == '[' && *p == ':') | ||||
| 		  { | ||||
| 		    /* Leave room for the null.  */ | ||||
| 		    char str[CHAR_CLASS_MAX_LENGTH + 1]; | ||||
| 		    size_t c1 = 0; | ||||
| # if defined _LIBC || (defined HAVE_WCTYPE_H && defined HAVE_WCHAR_H) | ||||
| 		    wctype_t wt; | ||||
| # endif | ||||
| 		    const char *startp = p; | ||||
| 
 | ||||
| 		    for (;;) | ||||
| 		      { | ||||
| 			if (c1 == CHAR_CLASS_MAX_LENGTH) | ||||
| 			  /* The name is too long and therefore the pattern
 | ||||
| 			     is ill-formed.  */ | ||||
| 			  return FNM_NOMATCH; | ||||
| 
 | ||||
| 			c = *++p; | ||||
| 			if (c == ':' && p[1] == ']') | ||||
| 			  { | ||||
| 			    p += 2; | ||||
| 			    break; | ||||
| 			  } | ||||
| 			if (c < 'a' || c >= 'z') | ||||
| 			  { | ||||
| 			    /* This cannot possibly be a character class name.
 | ||||
| 			       Match it as a normal range.  */ | ||||
| 			    p = startp; | ||||
| 			    c = '['; | ||||
| 			    goto normal_bracket; | ||||
| 			  } | ||||
| 			str[c1++] = c; | ||||
| 		      } | ||||
| 		    str[c1] = '\0'; | ||||
| 
 | ||||
| # if defined _LIBC || (defined HAVE_WCTYPE_H && defined HAVE_WCHAR_H) | ||||
| 		    wt = IS_CHAR_CLASS (str); | ||||
| 		    if (wt == 0) | ||||
| 		      /* Invalid character class name.  */ | ||||
| 		      return FNM_NOMATCH; | ||||
| 
 | ||||
| 		    if (__iswctype (__btowc ((unsigned char) *n), wt)) | ||||
| 		      goto matched; | ||||
| # else | ||||
| 		    if ((STREQ (str, "alnum") && ISALNUM ((unsigned char) *n)) | ||||
| 			|| (STREQ (str, "alpha") && ISALPHA ((unsigned char) *n)) | ||||
| 			|| (STREQ (str, "blank") && ISBLANK ((unsigned char) *n)) | ||||
| 			|| (STREQ (str, "cntrl") && ISCNTRL ((unsigned char) *n)) | ||||
| 			|| (STREQ (str, "digit") && ISDIGIT ((unsigned char) *n)) | ||||
| 			|| (STREQ (str, "graph") && ISGRAPH ((unsigned char) *n)) | ||||
| 			|| (STREQ (str, "lower") && ISLOWER ((unsigned char) *n)) | ||||
| 			|| (STREQ (str, "print") && ISPRINT ((unsigned char) *n)) | ||||
| 			|| (STREQ (str, "punct") && ISPUNCT ((unsigned char) *n)) | ||||
| 			|| (STREQ (str, "space") && ISSPACE ((unsigned char) *n)) | ||||
| 			|| (STREQ (str, "upper") && ISUPPER ((unsigned char) *n)) | ||||
| 			|| (STREQ (str, "xdigit") && ISXDIGIT ((unsigned char) *n))) | ||||
| 		      goto matched; | ||||
| # endif | ||||
| 		  } | ||||
| 		else if (c == '\0') | ||||
| 		  /* [ (unterminated) loses.  */ | ||||
| 		  return FNM_NOMATCH; | ||||
| 		else | ||||
| 		  { | ||||
| 		  normal_bracket: | ||||
| 		    if (FOLD (c) == fn) | ||||
| 		      goto matched; | ||||
| 
 | ||||
| 		    cold = c; | ||||
| 		    c = *p++; | ||||
| 
 | ||||
| 		    if (c == '-' && *p != ']') | ||||
| 		      { | ||||
| 			/* It is a range.  */ | ||||
| 			unsigned char cend = *p++; | ||||
| 			if (!(flags & FNM_NOESCAPE) && cend == '\\') | ||||
| 			  cend = *p++; | ||||
| 			if (cend == '\0') | ||||
| 			  return FNM_NOMATCH; | ||||
| 
 | ||||
| 			if (cold <= fn && fn <= FOLD (cend)) | ||||
| 			  goto matched; | ||||
| 
 | ||||
| 			c = *p++; | ||||
| 		      } | ||||
| 		  } | ||||
| 
 | ||||
| 		if (c == ']') | ||||
| 		  break; | ||||
| 	      } | ||||
| 
 | ||||
| 	    if (!not) | ||||
| 	      return FNM_NOMATCH; | ||||
| 	    break; | ||||
| 
 | ||||
| 	  matched: | ||||
| 	    /* Skip the rest of the [...] that already matched.  */ | ||||
| 	    while (c != ']') | ||||
| 	      { | ||||
| 		if (c == '\0') | ||||
| 		  /* [... (unterminated) loses.  */ | ||||
| 		  return FNM_NOMATCH; | ||||
| 
 | ||||
| 		c = *p++; | ||||
| 		if (!(flags & FNM_NOESCAPE) && c == '\\') | ||||
| 		  { | ||||
| 		    if (*p == '\0') | ||||
| 		      return FNM_NOMATCH; | ||||
| 		    /* XXX 1003.2d11 is unclear if this is right.  */ | ||||
| 		    ++p; | ||||
| 		  } | ||||
| 		else if (c == '[' && *p == ':') | ||||
| 		  { | ||||
| 		    do | ||||
| 		      if (*++p == '\0') | ||||
| 			return FNM_NOMATCH; | ||||
| 		    while (*p != ':' || p[1] == ']'); | ||||
| 		    p += 2; | ||||
| 		    c = *p; | ||||
| 		  } | ||||
| 	      } | ||||
| 	    if (not) | ||||
| 	      return FNM_NOMATCH; | ||||
| 	  } | ||||
| 	  break; | ||||
| 
 | ||||
| 	default: | ||||
| 	  if (c != FOLD ((unsigned char) *n)) | ||||
| 	    return FNM_NOMATCH; | ||||
| 	} | ||||
| 
 | ||||
|       ++n; | ||||
|     } | ||||
| 
 | ||||
|   if (*n == '\0') | ||||
|     return 0; | ||||
| 
 | ||||
|   if ((flags & FNM_LEADING_DIR) && *n == '/') | ||||
|     /* The FNM_LEADING_DIR flag says that "foo*" matches "foobar/frobozz".  */ | ||||
|     return 0; | ||||
| 
 | ||||
|   return FNM_NOMATCH; | ||||
| 
 | ||||
| # undef FOLD | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| int | ||||
| fnmatch (pattern, string, flags) | ||||
|      const char *pattern; | ||||
|      const char *string; | ||||
|      int flags; | ||||
| { | ||||
|   return internal_fnmatch (pattern, string, flags & FNM_PERIOD, flags); | ||||
| } | ||||
| 
 | ||||
| #endif	/* _LIBC or not __GNU_LIBRARY__.  */ | ||||
							
								
								
									
										85
									
								
								third_party/make/lib/fnmatch.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										85
									
								
								third_party/make/lib/fnmatch.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,85 @@ | |||
| /* Copyright (C) 1991, 1992, 1993, 1996, 1997, 1998, 1999 Free Software
 | ||||
| Foundation, Inc. | ||||
| This file is part of the GNU C Library. | ||||
| 
 | ||||
| The GNU C Library is free software; you can redistribute it and/or | ||||
| modify it under the terms of the GNU Library General Public License as | ||||
| published by the Free Software Foundation; either version 2 of the | ||||
| License, or (at your option) any later version. | ||||
| 
 | ||||
| The GNU C Library is distributed in the hope that it will be useful, | ||||
| but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
| Library General Public License for more details. | ||||
| 
 | ||||
| You should have received a copy of the GNU Library General Public License | ||||
| along with this library; see the file COPYING.LIB.  If not, write to the Free | ||||
| Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 | ||||
| USA.  */ | ||||
| 
 | ||||
| #ifndef	_FNMATCH_H | ||||
| #define	_FNMATCH_H	1 | ||||
| 
 | ||||
| #ifdef	__cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| #if defined __cplusplus || (defined __STDC__ && __STDC__) || defined WINDOWS32 | ||||
| # if !defined __GLIBC__ | ||||
| #  undef	__P | ||||
| #  define __P(protos)	protos | ||||
| # endif | ||||
| #else /* Not C++ or ANSI C.  */ | ||||
| # undef	__P | ||||
| # define __P(protos)	() | ||||
| /* We can get away without defining `const' here only because in this file
 | ||||
|    it is used only inside the prototype for `fnmatch', which is elided in | ||||
|    non-ANSI C where `const' is problematical.  */ | ||||
| #endif /* C++ or ANSI C.  */ | ||||
| 
 | ||||
| #ifndef const | ||||
| # if (defined __STDC__ && __STDC__) || defined __cplusplus || defined WINDOWS32 | ||||
| #  define __const	const | ||||
| # else | ||||
| #  define __const | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| /* We #undef these before defining them because some losing systems
 | ||||
|    (HP-UX A.08.07 for example) define these in <unistd.h>.  */ | ||||
| #undef	FNM_PATHNAME | ||||
| #undef	FNM_NOESCAPE | ||||
| #undef	FNM_PERIOD | ||||
| 
 | ||||
| /* Bits set in the FLAGS argument to `fnmatch'.  */ | ||||
| #define	FNM_PATHNAME	(1 << 0) /* No wildcard can ever match `/'.  */ | ||||
| #define	FNM_NOESCAPE	(1 << 1) /* Backslashes don't quote special chars.  */ | ||||
| #define	FNM_PERIOD	(1 << 2) /* Leading `.' is matched only explicitly.  */ | ||||
| 
 | ||||
| #if !defined _POSIX_C_SOURCE || _POSIX_C_SOURCE < 2 || defined _GNU_SOURCE | ||||
| # define FNM_FILE_NAME	 FNM_PATHNAME	/* Preferred GNU name.  */ | ||||
| # define FNM_LEADING_DIR (1 << 3)	/* Ignore `/...' after a match.  */ | ||||
| # define FNM_CASEFOLD	 (1 << 4)	/* Compare without regard to case.  */ | ||||
| #endif | ||||
| 
 | ||||
| /* Value returned by `fnmatch' if STRING does not match PATTERN.  */ | ||||
| #define	FNM_NOMATCH	1 | ||||
| 
 | ||||
| /* This value is returned if the implementation does not support
 | ||||
|    `fnmatch'.  Since this is not the case here it will never be | ||||
|    returned but the conformance test suites still require the symbol | ||||
|    to be defined.  */ | ||||
| #ifdef _XOPEN_SOURCE | ||||
| # define FNM_NOSYS	(-1) | ||||
| #endif | ||||
| 
 | ||||
| /* Match NAME against the filename pattern PATTERN,
 | ||||
|    returning zero if it matches, FNM_NOMATCH if not.  */ | ||||
| extern int fnmatch __P ((__const char *__pattern, __const char *__name, | ||||
| 			 int __flags)); | ||||
| 
 | ||||
| #ifdef	__cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* fnmatch.h */ | ||||
							
								
								
									
										124
									
								
								third_party/make/lib/getdtablesize.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								third_party/make/lib/getdtablesize.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,124 @@ | |||
| /* getdtablesize() function: Return maximum possible file descriptor value + 1.
 | ||||
|    Copyright (C) 2008-2020 Free Software Foundation, Inc. | ||||
|    Written by Bruno Haible <bruno@clisp.org>, 2008. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include <unistd.h> | ||||
| 
 | ||||
| #if defined _WIN32 && ! defined __CYGWIN__ | ||||
| 
 | ||||
| # include <stdio.h> | ||||
| 
 | ||||
| # if HAVE_MSVC_INVALID_PARAMETER_HANDLER | ||||
| #  include "msvc-inval.h" | ||||
| # endif | ||||
| 
 | ||||
| # if HAVE_MSVC_INVALID_PARAMETER_HANDLER | ||||
| static int | ||||
| _setmaxstdio_nothrow (int newmax) | ||||
| { | ||||
|   int result; | ||||
| 
 | ||||
|   TRY_MSVC_INVAL | ||||
|     { | ||||
|       result = _setmaxstdio (newmax); | ||||
|     } | ||||
|   CATCH_MSVC_INVAL | ||||
|     { | ||||
|       result = -1; | ||||
|     } | ||||
|   DONE_MSVC_INVAL; | ||||
| 
 | ||||
|   return result; | ||||
| } | ||||
| # else | ||||
| #  define _setmaxstdio_nothrow _setmaxstdio | ||||
| # endif | ||||
| 
 | ||||
| /* Cache for the previous getdtablesize () result.  Safe to cache because
 | ||||
|    Windows also lacks setrlimit.  */ | ||||
| static int dtablesize; | ||||
| 
 | ||||
| int | ||||
| getdtablesize (void) | ||||
| { | ||||
|   if (dtablesize == 0) | ||||
|     { | ||||
|       /* We are looking for the number N such that the valid file descriptors
 | ||||
|          are 0..N-1.  It can be obtained through a loop as follows: | ||||
|            { | ||||
|              int fd; | ||||
|              for (fd = 3; fd < 65536; fd++) | ||||
|                if (dup2 (0, fd) == -1) | ||||
|                  break; | ||||
|              return fd; | ||||
|            } | ||||
|          On Windows XP, the result is 2048. | ||||
|          The drawback of this loop is that it allocates memory for a libc | ||||
|          internal array that is never freed. | ||||
| 
 | ||||
|          The number N can also be obtained as the upper bound for | ||||
|          _getmaxstdio ().  _getmaxstdio () returns the maximum number of open | ||||
|          FILE objects.  The sanity check in _setmaxstdio reveals the maximum | ||||
|          number of file descriptors.  This too allocates memory, but it is | ||||
|          freed when we call _setmaxstdio with the original value.  */ | ||||
|       int orig_max_stdio = _getmaxstdio (); | ||||
|       unsigned int bound; | ||||
|       for (bound = 0x10000; _setmaxstdio_nothrow (bound) < 0; bound = bound / 2) | ||||
|         ; | ||||
|       _setmaxstdio_nothrow (orig_max_stdio); | ||||
|       dtablesize = bound; | ||||
|     } | ||||
|   return dtablesize; | ||||
| } | ||||
| 
 | ||||
| #else | ||||
| 
 | ||||
| # include <limits.h> | ||||
| # include <sys/resource.h> | ||||
| 
 | ||||
| # ifndef RLIM_SAVED_CUR | ||||
| #  define RLIM_SAVED_CUR RLIM_INFINITY | ||||
| # endif | ||||
| # ifndef RLIM_SAVED_MAX | ||||
| #  define RLIM_SAVED_MAX RLIM_INFINITY | ||||
| # endif | ||||
| 
 | ||||
| # ifdef __CYGWIN__ | ||||
|   /* Cygwin 1.7.25 auto-increases the RLIMIT_NOFILE soft limit until it
 | ||||
|      hits the compile-time constant hard limit of 3200.  We might as | ||||
|      well just report the hard limit.  */ | ||||
| #  define rlim_cur rlim_max | ||||
| # endif | ||||
| 
 | ||||
| int | ||||
| getdtablesize (void) | ||||
| { | ||||
|   struct rlimit lim; | ||||
| 
 | ||||
|   if (getrlimit (RLIMIT_NOFILE, &lim) == 0 | ||||
|       && 0 <= lim.rlim_cur && lim.rlim_cur <= INT_MAX | ||||
|       && lim.rlim_cur != RLIM_INFINITY | ||||
|       && lim.rlim_cur != RLIM_SAVED_CUR | ||||
|       && lim.rlim_cur != RLIM_SAVED_MAX) | ||||
|     return lim.rlim_cur; | ||||
| 
 | ||||
|   return INT_MAX; | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
							
								
								
									
										953
									
								
								third_party/make/lib/getloadavg.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										953
									
								
								third_party/make/lib/getloadavg.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,953 @@ | |||
| /* Get the system load averages.
 | ||||
| 
 | ||||
|    Copyright (C) 1985-1989, 1991-1995, 1997, 1999-2000, 2003-2020 Free Software | ||||
|    Foundation, Inc. | ||||
| 
 | ||||
|    NOTE: The canonical source of this file is maintained with gnulib. | ||||
|    Bugs can be reported to bug-gnulib@gnu.org. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| /* Compile-time symbols that this file uses:
 | ||||
| 
 | ||||
|    HAVE_PSTAT_GETDYNAMIC        Define this if your system has the | ||||
|                                 pstat_getdynamic function.  I think it | ||||
|                                 is unique to HPUX9.  The best way to get the | ||||
|                                 definition is through the AC_FUNC_GETLOADAVG | ||||
|                                 macro that comes with autoconf 2.13 or newer. | ||||
|                                 If that isn't an option, then just put | ||||
|                                 AC_CHECK_FUNCS(pstat_getdynamic) in your | ||||
|                                 configure.ac file. | ||||
|    HAVE_LIBPERFSTAT Define this if your system has the | ||||
|                                 perfstat_cpu_total function in libperfstat (AIX). | ||||
|    FIXUP_KERNEL_SYMBOL_ADDR()   Adjust address in returned struct nlist. | ||||
|    KERNEL_FILE                  Name of the kernel file to nlist. | ||||
|    LDAV_CVT()                   Scale the load average from the kernel. | ||||
|                                 Returns a double. | ||||
|    LDAV_SYMBOL                  Name of kernel symbol giving load average. | ||||
|    LOAD_AVE_TYPE                Type of the load average array in the kernel. | ||||
|                                 Must be defined unless one of | ||||
|                                 apollo, DGUX, NeXT, or UMAX is defined; | ||||
|                                 or we have libkstat; | ||||
|                                 otherwise, no load average is available. | ||||
|    HAVE_NLIST_H                 nlist.h is available.  NLIST_STRUCT defaults | ||||
|                                 to this. | ||||
|    NLIST_STRUCT                 Include nlist.h, not a.out.h. | ||||
|    N_NAME_POINTER               The nlist n_name element is a pointer, | ||||
|                                 not an array. | ||||
|    HAVE_STRUCT_NLIST_N_UN_N_NAME 'n_un.n_name' is member of 'struct nlist'. | ||||
|    LINUX_LDAV_FILE              [__linux__, __ANDROID__, __CYGWIN__]: File | ||||
|                                 containing load averages. | ||||
| 
 | ||||
|    Specific system predefines this file uses, aside from setting | ||||
|    default values if not emacs: | ||||
| 
 | ||||
|    apollo | ||||
|    BSD                          Real BSD, not just BSD-like. | ||||
|    DGUX | ||||
|    eunice                       UNIX emulator under VMS. | ||||
|    hpux | ||||
|    __MSDOS__                    No-op for MSDOS. | ||||
|    NeXT | ||||
|    sgi | ||||
|    UMAX | ||||
|    UMAX4_3 | ||||
|    VMS | ||||
|    _WIN32                       Native Windows (possibly also defined on Cygwin) | ||||
|    __linux__, __ANDROID__       Linux: assumes /proc file system mounted. | ||||
|                                 Support from Michael K. Johnson. | ||||
|    __CYGWIN__                   Cygwin emulates linux /proc/loadavg. | ||||
|    __NetBSD__                   NetBSD: assumes /kern file system mounted. | ||||
| 
 | ||||
|    In addition, to avoid nesting many #ifdefs, we internally set | ||||
|    LDAV_DONE to indicate that the load average has been computed. | ||||
| 
 | ||||
|    We also #define LDAV_PRIVILEGED if a program will require | ||||
|    special installation to be able to call getloadavg.  */ | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| #include <errno.h> | ||||
| #include <stdbool.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| # include <sys/types.h> | ||||
| 
 | ||||
| # if HAVE_SYS_PARAM_H | ||||
| #  include <sys/param.h> | ||||
| # endif | ||||
| 
 | ||||
| # include "intprops.h" | ||||
| 
 | ||||
| # if defined _WIN32 && ! defined __CYGWIN__ && ! defined WINDOWS32 | ||||
| #  define WINDOWS32 | ||||
| # endif | ||||
| 
 | ||||
| # ifdef NeXT | ||||
| /* NeXT in the 2.{0,1,2} releases defines BSD in <sys/param.h>, which
 | ||||
|    conflicts with the definition understood in this file, that this | ||||
|    really is BSD. */ | ||||
| #  undef BSD | ||||
| 
 | ||||
| /* NeXT defines FSCALE in <sys/param.h>.  However, we take FSCALE being
 | ||||
|    defined to mean that the nlist method should be used, which is not true.  */ | ||||
| #  undef FSCALE | ||||
| # endif | ||||
| 
 | ||||
| /* Same issues as for NeXT apply to the HURD-based GNU system.  */ | ||||
| # ifdef __GNU__ | ||||
| #  undef BSD | ||||
| #  undef FSCALE | ||||
| # endif /* __GNU__ */ | ||||
| 
 | ||||
| /* Set values that are different from the defaults, which are
 | ||||
|    set a little farther down with #ifndef.  */ | ||||
| 
 | ||||
| 
 | ||||
| /* Some shorthands.  */ | ||||
| 
 | ||||
| # if defined (HPUX) && !defined (hpux) | ||||
| #  define hpux | ||||
| # endif | ||||
| 
 | ||||
| # if defined (__hpux) && !defined (hpux) | ||||
| #  define hpux | ||||
| # endif | ||||
| 
 | ||||
| # if defined (__sun) && !defined (sun) | ||||
| #  define sun | ||||
| # endif | ||||
| 
 | ||||
| # if defined (hp300) && !defined (hpux) | ||||
| #  define MORE_BSD | ||||
| # endif | ||||
| 
 | ||||
| # if defined (__SVR4) && !defined (SVR4) | ||||
| #  define SVR4 | ||||
| # endif | ||||
| 
 | ||||
| # if (defined (sun) && defined (SVR4)) || defined (SOLARIS2) | ||||
| #  define SUNOS_5 | ||||
| # endif | ||||
| 
 | ||||
| # if defined (__osf__) && (defined (__alpha) || defined (__alpha__)) | ||||
| #  define OSF_ALPHA | ||||
| #  include <sys/mbuf.h> | ||||
| #  include <sys/socket.h> | ||||
| #  include <net/route.h> | ||||
| #  include <sys/table.h> | ||||
| /* Tru64 4.0D's table.h redefines sys */ | ||||
| #  undef sys | ||||
| # endif | ||||
| 
 | ||||
| # if defined (__osf__) && (defined (mips) || defined (__mips__)) | ||||
| #  define OSF_MIPS | ||||
| #  include <sys/table.h> | ||||
| # endif | ||||
| 
 | ||||
| 
 | ||||
| /* VAX C can't handle multi-line #ifs, or lines longer than 256 chars.  */ | ||||
| # ifndef LOAD_AVE_TYPE | ||||
| 
 | ||||
| #  ifdef MORE_BSD | ||||
| #   define LOAD_AVE_TYPE long | ||||
| #  endif | ||||
| 
 | ||||
| #  ifdef sun | ||||
| #   define LOAD_AVE_TYPE long | ||||
| #  endif | ||||
| 
 | ||||
| #  ifdef sgi | ||||
| #   define LOAD_AVE_TYPE long | ||||
| #  endif | ||||
| 
 | ||||
| #  ifdef SVR4 | ||||
| #   define LOAD_AVE_TYPE long | ||||
| #  endif | ||||
| 
 | ||||
| #  ifdef OSF_ALPHA | ||||
| #   define LOAD_AVE_TYPE long | ||||
| #  endif | ||||
| 
 | ||||
| #  if defined _AIX && ! defined HAVE_LIBPERFSTAT | ||||
| #   define LOAD_AVE_TYPE long | ||||
| #  endif | ||||
| 
 | ||||
| # endif /* No LOAD_AVE_TYPE.  */ | ||||
| 
 | ||||
| # ifdef OSF_ALPHA | ||||
| /* <sys/param.h> defines an incorrect value for FSCALE on Alpha OSF/1,
 | ||||
|    according to ghazi@noc.rutgers.edu.  */ | ||||
| #  undef FSCALE | ||||
| #  define FSCALE 1024.0 | ||||
| # endif | ||||
| 
 | ||||
| 
 | ||||
| # ifndef FSCALE | ||||
| 
 | ||||
| /* SunOS and some others define FSCALE in sys/param.h.  */ | ||||
| 
 | ||||
| #  ifdef MORE_BSD | ||||
| #   define FSCALE 2048.0 | ||||
| #  endif | ||||
| 
 | ||||
| #  if defined (MIPS) || defined (SVR4) | ||||
| #   define FSCALE 256 | ||||
| #  endif | ||||
| 
 | ||||
| #  if defined (sgi) | ||||
| /* Sometimes both MIPS and sgi are defined, so FSCALE was just defined
 | ||||
|    above under #ifdef MIPS.  But we want the sgi value.  */ | ||||
| #   undef FSCALE | ||||
| #   define FSCALE 1000.0 | ||||
| #  endif | ||||
| 
 | ||||
| #  if defined _AIX && !defined HAVE_LIBPERFSTAT | ||||
| #   define FSCALE 65536.0 | ||||
| #  endif | ||||
| 
 | ||||
| # endif /* Not FSCALE.  */ | ||||
| 
 | ||||
| # if !defined (LDAV_CVT) && defined (FSCALE) | ||||
| #  define LDAV_CVT(n) (((double) (n)) / FSCALE) | ||||
| # endif | ||||
| 
 | ||||
| # ifndef NLIST_STRUCT | ||||
| #  if HAVE_NLIST_H | ||||
| #   define NLIST_STRUCT | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
| # if defined (sgi) || (defined (mips) && !defined (BSD)) | ||||
| #  define FIXUP_KERNEL_SYMBOL_ADDR(nl) ((nl)[0].n_value &= ~(1 << 31)) | ||||
| # endif | ||||
| 
 | ||||
| 
 | ||||
| # if !defined (KERNEL_FILE) && defined (hpux) | ||||
| #  define KERNEL_FILE "/hp-ux" | ||||
| # endif | ||||
| 
 | ||||
| # if !defined (KERNEL_FILE) && (defined (MIPS) || defined (SVR4) || defined (ISC) || defined (sgi)) | ||||
| #  define KERNEL_FILE "/unix" | ||||
| # endif | ||||
| 
 | ||||
| 
 | ||||
| # if !defined (LDAV_SYMBOL) && (defined (hpux) || defined (SVR4) || defined (ISC) || defined (sgi) || (defined (_AIX) && !defined(HAVE_LIBPERFSTAT))) | ||||
| #  define LDAV_SYMBOL "avenrun" | ||||
| # endif | ||||
| 
 | ||||
| # ifdef HAVE_UNISTD_H | ||||
| #  include <unistd.h> | ||||
| # endif | ||||
| 
 | ||||
| /* LOAD_AVE_TYPE should only get defined if we're going to use the
 | ||||
|    nlist method.  */ | ||||
| # if !defined (LOAD_AVE_TYPE) && (defined (BSD) || defined (LDAV_CVT) || defined (KERNEL_FILE) || defined (LDAV_SYMBOL)) | ||||
| #  define LOAD_AVE_TYPE double | ||||
| # endif | ||||
| 
 | ||||
| # ifdef LOAD_AVE_TYPE | ||||
| 
 | ||||
| #  ifndef __VMS | ||||
| #   if !(defined __linux__ || defined __ANDROID__) | ||||
| #    ifndef NLIST_STRUCT | ||||
| #     include <a.out.h> | ||||
| #    else /* NLIST_STRUCT */ | ||||
| #     include <nlist.h> | ||||
| #    endif /* NLIST_STRUCT */ | ||||
| 
 | ||||
| #    ifdef SUNOS_5 | ||||
| #     include <kvm.h> | ||||
| #     include <kstat.h> | ||||
| #    endif | ||||
| 
 | ||||
| #    if defined (hpux) && defined (HAVE_PSTAT_GETDYNAMIC) | ||||
| #     include <sys/pstat.h> | ||||
| #    endif | ||||
| 
 | ||||
| #    ifndef KERNEL_FILE | ||||
| #     define KERNEL_FILE "/vmunix" | ||||
| #    endif /* KERNEL_FILE */ | ||||
| 
 | ||||
| #    ifndef LDAV_SYMBOL | ||||
| #     define LDAV_SYMBOL "_avenrun" | ||||
| #    endif /* LDAV_SYMBOL */ | ||||
| #   endif /* __linux__ || __ANDROID__ */ | ||||
| 
 | ||||
| #  else /* __VMS */ | ||||
| 
 | ||||
| #   ifndef eunice | ||||
| #    include <iodef.h> | ||||
| #    include <descrip.h> | ||||
| #   else /* eunice */ | ||||
| #    include <vms/iodef.h> | ||||
| #   endif /* eunice */ | ||||
| #  endif /* __VMS */ | ||||
| 
 | ||||
| #  ifndef LDAV_CVT | ||||
| #   define LDAV_CVT(n) ((double) (n)) | ||||
| #  endif /* !LDAV_CVT */ | ||||
| 
 | ||||
| # endif /* LOAD_AVE_TYPE */ | ||||
| 
 | ||||
| # if defined HAVE_LIBPERFSTAT | ||||
| #  include <sys/protosw.h> | ||||
| #  include <libperfstat.h> | ||||
| #  include <sys/proc.h> | ||||
| #  ifndef SBITS | ||||
| #   define SBITS 16 | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
| # if defined (__GNU__) && !defined (NeXT) | ||||
| /* Note that NeXT Openstep defines __GNU__ even though it should not.  */ | ||||
| /* GNU system acts much like NeXT, for load average purposes,
 | ||||
|    but not exactly.  */ | ||||
| #  define NeXT | ||||
| #  define host_self mach_host_self | ||||
| # endif | ||||
| 
 | ||||
| # ifdef NeXT | ||||
| #  ifdef HAVE_MACH_MACH_H | ||||
| #   include <mach/mach.h> | ||||
| #  else | ||||
| #   include <mach.h> | ||||
| #  endif | ||||
| # endif /* NeXT */ | ||||
| 
 | ||||
| # ifdef sgi | ||||
| #  include <sys/sysmp.h> | ||||
| # endif /* sgi */ | ||||
| 
 | ||||
| # ifdef UMAX | ||||
| #  include <signal.h> | ||||
| #  include <sys/time.h> | ||||
| #  include <sys/wait.h> | ||||
| #  include <sys/syscall.h> | ||||
| 
 | ||||
| #  ifdef UMAX_43 | ||||
| #   include <machine/cpu.h> | ||||
| #   include <inq_stats/statistics.h> | ||||
| #   include <inq_stats/sysstats.h> | ||||
| #   include <inq_stats/cpustats.h> | ||||
| #   include <inq_stats/procstats.h> | ||||
| #  else /* Not UMAX_43.  */ | ||||
| #   include <sys/sysdefs.h> | ||||
| #   include <sys/statistics.h> | ||||
| #   include <sys/sysstats.h> | ||||
| #   include <sys/cpudefs.h> | ||||
| #   include <sys/cpustats.h> | ||||
| #   include <sys/procstats.h> | ||||
| #  endif /* Not UMAX_43.  */ | ||||
| # endif /* UMAX */ | ||||
| 
 | ||||
| # ifdef DGUX | ||||
| #  include <sys/dg_sys_info.h> | ||||
| # endif | ||||
| 
 | ||||
| # if (defined __linux__ || defined __ANDROID__ \ | ||||
|       || defined __CYGWIN__ || defined SUNOS_5 \ | ||||
|       || (defined LOAD_AVE_TYPE && ! defined __VMS)) | ||||
| #  include <fcntl.h> | ||||
| # endif | ||||
|  | ||||
| /* Avoid static vars inside a function since in HPUX they dump as pure.  */ | ||||
| 
 | ||||
| # ifdef NeXT | ||||
| static processor_set_t default_set; | ||||
| static bool getloadavg_initialized; | ||||
| # endif /* NeXT */ | ||||
| 
 | ||||
| # ifdef UMAX | ||||
| static unsigned int cpus = 0; | ||||
| static unsigned int samples; | ||||
| # endif /* UMAX */ | ||||
| 
 | ||||
| # ifdef DGUX | ||||
| static struct dg_sys_info_load_info load_info;  /* what-a-mouthful! */ | ||||
| # endif /* DGUX */ | ||||
| 
 | ||||
| # if !defined (HAVE_LIBKSTAT) && defined (LOAD_AVE_TYPE) | ||||
| /* File descriptor open to /dev/kmem or VMS load ave driver.  */ | ||||
| static int channel; | ||||
| /* True if channel is valid.  */ | ||||
| static bool getloadavg_initialized; | ||||
| /* Offset in kmem to seek to read load average, or 0 means invalid.  */ | ||||
| static long offset; | ||||
| 
 | ||||
| #  if ! defined __VMS && ! defined sgi && ! (defined __linux__ || defined __ANDROID__) | ||||
| static struct nlist name_list[2]; | ||||
| #  endif | ||||
| 
 | ||||
| #  ifdef SUNOS_5 | ||||
| static kvm_t *kd; | ||||
| #  endif /* SUNOS_5 */ | ||||
| 
 | ||||
| # endif /* LOAD_AVE_TYPE && !HAVE_LIBKSTAT */ | ||||
|  | ||||
| /* Put the 1 minute, 5 minute and 15 minute load averages
 | ||||
|    into the first NELEM elements of LOADAVG. | ||||
|    Return the number written (never more than 3, but may be less than NELEM), | ||||
|    or -1 (setting errno) if an error occurred.  */ | ||||
| 
 | ||||
| int | ||||
| getloadavg (double loadavg[], int nelem) | ||||
| { | ||||
|   int elem = 0;                 /* Return value.  */ | ||||
| 
 | ||||
| # ifdef NO_GET_LOAD_AVG | ||||
| #  define LDAV_DONE | ||||
|   errno = ENOSYS; | ||||
|   elem = -1; | ||||
| # endif | ||||
| 
 | ||||
| # if !defined (LDAV_DONE) && defined (HAVE_LIBKSTAT)       /* Solaris <= 2.6 */ | ||||
| /* Use libkstat because we don't have to be root.  */ | ||||
| #  define LDAV_DONE | ||||
|   kstat_ctl_t *kc; | ||||
|   kstat_t *ksp; | ||||
|   kstat_named_t *kn; | ||||
|   int saved_errno; | ||||
| 
 | ||||
|   kc = kstat_open (); | ||||
|   if (kc == NULL) | ||||
|     return -1; | ||||
|   ksp = kstat_lookup (kc, "unix", 0, "system_misc"); | ||||
|   if (ksp == NULL) | ||||
|     return -1; | ||||
|   if (kstat_read (kc, ksp, 0) == -1) | ||||
|     return -1; | ||||
| 
 | ||||
| 
 | ||||
|   kn = kstat_data_lookup (ksp, "avenrun_1min"); | ||||
|   if (kn == NULL) | ||||
|     { | ||||
|       /* Return -1 if no load average information is available.  */ | ||||
|       nelem = 0; | ||||
|       elem = -1; | ||||
|     } | ||||
| 
 | ||||
|   if (nelem >= 1) | ||||
|     loadavg[elem++] = (double) kn->value.ul / FSCALE; | ||||
| 
 | ||||
|   if (nelem >= 2) | ||||
|     { | ||||
|       kn = kstat_data_lookup (ksp, "avenrun_5min"); | ||||
|       if (kn != NULL) | ||||
|         { | ||||
|           loadavg[elem++] = (double) kn->value.ul / FSCALE; | ||||
| 
 | ||||
|           if (nelem >= 3) | ||||
|             { | ||||
|               kn = kstat_data_lookup (ksp, "avenrun_15min"); | ||||
|               if (kn != NULL) | ||||
|                 loadavg[elem++] = (double) kn->value.ul / FSCALE; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|   saved_errno = errno; | ||||
|   kstat_close (kc); | ||||
|   errno = saved_errno; | ||||
| # endif /* HAVE_LIBKSTAT */ | ||||
| 
 | ||||
| # if !defined (LDAV_DONE) && defined (hpux) && defined (HAVE_PSTAT_GETDYNAMIC) | ||||
|                                                            /* HP-UX */ | ||||
| /* Use pstat_getdynamic() because we don't have to be root.  */ | ||||
| #  define LDAV_DONE | ||||
| #  undef LOAD_AVE_TYPE | ||||
| 
 | ||||
|   struct pst_dynamic dyn_info; | ||||
|   if (pstat_getdynamic (&dyn_info, sizeof (dyn_info), 0, 0) < 0) | ||||
|     return -1; | ||||
|   if (nelem > 0) | ||||
|     loadavg[elem++] = dyn_info.psd_avg_1_min; | ||||
|   if (nelem > 1) | ||||
|     loadavg[elem++] = dyn_info.psd_avg_5_min; | ||||
|   if (nelem > 2) | ||||
|     loadavg[elem++] = dyn_info.psd_avg_15_min; | ||||
| 
 | ||||
| # endif /* hpux && HAVE_PSTAT_GETDYNAMIC */ | ||||
| 
 | ||||
| # if ! defined LDAV_DONE && defined HAVE_LIBPERFSTAT       /* AIX */ | ||||
| #  define LDAV_DONE | ||||
| #  undef LOAD_AVE_TYPE | ||||
| /* Use perfstat_cpu_total because we don't have to be root. */ | ||||
|   { | ||||
|     perfstat_cpu_total_t cpu_stats; | ||||
|     int result = perfstat_cpu_total (NULL, &cpu_stats, sizeof cpu_stats, 1); | ||||
|     if (result == -1) | ||||
|       return result; | ||||
|     loadavg[0] = cpu_stats.loadavg[0] / (double)(1 << SBITS); | ||||
|     loadavg[1] = cpu_stats.loadavg[1] / (double)(1 << SBITS); | ||||
|     loadavg[2] = cpu_stats.loadavg[2] / (double)(1 << SBITS); | ||||
|     elem = 3; | ||||
|   } | ||||
| # endif | ||||
| 
 | ||||
| # if !defined (LDAV_DONE) && (defined __linux__ || defined __ANDROID__ || defined __CYGWIN__) | ||||
|                                       /* Linux without glibc, Android, Cygwin */ | ||||
| #  define LDAV_DONE | ||||
| #  undef LOAD_AVE_TYPE | ||||
| 
 | ||||
| #  ifndef LINUX_LDAV_FILE | ||||
| #   define LINUX_LDAV_FILE "/proc/loadavg" | ||||
| #  endif | ||||
| 
 | ||||
|   char ldavgbuf[3 * (INT_STRLEN_BOUND (int) + sizeof ".00 ")]; | ||||
|   char const *ptr = ldavgbuf; | ||||
|   int fd, count, saved_errno; | ||||
| 
 | ||||
|   fd = open (LINUX_LDAV_FILE, O_RDONLY); | ||||
|   if (fd == -1) | ||||
|     return -1; | ||||
|   count = read (fd, ldavgbuf, sizeof ldavgbuf - 1); | ||||
|   saved_errno = errno; | ||||
|   (void) close (fd); | ||||
|   errno = saved_errno; | ||||
|   if (count <= 0) | ||||
|     return -1; | ||||
|   ldavgbuf[count] = '\0'; | ||||
| 
 | ||||
|   for (elem = 0; elem < nelem; elem++) | ||||
|     { | ||||
|       double numerator = 0; | ||||
|       double denominator = 1; | ||||
| 
 | ||||
|       while (*ptr == ' ') | ||||
|         ptr++; | ||||
| 
 | ||||
|       /* Finish if this number is missing, and report an error if all
 | ||||
|          were missing.  */ | ||||
|       if (! ('0' <= *ptr && *ptr <= '9')) | ||||
|         { | ||||
|           if (elem == 0) | ||||
|             { | ||||
|               errno = ENOTSUP; | ||||
|               return -1; | ||||
|             } | ||||
|           break; | ||||
|         } | ||||
| 
 | ||||
|       while ('0' <= *ptr && *ptr <= '9') | ||||
|         numerator = 10 * numerator + (*ptr++ - '0'); | ||||
| 
 | ||||
|       if (*ptr == '.') | ||||
|         for (ptr++; '0' <= *ptr && *ptr <= '9'; ptr++) | ||||
|           numerator = 10 * numerator + (*ptr - '0'), denominator *= 10; | ||||
| 
 | ||||
|       loadavg[elem++] = numerator / denominator; | ||||
|     } | ||||
| 
 | ||||
|   return elem; | ||||
| 
 | ||||
| # endif /* __linux__ || __ANDROID__ || __CYGWIN__ */ | ||||
| 
 | ||||
| # if !defined (LDAV_DONE) && defined (__NetBSD__)          /* NetBSD < 0.9 */ | ||||
| #  define LDAV_DONE | ||||
| #  undef LOAD_AVE_TYPE | ||||
| 
 | ||||
| #  ifndef NETBSD_LDAV_FILE | ||||
| #   define NETBSD_LDAV_FILE "/kern/loadavg" | ||||
| #  endif | ||||
| 
 | ||||
|   unsigned long int load_ave[3], scale; | ||||
|   int count; | ||||
|   FILE *fp; | ||||
| 
 | ||||
|   fp = fopen (NETBSD_LDAV_FILE, "r"); | ||||
|   if (fp == NULL) | ||||
|     return -1; | ||||
|   count = fscanf (fp, "%lu %lu %lu %lu\n", | ||||
|                   &load_ave[0], &load_ave[1], &load_ave[2], | ||||
|                   &scale); | ||||
|   (void) fclose (fp); | ||||
|   if (count != 4) | ||||
|     { | ||||
|       errno = ENOTSUP; | ||||
|       return -1; | ||||
|     } | ||||
| 
 | ||||
|   for (elem = 0; elem < nelem; elem++) | ||||
|     loadavg[elem] = (double) load_ave[elem] / (double) scale; | ||||
| 
 | ||||
|   return elem; | ||||
| 
 | ||||
| # endif /* __NetBSD__ */ | ||||
| 
 | ||||
| # if !defined (LDAV_DONE) && defined (NeXT)                /* NeXTStep */ | ||||
| #  define LDAV_DONE | ||||
|   /* The NeXT code was adapted from iscreen 3.2.  */ | ||||
| 
 | ||||
|   host_t host; | ||||
|   struct processor_set_basic_info info; | ||||
|   unsigned int info_count; | ||||
| 
 | ||||
|   /* We only know how to get the 1-minute average for this system,
 | ||||
|      so even if the caller asks for more than 1, we only return 1.  */ | ||||
| 
 | ||||
|   if (!getloadavg_initialized) | ||||
|     { | ||||
|       if (processor_set_default (host_self (), &default_set) == KERN_SUCCESS) | ||||
|         getloadavg_initialized = true; | ||||
|     } | ||||
| 
 | ||||
|   if (getloadavg_initialized) | ||||
|     { | ||||
|       info_count = PROCESSOR_SET_BASIC_INFO_COUNT; | ||||
|       if (processor_set_info (default_set, PROCESSOR_SET_BASIC_INFO, &host, | ||||
|                               (processor_set_info_t) &info, &info_count) | ||||
|           != KERN_SUCCESS) | ||||
|         getloadavg_initialized = false; | ||||
|       else | ||||
|         { | ||||
|           if (nelem > 0) | ||||
|             loadavg[elem++] = (double) info.load_average / LOAD_SCALE; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|   if (!getloadavg_initialized) | ||||
|     { | ||||
|       errno = ENOTSUP; | ||||
|       return -1; | ||||
|     } | ||||
| # endif /* NeXT */ | ||||
| 
 | ||||
| # if !defined (LDAV_DONE) && defined (UMAX) | ||||
| #  define LDAV_DONE | ||||
| /* UMAX 4.2, which runs on the Encore Multimax multiprocessor, does not
 | ||||
|    have a /dev/kmem.  Information about the workings of the running kernel | ||||
|    can be gathered with inq_stats system calls. | ||||
|    We only know how to get the 1-minute average for this system.  */ | ||||
| 
 | ||||
|   struct proc_summary proc_sum_data; | ||||
|   struct stat_descr proc_info; | ||||
|   double load; | ||||
|   register unsigned int i, j; | ||||
| 
 | ||||
|   if (cpus == 0) | ||||
|     { | ||||
|       register unsigned int c, i; | ||||
|       struct cpu_config conf; | ||||
|       struct stat_descr desc; | ||||
| 
 | ||||
|       desc.sd_next = 0; | ||||
|       desc.sd_subsys = SUBSYS_CPU; | ||||
|       desc.sd_type = CPUTYPE_CONFIG; | ||||
|       desc.sd_addr = (char *) &conf; | ||||
|       desc.sd_size = sizeof conf; | ||||
| 
 | ||||
|       if (inq_stats (1, &desc)) | ||||
|         return -1; | ||||
| 
 | ||||
|       c = 0; | ||||
|       for (i = 0; i < conf.config_maxclass; ++i) | ||||
|         { | ||||
|           struct class_stats stats; | ||||
|           memset (&stats, 0, sizeof stats); | ||||
| 
 | ||||
|           desc.sd_type = CPUTYPE_CLASS; | ||||
|           desc.sd_objid = i; | ||||
|           desc.sd_addr = (char *) &stats; | ||||
|           desc.sd_size = sizeof stats; | ||||
| 
 | ||||
|           if (inq_stats (1, &desc)) | ||||
|             return -1; | ||||
| 
 | ||||
|           c += stats.class_numcpus; | ||||
|         } | ||||
|       cpus = c; | ||||
|       samples = cpus < 2 ? 3 : (2 * cpus / 3); | ||||
|     } | ||||
| 
 | ||||
|   proc_info.sd_next = 0; | ||||
|   proc_info.sd_subsys = SUBSYS_PROC; | ||||
|   proc_info.sd_type = PROCTYPE_SUMMARY; | ||||
|   proc_info.sd_addr = (char *) &proc_sum_data; | ||||
|   proc_info.sd_size = sizeof (struct proc_summary); | ||||
|   proc_info.sd_sizeused = 0; | ||||
| 
 | ||||
|   if (inq_stats (1, &proc_info) != 0) | ||||
|     return -1; | ||||
| 
 | ||||
|   load = proc_sum_data.ps_nrunnable; | ||||
|   j = 0; | ||||
|   for (i = samples - 1; i > 0; --i) | ||||
|     { | ||||
|       load += proc_sum_data.ps_nrun[j]; | ||||
|       if (j++ == PS_NRUNSIZE) | ||||
|         j = 0; | ||||
|     } | ||||
| 
 | ||||
|   if (nelem > 0) | ||||
|     loadavg[elem++] = load / samples / cpus; | ||||
| # endif /* UMAX */ | ||||
| 
 | ||||
| # if !defined (LDAV_DONE) && defined (DGUX) | ||||
| #  define LDAV_DONE | ||||
|   /* This call can return -1 for an error, but with good args
 | ||||
|      it's not supposed to fail.  The first argument is for no | ||||
|      apparent reason of type 'long int *'.  */ | ||||
|   dg_sys_info ((long int *) &load_info, | ||||
|                DG_SYS_INFO_LOAD_INFO_TYPE, | ||||
|                DG_SYS_INFO_LOAD_VERSION_0); | ||||
| 
 | ||||
|   if (nelem > 0) | ||||
|     loadavg[elem++] = load_info.one_minute; | ||||
|   if (nelem > 1) | ||||
|     loadavg[elem++] = load_info.five_minute; | ||||
|   if (nelem > 2) | ||||
|     loadavg[elem++] = load_info.fifteen_minute; | ||||
| # endif /* DGUX */ | ||||
| 
 | ||||
| # if !defined (LDAV_DONE) && defined (apollo) | ||||
| #  define LDAV_DONE | ||||
| /* Apollo code from lisch@mentorg.com (Ray Lischner).
 | ||||
| 
 | ||||
|    This system call is not documented.  The load average is obtained as | ||||
|    three long integers, for the load average over the past minute, | ||||
|    five minutes, and fifteen minutes.  Each value is a scaled integer, | ||||
|    with 16 bits of integer part and 16 bits of fraction part. | ||||
| 
 | ||||
|    I'm not sure which operating system first supported this system call, | ||||
|    but I know that SR10.2 supports it.  */ | ||||
| 
 | ||||
|   extern void proc1_$get_loadav (); | ||||
|   unsigned long load_ave[3]; | ||||
| 
 | ||||
|   proc1_$get_loadav (load_ave); | ||||
| 
 | ||||
|   if (nelem > 0) | ||||
|     loadavg[elem++] = load_ave[0] / 65536.0; | ||||
|   if (nelem > 1) | ||||
|     loadavg[elem++] = load_ave[1] / 65536.0; | ||||
|   if (nelem > 2) | ||||
|     loadavg[elem++] = load_ave[2] / 65536.0; | ||||
| # endif /* apollo */ | ||||
| 
 | ||||
| # if !defined (LDAV_DONE) && defined (OSF_MIPS) | ||||
| #  define LDAV_DONE | ||||
| 
 | ||||
|   struct tbl_loadavg load_ave; | ||||
|   table (TBL_LOADAVG, 0, &load_ave, 1, sizeof (load_ave)); | ||||
|   loadavg[elem++] | ||||
|     = (load_ave.tl_lscale == 0 | ||||
|        ? load_ave.tl_avenrun.d[0] | ||||
|        : (load_ave.tl_avenrun.l[0] / (double) load_ave.tl_lscale)); | ||||
| # endif /* OSF_MIPS */ | ||||
| 
 | ||||
| # if !defined (LDAV_DONE) && (defined (__MSDOS__) || defined (WINDOWS32)) | ||||
|                                                            /* DJGPP */ | ||||
| #  define LDAV_DONE | ||||
| 
 | ||||
|   /* A faithful emulation is going to have to be saved for a rainy day.  */ | ||||
|   for ( ; elem < nelem; elem++) | ||||
|     { | ||||
|       loadavg[elem] = 0.0; | ||||
|     } | ||||
| # endif  /* __MSDOS__ || WINDOWS32 */ | ||||
| 
 | ||||
| # if !defined (LDAV_DONE) && defined (OSF_ALPHA)           /* OSF/1 */ | ||||
| #  define LDAV_DONE | ||||
| 
 | ||||
|   struct tbl_loadavg load_ave; | ||||
|   table (TBL_LOADAVG, 0, &load_ave, 1, sizeof (load_ave)); | ||||
|   for (elem = 0; elem < nelem; elem++) | ||||
|     loadavg[elem] | ||||
|       = (load_ave.tl_lscale == 0 | ||||
|          ? load_ave.tl_avenrun.d[elem] | ||||
|          : (load_ave.tl_avenrun.l[elem] / (double) load_ave.tl_lscale)); | ||||
| # endif /* OSF_ALPHA */ | ||||
| 
 | ||||
| # if ! defined LDAV_DONE && defined __VMS                  /* VMS */ | ||||
|   /* VMS specific code -- read from the Load Ave driver.  */ | ||||
| 
 | ||||
|   LOAD_AVE_TYPE load_ave[3]; | ||||
|   static bool getloadavg_initialized; | ||||
| #  ifdef eunice | ||||
|   struct | ||||
|   { | ||||
|     int dsc$w_length; | ||||
|     char *dsc$a_pointer; | ||||
|   } descriptor; | ||||
| #  endif | ||||
| 
 | ||||
|   /* Ensure that there is a channel open to the load ave device.  */ | ||||
|   if (!getloadavg_initialized) | ||||
|     { | ||||
|       /* Attempt to open the channel.  */ | ||||
| #  ifdef eunice | ||||
|       descriptor.dsc$w_length = 18; | ||||
|       descriptor.dsc$a_pointer = "$$VMS_LOAD_AVERAGE"; | ||||
| #  else | ||||
|       $DESCRIPTOR (descriptor, "LAV0:"); | ||||
| #  endif | ||||
|       if (sys$assign (&descriptor, &channel, 0, 0) & 1) | ||||
|         getloadavg_initialized = true; | ||||
|     } | ||||
| 
 | ||||
|   /* Read the load average vector.  */ | ||||
|   if (getloadavg_initialized | ||||
|       && !(sys$qiow (0, channel, IO$_READVBLK, 0, 0, 0, | ||||
|                      load_ave, 12, 0, 0, 0, 0) & 1)) | ||||
|     { | ||||
|       sys$dassgn (channel); | ||||
|       getloadavg_initialized = false; | ||||
|     } | ||||
| 
 | ||||
|   if (!getloadavg_initialized) | ||||
|     { | ||||
|       errno = ENOTSUP; | ||||
|       return -1; | ||||
|     } | ||||
| # endif /* ! defined LDAV_DONE && defined __VMS */ | ||||
| 
 | ||||
| # if ! defined LDAV_DONE && defined LOAD_AVE_TYPE && ! defined __VMS | ||||
|                                                   /* IRIX, other old systems */ | ||||
| 
 | ||||
|   /* UNIX-specific code -- read the average from /dev/kmem.  */ | ||||
| 
 | ||||
| #  define LDAV_PRIVILEGED               /* This code requires special installation.  */ | ||||
| 
 | ||||
|   LOAD_AVE_TYPE load_ave[3]; | ||||
| 
 | ||||
|   /* Get the address of LDAV_SYMBOL.  */ | ||||
|   if (offset == 0) | ||||
|     { | ||||
| #  ifndef sgi | ||||
| #   if ! defined NLIST_STRUCT || ! defined N_NAME_POINTER | ||||
|       strcpy (name_list[0].n_name, LDAV_SYMBOL); | ||||
|       strcpy (name_list[1].n_name, ""); | ||||
| #   else /* NLIST_STRUCT */ | ||||
| #    ifdef HAVE_STRUCT_NLIST_N_UN_N_NAME | ||||
|       name_list[0].n_un.n_name = LDAV_SYMBOL; | ||||
|       name_list[1].n_un.n_name = 0; | ||||
| #    else /* not HAVE_STRUCT_NLIST_N_UN_N_NAME */ | ||||
|       name_list[0].n_name = LDAV_SYMBOL; | ||||
|       name_list[1].n_name = 0; | ||||
| #    endif /* not HAVE_STRUCT_NLIST_N_UN_N_NAME */ | ||||
| #   endif /* NLIST_STRUCT */ | ||||
| 
 | ||||
| #   ifndef SUNOS_5 | ||||
|       if ( | ||||
| #    if !defined (_AIX) | ||||
|           nlist (KERNEL_FILE, name_list) | ||||
| #    else  /* _AIX */ | ||||
|           knlist (name_list, 1, sizeof (name_list[0])) | ||||
| #    endif | ||||
|           >= 0) | ||||
|           /* Omit "&& name_list[0].n_type != 0 " -- it breaks on Sun386i.  */ | ||||
|           { | ||||
| #    ifdef FIXUP_KERNEL_SYMBOL_ADDR | ||||
|             FIXUP_KERNEL_SYMBOL_ADDR (name_list); | ||||
| #    endif | ||||
|             offset = name_list[0].n_value; | ||||
|           } | ||||
| #   endif /* !SUNOS_5 */ | ||||
| #  else  /* sgi */ | ||||
|       ptrdiff_t ldav_off = sysmp (MP_KERNADDR, MPKA_AVENRUN); | ||||
|       if (ldav_off != -1) | ||||
|         offset = (long int) ldav_off & 0x7fffffff; | ||||
| #  endif /* sgi */ | ||||
|     } | ||||
| 
 | ||||
|   /* Make sure we have /dev/kmem open.  */ | ||||
|   if (!getloadavg_initialized) | ||||
|     { | ||||
| #  ifndef SUNOS_5 | ||||
|       /* Set the channel to close on exec, so it does not
 | ||||
|          litter any child's descriptor table.  */ | ||||
| #   ifndef O_CLOEXEC | ||||
| #    define O_CLOEXEC 0 | ||||
| #   endif | ||||
|       int fd = open ("/dev/kmem", O_RDONLY | O_CLOEXEC); | ||||
|       if (0 <= fd) | ||||
|         { | ||||
| #   if F_DUPFD_CLOEXEC | ||||
|           if (fd <= STDERR_FILENO) | ||||
|             { | ||||
|               int fd1 = fcntl (fd, F_DUPFD_CLOEXEC, STDERR_FILENO + 1); | ||||
|               close (fd); | ||||
|               fd = fd1; | ||||
|             } | ||||
| #   endif | ||||
|           if (0 <= fd) | ||||
|             { | ||||
|               channel = fd; | ||||
|               getloadavg_initialized = true; | ||||
|             } | ||||
|         } | ||||
| #  else /* SUNOS_5 */ | ||||
|       /* We pass 0 for the kernel, corefile, and swapfile names
 | ||||
|          to use the currently running kernel.  */ | ||||
|       kd = kvm_open (0, 0, 0, O_RDONLY, 0); | ||||
|       if (kd != NULL) | ||||
|         { | ||||
|           /* nlist the currently running kernel.  */ | ||||
|           kvm_nlist (kd, name_list); | ||||
|           offset = name_list[0].n_value; | ||||
|           getloadavg_initialized = true; | ||||
|         } | ||||
| #  endif /* SUNOS_5 */ | ||||
|     } | ||||
| 
 | ||||
|   /* If we can, get the load average values.  */ | ||||
|   if (offset && getloadavg_initialized) | ||||
|     { | ||||
|       /* Try to read the load.  */ | ||||
| #  ifndef SUNOS_5 | ||||
|       if (lseek (channel, offset, 0) == -1L | ||||
|           || read (channel, (char *) load_ave, sizeof (load_ave)) | ||||
|           != sizeof (load_ave)) | ||||
|         { | ||||
|           close (channel); | ||||
|           getloadavg_initialized = false; | ||||
|         } | ||||
| #  else  /* SUNOS_5 */ | ||||
|       if (kvm_read (kd, offset, (char *) load_ave, sizeof (load_ave)) | ||||
|           != sizeof (load_ave)) | ||||
|         { | ||||
|           kvm_close (kd); | ||||
|           getloadavg_initialized = false; | ||||
|         } | ||||
| #  endif /* SUNOS_5 */ | ||||
|     } | ||||
| 
 | ||||
|   if (offset == 0 || !getloadavg_initialized) | ||||
|     { | ||||
|       errno = ENOTSUP; | ||||
|       return -1; | ||||
|     } | ||||
| # endif /* ! defined LDAV_DONE && defined LOAD_AVE_TYPE && ! defined __VMS */ | ||||
| 
 | ||||
| # if !defined (LDAV_DONE) && defined (LOAD_AVE_TYPE) /* Including VMS.  */ | ||||
|   if (nelem > 0) | ||||
|     loadavg[elem++] = LDAV_CVT (load_ave[0]); | ||||
|   if (nelem > 1) | ||||
|     loadavg[elem++] = LDAV_CVT (load_ave[1]); | ||||
|   if (nelem > 2) | ||||
|     loadavg[elem++] = LDAV_CVT (load_ave[2]); | ||||
| 
 | ||||
| #  define LDAV_DONE | ||||
| # endif /* !LDAV_DONE && LOAD_AVE_TYPE */ | ||||
| 
 | ||||
| # if !defined LDAV_DONE | ||||
|   errno = ENOSYS; | ||||
|   elem = -1; | ||||
| # endif | ||||
|   return elem; | ||||
| } | ||||
							
								
								
									
										260
									
								
								third_party/make/lib/getprogname.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										260
									
								
								third_party/make/lib/getprogname.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,260 @@ | |||
| /* Program name management.
 | ||||
|    Copyright (C) 2016-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include "getprogname.h" | ||||
| 
 | ||||
| #include <errno.h> /* get program_invocation_name declaration */ | ||||
| #include <stdlib.h> /* get __argv declaration */ | ||||
| 
 | ||||
| #ifdef _AIX | ||||
| # include <unistd.h> | ||||
| # include <procinfo.h> | ||||
| # include <string.h> | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __MVS__ | ||||
| # ifndef _OPEN_SYS | ||||
| #  define _OPEN_SYS | ||||
| # endif | ||||
| # include <string.h> | ||||
| # include <sys/ps.h> | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __hpux | ||||
| # include <unistd.h> | ||||
| # include <sys/param.h> | ||||
| # include <sys/pstat.h> | ||||
| # include <string.h> | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __sgi | ||||
| # include <string.h> | ||||
| # include <unistd.h> | ||||
| # include <stdio.h> | ||||
| # include <fcntl.h> | ||||
| # include <sys/procfs.h> | ||||
| #endif | ||||
| 
 | ||||
| #include "dirname.h" | ||||
| 
 | ||||
| #ifndef HAVE_GETPROGNAME             /* not Mac OS X, FreeBSD, NetBSD, OpenBSD >= 5.4, Cygwin */ | ||||
| char const * | ||||
| getprogname (void) | ||||
| { | ||||
| # if HAVE_DECL_PROGRAM_INVOCATION_SHORT_NAME                /* glibc, BeOS */ | ||||
|   /* https://www.gnu.org/software/libc/manual/html_node/Error-Messages.html */ | ||||
|   return program_invocation_short_name; | ||||
| # elif HAVE_DECL_PROGRAM_INVOCATION_NAME                    /* glibc, BeOS */ | ||||
|   /* https://www.gnu.org/software/libc/manual/html_node/Error-Messages.html */ | ||||
|   return last_component (program_invocation_name); | ||||
| # elif HAVE_GETEXECNAME                                     /* Solaris */ | ||||
|   /* https://docs.oracle.com/cd/E19253-01/816-5168/6mbb3hrb1/index.html */ | ||||
|   const char *p = getexecname (); | ||||
|   if (!p) | ||||
|     p = "?"; | ||||
|   return last_component (p); | ||||
| # elif HAVE_DECL___ARGV                                     /* mingw, MSVC */ | ||||
|   /* https://docs.microsoft.com/en-us/cpp/c-runtime-library/argc-argv-wargv */ | ||||
|   const char *p = __argv && __argv[0] ? __argv[0] : "?"; | ||||
|   return last_component (p); | ||||
| # elif HAVE_VAR___PROGNAME                                  /* OpenBSD, Android, QNX */ | ||||
|   /* https://man.openbsd.org/style.9 */ | ||||
|   /* http://www.qnx.de/developers/docs/6.5.0/index.jsp?topic=%2Fcom.qnx.doc.neutrino_lib_ref%2Fp%2F__progname.html */ | ||||
|   /* Be careful to declare this only when we absolutely need it
 | ||||
|      (OpenBSD 5.1), rather than when it's available.  Otherwise, | ||||
|      its mere declaration makes program_invocation_short_name | ||||
|      malfunction (have zero length) with Fedora 25's glibc.  */ | ||||
|   extern char *__progname; | ||||
|   const char *p = __progname; | ||||
| #  if defined __ANDROID__ | ||||
|   return last_component (p); | ||||
| #  else | ||||
|   return p && p[0] ? p : "?"; | ||||
| #  endif | ||||
| # elif _AIX                                                 /* AIX */ | ||||
|   /* Idea by Bastien ROUCARIÈS,
 | ||||
|      https://lists.gnu.org/r/bug-gnulib/2010-12/msg00095.html
 | ||||
|      Reference: https://www.ibm.com/support/knowledgecenter/en/ssw_aix_61/com.ibm.aix.basetrf1/getprocs.htm
 | ||||
|   */ | ||||
|   static char *p; | ||||
|   static int first = 1; | ||||
|   if (first) | ||||
|     { | ||||
|       first = 0; | ||||
|       pid_t pid = getpid (); | ||||
|       struct procentry64 procs; | ||||
|       p = (0 < getprocs64 (&procs, sizeof procs, NULL, 0, &pid, 1) | ||||
|            ? strdup (procs.pi_comm) | ||||
|            : NULL); | ||||
|       if (!p) | ||||
|         p = "?"; | ||||
|     } | ||||
|   return p; | ||||
| # elif defined __hpux | ||||
|   static char *p; | ||||
|   static int first = 1; | ||||
|   if (first) | ||||
|     { | ||||
|       first = 0; | ||||
|       pid_t pid = getpid (); | ||||
|       struct pst_status status; | ||||
|       if (pstat_getproc (&status, sizeof status, 0, pid) > 0) | ||||
|         { | ||||
|           char *ucomm = status.pst_ucomm; | ||||
|           char *cmd = status.pst_cmd; | ||||
|           if (strlen (ucomm) < PST_UCOMMLEN - 1) | ||||
|             p = ucomm; | ||||
|           else | ||||
|             { | ||||
|               /* ucomm is truncated to length PST_UCOMMLEN - 1.
 | ||||
|                  Look at cmd instead.  */ | ||||
|               char *space = strchr (cmd, ' '); | ||||
|               if (space != NULL) | ||||
|                 *space = '\0'; | ||||
|               p = strrchr (cmd, '/'); | ||||
|               if (p != NULL) | ||||
|                 p++; | ||||
|               else | ||||
|                 p = cmd; | ||||
|               if (strlen (p) > PST_UCOMMLEN - 1 | ||||
|                   && memcmp (p, ucomm, PST_UCOMMLEN - 1) == 0) | ||||
|                 /* p is less truncated than ucomm.  */ | ||||
|                 ; | ||||
|               else | ||||
|                 p = ucomm; | ||||
|             } | ||||
|           p = strdup (p); | ||||
|         } | ||||
|       else | ||||
|         { | ||||
| #  if !defined __LP64__ | ||||
|           /* Support for 32-bit programs running in 64-bit HP-UX.
 | ||||
|              The documented way to do this is to use the same source code | ||||
|              as above, but in a compilation unit where '#define _PSTAT64 1' | ||||
|              is in effect.  I prefer a single compilation unit; the struct | ||||
|              size and the offsets are not going to change.  */ | ||||
|           char status64[1216]; | ||||
|           if (__pstat_getproc64 (status64, sizeof status64, 0, pid) > 0) | ||||
|             { | ||||
|               char *ucomm = status64 + 288; | ||||
|               char *cmd = status64 + 168; | ||||
|               if (strlen (ucomm) < PST_UCOMMLEN - 1) | ||||
|                 p = ucomm; | ||||
|               else | ||||
|                 { | ||||
|                   /* ucomm is truncated to length PST_UCOMMLEN - 1.
 | ||||
|                      Look at cmd instead.  */ | ||||
|                   char *space = strchr (cmd, ' '); | ||||
|                   if (space != NULL) | ||||
|                     *space = '\0'; | ||||
|                   p = strrchr (cmd, '/'); | ||||
|                   if (p != NULL) | ||||
|                     p++; | ||||
|                   else | ||||
|                     p = cmd; | ||||
|                   if (strlen (p) > PST_UCOMMLEN - 1 | ||||
|                       && memcmp (p, ucomm, PST_UCOMMLEN - 1) == 0) | ||||
|                     /* p is less truncated than ucomm.  */ | ||||
|                     ; | ||||
|                   else | ||||
|                     p = ucomm; | ||||
|                 } | ||||
|               p = strdup (p); | ||||
|             } | ||||
|           else | ||||
| #  endif | ||||
|             p = NULL; | ||||
|         } | ||||
|       if (!p) | ||||
|         p = "?"; | ||||
|     } | ||||
|   return p; | ||||
| # elif __MVS__                                              /* z/OS */ | ||||
|   /* https://www.ibm.com/support/knowledgecenter/SSLTBW_2.1.0/com.ibm.zos.v2r1.bpxbd00/rtwgetp.htm */ | ||||
|   static char *p = "?"; | ||||
|   static int first = 1; | ||||
|   if (first) | ||||
|     { | ||||
|       pid_t pid = getpid (); | ||||
|       int token; | ||||
|       W_PSPROC buf; | ||||
|       first = 0; | ||||
|       memset (&buf, 0, sizeof(buf)); | ||||
|       buf.ps_cmdptr    = (char *) malloc (buf.ps_cmdlen    = PS_CMDBLEN_LONG); | ||||
|       buf.ps_conttyptr = (char *) malloc (buf.ps_conttylen = PS_CONTTYBLEN); | ||||
|       buf.ps_pathptr   = (char *) malloc (buf.ps_pathlen   = PS_PATHBLEN); | ||||
|       if (buf.ps_cmdptr && buf.ps_conttyptr && buf.ps_pathptr) | ||||
|         { | ||||
|           for (token = 0; token >= 0; | ||||
|                token = w_getpsent (token, &buf, sizeof(buf))) | ||||
|             { | ||||
|               if (token > 0 && buf.ps_pid == pid) | ||||
|                 { | ||||
|                   char *s = strdup (last_component (buf.ps_pathptr)); | ||||
|                   if (s) | ||||
|                     p = s; | ||||
|                   break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|       free (buf.ps_cmdptr); | ||||
|       free (buf.ps_conttyptr); | ||||
|       free (buf.ps_pathptr); | ||||
|     } | ||||
|   return p; | ||||
| # elif defined __sgi                                        /* IRIX */ | ||||
|   char filename[50]; | ||||
|   int fd; | ||||
| 
 | ||||
|   sprintf (filename, "/proc/pinfo/%d", (int) getpid ()); | ||||
|   fd = open (filename, O_RDONLY); | ||||
|   if (0 <= fd) | ||||
|     { | ||||
|       prpsinfo_t buf; | ||||
|       int ioctl_ok = 0 <= ioctl (fd, PIOCPSINFO, &buf); | ||||
|       close (fd); | ||||
|       if (ioctl_ok) | ||||
|         { | ||||
|           char *name = buf.pr_fname; | ||||
|           size_t namesize = sizeof buf.pr_fname; | ||||
|           /* It may not be NUL-terminated.  */ | ||||
|           char *namenul = memchr (name, '\0', namesize); | ||||
|           size_t namelen = namenul ? namenul - name : namesize; | ||||
|           char *namecopy = malloc (namelen + 1); | ||||
|           if (namecopy) | ||||
|             { | ||||
|               namecopy[namelen] = '\0'; | ||||
|               return memcpy (namecopy, name, namelen); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|   return NULL; | ||||
| # else | ||||
| #  error "getprogname module not ported to this OS" | ||||
| # endif | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| /*
 | ||||
|  * Hey Emacs! | ||||
|  * Local Variables: | ||||
|  * coding: utf-8 | ||||
|  * End: | ||||
|  */ | ||||
							
								
								
									
										40
									
								
								third_party/make/lib/getprogname.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								third_party/make/lib/getprogname.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,40 @@ | |||
| /* Program name management.
 | ||||
|    Copyright (C) 2016-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _GL_GETPROGNAME_H | ||||
| #define _GL_GETPROGNAME_H | ||||
| 
 | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| /* Return the base name of the executing program.
 | ||||
|    On native Windows this will usually end in ".exe" or ".EXE". */ | ||||
| #ifndef HAVE_GETPROGNAME | ||||
| extern char const *getprogname (void) | ||||
| # ifdef HAVE_DECL_PROGRAM_INVOCATION_NAME | ||||
|   _GL_ATTRIBUTE_PURE | ||||
| # endif | ||||
|   ; | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
							
								
								
									
										301
									
								
								third_party/make/lib/gettext.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										301
									
								
								third_party/make/lib/gettext.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,301 @@ | |||
| /* Convenience header for conditional use of GNU <libintl.h>.
 | ||||
|    Copyright (C) 1995-1998, 2000-2002, 2004-2006, 2009-2020 Free Software | ||||
|    Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License along | ||||
|    with this program; if not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _LIBGETTEXT_H | ||||
| #define _LIBGETTEXT_H 1 | ||||
| 
 | ||||
| /* NLS can be disabled through the configure --disable-nls option
 | ||||
|    or through "#define ENABLE NLS 0" before including this file.  */ | ||||
| #if defined ENABLE_NLS && ENABLE_NLS | ||||
| 
 | ||||
| /* Get declarations of GNU message catalog functions.  */ | ||||
| # include <libintl.h> | ||||
| 
 | ||||
| /* You can set the DEFAULT_TEXT_DOMAIN macro to specify the domain used by
 | ||||
|    the gettext() and ngettext() macros.  This is an alternative to calling | ||||
|    textdomain(), and is useful for libraries.  */ | ||||
| # ifdef DEFAULT_TEXT_DOMAIN | ||||
| #  undef gettext | ||||
| #  define gettext(Msgid) \ | ||||
|      dgettext (DEFAULT_TEXT_DOMAIN, Msgid) | ||||
| #  undef ngettext | ||||
| #  define ngettext(Msgid1, Msgid2, N) \ | ||||
|      dngettext (DEFAULT_TEXT_DOMAIN, Msgid1, Msgid2, N) | ||||
| # endif | ||||
| 
 | ||||
| #else | ||||
| 
 | ||||
| /* Solaris /usr/include/locale.h includes /usr/include/libintl.h, which
 | ||||
|    chokes if dcgettext is defined as a macro.  So include it now, to make | ||||
|    later inclusions of <locale.h> a NOP.  We don't include <libintl.h> | ||||
|    as well because people using "gettext.h" will not include <libintl.h>, | ||||
|    and also including <libintl.h> would fail on SunOS 4, whereas <locale.h> | ||||
|    is OK.  */ | ||||
| #if defined(__sun) | ||||
| # include <locale.h> | ||||
| #endif | ||||
| 
 | ||||
| /* Many header files from the libstdc++ coming with g++ 3.3 or newer include
 | ||||
|    <libintl.h>, which chokes if dcgettext is defined as a macro.  So include | ||||
|    it now, to make later inclusions of <libintl.h> a NOP.  */ | ||||
| #if defined(__cplusplus) && defined(__GNUG__) && (__GNUC__ >= 3) | ||||
| # include <cstdlib> | ||||
| # if (__GLIBC__ >= 2 && !defined __UCLIBC__) || _GLIBCXX_HAVE_LIBINTL_H | ||||
| #  include <libintl.h> | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| /* Disabled NLS.
 | ||||
|    The casts to 'const char *' serve the purpose of producing warnings | ||||
|    for invalid uses of the value returned from these functions. | ||||
|    On pre-ANSI systems without 'const', the config.h file is supposed to | ||||
|    contain "#define const".  */ | ||||
| # undef gettext | ||||
| # define gettext(Msgid) ((const char *) (Msgid)) | ||||
| # undef dgettext | ||||
| # define dgettext(Domainname, Msgid) ((void) (Domainname), gettext (Msgid)) | ||||
| # undef dcgettext | ||||
| # define dcgettext(Domainname, Msgid, Category) \ | ||||
|     ((void) (Category), dgettext (Domainname, Msgid)) | ||||
| # undef ngettext | ||||
| # define ngettext(Msgid1, Msgid2, N) \ | ||||
|     ((N) == 1 \ | ||||
|      ? ((void) (Msgid2), (const char *) (Msgid1)) \ | ||||
|      : ((void) (Msgid1), (const char *) (Msgid2))) | ||||
| # undef dngettext | ||||
| # define dngettext(Domainname, Msgid1, Msgid2, N) \ | ||||
|     ((void) (Domainname), ngettext (Msgid1, Msgid2, N)) | ||||
| # undef dcngettext | ||||
| # define dcngettext(Domainname, Msgid1, Msgid2, N, Category) \ | ||||
|     ((void) (Category), dngettext (Domainname, Msgid1, Msgid2, N)) | ||||
| # undef textdomain | ||||
| # define textdomain(Domainname) ((const char *) (Domainname)) | ||||
| # undef bindtextdomain | ||||
| # define bindtextdomain(Domainname, Dirname) \ | ||||
|     ((void) (Domainname), (const char *) (Dirname)) | ||||
| # undef bind_textdomain_codeset | ||||
| # define bind_textdomain_codeset(Domainname, Codeset) \ | ||||
|     ((void) (Domainname), (const char *) (Codeset)) | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| /* Prefer gnulib's setlocale override over libintl's setlocale override.  */ | ||||
| #ifdef GNULIB_defined_setlocale | ||||
| # undef setlocale | ||||
| # define setlocale rpl_setlocale | ||||
| #endif | ||||
| 
 | ||||
| /* A pseudo function call that serves as a marker for the automated
 | ||||
|    extraction of messages, but does not call gettext().  The run-time | ||||
|    translation is done at a different place in the code. | ||||
|    The argument, String, should be a literal string.  Concatenated strings | ||||
|    and other string expressions won't work. | ||||
|    The macro's expansion is not parenthesized, so that it is suitable as | ||||
|    initializer for static 'char[]' or 'const char[]' variables.  */ | ||||
| #define gettext_noop(String) String | ||||
| 
 | ||||
| /* The separator between msgctxt and msgid in a .mo file.  */ | ||||
| #define GETTEXT_CONTEXT_GLUE "\004" | ||||
| 
 | ||||
| /* Pseudo function calls, taking a MSGCTXT and a MSGID instead of just a
 | ||||
|    MSGID.  MSGCTXT and MSGID must be string literals.  MSGCTXT should be | ||||
|    short and rarely need to change. | ||||
|    The letter 'p' stands for 'particular' or 'special'.  */ | ||||
| #ifdef DEFAULT_TEXT_DOMAIN | ||||
| # define pgettext(Msgctxt, Msgid) \ | ||||
|    pgettext_aux (DEFAULT_TEXT_DOMAIN, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES) | ||||
| #else | ||||
| # define pgettext(Msgctxt, Msgid) \ | ||||
|    pgettext_aux (NULL, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES) | ||||
| #endif | ||||
| #define dpgettext(Domainname, Msgctxt, Msgid) \ | ||||
|   pgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, LC_MESSAGES) | ||||
| #define dcpgettext(Domainname, Msgctxt, Msgid, Category) \ | ||||
|   pgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, Category) | ||||
| #ifdef DEFAULT_TEXT_DOMAIN | ||||
| # define npgettext(Msgctxt, Msgid, MsgidPlural, N) \ | ||||
|    npgettext_aux (DEFAULT_TEXT_DOMAIN, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES) | ||||
| #else | ||||
| # define npgettext(Msgctxt, Msgid, MsgidPlural, N) \ | ||||
|    npgettext_aux (NULL, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES) | ||||
| #endif | ||||
| #define dnpgettext(Domainname, Msgctxt, Msgid, MsgidPlural, N) \ | ||||
|   npgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, LC_MESSAGES) | ||||
| #define dcnpgettext(Domainname, Msgctxt, Msgid, MsgidPlural, N, Category) \ | ||||
|   npgettext_aux (Domainname, Msgctxt GETTEXT_CONTEXT_GLUE Msgid, Msgid, MsgidPlural, N, Category) | ||||
| 
 | ||||
| #ifdef __GNUC__ | ||||
| __inline | ||||
| #else | ||||
| #ifdef __cplusplus | ||||
| inline | ||||
| #endif | ||||
| #endif | ||||
| static const char * | ||||
| pgettext_aux (const char *domain, | ||||
|               const char *msg_ctxt_id, const char *msgid, | ||||
|               int category) | ||||
| { | ||||
|   const char *translation = dcgettext (domain, msg_ctxt_id, category); | ||||
|   if (translation == msg_ctxt_id) | ||||
|     return msgid; | ||||
|   else | ||||
|     return translation; | ||||
| } | ||||
| 
 | ||||
| #ifdef __GNUC__ | ||||
| __inline | ||||
| #else | ||||
| #ifdef __cplusplus | ||||
| inline | ||||
| #endif | ||||
| #endif | ||||
| static const char * | ||||
| npgettext_aux (const char *domain, | ||||
|                const char *msg_ctxt_id, const char *msgid, | ||||
|                const char *msgid_plural, unsigned long int n, | ||||
|                int category) | ||||
| { | ||||
|   const char *translation = | ||||
|     dcngettext (domain, msg_ctxt_id, msgid_plural, n, category); | ||||
|   if (translation == msg_ctxt_id || translation == msgid_plural) | ||||
|     return (n == 1 ? msgid : msgid_plural); | ||||
|   else | ||||
|     return translation; | ||||
| } | ||||
| 
 | ||||
| /* The same thing extended for non-constant arguments.  Here MSGCTXT and MSGID
 | ||||
|    can be arbitrary expressions.  But for string literals these macros are | ||||
|    less efficient than those above.  */ | ||||
| 
 | ||||
| #include <string.h> | ||||
| 
 | ||||
| /* GNULIB_NO_VLA can be defined to disable use of VLAs even if supported.
 | ||||
|    This relates to the -Wvla and -Wvla-larger-than warnings, enabled in | ||||
|    the default GCC many warnings set.  This allows programs to disable use | ||||
|    of VLAs, which may be unintended, or may be awkward to support portably, | ||||
|    or may have security implications due to non-deterministic stack usage.  */ | ||||
| 
 | ||||
| #if (!defined GNULIB_NO_VLA \ | ||||
|      && (((__GNUC__ >= 3 || __GNUG__ >= 2) && !defined __STRICT_ANSI__) \ | ||||
|      /*  || (__STDC_VERSION__ == 199901L && !defined __HP_cc)
 | ||||
|          || (__STDC_VERSION__ >= 201112L && !defined __STDC_NO_VLA__) */ )) | ||||
| # define _LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS 1 | ||||
| #else | ||||
| # define _LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS 0 | ||||
| #endif | ||||
| 
 | ||||
| #if !_LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS | ||||
| #include <stdlib.h> | ||||
| #endif | ||||
| 
 | ||||
| #define pgettext_expr(Msgctxt, Msgid) \ | ||||
|   dcpgettext_expr (NULL, Msgctxt, Msgid, LC_MESSAGES) | ||||
| #define dpgettext_expr(Domainname, Msgctxt, Msgid) \ | ||||
|   dcpgettext_expr (Domainname, Msgctxt, Msgid, LC_MESSAGES) | ||||
| 
 | ||||
| #ifdef __GNUC__ | ||||
| __inline | ||||
| #else | ||||
| #ifdef __cplusplus | ||||
| inline | ||||
| #endif | ||||
| #endif | ||||
| static const char * | ||||
| dcpgettext_expr (const char *domain, | ||||
|                  const char *msgctxt, const char *msgid, | ||||
|                  int category) | ||||
| { | ||||
|   size_t msgctxt_len = strlen (msgctxt) + 1; | ||||
|   size_t msgid_len = strlen (msgid) + 1; | ||||
|   const char *translation; | ||||
| #if _LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS | ||||
|   char msg_ctxt_id[msgctxt_len + msgid_len]; | ||||
| #else | ||||
|   char buf[1024]; | ||||
|   char *msg_ctxt_id = | ||||
|     (msgctxt_len + msgid_len <= sizeof (buf) | ||||
|      ? buf | ||||
|      : (char *) malloc (msgctxt_len + msgid_len)); | ||||
|   if (msg_ctxt_id != NULL) | ||||
| #endif | ||||
|     { | ||||
|       int found_translation; | ||||
|       memcpy (msg_ctxt_id, msgctxt, msgctxt_len - 1); | ||||
|       msg_ctxt_id[msgctxt_len - 1] = '\004'; | ||||
|       memcpy (msg_ctxt_id + msgctxt_len, msgid, msgid_len); | ||||
|       translation = dcgettext (domain, msg_ctxt_id, category); | ||||
|       found_translation = (translation != msg_ctxt_id); | ||||
| #if !_LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS | ||||
|       if (msg_ctxt_id != buf) | ||||
|         free (msg_ctxt_id); | ||||
| #endif | ||||
|       if (found_translation) | ||||
|         return translation; | ||||
|     } | ||||
|   return msgid; | ||||
| } | ||||
| 
 | ||||
| #define npgettext_expr(Msgctxt, Msgid, MsgidPlural, N) \ | ||||
|   dcnpgettext_expr (NULL, Msgctxt, Msgid, MsgidPlural, N, LC_MESSAGES) | ||||
| #define dnpgettext_expr(Domainname, Msgctxt, Msgid, MsgidPlural, N) \ | ||||
|   dcnpgettext_expr (Domainname, Msgctxt, Msgid, MsgidPlural, N, LC_MESSAGES) | ||||
| 
 | ||||
| #ifdef __GNUC__ | ||||
| __inline | ||||
| #else | ||||
| #ifdef __cplusplus | ||||
| inline | ||||
| #endif | ||||
| #endif | ||||
| static const char * | ||||
| dcnpgettext_expr (const char *domain, | ||||
|                   const char *msgctxt, const char *msgid, | ||||
|                   const char *msgid_plural, unsigned long int n, | ||||
|                   int category) | ||||
| { | ||||
|   size_t msgctxt_len = strlen (msgctxt) + 1; | ||||
|   size_t msgid_len = strlen (msgid) + 1; | ||||
|   const char *translation; | ||||
| #if _LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS | ||||
|   char msg_ctxt_id[msgctxt_len + msgid_len]; | ||||
| #else | ||||
|   char buf[1024]; | ||||
|   char *msg_ctxt_id = | ||||
|     (msgctxt_len + msgid_len <= sizeof (buf) | ||||
|      ? buf | ||||
|      : (char *) malloc (msgctxt_len + msgid_len)); | ||||
|   if (msg_ctxt_id != NULL) | ||||
| #endif | ||||
|     { | ||||
|       int found_translation; | ||||
|       memcpy (msg_ctxt_id, msgctxt, msgctxt_len - 1); | ||||
|       msg_ctxt_id[msgctxt_len - 1] = '\004'; | ||||
|       memcpy (msg_ctxt_id + msgctxt_len, msgid, msgid_len); | ||||
|       translation = dcngettext (domain, msg_ctxt_id, msgid_plural, n, category); | ||||
|       found_translation = !(translation == msg_ctxt_id || translation == msgid_plural); | ||||
| #if !_LIBGETTEXT_HAVE_VARIABLE_SIZE_ARRAYS | ||||
|       if (msg_ctxt_id != buf) | ||||
|         free (msg_ctxt_id); | ||||
| #endif | ||||
|       if (found_translation) | ||||
|         return translation; | ||||
|     } | ||||
|   return (n == 1 ? msgid : msgid_plural); | ||||
| } | ||||
| 
 | ||||
| #endif /* _LIBGETTEXT_H */ | ||||
							
								
								
									
										1437
									
								
								third_party/make/lib/glob.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1437
									
								
								third_party/make/lib/glob.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										210
									
								
								third_party/make/lib/glob.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										210
									
								
								third_party/make/lib/glob.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,210 @@ | |||
| /* Copyright (C) 1991, 1992, 1995, 1996, 1997, 1998 Free Software Foundation,
 | ||||
| Inc. | ||||
| 
 | ||||
| The GNU C Library is free software; you can redistribute it and/or | ||||
| modify it under the terms of the GNU Library General Public License as | ||||
| published by the Free Software Foundation; either version 2 of the | ||||
| License, or (at your option) any later version. | ||||
| 
 | ||||
| The GNU C Library is distributed in the hope that it will be useful, | ||||
| but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
| Library General Public License for more details. | ||||
| 
 | ||||
| You should have received a copy of the GNU Library General Public License | ||||
| along with this library; see the file COPYING.LIB.  If not, write to the Free | ||||
| Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 | ||||
| USA.  */ | ||||
| 
 | ||||
| #ifndef	_GLOB_H | ||||
| #define	_GLOB_H	1 | ||||
| 
 | ||||
| #ifdef	__cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| #undef	__ptr_t | ||||
| #if defined __cplusplus || (defined __STDC__ && __STDC__) || defined WINDOWS32 | ||||
| # if !defined __GLIBC__ | ||||
| #  undef __P | ||||
| #  undef __PMT | ||||
| #  define __P(protos)	protos | ||||
| #  define __PMT(protos)	protos | ||||
| #  if !defined __GNUC__ || __GNUC__ < 2 | ||||
| #   undef __const | ||||
| #   define __const const | ||||
| #  endif | ||||
| # endif | ||||
| # define __ptr_t	void * | ||||
| #else /* Not C++ or ANSI C.  */ | ||||
| # undef	__P | ||||
| # undef __PMT | ||||
| # define __P(protos)	() | ||||
| # define __PMT(protos)	() | ||||
| # undef	__const | ||||
| # define __const | ||||
| # define __ptr_t	char * | ||||
| #endif /* C++ or ANSI C.  */ | ||||
| 
 | ||||
| /* We need `size_t' for the following definitions.  */ | ||||
| #ifndef __size_t | ||||
| # if defined __FreeBSD__ | ||||
| #  define __size_t size_t | ||||
| # else | ||||
| #  if defined __GNUC__ && __GNUC__ >= 2 | ||||
| typedef __SIZE_TYPE__ __size_t; | ||||
| #  else | ||||
| /* This is a guess.  */ | ||||
| /*hb
 | ||||
|  *	Conflicts with DECCs already defined type __size_t. | ||||
|  *	Defining an own type with a name beginning with '__' is no good. | ||||
|  *	Anyway if DECC is used and __SIZE_T is defined then __size_t is | ||||
|  *	already defined (and I hope it's exactly the one we need here). | ||||
|  */ | ||||
| #   if !(defined __DECC && defined __SIZE_T) | ||||
| typedef unsigned long int __size_t; | ||||
| #   endif | ||||
| #  endif | ||||
| # endif | ||||
| #else | ||||
| /* The GNU CC stddef.h version defines __size_t as empty.  We need a real
 | ||||
|    definition.  */ | ||||
| # undef __size_t | ||||
| # define __size_t size_t | ||||
| #endif | ||||
| 
 | ||||
| /* Bits set in the FLAGS argument to `glob'.  */ | ||||
| #define	GLOB_ERR	(1 << 0)/* Return on read errors.  */ | ||||
| #define	GLOB_MARK	(1 << 1)/* Append a slash to each name.  */ | ||||
| #define	GLOB_NOSORT	(1 << 2)/* Don't sort the names.  */ | ||||
| #define	GLOB_DOOFFS	(1 << 3)/* Insert PGLOB->gl_offs NULLs.  */ | ||||
| #define	GLOB_NOCHECK	(1 << 4)/* If nothing matches, return the pattern.  */ | ||||
| #define	GLOB_APPEND	(1 << 5)/* Append to results of a previous call.  */ | ||||
| #define	GLOB_NOESCAPE	(1 << 6)/* Backslashes don't quote metacharacters.  */ | ||||
| #define	GLOB_PERIOD	(1 << 7)/* Leading `.' can be matched by metachars.  */ | ||||
| 
 | ||||
| #if (!defined _POSIX_C_SOURCE || _POSIX_C_SOURCE < 2 || defined _BSD_SOURCE \ | ||||
|      || defined _GNU_SOURCE) | ||||
| # define GLOB_MAGCHAR	 (1 << 8)/* Set in gl_flags if any metachars seen.  */ | ||||
| # define GLOB_ALTDIRFUNC (1 << 9)/* Use gl_opendir et al functions.  */ | ||||
| # define GLOB_BRACE	 (1 << 10)/* Expand "{a,b}" to "a" "b".  */ | ||||
| # define GLOB_NOMAGIC	 (1 << 11)/* If no magic chars, return the pattern.  */ | ||||
| # define GLOB_TILDE	 (1 << 12)/* Expand ~user and ~ to home directories. */ | ||||
| # define GLOB_ONLYDIR	 (1 << 13)/* Match only directories.  */ | ||||
| # define GLOB_TILDE_CHECK (1 << 14)/* Like GLOB_TILDE but return an error | ||||
| 				      if the user name is not available.  */ | ||||
| # define __GLOB_FLAGS	(GLOB_ERR|GLOB_MARK|GLOB_NOSORT|GLOB_DOOFFS| \ | ||||
| 			 GLOB_NOESCAPE|GLOB_NOCHECK|GLOB_APPEND|     \ | ||||
| 			 GLOB_PERIOD|GLOB_ALTDIRFUNC|GLOB_BRACE|     \ | ||||
| 			 GLOB_NOMAGIC|GLOB_TILDE|GLOB_ONLYDIR|GLOB_TILDE_CHECK) | ||||
| #else | ||||
| # define __GLOB_FLAGS	(GLOB_ERR|GLOB_MARK|GLOB_NOSORT|GLOB_DOOFFS| \ | ||||
| 			 GLOB_NOESCAPE|GLOB_NOCHECK|GLOB_APPEND|     \ | ||||
| 			 GLOB_PERIOD) | ||||
| #endif | ||||
| 
 | ||||
| /* Error returns from `glob'.  */ | ||||
| #define	GLOB_NOSPACE	1	/* Ran out of memory.  */ | ||||
| #define	GLOB_ABORTED	2	/* Read error.  */ | ||||
| #define	GLOB_NOMATCH	3	/* No matches found.  */ | ||||
| #define GLOB_NOSYS	4	/* Not implemented.  */ | ||||
| #ifdef _GNU_SOURCE | ||||
| /* Previous versions of this file defined GLOB_ABEND instead of
 | ||||
|    GLOB_ABORTED.  Provide a compatibility definition here.  */ | ||||
| # define GLOB_ABEND GLOB_ABORTED | ||||
| #endif | ||||
| 
 | ||||
| /* Structure describing a globbing run.  */ | ||||
| #if !defined _AMIGA && !defined VMS /* Buggy compiler.   */ | ||||
| struct stat; | ||||
| #endif | ||||
| typedef struct | ||||
|   { | ||||
|     __size_t gl_pathc;		/* Count of paths matched by the pattern.  */ | ||||
|     char **gl_pathv;		/* List of matched pathnames.  */ | ||||
|     __size_t gl_offs;		/* Slots to reserve in `gl_pathv'.  */ | ||||
|     int gl_flags;		/* Set to FLAGS, maybe | GLOB_MAGCHAR.  */ | ||||
| 
 | ||||
|     /* If the GLOB_ALTDIRFUNC flag is set, the following functions
 | ||||
|        are used instead of the normal file access functions.  */ | ||||
|     void (*gl_closedir) __PMT ((void *)); | ||||
|     struct dirent *(*gl_readdir) __PMT ((void *)); | ||||
|     __ptr_t (*gl_opendir) __PMT ((__const char *)); | ||||
|     int (*gl_lstat) __PMT ((__const char *, struct stat *)); | ||||
| #if defined(VMS) && defined(__DECC) && !defined(_POSIX_C_SOURCE) | ||||
|     int (*gl_stat) __PMT ((__const char *, struct stat *, ...)); | ||||
| #else | ||||
|     int (*gl_stat) __PMT ((__const char *, struct stat *)); | ||||
| #endif | ||||
|   } glob_t; | ||||
| 
 | ||||
| #ifdef _LARGEFILE64_SOURCE | ||||
| struct stat64; | ||||
| typedef struct | ||||
|   { | ||||
|     __size_t gl_pathc; | ||||
|     char **gl_pathv; | ||||
|     __size_t gl_offs; | ||||
|     int gl_flags; | ||||
| 
 | ||||
|     /* If the GLOB_ALTDIRFUNC flag is set, the following functions
 | ||||
|        are used instead of the normal file access functions.  */ | ||||
|     void (*gl_closedir) __PMT ((void *)); | ||||
|     struct dirent64 *(*gl_readdir) __PMT ((void *)); | ||||
|     __ptr_t (*gl_opendir) __PMT ((__const char *)); | ||||
|     int (*gl_lstat) __PMT ((__const char *, struct stat64 *)); | ||||
|     int (*gl_stat) __PMT ((__const char *, struct stat64 *)); | ||||
|   } glob64_t; | ||||
| #endif | ||||
| 
 | ||||
| #if _FILE_OFFSET_BITS == 64 && __GNUC__ < 2 | ||||
| # define glob glob64 | ||||
| # define globfree globfree64 | ||||
| #else | ||||
| # ifdef _LARGEFILE64_SOURCE | ||||
| extern int glob64 __P ((__const char *__pattern, int __flags, | ||||
| 			int (*__errfunc) (__const char *, int), | ||||
| 			glob64_t *__pglob)); | ||||
| 
 | ||||
| extern void globfree64 __P ((glob64_t *__pglob)); | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| /* Do glob searching for PATTERN, placing results in PGLOB.
 | ||||
|    The bits defined above may be set in FLAGS. | ||||
|    If a directory cannot be opened or read and ERRFUNC is not nil, | ||||
|    it is called with the pathname that caused the error, and the | ||||
|    `errno' value from the failing call; if it returns non-zero | ||||
|    `glob' returns GLOB_ABEND; if it returns zero, the error is ignored. | ||||
|    If memory cannot be allocated for PGLOB, GLOB_NOSPACE is returned. | ||||
|    Otherwise, `glob' returns zero.  */ | ||||
| #if _FILE_OFFSET_BITS != 64 || __GNUC__ < 2 | ||||
| extern int glob __P ((__const char *__pattern, int __flags, | ||||
| 		      int (*__errfunc) (__const char *, int), | ||||
| 		      glob_t *__pglob)); | ||||
| 
 | ||||
| /* Free storage allocated in PGLOB by a previous `glob' call.  */ | ||||
| extern void globfree __P ((glob_t *__pglob)); | ||||
| #else | ||||
| extern int glob __P ((__const char *__pattern, int __flags, | ||||
| 		      int (*__errfunc) (__const char *, int), | ||||
| 		      glob_t *__pglob)) __asm__ ("glob64"); | ||||
| 
 | ||||
| extern void globfree __P ((glob_t *__pglob)) __asm__ ("globfree64"); | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| #ifdef _GNU_SOURCE | ||||
| /* Return nonzero if PATTERN contains any metacharacters.
 | ||||
|    Metacharacters can be quoted with backslashes if QUOTE is nonzero. | ||||
| 
 | ||||
|    This function is not part of the interface specified by POSIX.2 | ||||
|    but several programs want to use it.  */ | ||||
| extern int glob_pattern_p __P ((__const char *__pattern, int __quote)); | ||||
| #endif | ||||
| 
 | ||||
| #ifdef	__cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif /* glob.h  */ | ||||
							
								
								
									
										584
									
								
								third_party/make/lib/intprops.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										584
									
								
								third_party/make/lib/intprops.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,584 @@ | |||
| /* intprops.h -- properties of integer types
 | ||||
| 
 | ||||
|    Copyright (C) 2001-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify it | ||||
|    under the terms of the GNU General Public License as published | ||||
|    by the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| /* Written by Paul Eggert.  */ | ||||
| 
 | ||||
| #ifndef _GL_INTPROPS_H | ||||
| #define _GL_INTPROPS_H | ||||
| 
 | ||||
| #include <limits.h> | ||||
| 
 | ||||
| /* Return a value with the common real type of E and V and the value of V.
 | ||||
|    Do not evaluate E.  */ | ||||
| #define _GL_INT_CONVERT(e, v) ((1 ? 0 : (e)) + (v)) | ||||
| 
 | ||||
| /* Act like _GL_INT_CONVERT (E, -V) but work around a bug in IRIX 6.5 cc; see
 | ||||
|    <https://lists.gnu.org/r/bug-gnulib/2011-05/msg00406.html>.  */
 | ||||
| #define _GL_INT_NEGATE_CONVERT(e, v) ((1 ? 0 : (e)) - (v)) | ||||
| 
 | ||||
| /* The extra casts in the following macros work around compiler bugs,
 | ||||
|    e.g., in Cray C 5.0.3.0.  */ | ||||
| 
 | ||||
| /* True if the arithmetic type T is an integer type.  bool counts as
 | ||||
|    an integer.  */ | ||||
| #define TYPE_IS_INTEGER(t) ((t) 1.5 == 1) | ||||
| 
 | ||||
| /* True if the real type T is signed.  */ | ||||
| #define TYPE_SIGNED(t) (! ((t) 0 < (t) -1)) | ||||
| 
 | ||||
| /* Return 1 if the real expression E, after promotion, has a
 | ||||
|    signed or floating type.  Do not evaluate E.  */ | ||||
| #define EXPR_SIGNED(e) (_GL_INT_NEGATE_CONVERT (e, 1) < 0) | ||||
| 
 | ||||
| 
 | ||||
| /* Minimum and maximum values for integer types and expressions.  */ | ||||
| 
 | ||||
| /* The width in bits of the integer type or expression T.
 | ||||
|    Do not evaluate T. | ||||
|    Padding bits are not supported; this is checked at compile-time below.  */ | ||||
| #define TYPE_WIDTH(t) (sizeof (t) * CHAR_BIT) | ||||
| 
 | ||||
| /* The maximum and minimum values for the integer type T.  */ | ||||
| #define TYPE_MINIMUM(t) ((t) ~ TYPE_MAXIMUM (t)) | ||||
| #define TYPE_MAXIMUM(t)                                                 \ | ||||
|   ((t) (! TYPE_SIGNED (t)                                               \ | ||||
|         ? (t) -1                                                        \ | ||||
|         : ((((t) 1 << (TYPE_WIDTH (t) - 2)) - 1) * 2 + 1))) | ||||
| 
 | ||||
| /* The maximum and minimum values for the type of the expression E,
 | ||||
|    after integer promotion.  E is not evaluated.  */ | ||||
| #define _GL_INT_MINIMUM(e)                                              \ | ||||
|   (EXPR_SIGNED (e)                                                      \ | ||||
|    ? ~ _GL_SIGNED_INT_MAXIMUM (e)                                       \ | ||||
|    : _GL_INT_CONVERT (e, 0)) | ||||
| #define _GL_INT_MAXIMUM(e)                                              \ | ||||
|   (EXPR_SIGNED (e)                                                      \ | ||||
|    ? _GL_SIGNED_INT_MAXIMUM (e)                                         \ | ||||
|    : _GL_INT_NEGATE_CONVERT (e, 1)) | ||||
| #define _GL_SIGNED_INT_MAXIMUM(e)                                       \ | ||||
|   (((_GL_INT_CONVERT (e, 1) << (TYPE_WIDTH ((e) + 0) - 2)) - 1) * 2 + 1) | ||||
| 
 | ||||
| /* Work around OpenVMS incompatibility with C99.  */ | ||||
| #if !defined LLONG_MAX && defined __INT64_MAX | ||||
| # define LLONG_MAX __INT64_MAX | ||||
| # define LLONG_MIN __INT64_MIN | ||||
| #endif | ||||
| 
 | ||||
| /* This include file assumes that signed types are two's complement without
 | ||||
|    padding bits; the above macros have undefined behavior otherwise. | ||||
|    If this is a problem for you, please let us know how to fix it for your host. | ||||
|    This assumption is tested by the intprops-tests module.  */ | ||||
| 
 | ||||
| /* Does the __typeof__ keyword work?  This could be done by
 | ||||
|    'configure', but for now it's easier to do it by hand.  */ | ||||
| #if (2 <= __GNUC__ \ | ||||
|      || (1210 <= __IBMC__ && defined __IBM__TYPEOF__) \ | ||||
|      || (0x5110 <= __SUNPRO_C && !__STDC__)) | ||||
| # define _GL_HAVE___TYPEOF__ 1 | ||||
| #else | ||||
| # define _GL_HAVE___TYPEOF__ 0 | ||||
| #endif | ||||
| 
 | ||||
| /* Return 1 if the integer type or expression T might be signed.  Return 0
 | ||||
|    if it is definitely unsigned.  This macro does not evaluate its argument, | ||||
|    and expands to an integer constant expression.  */ | ||||
| #if _GL_HAVE___TYPEOF__ | ||||
| # define _GL_SIGNED_TYPE_OR_EXPR(t) TYPE_SIGNED (__typeof__ (t)) | ||||
| #else | ||||
| # define _GL_SIGNED_TYPE_OR_EXPR(t) 1 | ||||
| #endif | ||||
| 
 | ||||
| /* Bound on length of the string representing an unsigned integer
 | ||||
|    value representable in B bits.  log10 (2.0) < 146/485.  The | ||||
|    smallest value of B where this bound is not tight is 2621.  */ | ||||
| #define INT_BITS_STRLEN_BOUND(b) (((b) * 146 + 484) / 485) | ||||
| 
 | ||||
| /* Bound on length of the string representing an integer type or expression T.
 | ||||
|    Subtract 1 for the sign bit if T is signed, and then add 1 more for | ||||
|    a minus sign if needed. | ||||
| 
 | ||||
|    Because _GL_SIGNED_TYPE_OR_EXPR sometimes returns 1 when its argument is | ||||
|    unsigned, this macro may overestimate the true bound by one byte when | ||||
|    applied to unsigned types of size 2, 4, 16, ... bytes.  */ | ||||
| #define INT_STRLEN_BOUND(t)                                     \ | ||||
|   (INT_BITS_STRLEN_BOUND (TYPE_WIDTH (t) - _GL_SIGNED_TYPE_OR_EXPR (t)) \ | ||||
|    + _GL_SIGNED_TYPE_OR_EXPR (t)) | ||||
| 
 | ||||
| /* Bound on buffer size needed to represent an integer type or expression T,
 | ||||
|    including the terminating null.  */ | ||||
| #define INT_BUFSIZE_BOUND(t) (INT_STRLEN_BOUND (t) + 1) | ||||
| 
 | ||||
| 
 | ||||
| /* Range overflow checks.
 | ||||
| 
 | ||||
|    The INT_<op>_RANGE_OVERFLOW macros return 1 if the corresponding C | ||||
|    operators might not yield numerically correct answers due to | ||||
|    arithmetic overflow.  They do not rely on undefined or | ||||
|    implementation-defined behavior.  Their implementations are simple | ||||
|    and straightforward, but they are a bit harder to use than the | ||||
|    INT_<op>_OVERFLOW macros described below. | ||||
| 
 | ||||
|    Example usage: | ||||
| 
 | ||||
|      long int i = ...; | ||||
|      long int j = ...; | ||||
|      if (INT_MULTIPLY_RANGE_OVERFLOW (i, j, LONG_MIN, LONG_MAX)) | ||||
|        printf ("multiply would overflow"); | ||||
|      else | ||||
|        printf ("product is %ld", i * j); | ||||
| 
 | ||||
|    Restrictions on *_RANGE_OVERFLOW macros: | ||||
| 
 | ||||
|    These macros do not check for all possible numerical problems or | ||||
|    undefined or unspecified behavior: they do not check for division | ||||
|    by zero, for bad shift counts, or for shifting negative numbers. | ||||
| 
 | ||||
|    These macros may evaluate their arguments zero or multiple times, | ||||
|    so the arguments should not have side effects.  The arithmetic | ||||
|    arguments (including the MIN and MAX arguments) must be of the same | ||||
|    integer type after the usual arithmetic conversions, and the type | ||||
|    must have minimum value MIN and maximum MAX.  Unsigned types should | ||||
|    use a zero MIN of the proper type. | ||||
| 
 | ||||
|    These macros are tuned for constant MIN and MAX.  For commutative | ||||
|    operations such as A + B, they are also tuned for constant B.  */ | ||||
| 
 | ||||
| /* Return 1 if A + B would overflow in [MIN,MAX] arithmetic.
 | ||||
|    See above for restrictions.  */ | ||||
| #define INT_ADD_RANGE_OVERFLOW(a, b, min, max)          \ | ||||
|   ((b) < 0                                              \ | ||||
|    ? (a) < (min) - (b)                                  \ | ||||
|    : (max) - (b) < (a)) | ||||
| 
 | ||||
| /* Return 1 if A - B would overflow in [MIN,MAX] arithmetic.
 | ||||
|    See above for restrictions.  */ | ||||
| #define INT_SUBTRACT_RANGE_OVERFLOW(a, b, min, max)     \ | ||||
|   ((b) < 0                                              \ | ||||
|    ? (max) + (b) < (a)                                  \ | ||||
|    : (a) < (min) + (b)) | ||||
| 
 | ||||
| /* Return 1 if - A would overflow in [MIN,MAX] arithmetic.
 | ||||
|    See above for restrictions.  */ | ||||
| #define INT_NEGATE_RANGE_OVERFLOW(a, min, max)          \ | ||||
|   ((min) < 0                                            \ | ||||
|    ? (a) < - (max)                                      \ | ||||
|    : 0 < (a)) | ||||
| 
 | ||||
| /* Return 1 if A * B would overflow in [MIN,MAX] arithmetic.
 | ||||
|    See above for restrictions.  Avoid && and || as they tickle | ||||
|    bugs in Sun C 5.11 2010/08/13 and other compilers; see | ||||
|    <https://lists.gnu.org/r/bug-gnulib/2011-05/msg00401.html>.  */
 | ||||
| #define INT_MULTIPLY_RANGE_OVERFLOW(a, b, min, max)     \ | ||||
|   ((b) < 0                                              \ | ||||
|    ? ((a) < 0                                           \ | ||||
|       ? (a) < (max) / (b)                               \ | ||||
|       : (b) == -1                                       \ | ||||
|       ? 0                                               \ | ||||
|       : (min) / (b) < (a))                              \ | ||||
|    : (b) == 0                                           \ | ||||
|    ? 0                                                  \ | ||||
|    : ((a) < 0                                           \ | ||||
|       ? (a) < (min) / (b)                               \ | ||||
|       : (max) / (b) < (a))) | ||||
| 
 | ||||
| /* Return 1 if A / B would overflow in [MIN,MAX] arithmetic.
 | ||||
|    See above for restrictions.  Do not check for division by zero.  */ | ||||
| #define INT_DIVIDE_RANGE_OVERFLOW(a, b, min, max)       \ | ||||
|   ((min) < 0 && (b) == -1 && (a) < - (max)) | ||||
| 
 | ||||
| /* Return 1 if A % B would overflow in [MIN,MAX] arithmetic.
 | ||||
|    See above for restrictions.  Do not check for division by zero. | ||||
|    Mathematically, % should never overflow, but on x86-like hosts | ||||
|    INT_MIN % -1 traps, and the C standard permits this, so treat this | ||||
|    as an overflow too.  */ | ||||
| #define INT_REMAINDER_RANGE_OVERFLOW(a, b, min, max)    \ | ||||
|   INT_DIVIDE_RANGE_OVERFLOW (a, b, min, max) | ||||
| 
 | ||||
| /* Return 1 if A << B would overflow in [MIN,MAX] arithmetic.
 | ||||
|    See above for restrictions.  Here, MIN and MAX are for A only, and B need | ||||
|    not be of the same type as the other arguments.  The C standard says that | ||||
|    behavior is undefined for shifts unless 0 <= B < wordwidth, and that when | ||||
|    A is negative then A << B has undefined behavior and A >> B has | ||||
|    implementation-defined behavior, but do not check these other | ||||
|    restrictions.  */ | ||||
| #define INT_LEFT_SHIFT_RANGE_OVERFLOW(a, b, min, max)   \ | ||||
|   ((a) < 0                                              \ | ||||
|    ? (a) < (min) >> (b)                                 \ | ||||
|    : (max) >> (b) < (a)) | ||||
| 
 | ||||
| /* True if __builtin_add_overflow (A, B, P) and __builtin_sub_overflow
 | ||||
|    (A, B, P) work when P is non-null.  */ | ||||
| #if 5 <= __GNUC__ && !defined __ICC | ||||
| # define _GL_HAS_BUILTIN_ADD_OVERFLOW 1 | ||||
| #elif defined __has_builtin | ||||
| # define _GL_HAS_BUILTIN_ADD_OVERFLOW __has_builtin (__builtin_add_overflow) | ||||
| #else | ||||
| # define _GL_HAS_BUILTIN_ADD_OVERFLOW 0 | ||||
| #endif | ||||
| 
 | ||||
| /* True if __builtin_mul_overflow (A, B, P) works when P is non-null.  */ | ||||
| #ifdef __clang__ | ||||
| /* Work around Clang bug <https://bugs.llvm.org/show_bug.cgi?id=16404>.  */ | ||||
| # define _GL_HAS_BUILTIN_MUL_OVERFLOW 0 | ||||
| #else | ||||
| # define _GL_HAS_BUILTIN_MUL_OVERFLOW _GL_HAS_BUILTIN_ADD_OVERFLOW | ||||
| #endif | ||||
| 
 | ||||
| /* True if __builtin_add_overflow_p (A, B, C) works, and similarly for
 | ||||
|    __builtin_mul_overflow_p and __builtin_mul_overflow_p.  */ | ||||
| #define _GL_HAS_BUILTIN_OVERFLOW_P (7 <= __GNUC__) | ||||
| 
 | ||||
| /* The _GL*_OVERFLOW macros have the same restrictions as the
 | ||||
|    *_RANGE_OVERFLOW macros, except that they do not assume that operands | ||||
|    (e.g., A and B) have the same type as MIN and MAX.  Instead, they assume | ||||
|    that the result (e.g., A + B) has that type.  */ | ||||
| #if _GL_HAS_BUILTIN_OVERFLOW_P | ||||
| # define _GL_ADD_OVERFLOW(a, b, min, max)                               \ | ||||
|    __builtin_add_overflow_p (a, b, (__typeof__ ((a) + (b))) 0) | ||||
| # define _GL_SUBTRACT_OVERFLOW(a, b, min, max)                          \ | ||||
|    __builtin_sub_overflow_p (a, b, (__typeof__ ((a) - (b))) 0) | ||||
| # define _GL_MULTIPLY_OVERFLOW(a, b, min, max)                          \ | ||||
|    __builtin_mul_overflow_p (a, b, (__typeof__ ((a) * (b))) 0) | ||||
| #else | ||||
| # define _GL_ADD_OVERFLOW(a, b, min, max)                                \ | ||||
|    ((min) < 0 ? INT_ADD_RANGE_OVERFLOW (a, b, min, max)                  \ | ||||
|     : (a) < 0 ? (b) <= (a) + (b)                                         \ | ||||
|     : (b) < 0 ? (a) <= (a) + (b)                                         \ | ||||
|     : (a) + (b) < (b)) | ||||
| # define _GL_SUBTRACT_OVERFLOW(a, b, min, max)                           \ | ||||
|    ((min) < 0 ? INT_SUBTRACT_RANGE_OVERFLOW (a, b, min, max)             \ | ||||
|     : (a) < 0 ? 1                                                        \ | ||||
|     : (b) < 0 ? (a) - (b) <= (a)                                         \ | ||||
|     : (a) < (b)) | ||||
| # define _GL_MULTIPLY_OVERFLOW(a, b, min, max)                           \ | ||||
|    (((min) == 0 && (((a) < 0 && 0 < (b)) || ((b) < 0 && 0 < (a))))       \ | ||||
|     || INT_MULTIPLY_RANGE_OVERFLOW (a, b, min, max)) | ||||
| #endif | ||||
| #define _GL_DIVIDE_OVERFLOW(a, b, min, max)                             \ | ||||
|   ((min) < 0 ? (b) == _GL_INT_NEGATE_CONVERT (min, 1) && (a) < - (max)  \ | ||||
|    : (a) < 0 ? (b) <= (a) + (b) - 1                                     \ | ||||
|    : (b) < 0 && (a) + (b) <= (a)) | ||||
| #define _GL_REMAINDER_OVERFLOW(a, b, min, max)                          \ | ||||
|   ((min) < 0 ? (b) == _GL_INT_NEGATE_CONVERT (min, 1) && (a) < - (max)  \ | ||||
|    : (a) < 0 ? (a) % (b) != ((max) - (b) + 1) % (b)                     \ | ||||
|    : (b) < 0 && ! _GL_UNSIGNED_NEG_MULTIPLE (a, b, max)) | ||||
| 
 | ||||
| /* Return a nonzero value if A is a mathematical multiple of B, where
 | ||||
|    A is unsigned, B is negative, and MAX is the maximum value of A's | ||||
|    type.  A's type must be the same as (A % B)'s type.  Normally (A % | ||||
|    -B == 0) suffices, but things get tricky if -B would overflow.  */ | ||||
| #define _GL_UNSIGNED_NEG_MULTIPLE(a, b, max)                            \ | ||||
|   (((b) < -_GL_SIGNED_INT_MAXIMUM (b)                                   \ | ||||
|     ? (_GL_SIGNED_INT_MAXIMUM (b) == (max)                              \ | ||||
|        ? (a)                                                            \ | ||||
|        : (a) % (_GL_INT_CONVERT (a, _GL_SIGNED_INT_MAXIMUM (b)) + 1))   \ | ||||
|     : (a) % - (b))                                                      \ | ||||
|    == 0) | ||||
| 
 | ||||
| /* Check for integer overflow, and report low order bits of answer.
 | ||||
| 
 | ||||
|    The INT_<op>_OVERFLOW macros return 1 if the corresponding C operators | ||||
|    might not yield numerically correct answers due to arithmetic overflow. | ||||
|    The INT_<op>_WRAPV macros compute the low-order bits of the sum, | ||||
|    difference, and product of two C integers, and return 1 if these | ||||
|    low-order bits are not numerically correct. | ||||
|    These macros work correctly on all known practical hosts, and do not rely | ||||
|    on undefined behavior due to signed arithmetic overflow. | ||||
| 
 | ||||
|    Example usage, assuming A and B are long int: | ||||
| 
 | ||||
|      if (INT_MULTIPLY_OVERFLOW (a, b)) | ||||
|        printf ("result would overflow\n"); | ||||
|      else | ||||
|        printf ("result is %ld (no overflow)\n", a * b); | ||||
| 
 | ||||
|    Example usage with WRAPV flavor: | ||||
| 
 | ||||
|      long int result; | ||||
|      bool overflow = INT_MULTIPLY_WRAPV (a, b, &result); | ||||
|      printf ("result is %ld (%s)\n", result, | ||||
|              overflow ? "after overflow" : "no overflow"); | ||||
| 
 | ||||
|    Restrictions on these macros: | ||||
| 
 | ||||
|    These macros do not check for all possible numerical problems or | ||||
|    undefined or unspecified behavior: they do not check for division | ||||
|    by zero, for bad shift counts, or for shifting negative numbers. | ||||
| 
 | ||||
|    These macros may evaluate their arguments zero or multiple times, so the | ||||
|    arguments should not have side effects. | ||||
| 
 | ||||
|    The WRAPV macros are not constant expressions.  They support only | ||||
|    +, binary -, and *.  Because the WRAPV macros convert the result, | ||||
|    they report overflow in different circumstances than the OVERFLOW | ||||
|    macros do. | ||||
| 
 | ||||
|    These macros are tuned for their last input argument being a constant. | ||||
| 
 | ||||
|    Return 1 if the integer expressions A * B, A - B, -A, A * B, A / B, | ||||
|    A % B, and A << B would overflow, respectively.  */ | ||||
| 
 | ||||
| #define INT_ADD_OVERFLOW(a, b) \ | ||||
|   _GL_BINARY_OP_OVERFLOW (a, b, _GL_ADD_OVERFLOW) | ||||
| #define INT_SUBTRACT_OVERFLOW(a, b) \ | ||||
|   _GL_BINARY_OP_OVERFLOW (a, b, _GL_SUBTRACT_OVERFLOW) | ||||
| #if _GL_HAS_BUILTIN_OVERFLOW_P | ||||
| # define INT_NEGATE_OVERFLOW(a) INT_SUBTRACT_OVERFLOW (0, a) | ||||
| #else | ||||
| # define INT_NEGATE_OVERFLOW(a) \ | ||||
|    INT_NEGATE_RANGE_OVERFLOW (a, _GL_INT_MINIMUM (a), _GL_INT_MAXIMUM (a)) | ||||
| #endif | ||||
| #define INT_MULTIPLY_OVERFLOW(a, b) \ | ||||
|   _GL_BINARY_OP_OVERFLOW (a, b, _GL_MULTIPLY_OVERFLOW) | ||||
| #define INT_DIVIDE_OVERFLOW(a, b) \ | ||||
|   _GL_BINARY_OP_OVERFLOW (a, b, _GL_DIVIDE_OVERFLOW) | ||||
| #define INT_REMAINDER_OVERFLOW(a, b) \ | ||||
|   _GL_BINARY_OP_OVERFLOW (a, b, _GL_REMAINDER_OVERFLOW) | ||||
| #define INT_LEFT_SHIFT_OVERFLOW(a, b) \ | ||||
|   INT_LEFT_SHIFT_RANGE_OVERFLOW (a, b, \ | ||||
|                                  _GL_INT_MINIMUM (a), _GL_INT_MAXIMUM (a)) | ||||
| 
 | ||||
| /* Return 1 if the expression A <op> B would overflow,
 | ||||
|    where OP_RESULT_OVERFLOW (A, B, MIN, MAX) does the actual test, | ||||
|    assuming MIN and MAX are the minimum and maximum for the result type. | ||||
|    Arguments should be free of side effects.  */ | ||||
| #define _GL_BINARY_OP_OVERFLOW(a, b, op_result_overflow)        \ | ||||
|   op_result_overflow (a, b,                                     \ | ||||
|                       _GL_INT_MINIMUM (_GL_INT_CONVERT (a, b)), \ | ||||
|                       _GL_INT_MAXIMUM (_GL_INT_CONVERT (a, b))) | ||||
| 
 | ||||
| /* Store the low-order bits of A + B, A - B, A * B, respectively, into *R.
 | ||||
|    Return 1 if the result overflows.  See above for restrictions.  */ | ||||
| #if _GL_HAS_BUILTIN_ADD_OVERFLOW | ||||
| # define INT_ADD_WRAPV(a, b, r) __builtin_add_overflow (a, b, r) | ||||
| # define INT_SUBTRACT_WRAPV(a, b, r) __builtin_sub_overflow (a, b, r) | ||||
| #else | ||||
| # define INT_ADD_WRAPV(a, b, r) \ | ||||
|    _GL_INT_OP_WRAPV (a, b, r, +, _GL_INT_ADD_RANGE_OVERFLOW) | ||||
| # define INT_SUBTRACT_WRAPV(a, b, r) \ | ||||
|    _GL_INT_OP_WRAPV (a, b, r, -, _GL_INT_SUBTRACT_RANGE_OVERFLOW) | ||||
| #endif | ||||
| #if _GL_HAS_BUILTIN_MUL_OVERFLOW | ||||
| # if (9 < __GNUC__ + (3 <= __GNUC_MINOR__) \ | ||||
|       || (__GNUC__ == 8 && 4 <= __GNUC_MINOR__)) | ||||
| #  define INT_MULTIPLY_WRAPV(a, b, r) __builtin_mul_overflow (a, b, r) | ||||
| # else | ||||
|    /* Work around GCC bug 91450.  */ | ||||
| #  define INT_MULTIPLY_WRAPV(a, b, r) \ | ||||
|     ((!_GL_SIGNED_TYPE_OR_EXPR (*(r)) && EXPR_SIGNED (a) && EXPR_SIGNED (b) \ | ||||
|       && _GL_INT_MULTIPLY_RANGE_OVERFLOW (a, b, 0, (__typeof__ (*(r))) -1)) \ | ||||
|      ? ((void) __builtin_mul_overflow (a, b, r), 1) \ | ||||
|      : __builtin_mul_overflow (a, b, r)) | ||||
| # endif | ||||
| #else | ||||
| # define INT_MULTIPLY_WRAPV(a, b, r) \ | ||||
|    _GL_INT_OP_WRAPV (a, b, r, *, _GL_INT_MULTIPLY_RANGE_OVERFLOW) | ||||
| #endif | ||||
| 
 | ||||
| /* Nonzero if this compiler has GCC bug 68193 or Clang bug 25390.  See:
 | ||||
|    https://gcc.gnu.org/bugzilla/show_bug.cgi?id=68193
 | ||||
|    https://llvm.org/bugs/show_bug.cgi?id=25390
 | ||||
|    For now, assume all versions of GCC-like compilers generate bogus | ||||
|    warnings for _Generic.  This matters only for compilers that | ||||
|    lack relevant builtins.  */ | ||||
| #if __GNUC__ | ||||
| # define _GL__GENERIC_BOGUS 1 | ||||
| #else | ||||
| # define _GL__GENERIC_BOGUS 0 | ||||
| #endif | ||||
| 
 | ||||
| /* Store the low-order bits of A <op> B into *R, where OP specifies
 | ||||
|    the operation and OVERFLOW the overflow predicate.  Return 1 if the | ||||
|    result overflows.  See above for restrictions.  */ | ||||
| #if 201112 <= __STDC_VERSION__ && !_GL__GENERIC_BOGUS | ||||
| # define _GL_INT_OP_WRAPV(a, b, r, op, overflow) \ | ||||
|    (_Generic \ | ||||
|     (*(r), \ | ||||
|      signed char: \ | ||||
|        _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned int, \ | ||||
|                         signed char, SCHAR_MIN, SCHAR_MAX), \ | ||||
|      unsigned char: \ | ||||
|        _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned int, \ | ||||
|                         unsigned char, 0, UCHAR_MAX), \ | ||||
|      short int: \ | ||||
|        _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned int, \ | ||||
|                         short int, SHRT_MIN, SHRT_MAX), \ | ||||
|      unsigned short int: \ | ||||
|        _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned int, \ | ||||
|                         unsigned short int, 0, USHRT_MAX), \ | ||||
|      int: \ | ||||
|        _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned int, \ | ||||
|                         int, INT_MIN, INT_MAX), \ | ||||
|      unsigned int: \ | ||||
|        _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned int, \ | ||||
|                         unsigned int, 0, UINT_MAX), \ | ||||
|      long int: \ | ||||
|        _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned long int, \ | ||||
|                         long int, LONG_MIN, LONG_MAX), \ | ||||
|      unsigned long int: \ | ||||
|        _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned long int, \ | ||||
|                         unsigned long int, 0, ULONG_MAX), \ | ||||
|      long long int: \ | ||||
|        _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned long long int, \ | ||||
|                         long long int, LLONG_MIN, LLONG_MAX), \ | ||||
|      unsigned long long int: \ | ||||
|        _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned long long int, \ | ||||
|                         unsigned long long int, 0, ULLONG_MAX))) | ||||
| #else | ||||
| /* Store the low-order bits of A <op> B into *R, where OP specifies
 | ||||
|    the operation and OVERFLOW the overflow predicate.  If *R is | ||||
|    signed, its type is ST with bounds SMIN..SMAX; otherwise its type | ||||
|    is UT with bounds U..UMAX.  ST and UT are narrower than int. | ||||
|    Return 1 if the result overflows.  See above for restrictions.  */ | ||||
| # if _GL_HAVE___TYPEOF__ | ||||
| #  define _GL_INT_OP_WRAPV_SMALLISH(a,b,r,op,overflow,st,smin,smax,ut,umax) \ | ||||
|     (TYPE_SIGNED (__typeof__ (*(r))) \ | ||||
|      ? _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned int, st, smin, smax) \ | ||||
|      : _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned int, ut, 0, umax)) | ||||
| # else | ||||
| #  define _GL_INT_OP_WRAPV_SMALLISH(a,b,r,op,overflow,st,smin,smax,ut,umax) \ | ||||
|     (overflow (a, b, smin, smax) \ | ||||
|      ? (overflow (a, b, 0, umax) \ | ||||
|         ? (*(r) = _GL_INT_OP_WRAPV_VIA_UNSIGNED (a,b,op,unsigned,st), 1) \ | ||||
|         : (*(r) = _GL_INT_OP_WRAPV_VIA_UNSIGNED (a,b,op,unsigned,st)) < 0) \ | ||||
|      : (overflow (a, b, 0, umax) \ | ||||
|         ? (*(r) = _GL_INT_OP_WRAPV_VIA_UNSIGNED (a,b,op,unsigned,st)) >= 0 \ | ||||
|         : (*(r) = _GL_INT_OP_WRAPV_VIA_UNSIGNED (a,b,op,unsigned,st), 0))) | ||||
| # endif | ||||
| 
 | ||||
| # define _GL_INT_OP_WRAPV(a, b, r, op, overflow) \ | ||||
|    (sizeof *(r) == sizeof (signed char) \ | ||||
|     ? _GL_INT_OP_WRAPV_SMALLISH (a, b, r, op, overflow, \ | ||||
|                                  signed char, SCHAR_MIN, SCHAR_MAX, \ | ||||
|                                  unsigned char, UCHAR_MAX) \ | ||||
|     : sizeof *(r) == sizeof (short int) \ | ||||
|     ? _GL_INT_OP_WRAPV_SMALLISH (a, b, r, op, overflow, \ | ||||
|                                  short int, SHRT_MIN, SHRT_MAX, \ | ||||
|                                  unsigned short int, USHRT_MAX) \ | ||||
|     : sizeof *(r) == sizeof (int) \ | ||||
|     ? (EXPR_SIGNED (*(r)) \ | ||||
|        ? _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned int, \ | ||||
|                           int, INT_MIN, INT_MAX) \ | ||||
|        : _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned int, \ | ||||
|                           unsigned int, 0, UINT_MAX)) \ | ||||
|     : _GL_INT_OP_WRAPV_LONGISH(a, b, r, op, overflow)) | ||||
| # ifdef LLONG_MAX | ||||
| #  define _GL_INT_OP_WRAPV_LONGISH(a, b, r, op, overflow) \ | ||||
|     (sizeof *(r) == sizeof (long int) \ | ||||
|      ? (EXPR_SIGNED (*(r)) \ | ||||
|         ? _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned long int, \ | ||||
|                            long int, LONG_MIN, LONG_MAX) \ | ||||
|         : _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned long int, \ | ||||
|                            unsigned long int, 0, ULONG_MAX)) \ | ||||
|      : (EXPR_SIGNED (*(r)) \ | ||||
|         ? _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned long long int, \ | ||||
|                            long long int, LLONG_MIN, LLONG_MAX) \ | ||||
|         : _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned long long int, \ | ||||
|                            unsigned long long int, 0, ULLONG_MAX))) | ||||
| # else | ||||
| #  define _GL_INT_OP_WRAPV_LONGISH(a, b, r, op, overflow) \ | ||||
|     (EXPR_SIGNED (*(r)) \ | ||||
|      ? _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned long int, \ | ||||
|                         long int, LONG_MIN, LONG_MAX) \ | ||||
|      : _GL_INT_OP_CALC (a, b, r, op, overflow, unsigned long int, \ | ||||
|                         unsigned long int, 0, ULONG_MAX)) | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| /* Store the low-order bits of A <op> B into *R, where the operation
 | ||||
|    is given by OP.  Use the unsigned type UT for calculation to avoid | ||||
|    overflow problems.  *R's type is T, with extrema TMIN and TMAX. | ||||
|    T must be a signed integer type.  Return 1 if the result overflows.  */ | ||||
| #define _GL_INT_OP_CALC(a, b, r, op, overflow, ut, t, tmin, tmax) \ | ||||
|   (overflow (a, b, tmin, tmax) \ | ||||
|    ? (*(r) = _GL_INT_OP_WRAPV_VIA_UNSIGNED (a, b, op, ut, t), 1) \ | ||||
|    : (*(r) = _GL_INT_OP_WRAPV_VIA_UNSIGNED (a, b, op, ut, t), 0)) | ||||
| 
 | ||||
| /* Return the low-order bits of A <op> B, where the operation is given
 | ||||
|    by OP.  Use the unsigned type UT for calculation to avoid undefined | ||||
|    behavior on signed integer overflow, and convert the result to type T. | ||||
|    UT is at least as wide as T and is no narrower than unsigned int, | ||||
|    T is two's complement, and there is no padding or trap representations. | ||||
|    Assume that converting UT to T yields the low-order bits, as is | ||||
|    done in all known two's-complement C compilers.  E.g., see: | ||||
|    https://gcc.gnu.org/onlinedocs/gcc/Integers-implementation.html
 | ||||
| 
 | ||||
|    According to the C standard, converting UT to T yields an | ||||
|    implementation-defined result or signal for values outside T's | ||||
|    range.  However, code that works around this theoretical problem | ||||
|    runs afoul of a compiler bug in Oracle Studio 12.3 x86.  See: | ||||
|    https://lists.gnu.org/r/bug-gnulib/2017-04/msg00049.html
 | ||||
|    As the compiler bug is real, don't try to work around the | ||||
|    theoretical problem.  */ | ||||
| 
 | ||||
| #define _GL_INT_OP_WRAPV_VIA_UNSIGNED(a, b, op, ut, t) \ | ||||
|   ((t) ((ut) (a) op (ut) (b))) | ||||
| 
 | ||||
| /* Return true if the numeric values A + B, A - B, A * B fall outside
 | ||||
|    the range TMIN..TMAX.  Arguments should be integer expressions | ||||
|    without side effects.  TMIN should be signed and nonpositive. | ||||
|    TMAX should be positive, and should be signed unless TMIN is zero.  */ | ||||
| #define _GL_INT_ADD_RANGE_OVERFLOW(a, b, tmin, tmax) \ | ||||
|   ((b) < 0 \ | ||||
|    ? (((tmin) \ | ||||
|        ? ((EXPR_SIGNED (_GL_INT_CONVERT (a, (tmin) - (b))) || (b) < (tmin)) \ | ||||
|           && (a) < (tmin) - (b)) \ | ||||
|        : (a) <= -1 - (b)) \ | ||||
|       || ((EXPR_SIGNED (a) ? 0 <= (a) : (tmax) < (a)) && (tmax) < (a) + (b))) \ | ||||
|    : (a) < 0 \ | ||||
|    ? (((tmin) \ | ||||
|        ? ((EXPR_SIGNED (_GL_INT_CONVERT (b, (tmin) - (a))) || (a) < (tmin)) \ | ||||
|           && (b) < (tmin) - (a)) \ | ||||
|        : (b) <= -1 - (a)) \ | ||||
|       || ((EXPR_SIGNED (_GL_INT_CONVERT (a, b)) || (tmax) < (b)) \ | ||||
|           && (tmax) < (a) + (b))) \ | ||||
|    : (tmax) < (b) || (tmax) - (b) < (a)) | ||||
| #define _GL_INT_SUBTRACT_RANGE_OVERFLOW(a, b, tmin, tmax) \ | ||||
|   (((a) < 0) == ((b) < 0) \ | ||||
|    ? ((a) < (b) \ | ||||
|       ? !(tmin) || -1 - (tmin) < (b) - (a) - 1 \ | ||||
|       : (tmax) < (a) - (b)) \ | ||||
|    : (a) < 0 \ | ||||
|    ? ((!EXPR_SIGNED (_GL_INT_CONVERT ((a) - (tmin), b)) && (a) - (tmin) < 0) \ | ||||
|       || (a) - (tmin) < (b)) \ | ||||
|    : ((! (EXPR_SIGNED (_GL_INT_CONVERT (tmax, b)) \ | ||||
|           && EXPR_SIGNED (_GL_INT_CONVERT ((tmax) + (b), a))) \ | ||||
|        && (tmax) <= -1 - (b)) \ | ||||
|       || (tmax) + (b) < (a))) | ||||
| #define _GL_INT_MULTIPLY_RANGE_OVERFLOW(a, b, tmin, tmax) \ | ||||
|   ((b) < 0 \ | ||||
|    ? ((a) < 0 \ | ||||
|       ? (EXPR_SIGNED (_GL_INT_CONVERT (tmax, b)) \ | ||||
|          ? (a) < (tmax) / (b) \ | ||||
|          : ((INT_NEGATE_OVERFLOW (b) \ | ||||
|              ? _GL_INT_CONVERT (b, tmax) >> (TYPE_WIDTH (b) - 1) \ | ||||
|              : (tmax) / -(b)) \ | ||||
|             <= -1 - (a))) \ | ||||
|       : INT_NEGATE_OVERFLOW (_GL_INT_CONVERT (b, tmin)) && (b) == -1 \ | ||||
|       ? (EXPR_SIGNED (a) \ | ||||
|          ? 0 < (a) + (tmin) \ | ||||
|          : 0 < (a) && -1 - (tmin) < (a) - 1) \ | ||||
|       : (tmin) / (b) < (a)) \ | ||||
|    : (b) == 0 \ | ||||
|    ? 0 \ | ||||
|    : ((a) < 0 \ | ||||
|       ? (INT_NEGATE_OVERFLOW (_GL_INT_CONVERT (a, tmin)) && (a) == -1 \ | ||||
|          ? (EXPR_SIGNED (b) ? 0 < (b) + (tmin) : -1 - (tmin) < (b) - 1) \ | ||||
|          : (tmin) / (a) < (b)) \ | ||||
|       : (tmax) / (b) < (a))) | ||||
| 
 | ||||
| #endif /* _GL_INTPROPS_H */ | ||||
							
								
								
									
										104
									
								
								third_party/make/lib/limits.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								third_party/make/lib/limits.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,104 @@ | |||
| /* A GNU-like <limits.h>.
 | ||||
| 
 | ||||
|    Copyright 2016-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or | ||||
|    modify it under the terms of the GNU General Public License | ||||
|    as published by the Free Software Foundation; either version 3, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program; if not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _@GUARD_PREFIX@_LIMITS_H | ||||
| 
 | ||||
| #if __GNUC__ >= 3 | ||||
| @PRAGMA_SYSTEM_HEADER@ | ||||
| #endif | ||||
| @PRAGMA_COLUMNS@ | ||||
| 
 | ||||
| /* The include_next requires a split double-inclusion guard.  */ | ||||
| #@INCLUDE_NEXT@ @NEXT_LIMITS_H@ | ||||
| 
 | ||||
| #ifndef _@GUARD_PREFIX@_LIMITS_H | ||||
| #define _@GUARD_PREFIX@_LIMITS_H | ||||
| 
 | ||||
| #ifndef LLONG_MIN | ||||
| # if defined LONG_LONG_MIN /* HP-UX 11.31 */ | ||||
| #  define LLONG_MIN LONG_LONG_MIN | ||||
| # elif defined LONGLONG_MIN /* IRIX 6.5 */ | ||||
| #  define LLONG_MIN LONGLONG_MIN | ||||
| # elif defined __GNUC__ | ||||
| #  define LLONG_MIN (- __LONG_LONG_MAX__ - 1LL) | ||||
| # endif | ||||
| #endif | ||||
| #ifndef LLONG_MAX | ||||
| # if defined LONG_LONG_MAX /* HP-UX 11.31 */ | ||||
| #  define LLONG_MAX LONG_LONG_MAX | ||||
| # elif defined LONGLONG_MAX /* IRIX 6.5 */ | ||||
| #  define LLONG_MAX LONGLONG_MAX | ||||
| # elif defined __GNUC__ | ||||
| #  define LLONG_MAX __LONG_LONG_MAX__ | ||||
| # endif | ||||
| #endif | ||||
| #ifndef ULLONG_MAX | ||||
| # if defined ULONG_LONG_MAX /* HP-UX 11.31 */ | ||||
| #  define ULLONG_MAX ULONG_LONG_MAX | ||||
| # elif defined ULONGLONG_MAX /* IRIX 6.5 */ | ||||
| #  define ULLONG_MAX ULONGLONG_MAX | ||||
| # elif defined __GNUC__ | ||||
| #  define ULLONG_MAX (__LONG_LONG_MAX__ * 2ULL + 1ULL) | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| /* The number of usable bits in an unsigned or signed integer type
 | ||||
|    with minimum value MIN and maximum value MAX, as an int expression | ||||
|    suitable in #if.  Cover all known practical hosts.  This | ||||
|    implementation exploits the fact that MAX is 1 less than a power of | ||||
|    2, and merely counts the number of 1 bits in MAX; "COBn" means | ||||
|    "count the number of 1 bits in the low-order n bits").  */ | ||||
| #define _GL_INTEGER_WIDTH(min, max) (((min) < 0) + _GL_COB128 (max)) | ||||
| #define _GL_COB128(n) (_GL_COB64 ((n) >> 31 >> 31 >> 2) + _GL_COB64 (n)) | ||||
| #define _GL_COB64(n) (_GL_COB32 ((n) >> 31 >> 1) + _GL_COB32 (n)) | ||||
| #define _GL_COB32(n) (_GL_COB16 ((n) >> 16) + _GL_COB16 (n)) | ||||
| #define _GL_COB16(n) (_GL_COB8 ((n) >> 8) + _GL_COB8 (n)) | ||||
| #define _GL_COB8(n) (_GL_COB4 ((n) >> 4) + _GL_COB4 (n)) | ||||
| #define _GL_COB4(n) (!!((n) & 8) + !!((n) & 4) + !!((n) & 2) + !!((n) & 1)) | ||||
| 
 | ||||
| #ifndef WORD_BIT | ||||
| /* Assume 'int' is 32 bits wide.  */ | ||||
| # define WORD_BIT 32 | ||||
| #endif | ||||
| #ifndef LONG_BIT | ||||
| /* Assume 'long' is 32 or 64 bits wide.  */ | ||||
| # if LONG_MAX == INT_MAX | ||||
| #  define LONG_BIT 32 | ||||
| # else | ||||
| #  define LONG_BIT 64 | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| /* Macros specified by ISO/IEC TS 18661-1:2014.  */ | ||||
| 
 | ||||
| #if (! defined ULLONG_WIDTH                                             \ | ||||
|      && (defined _GNU_SOURCE || defined __STDC_WANT_IEC_60559_BFP_EXT__)) | ||||
| # define CHAR_WIDTH _GL_INTEGER_WIDTH (CHAR_MIN, CHAR_MAX) | ||||
| # define SCHAR_WIDTH _GL_INTEGER_WIDTH (SCHAR_MIN, SCHAR_MAX) | ||||
| # define UCHAR_WIDTH _GL_INTEGER_WIDTH (0, UCHAR_MAX) | ||||
| # define SHRT_WIDTH _GL_INTEGER_WIDTH (SHRT_MIN, SHRT_MAX) | ||||
| # define USHRT_WIDTH _GL_INTEGER_WIDTH (0, USHRT_MAX) | ||||
| # define INT_WIDTH _GL_INTEGER_WIDTH (INT_MIN, INT_MAX) | ||||
| # define UINT_WIDTH _GL_INTEGER_WIDTH (0, UINT_MAX) | ||||
| # define LONG_WIDTH _GL_INTEGER_WIDTH (LONG_MIN, LONG_MAX) | ||||
| # define ULONG_WIDTH _GL_INTEGER_WIDTH (0, ULONG_MAX) | ||||
| # define LLONG_WIDTH _GL_INTEGER_WIDTH (LLONG_MIN, LLONG_MAX) | ||||
| # define ULLONG_WIDTH _GL_INTEGER_WIDTH (0, ULLONG_MAX) | ||||
| #endif /* !ULLONG_WIDTH && (_GNU_SOURCE || __STDC_WANT_IEC_60559_BFP_EXT__) */ | ||||
| 
 | ||||
| #endif /* _@GUARD_PREFIX@_LIMITS_H */ | ||||
| #endif /* _@GUARD_PREFIX@_LIMITS_H */ | ||||
							
								
								
									
										56
									
								
								third_party/make/lib/malloc.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								third_party/make/lib/malloc.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,56 @@ | |||
| /* malloc() function that is glibc compatible.
 | ||||
| 
 | ||||
|    Copyright (C) 1997-1998, 2006-2007, 2009-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program; if not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| /* written by Jim Meyering and Bruno Haible */ | ||||
| 
 | ||||
| #define _GL_USE_STDLIB_ALLOC 1 | ||||
| #include <config.h> | ||||
| /* Only the AC_FUNC_MALLOC macro defines 'malloc' already in config.h.  */ | ||||
| #ifdef malloc | ||||
| # define NEED_MALLOC_GNU 1 | ||||
| # undef malloc | ||||
| /* Whereas the gnulib module 'malloc-gnu' defines HAVE_MALLOC_GNU.  */ | ||||
| #elif GNULIB_MALLOC_GNU && !HAVE_MALLOC_GNU | ||||
| # define NEED_MALLOC_GNU 1 | ||||
| #endif | ||||
| 
 | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| #include <errno.h> | ||||
| 
 | ||||
| /* Allocate an N-byte block of memory from the heap.
 | ||||
|    If N is zero, allocate a 1-byte block.  */ | ||||
| 
 | ||||
| void * | ||||
| rpl_malloc (size_t n) | ||||
| { | ||||
|   void *result; | ||||
| 
 | ||||
| #if NEED_MALLOC_GNU | ||||
|   if (n == 0) | ||||
|     n = 1; | ||||
| #endif | ||||
| 
 | ||||
|   result = malloc (n); | ||||
| 
 | ||||
| #if !HAVE_MALLOC_POSIX | ||||
|   if (result == NULL) | ||||
|     errno = ENOMEM; | ||||
| #endif | ||||
| 
 | ||||
|   return result; | ||||
| } | ||||
							
								
								
									
										129
									
								
								third_party/make/lib/msvc-inval.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										129
									
								
								third_party/make/lib/msvc-inval.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,129 @@ | |||
| /* Invalid parameter handler for MSVC runtime libraries.
 | ||||
|    Copyright (C) 2011-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License along | ||||
|    with this program; if not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include "msvc-inval.h" | ||||
| 
 | ||||
| #if HAVE_MSVC_INVALID_PARAMETER_HANDLER \ | ||||
|     && !(MSVC_INVALID_PARAMETER_HANDLING == SANE_LIBRARY_HANDLING) | ||||
| 
 | ||||
| /* Get _invalid_parameter_handler type and _set_invalid_parameter_handler
 | ||||
|    declaration.  */ | ||||
| # include <stdlib.h> | ||||
| 
 | ||||
| # if MSVC_INVALID_PARAMETER_HANDLING == DEFAULT_HANDLING | ||||
| 
 | ||||
| static void __cdecl | ||||
| gl_msvc_invalid_parameter_handler (const wchar_t *expression, | ||||
|                                    const wchar_t *function, | ||||
|                                    const wchar_t *file, | ||||
|                                    unsigned int line, | ||||
|                                    uintptr_t dummy) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| # else | ||||
| 
 | ||||
| /* Get declarations of the native Windows API functions.  */ | ||||
| #  define WIN32_LEAN_AND_MEAN | ||||
| #  include <windows.h> | ||||
| 
 | ||||
| #  if defined _MSC_VER | ||||
| 
 | ||||
| static void __cdecl | ||||
| gl_msvc_invalid_parameter_handler (const wchar_t *expression, | ||||
|                                    const wchar_t *function, | ||||
|                                    const wchar_t *file, | ||||
|                                    unsigned int line, | ||||
|                                    uintptr_t dummy) | ||||
| { | ||||
|   RaiseException (STATUS_GNULIB_INVALID_PARAMETER, 0, 0, NULL); | ||||
| } | ||||
| 
 | ||||
| #  else | ||||
| 
 | ||||
| /* An index to thread-local storage.  */ | ||||
| static DWORD tls_index; | ||||
| static int tls_initialized /* = 0 */; | ||||
| 
 | ||||
| /* Used as a fallback only.  */ | ||||
| static struct gl_msvc_inval_per_thread not_per_thread; | ||||
| 
 | ||||
| struct gl_msvc_inval_per_thread * | ||||
| gl_msvc_inval_current (void) | ||||
| { | ||||
|   if (!tls_initialized) | ||||
|     { | ||||
|       tls_index = TlsAlloc (); | ||||
|       tls_initialized = 1; | ||||
|     } | ||||
|   if (tls_index == TLS_OUT_OF_INDEXES) | ||||
|     /* TlsAlloc had failed.  */ | ||||
|     return ¬_per_thread; | ||||
|   else | ||||
|     { | ||||
|       struct gl_msvc_inval_per_thread *pointer = | ||||
|         (struct gl_msvc_inval_per_thread *) TlsGetValue (tls_index); | ||||
|       if (pointer == NULL) | ||||
|         { | ||||
|           /* First call.  Allocate a new 'struct gl_msvc_inval_per_thread'.  */ | ||||
|           pointer = | ||||
|             (struct gl_msvc_inval_per_thread *) | ||||
|             malloc (sizeof (struct gl_msvc_inval_per_thread)); | ||||
|           if (pointer == NULL) | ||||
|             /* Could not allocate memory.  Use the global storage.  */ | ||||
|             pointer = ¬_per_thread; | ||||
|           TlsSetValue (tls_index, pointer); | ||||
|         } | ||||
|       return pointer; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| static void __cdecl | ||||
| gl_msvc_invalid_parameter_handler (const wchar_t *expression, | ||||
|                                    const wchar_t *function, | ||||
|                                    const wchar_t *file, | ||||
|                                    unsigned int line, | ||||
|                                    uintptr_t dummy) | ||||
| { | ||||
|   struct gl_msvc_inval_per_thread *current = gl_msvc_inval_current (); | ||||
|   if (current->restart_valid) | ||||
|     longjmp (current->restart, 1); | ||||
|   else | ||||
|     /* An invalid parameter notification from outside the gnulib code.
 | ||||
|        Give the caller a chance to intervene.  */ | ||||
|     RaiseException (STATUS_GNULIB_INVALID_PARAMETER, 0, 0, NULL); | ||||
| } | ||||
| 
 | ||||
| #  endif | ||||
| 
 | ||||
| # endif | ||||
| 
 | ||||
| static int gl_msvc_inval_initialized /* = 0 */; | ||||
| 
 | ||||
| void | ||||
| gl_msvc_inval_ensure_handler (void) | ||||
| { | ||||
|   if (gl_msvc_inval_initialized == 0) | ||||
|     { | ||||
|       _set_invalid_parameter_handler (gl_msvc_invalid_parameter_handler); | ||||
|       gl_msvc_inval_initialized = 1; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
							
								
								
									
										222
									
								
								third_party/make/lib/msvc-inval.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										222
									
								
								third_party/make/lib/msvc-inval.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,222 @@ | |||
| /* Invalid parameter handler for MSVC runtime libraries.
 | ||||
|    Copyright (C) 2011-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License along | ||||
|    with this program; if not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _MSVC_INVAL_H | ||||
| #define _MSVC_INVAL_H | ||||
| 
 | ||||
| /* With MSVC runtime libraries with the "invalid parameter handler" concept,
 | ||||
|    functions like fprintf(), dup2(), or close() crash when the caller passes | ||||
|    an invalid argument.  But POSIX wants error codes (such as EINVAL or EBADF) | ||||
|    instead. | ||||
|    This file defines macros that turn such an invalid parameter notification | ||||
|    into a non-local exit.  An error code can then be produced at the target | ||||
|    of this exit.  You can thus write code like | ||||
| 
 | ||||
|      TRY_MSVC_INVAL | ||||
|        { | ||||
|          <Code that can trigger an invalid parameter notification | ||||
|           but does not do 'return', 'break', 'continue', nor 'goto'.> | ||||
|        } | ||||
|      CATCH_MSVC_INVAL | ||||
|        { | ||||
|          <Code that handles an invalid parameter notification | ||||
|           but does not do 'return', 'break', 'continue', nor 'goto'.> | ||||
|        } | ||||
|      DONE_MSVC_INVAL; | ||||
| 
 | ||||
|    This entire block expands to a single statement. | ||||
| 
 | ||||
|    The handling of invalid parameters can be done in three ways: | ||||
| 
 | ||||
|      * The default way, which is reasonable for programs (not libraries): | ||||
|        AC_DEFINE([MSVC_INVALID_PARAMETER_HANDLING], [DEFAULT_HANDLING]) | ||||
| 
 | ||||
|      * The way for libraries that make "hairy" calls (like close(-1), or | ||||
|        fclose(fp) where fileno(fp) is closed, or simply getdtablesize()): | ||||
|        AC_DEFINE([MSVC_INVALID_PARAMETER_HANDLING], [HAIRY_LIBRARY_HANDLING]) | ||||
| 
 | ||||
|      * The way for libraries that make no "hairy" calls: | ||||
|        AC_DEFINE([MSVC_INVALID_PARAMETER_HANDLING], [SANE_LIBRARY_HANDLING]) | ||||
|  */ | ||||
| 
 | ||||
| #define DEFAULT_HANDLING       0 | ||||
| #define HAIRY_LIBRARY_HANDLING 1 | ||||
| #define SANE_LIBRARY_HANDLING  2 | ||||
| 
 | ||||
| #if HAVE_MSVC_INVALID_PARAMETER_HANDLER \ | ||||
|     && !(MSVC_INVALID_PARAMETER_HANDLING == SANE_LIBRARY_HANDLING) | ||||
| /* A native Windows platform with the "invalid parameter handler" concept,
 | ||||
|    and either DEFAULT_HANDLING or HAIRY_LIBRARY_HANDLING.  */ | ||||
| 
 | ||||
| # if MSVC_INVALID_PARAMETER_HANDLING == DEFAULT_HANDLING | ||||
| /* Default handling.  */ | ||||
| 
 | ||||
| #  ifdef __cplusplus | ||||
| extern "C" { | ||||
| #  endif | ||||
| 
 | ||||
| /* Ensure that the invalid parameter handler in installed that just returns.
 | ||||
|    Because we assume no other part of the program installs a different | ||||
|    invalid parameter handler, this solution is multithread-safe.  */ | ||||
| extern void gl_msvc_inval_ensure_handler (void); | ||||
| 
 | ||||
| #  ifdef __cplusplus | ||||
| } | ||||
| #  endif | ||||
| 
 | ||||
| #  define TRY_MSVC_INVAL \ | ||||
|      do                                                                        \ | ||||
|        {                                                                       \ | ||||
|          gl_msvc_inval_ensure_handler ();                                      \ | ||||
|          if (1) | ||||
| #  define CATCH_MSVC_INVAL \ | ||||
|          else | ||||
| #  define DONE_MSVC_INVAL \ | ||||
|        }                                                                       \ | ||||
|      while (0) | ||||
| 
 | ||||
| # else | ||||
| /* Handling for hairy libraries.  */ | ||||
| 
 | ||||
| #  include <excpt.h> | ||||
| 
 | ||||
| /* Gnulib can define its own status codes, as described in the page
 | ||||
|    "Raising Software Exceptions" on microsoft.com | ||||
|    <https://docs.microsoft.com/en-us/cpp/cpp/raising-software-exceptions>.
 | ||||
|    Our status codes are composed of | ||||
|      - 0xE0000000, mandatory for all user-defined status codes, | ||||
|      - 0x474E550, a API identifier ("GNU"), | ||||
|      - 0, 1, 2, ..., used to distinguish different status codes from the | ||||
|        same API.  */ | ||||
| #  define STATUS_GNULIB_INVALID_PARAMETER (0xE0000000 + 0x474E550 + 0) | ||||
| 
 | ||||
| #  if defined _MSC_VER | ||||
| /* A compiler that supports __try/__except, as described in the page
 | ||||
|    "try-except statement" on microsoft.com | ||||
|    <https://docs.microsoft.com/en-us/cpp/cpp/try-except-statement>.
 | ||||
|    With __try/__except, we can use the multithread-safe exception handling.  */ | ||||
| 
 | ||||
| #   ifdef __cplusplus | ||||
| extern "C" { | ||||
| #   endif | ||||
| 
 | ||||
| /* Ensure that the invalid parameter handler in installed that raises a
 | ||||
|    software exception with code STATUS_GNULIB_INVALID_PARAMETER. | ||||
|    Because we assume no other part of the program installs a different | ||||
|    invalid parameter handler, this solution is multithread-safe.  */ | ||||
| extern void gl_msvc_inval_ensure_handler (void); | ||||
| 
 | ||||
| #   ifdef __cplusplus | ||||
| } | ||||
| #   endif | ||||
| 
 | ||||
| #   define TRY_MSVC_INVAL \ | ||||
|       do                                                                       \ | ||||
|         {                                                                      \ | ||||
|           gl_msvc_inval_ensure_handler ();                                     \ | ||||
|           __try | ||||
| #   define CATCH_MSVC_INVAL \ | ||||
|           __except (GetExceptionCode () == STATUS_GNULIB_INVALID_PARAMETER     \ | ||||
|                     ? EXCEPTION_EXECUTE_HANDLER                                \ | ||||
|                     : EXCEPTION_CONTINUE_SEARCH) | ||||
| #   define DONE_MSVC_INVAL \ | ||||
|         }                                                                      \ | ||||
|       while (0) | ||||
| 
 | ||||
| #  else | ||||
| /* Any compiler.
 | ||||
|    We can only use setjmp/longjmp.  */ | ||||
| 
 | ||||
| #   include <setjmp.h> | ||||
| 
 | ||||
| #   ifdef __cplusplus | ||||
| extern "C" { | ||||
| #   endif | ||||
| 
 | ||||
| struct gl_msvc_inval_per_thread | ||||
| { | ||||
|   /* The restart that will resume execution at the code between
 | ||||
|      CATCH_MSVC_INVAL and DONE_MSVC_INVAL.  It is enabled only between | ||||
|      TRY_MSVC_INVAL and CATCH_MSVC_INVAL.  */ | ||||
|   jmp_buf restart; | ||||
| 
 | ||||
|   /* Tells whether the contents of restart is valid.  */ | ||||
|   int restart_valid; | ||||
| }; | ||||
| 
 | ||||
| /* Ensure that the invalid parameter handler in installed that passes
 | ||||
|    control to the gl_msvc_inval_restart if it is valid, or raises a | ||||
|    software exception with code STATUS_GNULIB_INVALID_PARAMETER otherwise. | ||||
|    Because we assume no other part of the program installs a different | ||||
|    invalid parameter handler, this solution is multithread-safe.  */ | ||||
| extern void gl_msvc_inval_ensure_handler (void); | ||||
| 
 | ||||
| /* Return a pointer to the per-thread data for the current thread.  */ | ||||
| extern struct gl_msvc_inval_per_thread *gl_msvc_inval_current (void); | ||||
| 
 | ||||
| #   ifdef __cplusplus | ||||
| } | ||||
| #   endif | ||||
| 
 | ||||
| #   define TRY_MSVC_INVAL \ | ||||
|       do                                                                       \ | ||||
|         {                                                                      \ | ||||
|           struct gl_msvc_inval_per_thread *msvc_inval_current;                 \ | ||||
|           gl_msvc_inval_ensure_handler ();                                     \ | ||||
|           msvc_inval_current = gl_msvc_inval_current ();                       \ | ||||
|           /* First, initialize gl_msvc_inval_restart.  */                      \ | ||||
|           if (setjmp (msvc_inval_current->restart) == 0)                       \ | ||||
|             {                                                                  \ | ||||
|               /* Then, mark it as valid.  */                                   \ | ||||
|               msvc_inval_current->restart_valid = 1; | ||||
| #   define CATCH_MSVC_INVAL \ | ||||
|               /* Execution completed.                                          \
 | ||||
|                  Mark gl_msvc_inval_restart as invalid.  */                    \ | ||||
|               msvc_inval_current->restart_valid = 0;                           \ | ||||
|             }                                                                  \ | ||||
|           else                                                                 \ | ||||
|             {                                                                  \ | ||||
|               /* Execution triggered an invalid parameter notification.        \
 | ||||
|                  Mark gl_msvc_inval_restart as invalid.  */                    \ | ||||
|               msvc_inval_current->restart_valid = 0; | ||||
| #   define DONE_MSVC_INVAL \ | ||||
|             }                                                                  \ | ||||
|         }                                                                      \ | ||||
|       while (0) | ||||
| 
 | ||||
| #  endif | ||||
| 
 | ||||
| # endif | ||||
| 
 | ||||
| #else | ||||
| /* A platform that does not need to the invalid parameter handler,
 | ||||
|    or when SANE_LIBRARY_HANDLING is desired.  */ | ||||
| 
 | ||||
| /* The braces here avoid GCC warnings like
 | ||||
|    "warning: suggest explicit braces to avoid ambiguous 'else'".  */ | ||||
| # define TRY_MSVC_INVAL \ | ||||
|     do                                                                         \ | ||||
|       {                                                                        \ | ||||
|         if (1) | ||||
| # define CATCH_MSVC_INVAL \ | ||||
|         else | ||||
| # define DONE_MSVC_INVAL \ | ||||
|       }                                                                        \ | ||||
|     while (0) | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| #endif /* _MSVC_INVAL_H */ | ||||
							
								
								
									
										51
									
								
								third_party/make/lib/msvc-nothrow.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								third_party/make/lib/msvc-nothrow.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,51 @@ | |||
| /* Wrappers that don't throw invalid parameter notifications
 | ||||
|    with MSVC runtime libraries. | ||||
|    Copyright (C) 2011-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License along | ||||
|    with this program; if not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include "msvc-nothrow.h" | ||||
| 
 | ||||
| /* Get declarations of the native Windows API functions.  */ | ||||
| #define WIN32_LEAN_AND_MEAN | ||||
| #include <windows.h> | ||||
| 
 | ||||
| #if HAVE_MSVC_INVALID_PARAMETER_HANDLER | ||||
| # include "msvc-inval.h" | ||||
| #endif | ||||
| 
 | ||||
| #undef _get_osfhandle | ||||
| 
 | ||||
| #if HAVE_MSVC_INVALID_PARAMETER_HANDLER | ||||
| intptr_t | ||||
| _gl_nothrow_get_osfhandle (int fd) | ||||
| { | ||||
|   intptr_t result; | ||||
| 
 | ||||
|   TRY_MSVC_INVAL | ||||
|     { | ||||
|       result = _get_osfhandle (fd); | ||||
|     } | ||||
|   CATCH_MSVC_INVAL | ||||
|     { | ||||
|       result = (intptr_t) INVALID_HANDLE_VALUE; | ||||
|     } | ||||
|   DONE_MSVC_INVAL; | ||||
| 
 | ||||
|   return result; | ||||
| } | ||||
| #endif | ||||
							
								
								
									
										43
									
								
								third_party/make/lib/msvc-nothrow.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								third_party/make/lib/msvc-nothrow.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,43 @@ | |||
| /* Wrappers that don't throw invalid parameter notifications
 | ||||
|    with MSVC runtime libraries. | ||||
|    Copyright (C) 2011-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License along | ||||
|    with this program; if not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _MSVC_NOTHROW_H | ||||
| #define _MSVC_NOTHROW_H | ||||
| 
 | ||||
| /* With MSVC runtime libraries with the "invalid parameter handler" concept,
 | ||||
|    functions like fprintf(), dup2(), or close() crash when the caller passes | ||||
|    an invalid argument.  But POSIX wants error codes (such as EINVAL or EBADF) | ||||
|    instead. | ||||
|    This file defines wrappers that turn such an invalid parameter notification | ||||
|    into an error code.  */ | ||||
| 
 | ||||
| #if defined _WIN32 && ! defined __CYGWIN__ | ||||
| 
 | ||||
| /* Get original declaration of _get_osfhandle.  */ | ||||
| # include <io.h> | ||||
| 
 | ||||
| # if HAVE_MSVC_INVALID_PARAMETER_HANDLER | ||||
| 
 | ||||
| /* Override _get_osfhandle.  */ | ||||
| extern intptr_t _gl_nothrow_get_osfhandle (int fd); | ||||
| #  define _get_osfhandle _gl_nothrow_get_osfhandle | ||||
| 
 | ||||
| # endif | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| #endif /* _MSVC_NOTHROW_H */ | ||||
							
								
								
									
										132
									
								
								third_party/make/lib/stdbool.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										132
									
								
								third_party/make/lib/stdbool.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,132 @@ | |||
| /* Copyright (C) 2001-2003, 2006-2020 Free Software Foundation, Inc.
 | ||||
|    Written by Bruno Haible <haible@clisp.cons.org>, 2001. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program; if not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _GL_STDBOOL_H | ||||
| #define _GL_STDBOOL_H | ||||
| 
 | ||||
| /* ISO C 99 <stdbool.h> for platforms that lack it.  */ | ||||
| 
 | ||||
| /* Usage suggestions:
 | ||||
| 
 | ||||
|    Programs that use <stdbool.h> should be aware of some limitations | ||||
|    and standards compliance issues. | ||||
| 
 | ||||
|    Standards compliance: | ||||
| 
 | ||||
|        - <stdbool.h> must be #included before 'bool', 'false', 'true' | ||||
|          can be used. | ||||
| 
 | ||||
|        - You cannot assume that sizeof (bool) == 1. | ||||
| 
 | ||||
|        - Programs should not undefine the macros bool, true, and false, | ||||
|          as C99 lists that as an "obsolescent feature". | ||||
| 
 | ||||
|    Limitations of this substitute, when used in a C89 environment: | ||||
| 
 | ||||
|        - <stdbool.h> must be #included before the '_Bool' type can be used. | ||||
| 
 | ||||
|        - You cannot assume that _Bool is a typedef; it might be a macro. | ||||
| 
 | ||||
|        - Bit-fields of type 'bool' are not supported.  Portable code | ||||
|          should use 'unsigned int foo : 1;' rather than 'bool foo : 1;'. | ||||
| 
 | ||||
|        - In C99, casts and automatic conversions to '_Bool' or 'bool' are | ||||
|          performed in such a way that every nonzero value gets converted | ||||
|          to 'true', and zero gets converted to 'false'.  This doesn't work | ||||
|          with this substitute.  With this substitute, only the values 0 and 1 | ||||
|          give the expected result when converted to _Bool' or 'bool'. | ||||
| 
 | ||||
|        - C99 allows the use of (_Bool)0.0 in constant expressions, but | ||||
|          this substitute cannot always provide this property. | ||||
| 
 | ||||
|    Also, it is suggested that programs use 'bool' rather than '_Bool'; | ||||
|    this isn't required, but 'bool' is more common.  */ | ||||
| 
 | ||||
| 
 | ||||
| /* 7.16. Boolean type and values */ | ||||
| 
 | ||||
| /* BeOS <sys/socket.h> already #defines false 0, true 1.  We use the same
 | ||||
|    definitions below, but temporarily we have to #undef them.  */ | ||||
| #if defined __BEOS__ && !defined __HAIKU__ | ||||
| # include <OS.h> /* defines bool but not _Bool */ | ||||
| # undef false | ||||
| # undef true | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| # define _Bool bool | ||||
| # define bool bool | ||||
| #else | ||||
| # if defined __BEOS__ && !defined __HAIKU__ | ||||
|   /* A compiler known to have 'bool'.  */ | ||||
|   /* If the compiler already has both 'bool' and '_Bool', we can assume they
 | ||||
|      are the same types.  */ | ||||
| #  if !@HAVE__BOOL@ | ||||
| typedef bool _Bool; | ||||
| #  endif | ||||
| # else | ||||
| #  if !defined __GNUC__ | ||||
|    /* If @HAVE__BOOL@:
 | ||||
|         Some HP-UX cc and AIX IBM C compiler versions have compiler bugs when | ||||
|         the built-in _Bool type is used.  See | ||||
|           https://gcc.gnu.org/ml/gcc-patches/2003-12/msg02303.html
 | ||||
|           https://lists.gnu.org/r/bug-coreutils/2005-11/msg00161.html
 | ||||
|           https://lists.gnu.org/r/bug-coreutils/2005-10/msg00086.html
 | ||||
|         Similar bugs are likely with other compilers as well; this file | ||||
|         wouldn't be used if <stdbool.h> was working. | ||||
|         So we override the _Bool type. | ||||
|       If !@HAVE__BOOL@: | ||||
|         Need to define _Bool ourselves. As 'signed char' or as an enum type? | ||||
|         Use of a typedef, with SunPRO C, leads to a stupid | ||||
|           "warning: _Bool is a keyword in ISO C99". | ||||
|         Use of an enum type, with IRIX cc, leads to a stupid | ||||
|           "warning(1185): enumerated type mixed with another type". | ||||
|         Even the existence of an enum type, without a typedef, | ||||
|           "Invalid enumerator. (badenum)" with HP-UX cc on Tru64. | ||||
|         The only benefit of the enum, debuggability, is not important | ||||
|         with these compilers.  So use 'signed char' and no enum.  */ | ||||
| #   define _Bool signed char | ||||
| #  else | ||||
|    /* With this compiler, trust the _Bool type if the compiler has it.  */ | ||||
| #   if !@HAVE__BOOL@ | ||||
|    /* For the sake of symbolic names in gdb, define true and false as
 | ||||
|       enum constants, not only as macros. | ||||
|       It is tempting to write | ||||
|          typedef enum { false = 0, true = 1 } _Bool; | ||||
|       so that gdb prints values of type 'bool' symbolically.  But then | ||||
|       values of type '_Bool' might promote to 'int' or 'unsigned int' | ||||
|       (see ISO C 99 6.7.2.2.(4)); however, '_Bool' must promote to 'int' | ||||
|       (see ISO C 99 6.3.1.1.(2)).  So add a negative value to the | ||||
|       enum; this ensures that '_Bool' promotes to 'int'.  */ | ||||
| typedef enum { _Bool_must_promote_to_int = -1, false = 0, true = 1 } _Bool; | ||||
| #   endif | ||||
| #  endif | ||||
| # endif | ||||
| # define bool _Bool | ||||
| #endif | ||||
| 
 | ||||
| /* The other macros must be usable in preprocessor directives.  */ | ||||
| #ifdef __cplusplus | ||||
| # define false false | ||||
| # define true true | ||||
| #else | ||||
| # define false 0 | ||||
| # define true 1 | ||||
| #endif | ||||
| 
 | ||||
| #define __bool_true_false_are_defined 1 | ||||
| 
 | ||||
| #endif /* _GL_STDBOOL_H */ | ||||
							
								
								
									
										121
									
								
								third_party/make/lib/stddef.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										121
									
								
								third_party/make/lib/stddef.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,121 @@ | |||
| /* A substitute for POSIX 2008 <stddef.h>, for platforms that have issues.
 | ||||
| 
 | ||||
|    Copyright (C) 2009-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program; if not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| /* Written by Eric Blake.  */ | ||||
| 
 | ||||
| /*
 | ||||
|  * POSIX 2008 <stddef.h> for platforms that have issues. | ||||
|  * <https://pubs.opengroup.org/onlinepubs/9699919799/basedefs/stddef.h.html>
 | ||||
|  */ | ||||
| 
 | ||||
| #if __GNUC__ >= 3 | ||||
| @PRAGMA_SYSTEM_HEADER@ | ||||
| #endif | ||||
| @PRAGMA_COLUMNS@ | ||||
| 
 | ||||
| #if defined __need_wchar_t || defined __need_size_t  \ | ||||
|   || defined __need_ptrdiff_t || defined __need_NULL \ | ||||
|   || defined __need_wint_t | ||||
| /* Special invocation convention inside gcc header files.  In
 | ||||
|    particular, gcc provides a version of <stddef.h> that blindly | ||||
|    redefines NULL even when __need_wint_t was defined, even though | ||||
|    wint_t is not normally provided by <stddef.h>.  Hence, we must | ||||
|    remember if special invocation has ever been used to obtain wint_t, | ||||
|    in which case we need to clean up NULL yet again.  */ | ||||
| 
 | ||||
| # if !(defined _@GUARD_PREFIX@_STDDEF_H && defined _GL_STDDEF_WINT_T) | ||||
| #  ifdef __need_wint_t | ||||
| #   define _GL_STDDEF_WINT_T | ||||
| #  endif | ||||
| #  @INCLUDE_NEXT@ @NEXT_STDDEF_H@ | ||||
| # endif | ||||
| 
 | ||||
| #else | ||||
| /* Normal invocation convention.  */ | ||||
| 
 | ||||
| # ifndef _@GUARD_PREFIX@_STDDEF_H | ||||
| 
 | ||||
| /* The include_next requires a split double-inclusion guard.  */ | ||||
| 
 | ||||
| #  @INCLUDE_NEXT@ @NEXT_STDDEF_H@ | ||||
| 
 | ||||
| /* On NetBSD 5.0, the definition of NULL lacks proper parentheses.  */ | ||||
| #  if (@REPLACE_NULL@ \ | ||||
|        && (!defined _@GUARD_PREFIX@_STDDEF_H || defined _GL_STDDEF_WINT_T)) | ||||
| #   undef NULL | ||||
| #   ifdef __cplusplus | ||||
|    /* ISO C++ says that the macro NULL must expand to an integer constant
 | ||||
|       expression, hence '((void *) 0)' is not allowed in C++.  */ | ||||
| #    if __GNUG__ >= 3 | ||||
|     /* GNU C++ has a __null macro that behaves like an integer ('int' or
 | ||||
|        'long') but has the same size as a pointer.  Use that, to avoid | ||||
|        warnings.  */ | ||||
| #     define NULL __null | ||||
| #    else | ||||
| #     define NULL 0L | ||||
| #    endif | ||||
| #   else | ||||
| #    define NULL ((void *) 0) | ||||
| #   endif | ||||
| #  endif | ||||
| 
 | ||||
| #  ifndef _@GUARD_PREFIX@_STDDEF_H | ||||
| #   define _@GUARD_PREFIX@_STDDEF_H | ||||
| 
 | ||||
| /* Some platforms lack wchar_t.  */ | ||||
| #if !@HAVE_WCHAR_T@ | ||||
| # define wchar_t int | ||||
| #endif | ||||
| 
 | ||||
| /* Some platforms lack max_align_t.  The check for _GCC_MAX_ALIGN_T is
 | ||||
|    a hack in case the configure-time test was done with g++ even though | ||||
|    we are currently compiling with gcc. | ||||
|    On MSVC, max_align_t is defined only in C++ mode, after <cstddef> was | ||||
|    included.  Its definition is good since it has an alignment of 8 (on x86 | ||||
|    and x86_64).  */ | ||||
| #if defined _MSC_VER && defined __cplusplus | ||||
| # include <cstddef> | ||||
| #else | ||||
| # if ! (@HAVE_MAX_ALIGN_T@ || defined _GCC_MAX_ALIGN_T) | ||||
| #  if !GNULIB_defined_max_align_t | ||||
| /* On the x86, the maximum storage alignment of double, long, etc. is 4,
 | ||||
|    but GCC's C11 ABI for x86 says that max_align_t has an alignment of 8, | ||||
|    and the C11 standard allows this.  Work around this problem by | ||||
|    using __alignof__ (which returns 8 for double) rather than _Alignof | ||||
|    (which returns 4), and align each union member accordingly.  */ | ||||
| #   ifdef __GNUC__ | ||||
| #    define _GL_STDDEF_ALIGNAS(type) \ | ||||
|        __attribute__ ((__aligned__ (__alignof__ (type)))) | ||||
| #   else | ||||
| #    define _GL_STDDEF_ALIGNAS(type) /* */ | ||||
| #   endif | ||||
| typedef union | ||||
| { | ||||
|   char *__p _GL_STDDEF_ALIGNAS (char *); | ||||
|   double __d _GL_STDDEF_ALIGNAS (double); | ||||
|   long double __ld _GL_STDDEF_ALIGNAS (long double); | ||||
|   long int __i _GL_STDDEF_ALIGNAS (long int); | ||||
| } rpl_max_align_t; | ||||
| #   define max_align_t rpl_max_align_t | ||||
| #   define GNULIB_defined_max_align_t 1 | ||||
| #  endif | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| #  endif /* _@GUARD_PREFIX@_STDDEF_H */ | ||||
| # endif /* _@GUARD_PREFIX@_STDDEF_H */ | ||||
| #endif /* __need_XXX */ | ||||
							
								
								
									
										746
									
								
								third_party/make/lib/stdint.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										746
									
								
								third_party/make/lib/stdint.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,746 @@ | |||
| /* Copyright (C) 2001-2002, 2004-2020 Free Software Foundation, Inc.
 | ||||
|    Written by Paul Eggert, Bruno Haible, Sam Steingold, Peter Burwood. | ||||
|    This file is part of gnulib. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program; if not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| /*
 | ||||
|  * ISO C 99 <stdint.h> for platforms that lack it. | ||||
|  * <https://pubs.opengroup.org/onlinepubs/9699919799/basedefs/stdint.h.html>
 | ||||
|  */ | ||||
| 
 | ||||
| #ifndef _@GUARD_PREFIX@_STDINT_H | ||||
| 
 | ||||
| #if __GNUC__ >= 3 | ||||
| @PRAGMA_SYSTEM_HEADER@ | ||||
| #endif | ||||
| @PRAGMA_COLUMNS@ | ||||
| 
 | ||||
| /* When including a system file that in turn includes <inttypes.h>,
 | ||||
|    use the system <inttypes.h>, not our substitute.  This avoids | ||||
|    problems with (for example) VMS, whose <sys/bitypes.h> includes | ||||
|    <inttypes.h>.  */ | ||||
| #define _GL_JUST_INCLUDE_SYSTEM_INTTYPES_H | ||||
| 
 | ||||
| /* On Android (Bionic libc), <sys/types.h> includes this file before
 | ||||
|    having defined 'time_t'.  Therefore in this case avoid including | ||||
|    other system header files; just include the system's <stdint.h>. | ||||
|    Ideally we should test __BIONIC__ here, but it is only defined after | ||||
|    <sys/cdefs.h> has been included; hence test __ANDROID__ instead.  */ | ||||
| #if defined __ANDROID__ && defined _GL_INCLUDING_SYS_TYPES_H | ||||
| # @INCLUDE_NEXT@ @NEXT_STDINT_H@ | ||||
| #else | ||||
| 
 | ||||
| /* Get those types that are already defined in other system include
 | ||||
|    files, so that we can "#define int8_t signed char" below without | ||||
|    worrying about a later system include file containing a "typedef | ||||
|    signed char int8_t;" that will get messed up by our macro.  Our | ||||
|    macros should all be consistent with the system versions, except | ||||
|    for the "fast" types and macros, which we recommend against using | ||||
|    in public interfaces due to compiler differences.  */ | ||||
| 
 | ||||
| #if @HAVE_STDINT_H@ | ||||
| # if defined __sgi && ! defined __c99 | ||||
|    /* Bypass IRIX's <stdint.h> if in C89 mode, since it merely annoys users
 | ||||
|       with "This header file is to be used only for c99 mode compilations" | ||||
|       diagnostics.  */ | ||||
| #  define __STDINT_H__ | ||||
| # endif | ||||
| 
 | ||||
|   /* Some pre-C++11 <stdint.h> implementations need this.  */ | ||||
| # ifdef __cplusplus | ||||
| #  ifndef __STDC_CONSTANT_MACROS | ||||
| #   define __STDC_CONSTANT_MACROS 1 | ||||
| #  endif | ||||
| #  ifndef __STDC_LIMIT_MACROS | ||||
| #   define __STDC_LIMIT_MACROS 1 | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
|   /* Other systems may have an incomplete or buggy <stdint.h>.
 | ||||
|      Include it before <inttypes.h>, since any "#include <stdint.h>" | ||||
|      in <inttypes.h> would reinclude us, skipping our contents because | ||||
|      _@GUARD_PREFIX@_STDINT_H is defined. | ||||
|      The include_next requires a split double-inclusion guard.  */ | ||||
| # @INCLUDE_NEXT@ @NEXT_STDINT_H@ | ||||
| #endif | ||||
| 
 | ||||
| #if ! defined _@GUARD_PREFIX@_STDINT_H && ! defined _GL_JUST_INCLUDE_SYSTEM_STDINT_H | ||||
| #define _@GUARD_PREFIX@_STDINT_H | ||||
| 
 | ||||
| /* Get SCHAR_MIN, SCHAR_MAX, UCHAR_MAX, INT_MIN, INT_MAX,
 | ||||
|    LONG_MIN, LONG_MAX, ULONG_MAX, _GL_INTEGER_WIDTH.  */ | ||||
| #include <limits.h> | ||||
| 
 | ||||
| /* Override WINT_MIN and WINT_MAX if gnulib's <wchar.h> or <wctype.h> overrides
 | ||||
|    wint_t.  */ | ||||
| #if @GNULIB_OVERRIDES_WINT_T@ | ||||
| # undef WINT_MIN | ||||
| # undef WINT_MAX | ||||
| # define WINT_MIN 0x0U | ||||
| # define WINT_MAX 0xffffffffU | ||||
| #endif | ||||
| 
 | ||||
| #if ! @HAVE_C99_STDINT_H@ | ||||
| 
 | ||||
| /* <sys/types.h> defines some of the stdint.h types as well, on glibc,
 | ||||
|    IRIX 6.5, and OpenBSD 3.8 (via <machine/types.h>). | ||||
|    AIX 5.2 <sys/types.h> isn't needed and causes troubles. | ||||
|    Mac OS X 10.4.6 <sys/types.h> includes <stdint.h> (which is us), but | ||||
|    relies on the system <stdint.h> definitions, so include | ||||
|    <sys/types.h> after @NEXT_STDINT_H@.  */ | ||||
| # if @HAVE_SYS_TYPES_H@ && ! defined _AIX | ||||
| #  include <sys/types.h> | ||||
| # endif | ||||
| 
 | ||||
| # if @HAVE_INTTYPES_H@ | ||||
|   /* In OpenBSD 3.8, <inttypes.h> includes <machine/types.h>, which defines
 | ||||
|      int{8,16,32,64}_t, uint{8,16,32,64}_t and __BIT_TYPES_DEFINED__. | ||||
|      <inttypes.h> also defines intptr_t and uintptr_t.  */ | ||||
| #  include <inttypes.h> | ||||
| # elif @HAVE_SYS_INTTYPES_H@ | ||||
|   /* Solaris 7 <sys/inttypes.h> has the types except the *_fast*_t types, and
 | ||||
|      the macros except for *_FAST*_*, INTPTR_MIN, PTRDIFF_MIN, PTRDIFF_MAX.  */ | ||||
| #  include <sys/inttypes.h> | ||||
| # endif | ||||
| 
 | ||||
| # if @HAVE_SYS_BITYPES_H@ && ! defined __BIT_TYPES_DEFINED__ | ||||
|   /* Linux libc4 >= 4.6.7 and libc5 have a <sys/bitypes.h> that defines
 | ||||
|      int{8,16,32,64}_t and __BIT_TYPES_DEFINED__.  In libc5 >= 5.2.2 it is | ||||
|      included by <sys/types.h>.  */ | ||||
| #  include <sys/bitypes.h> | ||||
| # endif | ||||
| 
 | ||||
| # undef _GL_JUST_INCLUDE_SYSTEM_INTTYPES_H | ||||
| 
 | ||||
| /* Minimum and maximum values for an integer type under the usual assumption.
 | ||||
|    Return an unspecified value if BITS == 0, adding a check to pacify | ||||
|    picky compilers.  */ | ||||
| 
 | ||||
| /* These are separate macros, because if you try to merge these macros into
 | ||||
|    a single one, HP-UX cc rejects the resulting expression in constant | ||||
|    expressions.  */ | ||||
| # define _STDINT_UNSIGNED_MIN(bits, zero) \ | ||||
|     (zero) | ||||
| # define _STDINT_SIGNED_MIN(bits, zero) \ | ||||
|     (~ _STDINT_MAX (1, bits, zero)) | ||||
| 
 | ||||
| # define _STDINT_MAX(signed, bits, zero) \ | ||||
|     (((((zero) + 1) << ((bits) ? (bits) - 1 - (signed) : 0)) - 1) * 2 + 1) | ||||
| 
 | ||||
| #if !GNULIB_defined_stdint_types | ||||
| 
 | ||||
| /* 7.18.1.1. Exact-width integer types */ | ||||
| 
 | ||||
| /* Here we assume a standard architecture where the hardware integer
 | ||||
|    types have 8, 16, 32, optionally 64 bits.  */ | ||||
| 
 | ||||
| # undef int8_t | ||||
| # undef uint8_t | ||||
| typedef signed char gl_int8_t; | ||||
| typedef unsigned char gl_uint8_t; | ||||
| # define int8_t gl_int8_t | ||||
| # define uint8_t gl_uint8_t | ||||
| 
 | ||||
| # undef int16_t | ||||
| # undef uint16_t | ||||
| typedef short int gl_int16_t; | ||||
| typedef unsigned short int gl_uint16_t; | ||||
| # define int16_t gl_int16_t | ||||
| # define uint16_t gl_uint16_t | ||||
| 
 | ||||
| # undef int32_t | ||||
| # undef uint32_t | ||||
| typedef int gl_int32_t; | ||||
| typedef unsigned int gl_uint32_t; | ||||
| # define int32_t gl_int32_t | ||||
| # define uint32_t gl_uint32_t | ||||
| 
 | ||||
| /* If the system defines INT64_MAX, assume int64_t works.  That way,
 | ||||
|    if the underlying platform defines int64_t to be a 64-bit long long | ||||
|    int, the code below won't mistakenly define it to be a 64-bit long | ||||
|    int, which would mess up C++ name mangling.  We must use #ifdef | ||||
|    rather than #if, to avoid an error with HP-UX 10.20 cc.  */ | ||||
| 
 | ||||
| # ifdef INT64_MAX | ||||
| #  define GL_INT64_T | ||||
| # else | ||||
| /* Do not undefine int64_t if gnulib is not being used with 64-bit
 | ||||
|    types, since otherwise it breaks platforms like Tandem/NSK.  */ | ||||
| #  if LONG_MAX >> 31 >> 31 == 1 | ||||
| #   undef int64_t | ||||
| typedef long int gl_int64_t; | ||||
| #   define int64_t gl_int64_t | ||||
| #   define GL_INT64_T | ||||
| #  elif defined _MSC_VER | ||||
| #   undef int64_t | ||||
| typedef __int64 gl_int64_t; | ||||
| #   define int64_t gl_int64_t | ||||
| #   define GL_INT64_T | ||||
| #  else | ||||
| #   undef int64_t | ||||
| typedef long long int gl_int64_t; | ||||
| #   define int64_t gl_int64_t | ||||
| #   define GL_INT64_T | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
| # ifdef UINT64_MAX | ||||
| #  define GL_UINT64_T | ||||
| # else | ||||
| #  if ULONG_MAX >> 31 >> 31 >> 1 == 1 | ||||
| #   undef uint64_t | ||||
| typedef unsigned long int gl_uint64_t; | ||||
| #   define uint64_t gl_uint64_t | ||||
| #   define GL_UINT64_T | ||||
| #  elif defined _MSC_VER | ||||
| #   undef uint64_t | ||||
| typedef unsigned __int64 gl_uint64_t; | ||||
| #   define uint64_t gl_uint64_t | ||||
| #   define GL_UINT64_T | ||||
| #  else | ||||
| #   undef uint64_t | ||||
| typedef unsigned long long int gl_uint64_t; | ||||
| #   define uint64_t gl_uint64_t | ||||
| #   define GL_UINT64_T | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
| /* Avoid collision with Solaris 2.5.1 <pthread.h> etc.  */ | ||||
| # define _UINT8_T | ||||
| # define _UINT32_T | ||||
| # define _UINT64_T | ||||
| 
 | ||||
| 
 | ||||
| /* 7.18.1.2. Minimum-width integer types */ | ||||
| 
 | ||||
| /* Here we assume a standard architecture where the hardware integer
 | ||||
|    types have 8, 16, 32, optionally 64 bits. Therefore the leastN_t types | ||||
|    are the same as the corresponding N_t types.  */ | ||||
| 
 | ||||
| # undef int_least8_t | ||||
| # undef uint_least8_t | ||||
| # undef int_least16_t | ||||
| # undef uint_least16_t | ||||
| # undef int_least32_t | ||||
| # undef uint_least32_t | ||||
| # undef int_least64_t | ||||
| # undef uint_least64_t | ||||
| # define int_least8_t int8_t | ||||
| # define uint_least8_t uint8_t | ||||
| # define int_least16_t int16_t | ||||
| # define uint_least16_t uint16_t | ||||
| # define int_least32_t int32_t | ||||
| # define uint_least32_t uint32_t | ||||
| # ifdef GL_INT64_T | ||||
| #  define int_least64_t int64_t | ||||
| # endif | ||||
| # ifdef GL_UINT64_T | ||||
| #  define uint_least64_t uint64_t | ||||
| # endif | ||||
| 
 | ||||
| /* 7.18.1.3. Fastest minimum-width integer types */ | ||||
| 
 | ||||
| /* Note: Other <stdint.h> substitutes may define these types differently.
 | ||||
|    It is not recommended to use these types in public header files. */ | ||||
| 
 | ||||
| /* Here we assume a standard architecture where the hardware integer
 | ||||
|    types have 8, 16, 32, optionally 64 bits. Therefore the fastN_t types | ||||
|    are taken from the same list of types.  The following code normally | ||||
|    uses types consistent with glibc, as that lessens the chance of | ||||
|    incompatibility with older GNU hosts.  */ | ||||
| 
 | ||||
| # undef int_fast8_t | ||||
| # undef uint_fast8_t | ||||
| # undef int_fast16_t | ||||
| # undef uint_fast16_t | ||||
| # undef int_fast32_t | ||||
| # undef uint_fast32_t | ||||
| # undef int_fast64_t | ||||
| # undef uint_fast64_t | ||||
| typedef signed char gl_int_fast8_t; | ||||
| typedef unsigned char gl_uint_fast8_t; | ||||
| 
 | ||||
| # ifdef __sun | ||||
| /* Define types compatible with SunOS 5.10, so that code compiled under
 | ||||
|    earlier SunOS versions works with code compiled under SunOS 5.10.  */ | ||||
| typedef int gl_int_fast32_t; | ||||
| typedef unsigned int gl_uint_fast32_t; | ||||
| # else | ||||
| typedef long int gl_int_fast32_t; | ||||
| typedef unsigned long int gl_uint_fast32_t; | ||||
| # endif | ||||
| typedef gl_int_fast32_t gl_int_fast16_t; | ||||
| typedef gl_uint_fast32_t gl_uint_fast16_t; | ||||
| 
 | ||||
| # define int_fast8_t gl_int_fast8_t | ||||
| # define uint_fast8_t gl_uint_fast8_t | ||||
| # define int_fast16_t gl_int_fast16_t | ||||
| # define uint_fast16_t gl_uint_fast16_t | ||||
| # define int_fast32_t gl_int_fast32_t | ||||
| # define uint_fast32_t gl_uint_fast32_t | ||||
| # ifdef GL_INT64_T | ||||
| #  define int_fast64_t int64_t | ||||
| # endif | ||||
| # ifdef GL_UINT64_T | ||||
| #  define uint_fast64_t uint64_t | ||||
| # endif | ||||
| 
 | ||||
| /* 7.18.1.4. Integer types capable of holding object pointers */ | ||||
| 
 | ||||
| /* kLIBC's <stdint.h> defines _INTPTR_T_DECLARED and needs its own
 | ||||
|    definitions of intptr_t and uintptr_t (which use int and unsigned) | ||||
|    to avoid clashes with declarations of system functions like sbrk. | ||||
|    Similarly, mingw 5.22 <crtdefs.h> defines _INTPTR_T_DEFINED and | ||||
|    _UINTPTR_T_DEFINED and needs its own definitions of intptr_t and | ||||
|    uintptr_t to avoid conflicting declarations of system functions like | ||||
|    _findclose in <io.h>.  */ | ||||
| # if !((defined __KLIBC__ && defined _INTPTR_T_DECLARED) \ | ||||
|        || (defined __MINGW32__ && defined _INTPTR_T_DEFINED && defined _UINTPTR_T_DEFINED)) | ||||
| #  undef intptr_t | ||||
| #  undef uintptr_t | ||||
| #  ifdef _WIN64 | ||||
| typedef long long int gl_intptr_t; | ||||
| typedef unsigned long long int gl_uintptr_t; | ||||
| #  else | ||||
| typedef long int gl_intptr_t; | ||||
| typedef unsigned long int gl_uintptr_t; | ||||
| #  endif | ||||
| #  define intptr_t gl_intptr_t | ||||
| #  define uintptr_t gl_uintptr_t | ||||
| # endif | ||||
| 
 | ||||
| /* 7.18.1.5. Greatest-width integer types */ | ||||
| 
 | ||||
| /* Note: These types are compiler dependent. It may be unwise to use them in
 | ||||
|    public header files. */ | ||||
| 
 | ||||
| /* If the system defines INTMAX_MAX, assume that intmax_t works, and
 | ||||
|    similarly for UINTMAX_MAX and uintmax_t.  This avoids problems with | ||||
|    assuming one type where another is used by the system.  */ | ||||
| 
 | ||||
| # ifndef INTMAX_MAX | ||||
| #  undef INTMAX_C | ||||
| #  undef intmax_t | ||||
| #  if LONG_MAX >> 30 == 1 | ||||
| typedef long long int gl_intmax_t; | ||||
| #   define intmax_t gl_intmax_t | ||||
| #  elif defined GL_INT64_T | ||||
| #   define intmax_t int64_t | ||||
| #  else | ||||
| typedef long int gl_intmax_t; | ||||
| #   define intmax_t gl_intmax_t | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
| # ifndef UINTMAX_MAX | ||||
| #  undef UINTMAX_C | ||||
| #  undef uintmax_t | ||||
| #  if ULONG_MAX >> 31 == 1 | ||||
| typedef unsigned long long int gl_uintmax_t; | ||||
| #   define uintmax_t gl_uintmax_t | ||||
| #  elif defined GL_UINT64_T | ||||
| #   define uintmax_t uint64_t | ||||
| #  else | ||||
| typedef unsigned long int gl_uintmax_t; | ||||
| #   define uintmax_t gl_uintmax_t | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
| /* Verify that intmax_t and uintmax_t have the same size.  Too much code
 | ||||
|    breaks if this is not the case.  If this check fails, the reason is likely | ||||
|    to be found in the autoconf macros.  */ | ||||
| typedef int _verify_intmax_size[sizeof (intmax_t) == sizeof (uintmax_t) | ||||
|                                 ? 1 : -1]; | ||||
| 
 | ||||
| # define GNULIB_defined_stdint_types 1 | ||||
| # endif /* !GNULIB_defined_stdint_types */ | ||||
| 
 | ||||
| /* 7.18.2. Limits of specified-width integer types */ | ||||
| 
 | ||||
| /* 7.18.2.1. Limits of exact-width integer types */ | ||||
| 
 | ||||
| /* Here we assume a standard architecture where the hardware integer
 | ||||
|    types have 8, 16, 32, optionally 64 bits.  */ | ||||
| 
 | ||||
| # undef INT8_MIN | ||||
| # undef INT8_MAX | ||||
| # undef UINT8_MAX | ||||
| # define INT8_MIN  (~ INT8_MAX) | ||||
| # define INT8_MAX  127 | ||||
| # define UINT8_MAX  255 | ||||
| 
 | ||||
| # undef INT16_MIN | ||||
| # undef INT16_MAX | ||||
| # undef UINT16_MAX | ||||
| # define INT16_MIN  (~ INT16_MAX) | ||||
| # define INT16_MAX  32767 | ||||
| # define UINT16_MAX  65535 | ||||
| 
 | ||||
| # undef INT32_MIN | ||||
| # undef INT32_MAX | ||||
| # undef UINT32_MAX | ||||
| # define INT32_MIN  (~ INT32_MAX) | ||||
| # define INT32_MAX  2147483647 | ||||
| # define UINT32_MAX  4294967295U | ||||
| 
 | ||||
| # if defined GL_INT64_T && ! defined INT64_MAX | ||||
| /* Prefer (- INTMAX_C (1) << 63) over (~ INT64_MAX) because SunPRO C 5.0
 | ||||
|    evaluates the latter incorrectly in preprocessor expressions.  */ | ||||
| #  define INT64_MIN  (- INTMAX_C (1) << 63) | ||||
| #  define INT64_MAX  INTMAX_C (9223372036854775807) | ||||
| # endif | ||||
| 
 | ||||
| # if defined GL_UINT64_T && ! defined UINT64_MAX | ||||
| #  define UINT64_MAX  UINTMAX_C (18446744073709551615) | ||||
| # endif | ||||
| 
 | ||||
| /* 7.18.2.2. Limits of minimum-width integer types */ | ||||
| 
 | ||||
| /* Here we assume a standard architecture where the hardware integer
 | ||||
|    types have 8, 16, 32, optionally 64 bits. Therefore the leastN_t types | ||||
|    are the same as the corresponding N_t types.  */ | ||||
| 
 | ||||
| # undef INT_LEAST8_MIN | ||||
| # undef INT_LEAST8_MAX | ||||
| # undef UINT_LEAST8_MAX | ||||
| # define INT_LEAST8_MIN  INT8_MIN | ||||
| # define INT_LEAST8_MAX  INT8_MAX | ||||
| # define UINT_LEAST8_MAX  UINT8_MAX | ||||
| 
 | ||||
| # undef INT_LEAST16_MIN | ||||
| # undef INT_LEAST16_MAX | ||||
| # undef UINT_LEAST16_MAX | ||||
| # define INT_LEAST16_MIN  INT16_MIN | ||||
| # define INT_LEAST16_MAX  INT16_MAX | ||||
| # define UINT_LEAST16_MAX  UINT16_MAX | ||||
| 
 | ||||
| # undef INT_LEAST32_MIN | ||||
| # undef INT_LEAST32_MAX | ||||
| # undef UINT_LEAST32_MAX | ||||
| # define INT_LEAST32_MIN  INT32_MIN | ||||
| # define INT_LEAST32_MAX  INT32_MAX | ||||
| # define UINT_LEAST32_MAX  UINT32_MAX | ||||
| 
 | ||||
| # undef INT_LEAST64_MIN | ||||
| # undef INT_LEAST64_MAX | ||||
| # ifdef GL_INT64_T | ||||
| #  define INT_LEAST64_MIN  INT64_MIN | ||||
| #  define INT_LEAST64_MAX  INT64_MAX | ||||
| # endif | ||||
| 
 | ||||
| # undef UINT_LEAST64_MAX | ||||
| # ifdef GL_UINT64_T | ||||
| #  define UINT_LEAST64_MAX  UINT64_MAX | ||||
| # endif | ||||
| 
 | ||||
| /* 7.18.2.3. Limits of fastest minimum-width integer types */ | ||||
| 
 | ||||
| /* Here we assume a standard architecture where the hardware integer
 | ||||
|    types have 8, 16, 32, optionally 64 bits. Therefore the fastN_t types | ||||
|    are taken from the same list of types.  */ | ||||
| 
 | ||||
| # undef INT_FAST8_MIN | ||||
| # undef INT_FAST8_MAX | ||||
| # undef UINT_FAST8_MAX | ||||
| # define INT_FAST8_MIN  SCHAR_MIN | ||||
| # define INT_FAST8_MAX  SCHAR_MAX | ||||
| # define UINT_FAST8_MAX  UCHAR_MAX | ||||
| 
 | ||||
| # undef INT_FAST16_MIN | ||||
| # undef INT_FAST16_MAX | ||||
| # undef UINT_FAST16_MAX | ||||
| # define INT_FAST16_MIN  INT_FAST32_MIN | ||||
| # define INT_FAST16_MAX  INT_FAST32_MAX | ||||
| # define UINT_FAST16_MAX  UINT_FAST32_MAX | ||||
| 
 | ||||
| # undef INT_FAST32_MIN | ||||
| # undef INT_FAST32_MAX | ||||
| # undef UINT_FAST32_MAX | ||||
| # ifdef __sun | ||||
| #  define INT_FAST32_MIN  INT_MIN | ||||
| #  define INT_FAST32_MAX  INT_MAX | ||||
| #  define UINT_FAST32_MAX  UINT_MAX | ||||
| # else | ||||
| #  define INT_FAST32_MIN  LONG_MIN | ||||
| #  define INT_FAST32_MAX  LONG_MAX | ||||
| #  define UINT_FAST32_MAX  ULONG_MAX | ||||
| # endif | ||||
| 
 | ||||
| # undef INT_FAST64_MIN | ||||
| # undef INT_FAST64_MAX | ||||
| # ifdef GL_INT64_T | ||||
| #  define INT_FAST64_MIN  INT64_MIN | ||||
| #  define INT_FAST64_MAX  INT64_MAX | ||||
| # endif | ||||
| 
 | ||||
| # undef UINT_FAST64_MAX | ||||
| # ifdef GL_UINT64_T | ||||
| #  define UINT_FAST64_MAX  UINT64_MAX | ||||
| # endif | ||||
| 
 | ||||
| /* 7.18.2.4. Limits of integer types capable of holding object pointers */ | ||||
| 
 | ||||
| # undef INTPTR_MIN | ||||
| # undef INTPTR_MAX | ||||
| # undef UINTPTR_MAX | ||||
| # ifdef _WIN64 | ||||
| #  define INTPTR_MIN  LLONG_MIN | ||||
| #  define INTPTR_MAX  LLONG_MAX | ||||
| #  define UINTPTR_MAX  ULLONG_MAX | ||||
| # else | ||||
| #  define INTPTR_MIN  LONG_MIN | ||||
| #  define INTPTR_MAX  LONG_MAX | ||||
| #  define UINTPTR_MAX  ULONG_MAX | ||||
| # endif | ||||
| 
 | ||||
| /* 7.18.2.5. Limits of greatest-width integer types */ | ||||
| 
 | ||||
| # ifndef INTMAX_MAX | ||||
| #  undef INTMAX_MIN | ||||
| #  ifdef INT64_MAX | ||||
| #   define INTMAX_MIN  INT64_MIN | ||||
| #   define INTMAX_MAX  INT64_MAX | ||||
| #  else | ||||
| #   define INTMAX_MIN  INT32_MIN | ||||
| #   define INTMAX_MAX  INT32_MAX | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
| # ifndef UINTMAX_MAX | ||||
| #  ifdef UINT64_MAX | ||||
| #   define UINTMAX_MAX  UINT64_MAX | ||||
| #  else | ||||
| #   define UINTMAX_MAX  UINT32_MAX | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
| /* 7.18.3. Limits of other integer types */ | ||||
| 
 | ||||
| /* ptrdiff_t limits */ | ||||
| # undef PTRDIFF_MIN | ||||
| # undef PTRDIFF_MAX | ||||
| # if @APPLE_UNIVERSAL_BUILD@ | ||||
| #  ifdef _LP64 | ||||
| #   define PTRDIFF_MIN  _STDINT_SIGNED_MIN (64, 0l) | ||||
| #   define PTRDIFF_MAX  _STDINT_MAX (1, 64, 0l) | ||||
| #  else | ||||
| #   define PTRDIFF_MIN  _STDINT_SIGNED_MIN (32, 0) | ||||
| #   define PTRDIFF_MAX  _STDINT_MAX (1, 32, 0) | ||||
| #  endif | ||||
| # else | ||||
| #  define PTRDIFF_MIN  \ | ||||
|     _STDINT_SIGNED_MIN (@BITSIZEOF_PTRDIFF_T@, 0@PTRDIFF_T_SUFFIX@) | ||||
| #  define PTRDIFF_MAX  \ | ||||
|     _STDINT_MAX (1, @BITSIZEOF_PTRDIFF_T@, 0@PTRDIFF_T_SUFFIX@) | ||||
| # endif | ||||
| 
 | ||||
| /* sig_atomic_t limits */ | ||||
| # undef SIG_ATOMIC_MIN | ||||
| # undef SIG_ATOMIC_MAX | ||||
| # if @HAVE_SIGNED_SIG_ATOMIC_T@ | ||||
| #  define SIG_ATOMIC_MIN  \ | ||||
|     _STDINT_SIGNED_MIN (@BITSIZEOF_SIG_ATOMIC_T@, 0@SIG_ATOMIC_T_SUFFIX@) | ||||
| # else | ||||
| #  define SIG_ATOMIC_MIN  \ | ||||
|     _STDINT_UNSIGNED_MIN (@BITSIZEOF_SIG_ATOMIC_T@, 0@SIG_ATOMIC_T_SUFFIX@) | ||||
| # endif | ||||
| # define SIG_ATOMIC_MAX  \ | ||||
|    _STDINT_MAX (@HAVE_SIGNED_SIG_ATOMIC_T@, @BITSIZEOF_SIG_ATOMIC_T@, \ | ||||
|                 0@SIG_ATOMIC_T_SUFFIX@) | ||||
| 
 | ||||
| 
 | ||||
| /* size_t limit */ | ||||
| # undef SIZE_MAX | ||||
| # if @APPLE_UNIVERSAL_BUILD@ | ||||
| #  ifdef _LP64 | ||||
| #   define SIZE_MAX  _STDINT_MAX (0, 64, 0ul) | ||||
| #  else | ||||
| #   define SIZE_MAX  _STDINT_MAX (0, 32, 0ul) | ||||
| #  endif | ||||
| # else | ||||
| #  define SIZE_MAX  _STDINT_MAX (0, @BITSIZEOF_SIZE_T@, 0@SIZE_T_SUFFIX@) | ||||
| # endif | ||||
| 
 | ||||
| /* wchar_t limits */ | ||||
| /* Get WCHAR_MIN, WCHAR_MAX.
 | ||||
|    This include is not on the top, above, because on OSF/1 4.0 we have a | ||||
|    sequence of nested includes | ||||
|    <wchar.h> -> <stdio.h> -> <getopt.h> -> <stdlib.h>, and the latter includes | ||||
|    <stdint.h> and assumes its types are already defined.  */ | ||||
| # if @HAVE_WCHAR_H@ && ! (defined WCHAR_MIN && defined WCHAR_MAX) | ||||
|   /* BSD/OS 4.0.1 has a bug: <stddef.h>, <stdio.h> and <time.h> must be
 | ||||
|      included before <wchar.h>.  */ | ||||
| #  include <stddef.h> | ||||
| #  include <stdio.h> | ||||
| #  include <time.h> | ||||
| #  define _GL_JUST_INCLUDE_SYSTEM_WCHAR_H | ||||
| #  include <wchar.h> | ||||
| #  undef _GL_JUST_INCLUDE_SYSTEM_WCHAR_H | ||||
| # endif | ||||
| # undef WCHAR_MIN | ||||
| # undef WCHAR_MAX | ||||
| # if @HAVE_SIGNED_WCHAR_T@ | ||||
| #  define WCHAR_MIN  \ | ||||
|     _STDINT_SIGNED_MIN (@BITSIZEOF_WCHAR_T@, 0@WCHAR_T_SUFFIX@) | ||||
| # else | ||||
| #  define WCHAR_MIN  \ | ||||
|     _STDINT_UNSIGNED_MIN (@BITSIZEOF_WCHAR_T@, 0@WCHAR_T_SUFFIX@) | ||||
| # endif | ||||
| # define WCHAR_MAX  \ | ||||
|    _STDINT_MAX (@HAVE_SIGNED_WCHAR_T@, @BITSIZEOF_WCHAR_T@, 0@WCHAR_T_SUFFIX@) | ||||
| 
 | ||||
| /* wint_t limits */ | ||||
| /* If gnulib's <wchar.h> or <wctype.h> overrides wint_t, @WINT_T_SUFFIX@ is not
 | ||||
|    accurate, therefore use the definitions from above.  */ | ||||
| # if !@GNULIB_OVERRIDES_WINT_T@ | ||||
| #  undef WINT_MIN | ||||
| #  undef WINT_MAX | ||||
| #  if @HAVE_SIGNED_WINT_T@ | ||||
| #   define WINT_MIN  \ | ||||
|      _STDINT_SIGNED_MIN (@BITSIZEOF_WINT_T@, 0@WINT_T_SUFFIX@) | ||||
| #  else | ||||
| #   define WINT_MIN  \ | ||||
|      _STDINT_UNSIGNED_MIN (@BITSIZEOF_WINT_T@, 0@WINT_T_SUFFIX@) | ||||
| #  endif | ||||
| #  define WINT_MAX  \ | ||||
|     _STDINT_MAX (@HAVE_SIGNED_WINT_T@, @BITSIZEOF_WINT_T@, 0@WINT_T_SUFFIX@) | ||||
| # endif | ||||
| 
 | ||||
| /* 7.18.4. Macros for integer constants */ | ||||
| 
 | ||||
| /* 7.18.4.1. Macros for minimum-width integer constants */ | ||||
| /* According to ISO C 99 Technical Corrigendum 1 */ | ||||
| 
 | ||||
| /* Here we assume a standard architecture where the hardware integer
 | ||||
|    types have 8, 16, 32, optionally 64 bits, and int is 32 bits.  */ | ||||
| 
 | ||||
| # undef INT8_C | ||||
| # undef UINT8_C | ||||
| # define INT8_C(x) x | ||||
| # define UINT8_C(x) x | ||||
| 
 | ||||
| # undef INT16_C | ||||
| # undef UINT16_C | ||||
| # define INT16_C(x) x | ||||
| # define UINT16_C(x) x | ||||
| 
 | ||||
| # undef INT32_C | ||||
| # undef UINT32_C | ||||
| # define INT32_C(x) x | ||||
| # define UINT32_C(x) x ## U | ||||
| 
 | ||||
| # undef INT64_C | ||||
| # undef UINT64_C | ||||
| # if LONG_MAX >> 31 >> 31 == 1 | ||||
| #  define INT64_C(x) x##L | ||||
| # elif defined _MSC_VER | ||||
| #  define INT64_C(x) x##i64 | ||||
| # else | ||||
| #  define INT64_C(x) x##LL | ||||
| # endif | ||||
| # if ULONG_MAX >> 31 >> 31 >> 1 == 1 | ||||
| #  define UINT64_C(x) x##UL | ||||
| # elif defined _MSC_VER | ||||
| #  define UINT64_C(x) x##ui64 | ||||
| # else | ||||
| #  define UINT64_C(x) x##ULL | ||||
| # endif | ||||
| 
 | ||||
| /* 7.18.4.2. Macros for greatest-width integer constants */ | ||||
| 
 | ||||
| # ifndef INTMAX_C | ||||
| #  if LONG_MAX >> 30 == 1 | ||||
| #   define INTMAX_C(x)   x##LL | ||||
| #  elif defined GL_INT64_T | ||||
| #   define INTMAX_C(x)   INT64_C(x) | ||||
| #  else | ||||
| #   define INTMAX_C(x)   x##L | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
| # ifndef UINTMAX_C | ||||
| #  if ULONG_MAX >> 31 == 1 | ||||
| #   define UINTMAX_C(x)  x##ULL | ||||
| #  elif defined GL_UINT64_T | ||||
| #   define UINTMAX_C(x)  UINT64_C(x) | ||||
| #  else | ||||
| #   define UINTMAX_C(x)  x##UL | ||||
| #  endif | ||||
| # endif | ||||
| 
 | ||||
| #endif /* !@HAVE_C99_STDINT_H@ */ | ||||
| 
 | ||||
| /* Macros specified by ISO/IEC TS 18661-1:2014.  */ | ||||
| 
 | ||||
| #if (!defined UINTMAX_WIDTH \ | ||||
|      && (defined _GNU_SOURCE || defined __STDC_WANT_IEC_60559_BFP_EXT__)) | ||||
| # ifdef INT8_MAX | ||||
| #  define INT8_WIDTH _GL_INTEGER_WIDTH (INT8_MIN, INT8_MAX) | ||||
| # endif | ||||
| # ifdef UINT8_MAX | ||||
| #  define UINT8_WIDTH _GL_INTEGER_WIDTH (0, UINT8_MAX) | ||||
| # endif | ||||
| # ifdef INT16_MAX | ||||
| #  define INT16_WIDTH _GL_INTEGER_WIDTH (INT16_MIN, INT16_MAX) | ||||
| # endif | ||||
| # ifdef UINT16_MAX | ||||
| #  define UINT16_WIDTH _GL_INTEGER_WIDTH (0, UINT16_MAX) | ||||
| # endif | ||||
| # ifdef INT32_MAX | ||||
| #  define INT32_WIDTH _GL_INTEGER_WIDTH (INT32_MIN, INT32_MAX) | ||||
| # endif | ||||
| # ifdef UINT32_MAX | ||||
| #  define UINT32_WIDTH _GL_INTEGER_WIDTH (0, UINT32_MAX) | ||||
| # endif | ||||
| # ifdef INT64_MAX | ||||
| #  define INT64_WIDTH _GL_INTEGER_WIDTH (INT64_MIN, INT64_MAX) | ||||
| # endif | ||||
| # ifdef UINT64_MAX | ||||
| #  define UINT64_WIDTH _GL_INTEGER_WIDTH (0, UINT64_MAX) | ||||
| # endif | ||||
| # define INT_LEAST8_WIDTH _GL_INTEGER_WIDTH (INT_LEAST8_MIN, INT_LEAST8_MAX) | ||||
| # define UINT_LEAST8_WIDTH _GL_INTEGER_WIDTH (0, UINT_LEAST8_MAX) | ||||
| # define INT_LEAST16_WIDTH _GL_INTEGER_WIDTH (INT_LEAST16_MIN, INT_LEAST16_MAX) | ||||
| # define UINT_LEAST16_WIDTH _GL_INTEGER_WIDTH (0, UINT_LEAST16_MAX) | ||||
| # define INT_LEAST32_WIDTH _GL_INTEGER_WIDTH (INT_LEAST32_MIN, INT_LEAST32_MAX) | ||||
| # define UINT_LEAST32_WIDTH _GL_INTEGER_WIDTH (0, UINT_LEAST32_MAX) | ||||
| # define INT_LEAST64_WIDTH _GL_INTEGER_WIDTH (INT_LEAST64_MIN, INT_LEAST64_MAX) | ||||
| # define UINT_LEAST64_WIDTH _GL_INTEGER_WIDTH (0, UINT_LEAST64_MAX) | ||||
| # define INT_FAST8_WIDTH _GL_INTEGER_WIDTH (INT_FAST8_MIN, INT_FAST8_MAX) | ||||
| # define UINT_FAST8_WIDTH _GL_INTEGER_WIDTH (0, UINT_FAST8_MAX) | ||||
| # define INT_FAST16_WIDTH _GL_INTEGER_WIDTH (INT_FAST16_MIN, INT_FAST16_MAX) | ||||
| # define UINT_FAST16_WIDTH _GL_INTEGER_WIDTH (0, UINT_FAST16_MAX) | ||||
| # define INT_FAST32_WIDTH _GL_INTEGER_WIDTH (INT_FAST32_MIN, INT_FAST32_MAX) | ||||
| # define UINT_FAST32_WIDTH _GL_INTEGER_WIDTH (0, UINT_FAST32_MAX) | ||||
| # define INT_FAST64_WIDTH _GL_INTEGER_WIDTH (INT_FAST64_MIN, INT_FAST64_MAX) | ||||
| # define UINT_FAST64_WIDTH _GL_INTEGER_WIDTH (0, UINT_FAST64_MAX) | ||||
| # define INTPTR_WIDTH _GL_INTEGER_WIDTH (INTPTR_MIN, INTPTR_MAX) | ||||
| # define UINTPTR_WIDTH _GL_INTEGER_WIDTH (0, UINTPTR_MAX) | ||||
| # define INTMAX_WIDTH _GL_INTEGER_WIDTH (INTMAX_MIN, INTMAX_MAX) | ||||
| # define UINTMAX_WIDTH _GL_INTEGER_WIDTH (0, UINTMAX_MAX) | ||||
| # define PTRDIFF_WIDTH _GL_INTEGER_WIDTH (PTRDIFF_MIN, PTRDIFF_MAX) | ||||
| # define SIZE_WIDTH _GL_INTEGER_WIDTH (0, SIZE_MAX) | ||||
| # define WCHAR_WIDTH _GL_INTEGER_WIDTH (WCHAR_MIN, WCHAR_MAX) | ||||
| # ifdef WINT_MAX | ||||
| #  define WINT_WIDTH _GL_INTEGER_WIDTH (WINT_MIN, WINT_MAX) | ||||
| # endif | ||||
| # ifdef SIG_ATOMIC_MAX | ||||
| #  define SIG_ATOMIC_WIDTH _GL_INTEGER_WIDTH (SIG_ATOMIC_MIN, SIG_ATOMIC_MAX) | ||||
| # endif | ||||
| #endif /* !WINT_WIDTH && (_GNU_SOURCE || __STDC_WANT_IEC_60559_BFP_EXT__) */ | ||||
| 
 | ||||
| #endif /* _@GUARD_PREFIX@_STDINT_H */ | ||||
| #endif /* !(defined __ANDROID__ && ...) */ | ||||
| #endif /* !defined _@GUARD_PREFIX@_STDINT_H && !defined _GL_JUST_INCLUDE_SYSTEM_STDINT_H */ | ||||
							
								
								
									
										1444
									
								
								third_party/make/lib/stdio.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1444
									
								
								third_party/make/lib/stdio.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										1112
									
								
								third_party/make/lib/stdlib.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1112
									
								
								third_party/make/lib/stdlib.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										49
									
								
								third_party/make/lib/stpcpy.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								third_party/make/lib/stpcpy.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,49 @@ | |||
| /* stpcpy.c -- copy a string and return pointer to end of new string
 | ||||
|    Copyright (C) 1992, 1995, 1997-1998, 2006, 2009-2020 Free Software | ||||
|    Foundation, Inc. | ||||
| 
 | ||||
|    NOTE: The canonical source of this file is maintained with the GNU C Library. | ||||
|    Bugs can be reported to bug-glibc@prep.ai.mit.edu. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify it | ||||
|    under the terms of the GNU General Public License as published by the | ||||
|    Free Software Foundation; either version 3 of the License, or any | ||||
|    later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| #include <string.h> | ||||
| 
 | ||||
| #undef __stpcpy | ||||
| #ifdef _LIBC | ||||
| # undef stpcpy | ||||
| #endif | ||||
| 
 | ||||
| #ifndef weak_alias | ||||
| # define __stpcpy stpcpy | ||||
| #endif | ||||
| 
 | ||||
| /* Copy SRC to DEST, returning the address of the terminating '\0' in DEST.  */ | ||||
| char * | ||||
| __stpcpy (char *dest, const char *src) | ||||
| { | ||||
|   register char *d = dest; | ||||
|   register const char *s = src; | ||||
| 
 | ||||
|   do | ||||
|     *d++ = *s; | ||||
|   while (*s++ != '\0'); | ||||
| 
 | ||||
|   return d - 1; | ||||
| } | ||||
| #ifdef weak_alias | ||||
| weak_alias (__stpcpy, stpcpy) | ||||
| #endif | ||||
							
								
								
									
										302
									
								
								third_party/make/lib/strerror-override.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										302
									
								
								third_party/make/lib/strerror-override.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,302 @@ | |||
| /* strerror-override.c --- POSIX compatible system error routine
 | ||||
| 
 | ||||
|    Copyright (C) 2010-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| /* Written by Bruno Haible <bruno@clisp.org>, 2010.  */ | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| #include "strerror-override.h" | ||||
| 
 | ||||
| #include <errno.h> | ||||
| 
 | ||||
| #if GNULIB_defined_EWINSOCK /* native Windows platforms */ | ||||
| # if HAVE_WINSOCK2_H | ||||
| #  include <winsock2.h> | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| /* If ERRNUM maps to an errno value defined by gnulib, return a string
 | ||||
|    describing the error.  Otherwise return NULL.  */ | ||||
| const char * | ||||
| strerror_override (int errnum) | ||||
| { | ||||
|   /* These error messages are taken from glibc/sysdeps/gnu/errlist.c.  */ | ||||
|   switch (errnum) | ||||
|     { | ||||
| #if REPLACE_STRERROR_0 | ||||
|     case 0: | ||||
|       return "Success"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_ESOCK /* native Windows platforms with older <errno.h> */ | ||||
|     case EINPROGRESS: | ||||
|       return "Operation now in progress"; | ||||
|     case EALREADY: | ||||
|       return "Operation already in progress"; | ||||
|     case ENOTSOCK: | ||||
|       return "Socket operation on non-socket"; | ||||
|     case EDESTADDRREQ: | ||||
|       return "Destination address required"; | ||||
|     case EMSGSIZE: | ||||
|       return "Message too long"; | ||||
|     case EPROTOTYPE: | ||||
|       return "Protocol wrong type for socket"; | ||||
|     case ENOPROTOOPT: | ||||
|       return "Protocol not available"; | ||||
|     case EPROTONOSUPPORT: | ||||
|       return "Protocol not supported"; | ||||
|     case EOPNOTSUPP: | ||||
|       return "Operation not supported"; | ||||
|     case EAFNOSUPPORT: | ||||
|       return "Address family not supported by protocol"; | ||||
|     case EADDRINUSE: | ||||
|       return "Address already in use"; | ||||
|     case EADDRNOTAVAIL: | ||||
|       return "Cannot assign requested address"; | ||||
|     case ENETDOWN: | ||||
|       return "Network is down"; | ||||
|     case ENETUNREACH: | ||||
|       return "Network is unreachable"; | ||||
|     case ECONNRESET: | ||||
|       return "Connection reset by peer"; | ||||
|     case ENOBUFS: | ||||
|       return "No buffer space available"; | ||||
|     case EISCONN: | ||||
|       return "Transport endpoint is already connected"; | ||||
|     case ENOTCONN: | ||||
|       return "Transport endpoint is not connected"; | ||||
|     case ETIMEDOUT: | ||||
|       return "Connection timed out"; | ||||
|     case ECONNREFUSED: | ||||
|       return "Connection refused"; | ||||
|     case ELOOP: | ||||
|       return "Too many levels of symbolic links"; | ||||
|     case EHOSTUNREACH: | ||||
|       return "No route to host"; | ||||
|     case EWOULDBLOCK: | ||||
|       return "Operation would block"; | ||||
| #endif | ||||
| #if GNULIB_defined_ESTREAMS /* native Windows platforms with older <errno.h> */ | ||||
|     case ETXTBSY: | ||||
|       return "Text file busy"; | ||||
|     case ENODATA: | ||||
|       return "No data available"; | ||||
|     case ENOSR: | ||||
|       return "Out of streams resources"; | ||||
|     case ENOSTR: | ||||
|       return "Device not a stream"; | ||||
|     case ETIME: | ||||
|       return "Timer expired"; | ||||
|     case EOTHER: | ||||
|       return "Other error"; | ||||
| #endif | ||||
| #if GNULIB_defined_EWINSOCK /* native Windows platforms */ | ||||
|     case ESOCKTNOSUPPORT: | ||||
|       return "Socket type not supported"; | ||||
|     case EPFNOSUPPORT: | ||||
|       return "Protocol family not supported"; | ||||
|     case ESHUTDOWN: | ||||
|       return "Cannot send after transport endpoint shutdown"; | ||||
|     case ETOOMANYREFS: | ||||
|       return "Too many references: cannot splice"; | ||||
|     case EHOSTDOWN: | ||||
|       return "Host is down"; | ||||
|     case EPROCLIM: | ||||
|       return "Too many processes"; | ||||
|     case EUSERS: | ||||
|       return "Too many users"; | ||||
|     case EDQUOT: | ||||
|       return "Disk quota exceeded"; | ||||
|     case ESTALE: | ||||
|       return "Stale NFS file handle"; | ||||
|     case EREMOTE: | ||||
|       return "Object is remote"; | ||||
| # if HAVE_WINSOCK2_H | ||||
|       /* WSA_INVALID_HANDLE maps to EBADF */ | ||||
|       /* WSA_NOT_ENOUGH_MEMORY maps to ENOMEM */ | ||||
|       /* WSA_INVALID_PARAMETER maps to EINVAL */ | ||||
|     case WSA_OPERATION_ABORTED: | ||||
|       return "Overlapped operation aborted"; | ||||
|     case WSA_IO_INCOMPLETE: | ||||
|       return "Overlapped I/O event object not in signaled state"; | ||||
|     case WSA_IO_PENDING: | ||||
|       return "Overlapped operations will complete later"; | ||||
|       /* WSAEINTR maps to EINTR */ | ||||
|       /* WSAEBADF maps to EBADF */ | ||||
|       /* WSAEACCES maps to EACCES */ | ||||
|       /* WSAEFAULT maps to EFAULT */ | ||||
|       /* WSAEINVAL maps to EINVAL */ | ||||
|       /* WSAEMFILE maps to EMFILE */ | ||||
|       /* WSAEWOULDBLOCK maps to EWOULDBLOCK */ | ||||
|       /* WSAEINPROGRESS maps to EINPROGRESS */ | ||||
|       /* WSAEALREADY maps to EALREADY */ | ||||
|       /* WSAENOTSOCK maps to ENOTSOCK */ | ||||
|       /* WSAEDESTADDRREQ maps to EDESTADDRREQ */ | ||||
|       /* WSAEMSGSIZE maps to EMSGSIZE */ | ||||
|       /* WSAEPROTOTYPE maps to EPROTOTYPE */ | ||||
|       /* WSAENOPROTOOPT maps to ENOPROTOOPT */ | ||||
|       /* WSAEPROTONOSUPPORT maps to EPROTONOSUPPORT */ | ||||
|       /* WSAESOCKTNOSUPPORT is ESOCKTNOSUPPORT */ | ||||
|       /* WSAEOPNOTSUPP maps to EOPNOTSUPP */ | ||||
|       /* WSAEPFNOSUPPORT is EPFNOSUPPORT */ | ||||
|       /* WSAEAFNOSUPPORT maps to EAFNOSUPPORT */ | ||||
|       /* WSAEADDRINUSE maps to EADDRINUSE */ | ||||
|       /* WSAEADDRNOTAVAIL maps to EADDRNOTAVAIL */ | ||||
|       /* WSAENETDOWN maps to ENETDOWN */ | ||||
|       /* WSAENETUNREACH maps to ENETUNREACH */ | ||||
|       /* WSAENETRESET maps to ENETRESET */ | ||||
|       /* WSAECONNABORTED maps to ECONNABORTED */ | ||||
|       /* WSAECONNRESET maps to ECONNRESET */ | ||||
|       /* WSAENOBUFS maps to ENOBUFS */ | ||||
|       /* WSAEISCONN maps to EISCONN */ | ||||
|       /* WSAENOTCONN maps to ENOTCONN */ | ||||
|       /* WSAESHUTDOWN is ESHUTDOWN */ | ||||
|       /* WSAETOOMANYREFS is ETOOMANYREFS */ | ||||
|       /* WSAETIMEDOUT maps to ETIMEDOUT */ | ||||
|       /* WSAECONNREFUSED maps to ECONNREFUSED */ | ||||
|       /* WSAELOOP maps to ELOOP */ | ||||
|       /* WSAENAMETOOLONG maps to ENAMETOOLONG */ | ||||
|       /* WSAEHOSTDOWN is EHOSTDOWN */ | ||||
|       /* WSAEHOSTUNREACH maps to EHOSTUNREACH */ | ||||
|       /* WSAENOTEMPTY maps to ENOTEMPTY */ | ||||
|       /* WSAEPROCLIM is EPROCLIM */ | ||||
|       /* WSAEUSERS is EUSERS */ | ||||
|       /* WSAEDQUOT is EDQUOT */ | ||||
|       /* WSAESTALE is ESTALE */ | ||||
|       /* WSAEREMOTE is EREMOTE */ | ||||
|     case WSASYSNOTREADY: | ||||
|       return "Network subsystem is unavailable"; | ||||
|     case WSAVERNOTSUPPORTED: | ||||
|       return "Winsock.dll version out of range"; | ||||
|     case WSANOTINITIALISED: | ||||
|       return "Successful WSAStartup not yet performed"; | ||||
|     case WSAEDISCON: | ||||
|       return "Graceful shutdown in progress"; | ||||
|     case WSAENOMORE: case WSA_E_NO_MORE: | ||||
|       return "No more results"; | ||||
|     case WSAECANCELLED: case WSA_E_CANCELLED: | ||||
|       return "Call was canceled"; | ||||
|     case WSAEINVALIDPROCTABLE: | ||||
|       return "Procedure call table is invalid"; | ||||
|     case WSAEINVALIDPROVIDER: | ||||
|       return "Service provider is invalid"; | ||||
|     case WSAEPROVIDERFAILEDINIT: | ||||
|       return "Service provider failed to initialize"; | ||||
|     case WSASYSCALLFAILURE: | ||||
|       return "System call failure"; | ||||
|     case WSASERVICE_NOT_FOUND: | ||||
|       return "Service not found"; | ||||
|     case WSATYPE_NOT_FOUND: | ||||
|       return "Class type not found"; | ||||
|     case WSAEREFUSED: | ||||
|       return "Database query was refused"; | ||||
|     case WSAHOST_NOT_FOUND: | ||||
|       return "Host not found"; | ||||
|     case WSATRY_AGAIN: | ||||
|       return "Nonauthoritative host not found"; | ||||
|     case WSANO_RECOVERY: | ||||
|       return "Nonrecoverable error"; | ||||
|     case WSANO_DATA: | ||||
|       return "Valid name, no data record of requested type"; | ||||
|       /* WSA_QOS_* omitted */ | ||||
| # endif | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_ENOMSG | ||||
|     case ENOMSG: | ||||
|       return "No message of desired type"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_EIDRM | ||||
|     case EIDRM: | ||||
|       return "Identifier removed"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_ENOLINK | ||||
|     case ENOLINK: | ||||
|       return "Link has been severed"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_EPROTO | ||||
|     case EPROTO: | ||||
|       return "Protocol error"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_EMULTIHOP | ||||
|     case EMULTIHOP: | ||||
|       return "Multihop attempted"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_EBADMSG | ||||
|     case EBADMSG: | ||||
|       return "Bad message"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_EOVERFLOW | ||||
|     case EOVERFLOW: | ||||
|       return "Value too large for defined data type"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_ENOTSUP | ||||
|     case ENOTSUP: | ||||
|       return "Not supported"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_ENETRESET | ||||
|     case ENETRESET: | ||||
|       return "Network dropped connection on reset"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_ECONNABORTED | ||||
|     case ECONNABORTED: | ||||
|       return "Software caused connection abort"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_ESTALE | ||||
|     case ESTALE: | ||||
|       return "Stale NFS file handle"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_EDQUOT | ||||
|     case EDQUOT: | ||||
|       return "Disk quota exceeded"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_ECANCELED | ||||
|     case ECANCELED: | ||||
|       return "Operation canceled"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_EOWNERDEAD | ||||
|     case EOWNERDEAD: | ||||
|       return "Owner died"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_ENOTRECOVERABLE | ||||
|     case ENOTRECOVERABLE: | ||||
|       return "State not recoverable"; | ||||
| #endif | ||||
| 
 | ||||
| #if GNULIB_defined_EILSEQ | ||||
|     case EILSEQ: | ||||
|       return "Invalid or incomplete multibyte or wide character"; | ||||
| #endif | ||||
| 
 | ||||
|     default: | ||||
|       return NULL; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										56
									
								
								third_party/make/lib/strerror-override.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								third_party/make/lib/strerror-override.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,56 @@ | |||
| /* strerror-override.h --- POSIX compatible system error routine
 | ||||
| 
 | ||||
|    Copyright (C) 2010-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #ifndef _GL_STRERROR_OVERRIDE_H | ||||
| # define _GL_STRERROR_OVERRIDE_H | ||||
| 
 | ||||
| # include <errno.h> | ||||
| # include <stddef.h> | ||||
| 
 | ||||
| /* Reasonable buffer size that should never trigger ERANGE; if this
 | ||||
|    proves too small, we intentionally abort(), to remind us to fix | ||||
|    this value.  */ | ||||
| # define STACKBUF_LEN 256 | ||||
| 
 | ||||
| /* If ERRNUM maps to an errno value defined by gnulib, return a string
 | ||||
|    describing the error.  Otherwise return NULL.  */ | ||||
| # if REPLACE_STRERROR_0 \ | ||||
|      || GNULIB_defined_ESOCK \ | ||||
|      || GNULIB_defined_ESTREAMS \ | ||||
|      || GNULIB_defined_EWINSOCK \ | ||||
|      || GNULIB_defined_ENOMSG \ | ||||
|      || GNULIB_defined_EIDRM \ | ||||
|      || GNULIB_defined_ENOLINK \ | ||||
|      || GNULIB_defined_EPROTO \ | ||||
|      || GNULIB_defined_EMULTIHOP \ | ||||
|      || GNULIB_defined_EBADMSG \ | ||||
|      || GNULIB_defined_EOVERFLOW \ | ||||
|      || GNULIB_defined_ENOTSUP \ | ||||
|      || GNULIB_defined_ENETRESET \ | ||||
|      || GNULIB_defined_ECONNABORTED \ | ||||
|      || GNULIB_defined_ESTALE \ | ||||
|      || GNULIB_defined_EDQUOT \ | ||||
|      || GNULIB_defined_ECANCELED \ | ||||
|      || GNULIB_defined_EOWNERDEAD \ | ||||
|      || GNULIB_defined_ENOTRECOVERABLE \ | ||||
|      || GNULIB_defined_EILSEQ | ||||
| extern const char *strerror_override (int errnum) _GL_ATTRIBUTE_CONST; | ||||
| # else | ||||
| #  define strerror_override(ignored) NULL | ||||
| # endif | ||||
| 
 | ||||
| #endif /* _GL_STRERROR_OVERRIDE_H */ | ||||
							
								
								
									
										71
									
								
								third_party/make/lib/strerror.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								third_party/make/lib/strerror.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,71 @@ | |||
| /* strerror.c --- POSIX compatible system error routine
 | ||||
| 
 | ||||
|    Copyright (C) 2007-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| /* Specification.  */ | ||||
| #include <string.h> | ||||
| 
 | ||||
| #include <errno.h> | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| #include "intprops.h" | ||||
| #include "strerror-override.h" | ||||
| #include "verify.h" | ||||
| 
 | ||||
| /* Use the system functions, not the gnulib overrides in this file.  */ | ||||
| #undef sprintf | ||||
| 
 | ||||
| char * | ||||
| strerror (int n) | ||||
| #undef strerror | ||||
| { | ||||
|   static char buf[STACKBUF_LEN]; | ||||
|   size_t len; | ||||
| 
 | ||||
|   /* Cast away const, due to the historical signature of strerror;
 | ||||
|      callers should not be modifying the string.  */ | ||||
|   const char *msg = strerror_override (n); | ||||
|   if (msg) | ||||
|     return (char *) msg; | ||||
| 
 | ||||
|   msg = strerror (n); | ||||
| 
 | ||||
|   /* Our strerror_r implementation might use the system's strerror
 | ||||
|      buffer, so all other clients of strerror have to see the error | ||||
|      copied into a buffer that we manage.  This is not thread-safe, | ||||
|      even if the system strerror is, but portable programs shouldn't | ||||
|      be using strerror if they care about thread-safety.  */ | ||||
|   if (!msg || !*msg) | ||||
|     { | ||||
|       static char const fmt[] = "Unknown error %d"; | ||||
|       verify (sizeof buf >= sizeof (fmt) + INT_STRLEN_BOUND (n)); | ||||
|       sprintf (buf, fmt, n); | ||||
|       errno = EINVAL; | ||||
|       return buf; | ||||
|     } | ||||
| 
 | ||||
|   /* Fix STACKBUF_LEN if this ever aborts.  */ | ||||
|   len = strlen (msg); | ||||
|   if (sizeof buf <= len) | ||||
|     abort (); | ||||
| 
 | ||||
|   memcpy (buf, msg, len + 1); | ||||
|   return buf; | ||||
| } | ||||
							
								
								
									
										1067
									
								
								third_party/make/lib/string.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1067
									
								
								third_party/make/lib/string.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										45
									
								
								third_party/make/lib/stripslash.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								third_party/make/lib/stripslash.c
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,45 @@ | |||
| /* stripslash.c -- remove redundant trailing slashes from a file name
 | ||||
| 
 | ||||
|    Copyright (C) 1990, 2001, 2003-2006, 2009-2020 Free Software Foundation, | ||||
|    Inc. | ||||
| 
 | ||||
|    This program is free software: you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3 of the License, or | ||||
|    (at your option) any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #include <config.h> | ||||
| 
 | ||||
| #include "dirname.h" | ||||
| 
 | ||||
| /* Remove trailing slashes from FILE.  Return true if a trailing slash
 | ||||
|    was removed.  This is useful when using file name completion from a | ||||
|    shell that adds a "/" after directory names (such as tcsh and | ||||
|    bash), because on symlinks to directories, several system calls | ||||
|    have different semantics according to whether a trailing slash is | ||||
|    present.  */ | ||||
| 
 | ||||
| bool | ||||
| strip_trailing_slashes (char *file) | ||||
| { | ||||
|   char *base = last_component (file); | ||||
|   char *base_lim; | ||||
|   bool had_slash; | ||||
| 
 | ||||
|   /* last_component returns "" for file system roots, but we need to turn
 | ||||
|      "///" into "/".  */ | ||||
|   if (! *base) | ||||
|     base = file; | ||||
|   base_lim = base + base_len (base); | ||||
|   had_slash = (*base_lim != '\0'); | ||||
|   *base_lim = '\0'; | ||||
|   return had_slash; | ||||
| } | ||||
							
								
								
									
										106
									
								
								third_party/make/lib/sys_types.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								third_party/make/lib/sys_types.in.h
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,106 @@ | |||
| /* Provide a more complete sys/types.h.
 | ||||
| 
 | ||||
|    Copyright (C) 2011-2020 Free Software Foundation, Inc. | ||||
| 
 | ||||
|    This program is free software; you can redistribute it and/or modify | ||||
|    it under the terms of the GNU General Public License as published by | ||||
|    the Free Software Foundation; either version 3, or (at your option) | ||||
|    any later version. | ||||
| 
 | ||||
|    This program is distributed in the hope that it will be useful, | ||||
|    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|    GNU General Public License for more details. | ||||
| 
 | ||||
|    You should have received a copy of the GNU General Public License | ||||
|    along with this program; if not, see <https://www.gnu.org/licenses/>.  */
 | ||||
| 
 | ||||
| #if __GNUC__ >= 3 | ||||
| @PRAGMA_SYSTEM_HEADER@ | ||||
| #endif | ||||
| @PRAGMA_COLUMNS@ | ||||
| 
 | ||||
| #if defined _WIN32 && !defined __CYGWIN__ \ | ||||
|     && (defined __need_off_t || defined __need___off64_t \ | ||||
|         || defined __need_ssize_t || defined __need_time_t) | ||||
| 
 | ||||
| /* Special invocation convention inside mingw header files.  */ | ||||
| 
 | ||||
| #@INCLUDE_NEXT@ @NEXT_SYS_TYPES_H@ | ||||
| 
 | ||||
| #else | ||||
| /* Normal invocation convention.  */ | ||||
| 
 | ||||
| #ifndef _@GUARD_PREFIX@_SYS_TYPES_H | ||||
| 
 | ||||
| /* The include_next requires a split double-inclusion guard.  */ | ||||
| # define _GL_INCLUDING_SYS_TYPES_H | ||||
| #@INCLUDE_NEXT@ @NEXT_SYS_TYPES_H@ | ||||
| # undef _GL_INCLUDING_SYS_TYPES_H | ||||
| 
 | ||||
| #ifndef _@GUARD_PREFIX@_SYS_TYPES_H | ||||
| #define _@GUARD_PREFIX@_SYS_TYPES_H | ||||
| 
 | ||||
| /* Override off_t if Large File Support is requested on native Windows.  */ | ||||
| #if @WINDOWS_64_BIT_OFF_T@ | ||||
| /* Same as int64_t in <stdint.h>.  */ | ||||
| # if defined _MSC_VER | ||||
| #  define off_t __int64 | ||||
| # else | ||||
| #  define off_t long long int | ||||
| # endif | ||||
| /* Indicator, for gnulib internal purposes.  */ | ||||
| # define _GL_WINDOWS_64_BIT_OFF_T 1 | ||||
| #endif | ||||
| 
 | ||||
| /* Override dev_t and ino_t if distinguishable inodes support is requested
 | ||||
|    on native Windows.  */ | ||||
| #if @WINDOWS_STAT_INODES@ | ||||
| 
 | ||||
| # if @WINDOWS_STAT_INODES@ == 2 | ||||
| /* Experimental, not useful in Windows 10.  */ | ||||
| 
 | ||||
| /* Define dev_t to a 64-bit type.  */ | ||||
| #  if !defined GNULIB_defined_dev_t | ||||
| typedef unsigned long long int rpl_dev_t; | ||||
| #   undef dev_t | ||||
| #   define dev_t rpl_dev_t | ||||
| #   define GNULIB_defined_dev_t 1 | ||||
| #  endif | ||||
| 
 | ||||
| /* Define ino_t to a 128-bit type.  */ | ||||
| #  if !defined GNULIB_defined_ino_t | ||||
| /* MSVC does not have a 128-bit integer type.
 | ||||
|    GCC has a 128-bit integer type __int128, but only on 64-bit targets.  */ | ||||
| typedef struct { unsigned long long int _gl_ino[2]; } rpl_ino_t; | ||||
| #   undef ino_t | ||||
| #   define ino_t rpl_ino_t | ||||
| #   define GNULIB_defined_ino_t 1 | ||||
| #  endif | ||||
| 
 | ||||
| # else /* @WINDOWS_STAT_INODES@ == 1 */ | ||||
| 
 | ||||
| /* Define ino_t to a 64-bit type.  */ | ||||
| #  if !defined GNULIB_defined_ino_t | ||||
| typedef unsigned long long int rpl_ino_t; | ||||
| #   undef ino_t | ||||
| #   define ino_t rpl_ino_t | ||||
| #   define GNULIB_defined_ino_t 1 | ||||
| #  endif | ||||
| 
 | ||||
| # endif | ||||
| 
 | ||||
| /* Indicator, for gnulib internal purposes.  */ | ||||
| # define _GL_WINDOWS_STAT_INODES @WINDOWS_STAT_INODES@ | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| /* MSVC 9 defines size_t in <stddef.h>, not in <sys/types.h>.  */ | ||||
| /* But avoid namespace pollution on glibc systems.  */ | ||||
| #if (defined _WIN32 && ! defined __CYGWIN__) && ! defined __GLIBC__ | ||||
| # include <stddef.h> | ||||
| #endif | ||||
| 
 | ||||
| #endif /* _@GUARD_PREFIX@_SYS_TYPES_H */ | ||||
| #endif /* _@GUARD_PREFIX@_SYS_TYPES_H */ | ||||
| #endif /* __need_XXX */ | ||||
Some files were not shown because too many files have changed in this diff Show more
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue