aboutsummaryrefslogtreecommitdiffstats
path: root/configure.in
blob: acec6a0c911bcb8e6bd57da052dda908fae9e69a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
#                                               -*- Autoconf -*-
# Process this file with autoconf to produce a configure script.


# $Id$
# $URL$


# LCD4Linux autoconf script
#
# Copyright (C) 1999, 2000, 2001, 2002, 2003 Michael Reinelt <reinelt@eunet.at>
# Copyright (C) 2004, 2005, 2006, 2007 The LCD4Linux Team <lcd4linux-devel@users.sourceforge.net>
#
# This file is part of LCD4Linux.
#
# LCD4Linux 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.
#
# LCD4Linux 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.

AC_PREREQ(2.59)
AC_INIT([LCD4Linux],[0.10.1],[lcd4linux-users@lists.sourceforge.net])
AC_CONFIG_SRCDIR([lcd4linux.c])
AM_INIT_AUTOMAKE([lcd4linux],0.10.1)
AM_CONFIG_HEADER(config.h)

# Checks for programs.
AC_PROG_CC
AC_PROG_CPP
AC_PROG_INSTALL
AC_PROG_LN_S
AC_PROG_MAKE_SET

# dmalloc
AM_WITH_DMALLOC

# Checks for libraries.
AC_CHECK_LIB(m, log)

# curses
sinclude(curses.m4)
AC_CHECK_CURSES

