2005-08-05 01:06:17 +00:00
|
|
|
/*
|
|
|
|
* Conky, a system monitor, based on torsmo
|
|
|
|
*
|
|
|
|
* This program is licensed under BSD license, read COPYING
|
|
|
|
*
|
|
|
|
* $Id$
|
|
|
|
*/
|
|
|
|
|
2005-07-20 00:30:40 +00:00
|
|
|
#include "conky.h"
|
|
|
|
#include <string.h>
|
|
|
|
#include "ftp.h"
|
|
|
|
#include <math.h>
|
2005-07-25 01:54:01 +00:00
|
|
|
#include <time.h>
|
2005-07-20 00:30:40 +00:00
|
|
|
#include <pthread.h>
|
|
|
|
#include "metarinfo.h"
|
|
|
|
|
|
|
|
/* for threads */
|
|
|
|
static int status = 0;
|
|
|
|
|
|
|
|
|
2005-07-28 04:48:27 +00:00
|
|
|
int calculateRelativeHumidity(int temp, int dew)
|
|
|
|
{
|
2005-07-20 00:30:40 +00:00
|
|
|
float rh = 0.0;
|
2005-07-28 04:48:27 +00:00
|
|
|
rh = 100.0 * powf((112 - (0.1 * temp) + dew) /
|
|
|
|
(112 + (0.9 * temp)), 8);
|
|
|
|
return (int) rh;
|
2005-07-20 00:30:40 +00:00
|
|
|
}
|
|
|
|
|
2005-07-28 04:48:27 +00:00
|
|
|
int calculateWindChill(int temperatureC, int windKn)
|
|
|
|
{
|
2005-08-12 16:31:03 +00:00
|
|
|
double windKmh = windKn * 1.852;
|
2005-07-28 04:48:27 +00:00
|
|
|
return (int) (13.112 + 0.6215 * temperatureC -
|
|
|
|
11.37 * powf(windKmh,
|
|
|
|
.16) +
|
|
|
|
0.3965 * temperatureC * powf(windKmh, .16));
|
2005-07-20 00:30:40 +00:00
|
|
|
}
|
|
|
|
|
2005-08-12 16:31:03 +00:00
|
|
|
/*Should no longer be needed
|
2005-07-28 04:48:27 +00:00
|
|
|
int knTokph(int knSpeed)
|
|
|
|
{
|
2005-07-20 00:30:40 +00:00
|
|
|
return (knSpeed * 1.852);
|
|
|
|
}
|
2005-08-12 16:31:03 +00:00
|
|
|
*/
|
2005-07-28 04:48:27 +00:00
|
|
|
const char *calculateWindDirectionString(int degree)
|
|
|
|
{
|
2005-07-20 00:30:40 +00:00
|
|
|
if (degree < 22.5) {
|
|
|
|
return "North";
|
2005-07-28 04:48:27 +00:00
|
|
|
} else if (degree < 67.5) {
|
2005-07-20 00:30:40 +00:00
|
|
|
return "Northeast";
|
|
|
|
} else if (degree < 112.5) {
|
|
|
|
return "East";
|
|
|
|
} else if (degree < 157.5) {
|
|
|
|
return "Southeast";
|
2005-07-28 04:48:27 +00:00
|
|
|
} else if (degree < 202.5) {
|
2005-07-20 00:30:40 +00:00
|
|
|
return "South";
|
|
|
|
} else if (degree < 247.5) {
|
|
|
|
return "Southwest";
|
|
|
|
} else if (degree < 292.5) {
|
|
|
|
return "West";
|
2005-07-28 04:48:27 +00:00
|
|
|
} else if (degree < 337.5) {
|
2005-07-20 00:30:40 +00:00
|
|
|
return "Northwest";
|
|
|
|
} else {
|
|
|
|
return "North";
|
|
|
|
}
|
|
|
|
}
|
2005-07-28 04:48:27 +00:00
|
|
|
const char *calculateShortWindDirectionString(int degree)
|
|
|
|
{
|
2005-07-20 00:30:40 +00:00
|
|
|
if (degree < 22.5) {
|
|
|
|
return "N";
|
2005-07-28 04:48:27 +00:00
|
|
|
} else if (degree < 67.5) {
|
2005-07-20 00:30:40 +00:00
|
|
|
return "NE";
|
|
|
|
} else if (degree < 112.5) {
|
|
|
|
return "E";
|
|
|
|
} else if (degree < 157.5) {
|
|
|
|
return "SE";
|
2005-07-28 04:48:27 +00:00
|
|
|
} else if (degree < 202.5) {
|
2005-07-20 00:30:40 +00:00
|
|
|
return "S";
|
|
|
|
} else if (degree < 247.5) {
|
|
|
|
return "SW";
|
|
|
|
} else if (degree < 292.5) {
|
|
|
|
return "W";
|
2005-07-28 04:48:27 +00:00
|
|
|
} else if (degree < 337.5) {
|
2005-07-20 00:30:40 +00:00
|
|
|
return "NW";
|
|
|
|
} else {
|
|
|
|
return "N";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void ftpData(void *userData, const char *data, int len)
|
|
|
|
{
|
2005-07-28 04:48:27 +00:00
|
|
|
if (userData) {
|
|
|
|
} // do nothing to make stupid warning go away
|
2005-07-20 00:30:40 +00:00
|
|
|
if (len <= 0)
|
|
|
|
return;
|
|
|
|
|
2005-07-28 04:48:27 +00:00
|
|
|
if (data != NULL) {
|
2005-07-20 00:30:40 +00:00
|
|
|
line = strdup(data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-07-25 01:54:01 +00:00
|
|
|
extern unsigned int sleep(unsigned int);
|
2005-07-20 00:30:40 +00:00
|
|
|
|
2005-07-28 04:48:27 +00:00
|
|
|
void *fetch_ftp()
|
|
|
|
{
|
|
|
|
// try three times if it fails
|
2005-07-20 00:30:40 +00:00
|
|
|
int tries = 0;
|
|
|
|
do {
|
|
|
|
if (tries > 0) {
|
|
|
|
/* this happens too often, so i'll leave it commented fprintf(stderr, "METAR update failed for some reason, retry %i\n", tries); */
|
2005-07-28 04:48:27 +00:00
|
|
|
sleep(15); /* give it some time in case the server is busy or down */
|
2005-07-20 00:30:40 +00:00
|
|
|
}
|
2005-07-25 01:54:01 +00:00
|
|
|
|
2005-07-20 00:30:40 +00:00
|
|
|
tries++;
|
2005-07-28 04:48:27 +00:00
|
|
|
if (strlen(metar_station) != 8) {
|
2005-07-25 01:54:01 +00:00
|
|
|
ERR("You didn't supply a valid METAR station code\n");
|
2005-07-25 01:13:26 +00:00
|
|
|
return NULL;
|
2005-07-20 00:30:40 +00:00
|
|
|
}
|
|
|
|
if (metar_server == NULL)
|
|
|
|
metar_server = strdup("weather.noaa.gov");
|
|
|
|
if (metar_path == NULL)
|
2005-07-28 04:48:27 +00:00
|
|
|
metar_path =
|
|
|
|
strdup("/data/observations/metar/stations");
|
|
|
|
|
2005-07-20 00:30:40 +00:00
|
|
|
int res;
|
|
|
|
initFtp();
|
|
|
|
res = connectFtp(metar_server, 0);
|
|
|
|
if (res < 0) {
|
2005-07-30 22:59:01 +00:00
|
|
|
ERR("Couldn't connect to %s, retrying\n",
|
|
|
|
metar_server);
|
2005-07-30 20:45:17 +00:00
|
|
|
continue;
|
2005-07-20 00:30:40 +00:00
|
|
|
}
|
|
|
|
res = changeFtpDirectory(metar_path);
|
|
|
|
if (res < 0) {
|
2005-07-28 04:48:27 +00:00
|
|
|
ERR("Metar update failed (couldn't CWD to %s)\n",
|
|
|
|
metar_path);
|
2005-07-20 00:30:40 +00:00
|
|
|
disconnectFtp();
|
2005-07-30 20:45:17 +00:00
|
|
|
continue;
|
2005-07-20 00:30:40 +00:00
|
|
|
}
|
|
|
|
if (res == 0) {
|
2005-07-25 01:54:01 +00:00
|
|
|
ERR("Metar update failed\n");
|
2005-07-30 20:45:17 +00:00
|
|
|
continue;
|
2005-07-20 00:30:40 +00:00
|
|
|
}
|
|
|
|
if (getFtp(ftpData, NULL, metar_station) < 0) {
|
2005-07-25 01:54:01 +00:00
|
|
|
ERR("Failed to get file %s\n", metar_station);
|
2005-07-20 00:30:40 +00:00
|
|
|
}
|
2005-07-28 04:48:27 +00:00
|
|
|
|
2005-07-20 00:30:40 +00:00
|
|
|
disconnectFtp();
|
2005-07-28 04:48:27 +00:00
|
|
|
if (line != NULL) {
|
2005-07-20 00:30:40 +00:00
|
|
|
dcdNetMETAR(line, &data);
|
|
|
|
free(line);
|
|
|
|
line = NULL;
|
|
|
|
ftp_ok = 1;
|
|
|
|
metar_worked = 1;
|
2005-07-28 04:48:27 +00:00
|
|
|
} else {
|
2005-07-20 00:30:40 +00:00
|
|
|
ftp_ok = 0;
|
2005-07-25 00:22:16 +00:00
|
|
|
}
|
2005-07-20 00:30:40 +00:00
|
|
|
|
|
|
|
} while (ftp_ok == 0 && tries < 3);
|
|
|
|
status = 1;
|
2005-07-25 01:13:26 +00:00
|
|
|
return NULL;
|
2005-07-20 00:30:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static pthread_t thread1;
|
|
|
|
|
2005-07-28 04:48:27 +00:00
|
|
|
void update_metar()
|
|
|
|
{
|
|
|
|
int iret1;
|
2005-07-20 00:30:40 +00:00
|
|
|
if (!status) {
|
2005-07-25 00:22:16 +00:00
|
|
|
status = 2;
|
2005-07-28 04:48:27 +00:00
|
|
|
iret1 = pthread_create(&thread1, NULL, fetch_ftp, NULL);
|
2005-07-30 20:45:17 +00:00
|
|
|
} else if (status == 2) { /* thread is still running. let's kill it and start again */
|
2005-08-15 03:27:04 +00:00
|
|
|
/*pthread_cancel(thread1);
|
2005-07-30 20:45:17 +00:00
|
|
|
status = 2;
|
2005-08-15 03:27:04 +00:00
|
|
|
iret1 = pthread_create(&thread1, NULL, fetch_ftp, NULL);*/
|
|
|
|
/*
|
|
|
|
* actually, lets do nothing for a while
|
|
|
|
*/
|
2005-08-15 00:35:51 +00:00
|
|
|
} else if (status == 1) { /* status must be 1 */
|
2005-07-28 04:48:27 +00:00
|
|
|
pthread_join(thread1, NULL);
|
2005-07-20 00:30:40 +00:00
|
|
|
status = 2;
|
2005-07-28 04:48:27 +00:00
|
|
|
iret1 = pthread_create(&thread1, NULL, fetch_ftp, NULL);
|
2005-07-20 00:30:40 +00:00
|
|
|
}
|
2005-07-28 04:48:27 +00:00
|
|
|
|
2005-07-20 00:30:40 +00:00
|
|
|
}
|