labyrinth

annotate src/android/logger.c @ 3:45b91185b298

android port
author John Tsiombikas <nuclear@member.fsf.org>
date Fri, 01 May 2015 04:36:50 +0300
parents
children
rev   line source
nuclear@3 1 #include <stdio.h>
nuclear@3 2 #include <assert.h>
nuclear@3 3 #include <unistd.h>
nuclear@3 4 #include <pthread.h>
nuclear@3 5 #include <android/log.h>
nuclear@3 6 #include "logger.h"
nuclear@3 7
nuclear@3 8 static void *thread_func(void *arg);
nuclear@3 9
nuclear@3 10 static int pfd[2];
nuclear@3 11 static pthread_t thr;
nuclear@3 12 static int initialized;
nuclear@3 13
nuclear@3 14 int start_logger(void)
nuclear@3 15 {
nuclear@3 16 if(initialized) {
nuclear@3 17 return 1;
nuclear@3 18 }
nuclear@3 19
nuclear@3 20 /* set stdout to line-buffered, and stderr to unbuffered */
nuclear@3 21 setvbuf(stdout, 0, _IOLBF, 0);
nuclear@3 22 setvbuf(stderr, 0, _IONBF, 0);
nuclear@3 23
nuclear@3 24 if(pipe(pfd) == -1) {
nuclear@3 25 perror("failed to create logging pipe");
nuclear@3 26 return -1;
nuclear@3 27 }
nuclear@3 28 assert(pfd[0] > 2 && pfd[1] > 2);
nuclear@3 29
nuclear@3 30 /* redirect stdout & stderr to the write-end of the pipe */
nuclear@3 31 dup2(pfd[1], 1);
nuclear@3 32 dup2(pfd[1], 2);
nuclear@3 33
nuclear@3 34 /* start the logging thread */
nuclear@3 35 if(pthread_create(&thr, 0, thread_func, 0) == -1) {
nuclear@3 36 perror("failed to spawn logging thread");
nuclear@3 37 return -1;
nuclear@3 38 }
nuclear@3 39 pthread_detach(thr);
nuclear@3 40 return 0;
nuclear@3 41 }
nuclear@3 42
nuclear@3 43 static void *thread_func(void *arg)
nuclear@3 44 {
nuclear@3 45 ssize_t rdsz;
nuclear@3 46 char buf[257];
nuclear@3 47
nuclear@3 48 __android_log_print(ANDROID_LOG_DEBUG, APP_NAME, "logger starting up...");
nuclear@3 49
nuclear@3 50 while((rdsz = read(pfd[0], buf, sizeof buf - 1)) > 0) {
nuclear@3 51 if(buf[rdsz - 1] == '\n') {
nuclear@3 52 --rdsz;
nuclear@3 53 }
nuclear@3 54 buf[rdsz] = 0;
nuclear@3 55 __android_log_write(ANDROID_LOG_DEBUG, APP_NAME, buf);
nuclear@3 56 }
nuclear@3 57
nuclear@3 58 __android_log_print(ANDROID_LOG_DEBUG, APP_NAME, "logger shutting down...");
nuclear@3 59 return 0;
nuclear@3 60 }