diff options
| author | dimitri staessens <dimitri.staessens@intec.ugent.be> | 2016-07-06 19:14:42 +0200 | 
|---|---|---|
| committer | dimitri staessens <dimitri.staessens@intec.ugent.be> | 2016-07-06 19:14:42 +0200 | 
| commit | 4fb0d2bfb7486936ef05721667f03eccf664d56e (patch) | |
| tree | c3753f440085a2126e399cb8667d99eb91a8ad6a /src/lib | |
| parent | 90c3c96b5c9b1e4db6bb6d1894a21aec54a965b1 (diff) | |
| parent | bb85e730783ae34808e42c3107759f43106a9b1d (diff) | |
| download | ouroboros-4fb0d2bfb7486936ef05721667f03eccf664d56e.tar.gz ouroboros-4fb0d2bfb7486936ef05721667f03eccf664d56e.zip | |
Merged in sandervrijders/ouroboros/be (pull request #161)
lib, irmd, ipcpd: Provide the feature to write to logs
Diffstat (limited to 'src/lib')
| -rw-r--r-- | src/lib/CMakeLists.txt | 1 | ||||
| -rw-r--r-- | src/lib/ipcp.c | 12 | ||||
| -rw-r--r-- | src/lib/logs.c | 36 | 
3 files changed, 49 insertions, 0 deletions
| diff --git a/src/lib/CMakeLists.txt b/src/lib/CMakeLists.txt index 57f44f15..9c45269c 100644 --- a/src/lib/CMakeLists.txt +++ b/src/lib/CMakeLists.txt @@ -31,6 +31,7 @@ set(SOURCE_FILES    ipcp.c    irm.c    list.c +  logs.c    nsm.c    shm_ap_rbuff.c    shm_du_map.c diff --git a/src/lib/ipcp.c b/src/lib/ipcp.c index e4a82b60..5d46940d 100644 --- a/src/lib/ipcp.c +++ b/src/lib/ipcp.c @@ -109,6 +109,7 @@ pid_t ipcp_create(enum ipcp_type ipcp_type)          char * ipcp_dir = "/sbin/";          char * full_name = NULL;          char * exec_name = NULL; +        char * log_file = NULL;          sprintf(irmd_api, "%u", getpid()); @@ -149,8 +150,19 @@ pid_t ipcp_create(enum ipcp_type ipcp_type)          strcat(full_name, exec_name);          full_name[len] = '\0'; +        if (logfile != NULL) { +                log_file = malloc(20); +                if (log_file == NULL) { +                        LOG_ERR("Failed to malloc."); +                        exit(EXIT_FAILURE); +                } +                sprintf(log_file, "ipcpd-%u.log", getpid()); +        } + +        /* log_file to be placed at the end */          char * argv[] = {full_name,                           irmd_api, +                         log_file,                           0};          char * envp[] = {0}; diff --git a/src/lib/logs.c b/src/lib/logs.c new file mode 100644 index 00000000..d86073e4 --- /dev/null +++ b/src/lib/logs.c @@ -0,0 +1,36 @@ +/* + * Ouroboros - Copyright (C) 2016 + * + * Logging facilities + * + *    Sander Vrijders <sander.vrijders@intec.ugent.be> + * + * 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 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, write to the Free Software + * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + */ + +#define OUROBOROS_PREFIX "logging" + +#include <ouroboros/logs.h> + +FILE * logfile = NULL; + +int set_logfile(char * filename) +{ +        logfile = fopen(filename, "w"); +        if (logfile == NULL) +                return -1; + +        return 0; +} | 
