diff options
author | nork <nork@FreeBSD.org> | 2003-02-23 17:38:47 +0000 |
---|---|---|
committer | nork <nork@FreeBSD.org> | 2003-02-23 17:38:47 +0000 |
commit | 311b04a6b89c0dbe128247909d16bbf1447ff394 (patch) | |
tree | ef27b97124819369d885ac49b5f39bd2d4c5df72 /japanese/ebview-gtk2 | |
parent | 9940f2660b359640c4b000bbd698a2248775fa3c (diff) | |
download | FreeBSD-ports-311b04a6b89c0dbe128247909d16bbf1447ff394.zip FreeBSD-ports-311b04a6b89c0dbe128247909d16bbf1447ff394.tar.gz |
Ebview requires a rich stack size each thread, so extend to 256k.
I don't know whether or not enough size(to 256k), but some test ok.
Diffstat (limited to 'japanese/ebview-gtk2')
-rw-r--r-- | japanese/ebview-gtk2/Makefile | 1 | ||||
-rw-r--r-- | japanese/ebview-gtk2/files/patch-src::eb.c | 34 |
2 files changed, 34 insertions, 1 deletions
diff --git a/japanese/ebview-gtk2/Makefile b/japanese/ebview-gtk2/Makefile index 5b6b9a0..3194e18 100644 --- a/japanese/ebview-gtk2/Makefile +++ b/japanese/ebview-gtk2/Makefile @@ -7,6 +7,7 @@ PORTNAME= ebview PORTVERSION= 0.2.0 +PORTREVISION= 1 CATEGORIES= japanese MASTER_SITES= ${MASTER_SITE_SOURCEFORGE} MASTER_SITE_SUBDIR= ${PORTNAME} diff --git a/japanese/ebview-gtk2/files/patch-src::eb.c b/japanese/ebview-gtk2/files/patch-src::eb.c index c1a9ee2..1866b1b 100644 --- a/japanese/ebview-gtk2/files/patch-src::eb.c +++ b/japanese/ebview-gtk2/files/patch-src::eb.c @@ -1,5 +1,5 @@ --- src/eb.c.orig Mon Nov 18 18:13:06 2002 -+++ src/eb.c Sat Nov 30 09:04:05 2002 ++++ src/eb.c Mon Feb 24 02:06:33 2003 @@ -24,6 +24,7 @@ #include <iconv.h> #include <langinfo.h> @@ -8,3 +8,35 @@ #define MAX_HITS 50 +@@ -1746,7 +1747,8 @@ + DICT_GROUP *group; + char word[65535]; + +- strcpy(word, arg); ++ strncpy(word, arg, sizeof(word)-1); ++ word[sizeof(word)-1] = '\0'; + + group_item = g_list_first(group_list); + while(group_item != NULL){ +@@ -1854,15 +1856,19 @@ + { + gint rc; + gint method; ++ pthread_attr_t thread_attr; + + thread_running = 1; + hit_count = 0; +- rc = pthread_create(&tid, NULL, ebook_search_thread, (void *)word); ++ ++ pthread_attr_init(&thread_attr); ++ pthread_attr_setstacksize(&thread_attr, 256*1024); ++ rc = pthread_create(&tid, &thread_attr, ebook_search_thread, (void *)word); + if(rc != 0){ + perror("pthread_create"); + exit(1); + } +- ++ pthread_attr_destroy(&thread_attr); + + method = ebook_search_method(); + if(method == SEARCH_METHOD_FULL_TEXT){ |