diff options
author | tobi <tobi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-10-04 21:30:32 +0000 |
---|---|---|
committer | tobi <tobi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-10-04 21:30:32 +0000 |
commit | 82bbe4ec19209878d7c67e0b715ddd1bb4812468 (patch) | |
tree | 8fc6d2fea1b1e4f419fa9262f4e6faa4f4e68471 /libgfortran/intrinsics/system.c | |
parent | f403a081de4de3a678801c78756d2e4288e99914 (diff) | |
download | gcc-82bbe4ec19209878d7c67e0b715ddd1bb4812468.tar.gz |
fortran/
PR fortran/17776
* check.c (gfc_check_system_sub): New function.
* gfortran.h (gfc_generic_isym_id): Add GFC_ISYM_SYSTEM.
* intrinsic.c (add_functions): Add 'system'.
(add_subroutines): Add 'system'.
* intrinsic.h (gfc_check_etime_sub, gfc_check_getcwd_sub):
Move prototypes to other suborutines.
(gfc_check_system_sub, gfc_resolve_system, gfc_resolve_system_sub):
Add prototype.
(gfc_resolve_system_clock): Fix formatting of prototype.
* iresolve.c (gfc_resolve_system, gfc_resolve_system_sub): New
functions.
* trans-intrinsic.c (gfc_conv_intrinsic_function): Deal with
GFC_ISYM_SYSTEM.
libgfortran/
PR fortran/17776
* intrinsics/system.c: New file.
* Makefile.am: Add dependency for the new file.
* Makefile.in: Regenerate.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@88532 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libgfortran/intrinsics/system.c')
-rw-r--r-- | libgfortran/intrinsics/system.c | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/libgfortran/intrinsics/system.c b/libgfortran/intrinsics/system.c new file mode 100644 index 00000000000..38ae0a9d2a9 --- /dev/null +++ b/libgfortran/intrinsics/system.c @@ -0,0 +1,63 @@ +/* Implementation of the SYSTEM intrinsic. + Copyright (C) 2004 Free Software Foundation, Inc. + Contributed by Tobias Schlüter. + +This file is part of GCC. + +GCC 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. + +In addition to the permissions in the GNU General Public License, the +Free Software Foundation gives you unlimited permission to link the +compiled version of this file into combinations with other programs, +and to distribute those combinations without any restriction coming +from the use of this file. (The General Public License restrictions +do apply in other respects; for example, they cover modification of +the file, and distribution when not linked into a combined +executable.) + +GCC 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 GCC; see the file COPYING. If not, write to the Free +Software Foundation, 59 Temple Place - Suite 330, Boston, MA +02111-1307, USA. */ + +#include "config.h" +#include "libgfortran.h" + +#ifdef HAVE_STRING_H +#include <string.h> +#endif +#ifdef HAVE_STDLIB_H +#include <stdlib.h> +#endif + +void +prefix(system_sub) (const char * fcmd, GFC_INTEGER_4 * status, + gfc_charlen_type cmd_len) +{ + char cmd[cmd_len + 1]; + int stat; + + memcpy (cmd, fcmd, cmd_len); + cmd[cmd_len] = '\0'; + + stat = system (cmd); + if (status) + *status = stat; +} + +GFC_INTEGER_4 +prefix(system) (char * fcmd, gfc_charlen_type cmd_len) +{ + GFC_INTEGER_4 stat; + + prefix(system_sub) (fcmd, &stat, cmd_len); + return stat; +} |