From 903e846578b8a97c311a6e120edbd116a8b3f992 Mon Sep 17 00:00:00 2001 From: Martin Liska Date: Tue, 18 Jan 2022 09:54:35 +0100 Subject: Revert Ada .cc renaming renaming. gcc/ada/ChangeLog: * Make-generated.in: Revert renaming changes. * Makefile.rtl: Likewise. * adadecode.cc: Moved to... * adadecode.c: ...here. * affinity.cc: Moved to... * affinity.c: ...here. * argv-lynxos178-raven-cert.cc: Moved to... * argv-lynxos178-raven-cert.c: ...here. * argv.cc: Moved to... * argv.c: ...here. * aux-io.cc: Moved to... * aux-io.c: ...here. * cio.cc: Moved to... * cio.c: ...here. * cstreams.cc: Moved to... * cstreams.c: ...here. * env.cc: Moved to... * env.c: ...here. * exit.cc: Moved to... * exit.c: ...here. * expect.cc: Moved to... * expect.c: ...here. * final.cc: Moved to... * final.c: ...here. * gcc-interface/Makefile.in: * init.cc: Moved to... * init.c: ...here. * initialize.cc: Moved to... * initialize.c: ...here. * libgnarl/thread.cc: Moved to... * libgnarl/thread.c: ...here. * link.cc: Moved to... * link.c: ...here. * locales.cc: Moved to... * locales.c: ...here. * mkdir.cc: Moved to... * mkdir.c: ...here. * raise.cc: Moved to... * raise.c: ...here. * rtfinal.cc: Moved to... * rtfinal.c: ...here. * rtinit.cc: Moved to... * rtinit.c: ...here. * s-oscons-tmplt.c (CND): Revert renaming changes. * seh_init.cc: Moved to... * seh_init.c: ...here. * sigtramp-armdroid.cc: Moved to... * sigtramp-armdroid.c: ...here. * sigtramp-ios.cc: Moved to... * sigtramp-ios.c: ...here. * sigtramp-qnx.cc: Moved to... * sigtramp-qnx.c: ...here. * sigtramp-vxworks.cc: Moved to... * sigtramp-vxworks.c: ...here. * socket.cc: Moved to... * socket.c: ...here. * tracebak.cc: Moved to... * tracebak.c: ...here. * version.cc: Moved to... * version.c: ...here. * vx_stack_info.cc: Moved to... * vx_stack_info.c: ...here. --- gcc/ada/mkdir.c | 88 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 88 insertions(+) create mode 100644 gcc/ada/mkdir.c (limited to 'gcc/ada/mkdir.c') diff --git a/gcc/ada/mkdir.c b/gcc/ada/mkdir.c new file mode 100644 index 0000000..d54d5ec --- /dev/null +++ b/gcc/ada/mkdir.c @@ -0,0 +1,88 @@ +/**************************************************************************** + * * + * GNAT COMPILER COMPONENTS * + * * + * M K D I R * + * * + * C Implementation File * + * * + * Copyright (C) 2002-2022, Free Software Foundation, Inc. * + * * + * GNAT is free software; you can redistribute it and/or modify it under * + * terms of the GNU General Public License as published by the Free Soft- * + * ware Foundation; either version 3, or (at your option) any later ver- * + * sion. GNAT is distributed in the hope that it will be useful, but WITH- * + * OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * + * or FITNESS FOR A PARTICULAR PURPOSE. * + * * + * As a special exception under Section 7 of GPL version 3, you are granted * + * additional permissions described in the GCC Runtime Library Exception, * + * version 3.1, as published by the Free Software Foundation. * + * * + * You should have received a copy of the GNU General Public License and * + * a copy of the GCC Runtime Library Exception along with this program; * + * see the files COPYING3 and COPYING.RUNTIME respectively. If not, see * + * . * + * * + * GNAT was originally developed by the GNAT team at New York University. * + * Extensive contributions were provided by Ada Core Technologies Inc. * + * * + ****************************************************************************/ + +#ifdef __vxworks +#include "vxWorks.h" +#include +#endif /* __vxworks */ + +#ifdef IN_RTS +#include "runtime.h" +#include +#else +#include "config.h" +#include "system.h" +#endif + +#ifdef __MINGW32__ +#include "mingw32.h" +#include +#ifdef MAXPATHLEN +#define GNAT_MAX_PATH_LEN MAXPATHLEN +#else +#define GNAT_MAX_PATH_LEN 256 +#endif +#endif + +#include "adaint.h" + +/* This function provides a portable binding to the mkdir function. */ + +int +__gnat_mkdir (char *dir_name, int encoding ATTRIBUTE_UNUSED) +{ +#if defined (__vxworks) + + /* Pretend that the system mkdir is posix compliant even though it + sometimes is not, not expecting the second argument in some + configurations (e.g. vxworks 653 2.2, difference from 2.5). The + second actual argument will just be ignored in this case. */ + + typedef int posix_mkdir (const char * name, mode_t mode); + + posix_mkdir * vxmkdir = (posix_mkdir *)&mkdir; + return vxmkdir (dir_name, S_IRWXU | S_IRWXG | S_IRWXO); + +#elif defined (__MINGW32__) + TCHAR wname [GNAT_MAX_PATH_LEN + 2]; + + if (encoding == Encoding_Unspecified) + S2WSC (wname, dir_name, GNAT_MAX_PATH_LEN); + else if (encoding == Encoding_UTF8) + S2WSU (wname, dir_name, GNAT_MAX_PATH_LEN); + else + S2WS (wname, dir_name, GNAT_MAX_PATH_LEN); + + return _tmkdir (wname); +#else + return mkdir (dir_name, S_IRWXU | S_IRWXG | S_IRWXO); +#endif +} -- cgit v1.1