mirror of
https://bitbucket.org/jsuto/piler.git
synced 2024-12-25 20:20:12 +01:00
gui fixes
This commit is contained in:
parent
863d9ecb50
commit
1b9e2e639d
@ -25,7 +25,7 @@ OBJS = import_helper.o
|
|||||||
|
|
||||||
INSTALL = @INSTALL@
|
INSTALL = @INSTALL@
|
||||||
|
|
||||||
all: $(OBJS) parser debug import ptest
|
all: $(OBJS) parser debug import ptest test
|
||||||
|
|
||||||
parser: parser.c ../src/libpiler.a
|
parser: parser.c ../src/libpiler.a
|
||||||
$(CC) $(CFLAGS) $(INCDIR) $(DEFS) -o $@ $< -lpiler $(LIBS) $(LIBDIR)
|
$(CC) $(CFLAGS) $(INCDIR) $(DEFS) -o $@ $< -lpiler $(LIBS) $(LIBDIR)
|
||||||
@ -39,6 +39,8 @@ debug: debug.c ../src/libpiler.a
|
|||||||
import: import.c ../src/libpiler.a
|
import: import.c ../src/libpiler.a
|
||||||
$(CC) $(CFLAGS) $(INCDIR) $(DEFS) -o $@ $< -lpiler import_helper.o $(LIBS) $(LIBDIR)
|
$(CC) $(CFLAGS) $(INCDIR) $(DEFS) -o $@ $< -lpiler import_helper.o $(LIBS) $(LIBDIR)
|
||||||
|
|
||||||
|
test: test.c ../src/libpiler.a
|
||||||
|
$(CC) $(CFLAGS) $(INCDIR) $(DEFS) -o $@ $< -lpiler $(LIBS) $(LIBDIR)
|
||||||
|
|
||||||
%.o: $(srcdir)/%.c
|
%.o: $(srcdir)/%.c
|
||||||
$(CC) $(CFLAGS) -fPIC $(INCDIR) $(DEFS) -c $< -o $@
|
$(CC) $(CFLAGS) -fPIC $(INCDIR) $(DEFS) -c $< -o $@
|
||||||
@ -47,7 +49,7 @@ import: import.c ../src/libpiler.a
|
|||||||
install:
|
install:
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f parser debug import ptest
|
rm -f parser debug import ptest test
|
||||||
|
|
||||||
distclean: clean
|
distclean: clean
|
||||||
rm -f Makefile
|
rm -f Makefile
|
||||||
|
11
test/check.sh
Executable file
11
test/check.sh
Executable file
@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
for i in ../testemails/raw/*; do
|
||||||
|
./test $i > aa;
|
||||||
|
diff aa ../testemails/parsed/`basename $i`;
|
||||||
|
if [ $? -eq 0 ]; then echo OK; else echo `basename $i`": ERROR"; fi
|
||||||
|
done
|
||||||
|
|
||||||
|
rm -f aa
|
||||||
|
|
||||||
|
|
105
test/test.c
Normal file
105
test/test.c
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
/*
|
||||||
|
* test.c, SJ
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <time.h>
|
||||||
|
#include <locale.h>
|
||||||
|
#include <syslog.h>
|
||||||
|
#include <piler.h>
|
||||||
|
|
||||||
|
|
||||||
|
int main(int argc, char **argv){
|
||||||
|
int i;
|
||||||
|
struct stat st;
|
||||||
|
struct session_data sdata;
|
||||||
|
struct _state state;
|
||||||
|
struct __config cfg;
|
||||||
|
struct __data data;
|
||||||
|
struct import import;
|
||||||
|
|
||||||
|
srand(getpid());
|
||||||
|
|
||||||
|
if(argc < 2){
|
||||||
|
fprintf(stderr, "usage: %s <message>\n", argv[0]);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!can_i_write_current_directory()) __fatal("cannot write current directory!");
|
||||||
|
|
||||||
|
if(stat(argv[1], &st) != 0){
|
||||||
|
fprintf(stderr, "%s is not found\n", argv[1]);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
(void) openlog("test", LOG_PID, LOG_MAIL);
|
||||||
|
|
||||||
|
cfg = read_config(CONFIG_FILE);
|
||||||
|
|
||||||
|
if(open_database(&sdata, &cfg) == ERR) return 0;
|
||||||
|
|
||||||
|
setlocale(LC_MESSAGES, cfg.locale);
|
||||||
|
setlocale(LC_CTYPE, cfg.locale);
|
||||||
|
|
||||||
|
import.extra_recipient = NULL;
|
||||||
|
|
||||||
|
data.import = &import;
|
||||||
|
|
||||||
|
data.folder = 0;
|
||||||
|
data.recursive_folder_names = 0;
|
||||||
|
|
||||||
|
inithash(data.mydomains);
|
||||||
|
|
||||||
|
init_session_data(&sdata, &cfg);
|
||||||
|
|
||||||
|
sdata.sent = 0;
|
||||||
|
sdata.delivered = 0;
|
||||||
|
sdata.tot_len = st.st_size;
|
||||||
|
sdata.import = 1;
|
||||||
|
|
||||||
|
snprintf(sdata.ttmpfile, SMALLBUFSIZE-1, "%s", argv[1]);
|
||||||
|
snprintf(sdata.filename, SMALLBUFSIZE-1, "%s", argv[1]);
|
||||||
|
snprintf(sdata.tmpframe, SMALLBUFSIZE-1, "%s.m", argv[1]);
|
||||||
|
|
||||||
|
state = parse_message(&sdata, 1, &data, &cfg);
|
||||||
|
|
||||||
|
post_parse(&sdata, &state, &cfg);
|
||||||
|
|
||||||
|
printf("message-id: %s / %s\n", state.message_id, state.message_id_hash);
|
||||||
|
printf("from: *%s (%s)*\n", state.b_from, state.b_from_domain);
|
||||||
|
printf("to: *%s (%s)*\n", state.b_to, state.b_to_domain);
|
||||||
|
printf("reference: *%s*\n", state.reference);
|
||||||
|
printf("subject: *%s*\n", state.b_subject);
|
||||||
|
printf("body: *%s*\n", state.b_body);
|
||||||
|
|
||||||
|
printf("sent: %ld, delivered-date: %ld\n", sdata.sent, sdata.delivered);
|
||||||
|
|
||||||
|
make_digests(&sdata, &cfg);
|
||||||
|
|
||||||
|
printf("hdr len: %d\n", sdata.hdr_len);
|
||||||
|
|
||||||
|
printf("body digest: %s\n", sdata.bodydigest);
|
||||||
|
|
||||||
|
clearhash(data.mydomains);
|
||||||
|
|
||||||
|
for(i=1; i<=state.n_attachments; i++){
|
||||||
|
printf("i:%d, name=*%s*, type: *%s*, size: %d, int.name: %s, digest: %s\n", i, state.attachments[i].filename, state.attachments[i].type, state.attachments[i].size, state.attachments[i].internalname, state.attachments[i].digest);
|
||||||
|
unlink(state.attachments[i].internalname);
|
||||||
|
}
|
||||||
|
|
||||||
|
unlink(sdata.tmpframe);
|
||||||
|
|
||||||
|
printf("attachments:%s\n", sdata.attachments);
|
||||||
|
|
||||||
|
close_database(&sdata);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -72,16 +72,16 @@ class ModelGroupGroup extends Model {
|
|||||||
$where_cond = "";
|
$where_cond = "";
|
||||||
$Q = array();
|
$Q = array();
|
||||||
|
|
||||||
|
if($search) {
|
||||||
$search = preg_replace("/\s{1,}/", "", $search) . '%';
|
$search = preg_replace("/\s{1,}/", "", $search) . '%';
|
||||||
|
|
||||||
if($search){
|
|
||||||
$where_cond .= " WHERE `groupname` like '?'";
|
$where_cond .= " WHERE `groupname` like '?'";
|
||||||
array_push($Q, $search);
|
array_push($Q, $search);
|
||||||
}
|
}
|
||||||
|
|
||||||
$query = $this->db->query("SELECT COUNT(*) AS num FROM `" . TABLE_GROUP . "` $where_cond", $Q);
|
$query = $this->db->query("SELECT COUNT(*) AS num FROM `" . TABLE_GROUP . "` $where_cond", $Q);
|
||||||
|
|
||||||
return $query->num_rows;
|
return $query->row['num'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -300,11 +300,11 @@ class ModelSearchMessage extends Model {
|
|||||||
$msg = $p;
|
$msg = $p;
|
||||||
$p = '';
|
$p = '';
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if($boundary) {
|
if($boundary) {
|
||||||
$msg = substr($msg, 0, strlen($msg) - strlen($boundary) - 6);
|
$msg = substr($msg, 0, strlen($msg) - strlen($boundary) - 6);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return $has_journal;
|
return $has_journal;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user