# Checks for X11
AC_PATH_X
AC_PATH_XTRA
# double-check for X11
if test "$no_x" != "yes"; then
   AC_CHECK_HEADERS(X11/Xlib.h X11/Xutil.h, [no_x="$no_x"], [no_x="yes"])
   if test "$no_x" = "yes"; then
      AC_MSG_WARN([configure thinks X11 is available while it is *not*])
      AC_MSG_WARN([maybe someone wants to fix autoconf's AC PATH XTRA])
   fi
fi

# check for gd.h
AC_CHECK_HEADERS(gd/gd.h gd.h, [has_gd="true"; break], [has_gd="false"])

# check for usb.h
AC_CHECK_HEADERS(usb.h, [has_usb="true"], [has_usb="false"])

# check for luise.h
AC_CHECK_HEADERS(luise.h, [has_luise="true"], [has_luise="false"])

# check for serdisplib
AC_CHECK_HEADERS(serdisplib/serdisp.h, [has_serdisplib="true"], [has_serdisplib="false"])

# check for LCD-Linux
AC_CHECK_HEADERS(linux/lcd-linux.h linux/hd44780.h, [has_lcd_linux="true"], [has_lcd_linux="false"; break])

# check for python
AC_MSG_CHECKING(if python support is wanted)
AC_ARG_WITH(python,
[  --with-python           enable python support [[default=no]]],
[AC_MSG_RESULT($withval)], [AC_MSG_RESULT(no)])
if test "$with_python" = "yes"; then
  sinclude(ac_python_devel.m4)
  AC_PYTHON_DEVEL
fi

# drivers
sinclude(drivers.m4)

# plugins
sinclude(plugins.m4)

# Checks for header files.
AC_HEADER_DIRENT
AC_HEADER_STDC
AC_CHECK_HEADERS([arpa/inet.h fcntl.h netdb.h netinet/in.h stdlib.h string.h sys/ioctl.h sys/socket.h sys/time.h sys/vfs.h syslog.h termios.h unistd.h])
AC_CHECK_HEADERS(sys/io.h asm/io.h)
AC_CHECK_HEADERS(linux/parport.h linux/ppdev.h)
AC_CHECK_HEADERS(asm/msr.h)

# Checks for typedefs, structures, and compiler characteristics.
AC_C_CONST
AC_C_INLINE
AC_TYPE_OFF_T
AC_TYPE_PID_T
AC_TYPE_SIZE_T
AC_TYPE_SSIZE_T
AC_HEADER_TIME
AC_TYPE_UID_T


# Checks for library functions.
AC_FUNC_CLOSEDIR_VOID
AC_FUNC_ERROR_AT_LINE
AC_FUNC_FORK

# uClibc has no getloadavg()
# AC_FUNC_GETLOADAVG sounds promising, but does not really work
#AC_FUNC_GETLOADAVG

AC_PROG_GCC_TRADITIONAL

# removed for uClibc compatibility
#AC_FUNC_MALLOC
#AC_FUNC_REALLOC

AC_FUNC_SELECT_ARGTYPES
AC_TYPE_SIGNAL
AC_FUNC_STAT
AC_FUNC_STRFTIME
AC_FUNC_STRTOD
AC_CHECK_FUNCS([dup2 floor gethostbyname gettimeofday memmove memset pow putenv regcomp select socket sqrt strcasecmp strchr strcspn strdup strerror strncasecmp strndup strpbrk strrchr strstr strtol strtoul uname])

AC_CONFIG_FILES([Makefile])
AC_OUTPUT
@users.sourceforge.net> * * Based on the old isdn client (isdn.c) which is * Copyright (C) 1999, 2000 Michael Reinelt <reinelt@eunet.at> * * This file is part of LCD4Linux. * * LCD4Linux 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. * * LCD4Linux 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. * */ /* * exported functions: * * int plugin_init_isdn (void) * adds functions to access ISDN information * */ #include "config.h" #include <stdlib.h> #include <stdio.h> #include <string.h> #include <unistd.h> #include <errno.h> #include <fcntl.h> #include <sys/ioctl.h> #include <sys/types.h> #ifdef HAVE_LINUX_ISDN_H #include <linux/isdn.h> #else #warning isdn.h not found. CPS support deactivated. #endif #include "debug.h" #include "plugin.h" #include "qprintf.h" #include "hash.h" typedef struct { unsigned long in; unsigned long out; } CPS; static HASH ISDN_INFO; static HASH ISDN_CPS; static void hash_put_info(const char *name, const int channel, const char *val) { char key[16]; qprintf(key, sizeof(key), "%s[%d]", name, channel); hash_put(&ISDN_INFO, key, val); } static int parse_isdninfo(void) { int age; FILE *stream; long flags; /* reread every 10 msec only */ age = hash_age(&ISDN_INFO, NULL); if (age > 0 && age <= 10) return 0; /* open file */ stream = fopen("/dev/isdninfo", "r"); if (stream == NULL) { error("open(/dev/isdninfo) failed: %s", strerror(errno)); return -1; } /* get flags */ flags = fcntl(fileno(stream), F_GETFL); if (flags < 0) { error("fcntl(/dev/isdninfo, F_GETFL) failed: %s", strerror(errno)); return -1; } /* set O_NONBLOCK */ if (fcntl(fileno(stream), F_SETFL, flags | O_NONBLOCK) < 0) { error("fcntl(/dev/isdninfo, F_SETFL, O_NONBLOCK) failed: %s", strerror(errno)); return -1; } while (!feof(stream)) { char buffer[4096]; char *beg, *end; if (fgets(buffer, sizeof(buffer), stream) == NULL) break; beg = strchr(buffer, ':'); if (beg != NULL) { char delim[] = " \t\n"; int i = 0; *beg++ = '\0'; while (*beg && strchr(delim, *beg)) beg++; while (beg && *beg) { if ((end = strpbrk(beg, delim))) *end = '\0'; hash_put_info(buffer, i, beg); beg = end ? end + 1 : NULL; while (*beg && strchr(delim, *beg)) beg++; i++; } } else { error("Huh? no colon found in <%s>", buffer); } } fclose(stream); return 0; } static void my_isdn_info(RESULT * result, RESULT * arg1, RESULT * arg2) { char key[16], *val; if (parse_isdninfo() < 0) { SetResult(&result, R_STRING, ""); return; } qprintf(key, sizeof(key), "%s[%d]", R2S(arg1), (int) R2N(arg2)); val = hash_get(&ISDN_INFO, key, NULL); if (val == NULL) val = ""; SetResult(&result, R_STRING, val); } #ifdef HAVE_LINUX_ISDN_H static void hash_put_cps(const int channel, const CPS * cps) { char key[16], val[16]; qprintf(key, sizeof(key), channel < 0 ? "i" : "i%d", channel); qprintf(val, sizeof(val), "%u", cps->in); hash_put_delta(&ISDN_CPS, key, val); qprintf(key, sizeof(key), channel < 0 ? "o" : "o%d", channel); qprintf(val, sizeof(val), "%u", cps->out); hash_put_delta(&ISDN_CPS, key, val); } static int get_cps(void) { int age, i; static int fd = -2; CPS cps[ISDN_MAX_CHANNELS]; CPS sum; /* reread every 10 msec only */ age = hash_age(&ISDN_CPS, NULL); if (age > 0 && age <= 10) return 0; if (fd == -1) return -1; if (fd == -2) { fd = open("/dev/isdninfo", O_RDONLY | O_NDELAY); if (fd == -1) { error("open(/dev/isdninfo) failed: %s", strerror(errno)); return -1; } } if (ioctl(fd, IIOCGETCPS, &cps)) { error("ioctl(IIOCGETCPS) failed: %s", strerror(errno)); fd = -1; return -1; } sum.in = 0; sum.out = 0; for (i = 0; i < ISDN_MAX_CHANNELS; i++) { sum.in += cps[i].in; sum.out += cps[i].out; hash_put_cps(i, &cps[i]); } hash_put_cps(-1, &sum); return 0; } static void my_isdn_cps(RESULT * result, RESULT * arg1, RESULT * arg2) { double value; if (get_cps() < 0) { SetResult(&result, R_STRING, ""); return; } value = hash_get_delta(&ISDN_CPS, R2S(arg1), NULL, R2N(arg2)); SetResult(&result, R_NUMBER, &value); } #endif int plugin_init_isdn(void) { hash_create(&ISDN_INFO); hash_create(&ISDN_CPS); AddFunction("isdn::info", 2, my_isdn_info); #ifdef HAVE_LINUX_ISDN_H AddFunction("isdn::cps", 2, my_isdn_cps); #endif return 0; } void plugin_exit_isdn(void) { hash_destroy(&ISDN_INFO); hash_destroy(&ISDN_CPS); }