-
Notifications
You must be signed in to change notification settings - Fork 30
/
readme_k2src.txt
143 lines (108 loc) · 6.98 KB
/
readme_k2src.txt
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
139
140
141
142
143
K2pdfopt build help.
http://willus.com
Original: 7 September 2012
Last updated: 26 Dec 2023 (v2.55)
This "read me" file describes the source code distribution for k2pdfopt.
Version Change History
----------------------
See k2pdfoptlib\k2version.c.
K2pdfopt Source Files
---------------------
1. k2pdfopt.c (main module)
2. k2pdfopt C library (28 C files + 1 header file) in k2pdfoptlib subfolder.
Compile all C files in this subfolder and build them into libk2pdfopt.a.
Near the top of k2pdfopt.h are #defines which control third-party
library dependencies (HAVE_XXX_LIB) and whether or not the MS Windows
GUI is compiled in (HAVE_K2GUI).
3. willus.com general-purpose C library (43 C files + 1 header file) in
willuslib subfolder.
Compile all C files in this subfolder and build them into libwillus.a.
Near the top of willus.h are #defines which control third-party
library dependencies, i.e. HAVE_MUPDF_LIB. These are passed on to
the k2pdfopt library since k2pdfopt.h includes willus.h.
Third Party Libraries
---------------------
There are also a number of required 3rd-party open-source C/C++ libraries
for k2pdfopt. These libraries are not necessarily required when using
the k2pdfopt library in other applications (e.g. KindlePDFViewer--see
NOTE 4 below).
REQUIRED
--------
1. Z-lib 1.3 (zlib.net)
2. libpng 1.6.40 (www.libpng.org)
3. Turbo JPEG lib 2.1.5.1 (sourceforge.net/projects/libjpeg-turbo/)
TO INCLUDE MuPDF LIBRARY (search for HAVE_MUPDF in k2pdfopt.c)
--------------------------------------------------------------
4. JBIG2Dec 0.20 (jbig2dec.sourceforge.net)
5. OpenJPEG 2.5.0 (www.openjpeg.org)
6. FreeType 2.13.2 (freetype.sourceforge.net/index2.html)
7. lcms from MuPDF 1.23.7 distro
8. gumbo from MuPDF v1.21 distro
9. Mupdf 1.23.7 (mupdf.com) -- SEE NOTE 1.
TO INCLUDE DjVuLibre LIBRARY (search for HAVE_DJVU in k2pdfopt.c)
-----------------------------------------------------------------
10. DJVULibre 3.5.25.3 (C++) (djvu.sourceforge.net)
FOR OCR VERSIONS OF K2PDFOPT (search for HAVE_OCR in k2pdfopt.c)
----------------------------------------------------------------
11. GOCR 0.50 (sourceforge.net/jocr/)
12. Leptonica 1.83.0 (leptonica.com)
13. Tesseract 5.3.3 (C++) (code.google.com/tesseract-ocr/) -- SEE NOTE 2.
14. POSIX threads support (pretty standard with gcc implementations)
If you don't include MuPDF, DjVuLibre, or OCR, then k2pdfopt will
look for an installation of Ghostscript.
Notes
-----
1. Mods to the released MuPDF library are in the mupdf_mod folder.
Search for "willus" or "sumatra" or "bugs" in the files to find the mods.
2. Tesseract requires my small C API file plus some custom-modified source files.
These are in the tesseract_mod folder. Search for "willus" in the files to
find the mods. As of v2.52, k2pdfopt now auto-downloads Tesseract language
training files needed to perform OCR, so you no longer have to worry about
setting the TESSDATA_PREFIX environment variable correctly, but for other
tesseract applications, you should point the TESSDATA_PREFIX environment
variable to the root tesseract folder (e.g. TESSDATA_PREFIX=c:\tesseract-ocr\).
3. For a lot of the 3rd-party libraries, I combined their headers into one
header that gets included by some of the willus library source files.
I can't always remember which ones I did this for, so if you can't find
any of the included files (if they didn't come standard w/the 3rd party
library), look in my include_mod subfolder.
4. Building for KOReader or KindlePDFViewer:
a. In willus.h, search for "THIRD PARTY" and comment out all #define's
for third party libs, e.g. HAVE_Z_LIB, etc.
b. In k2pdfopt.h, uncomment this: #define K2PDFOPT_KINDLEPDFVIEWER
c. Compile all modules in libwillus and libk2pdfopt.
d. Look in the "kindlepdfviewer" subfolder for a couple examples of
how to call the k2pdfopt library functions. The k2view.c program
is stand-alone. If it is compiled without dependencies on third-party
libraries, it will be quite small (~300 KiB in windows).
e. If you are compiling with MINGW but don't have the Win32 API,
use the predefined macro: NO_WIN32_API (-DNO_WIN32_API).
5. I have included CMakeLists.txt files for the k2pdfopt and willus libraries
originally from Dirk Thierbach to help with Linux builds. He also contributed
the config.h.in file and the dtcompress.c file (in willus lib). It is
possible to build the project without using these files (I do not use them).
I have not confirmed that this file still works on the latest build.
Build Steps for k2pdfopt on Windows 11 (gcc 13.2.0)
---------------------------------------------------
My compile steps with gcc (MinGW) are as follows (assuming all the libraries are built
to libxxx.a files in d:\3rdparty_lib and headers are in d:\3rdparty_include):
64-bit
------
1. echo k2pdfopt ICON k2pdfopt.ico > k2pdfopt.rc
2. windres --target=pe-x86-64 -o resfile.o k2pdfopt.rc
3. gcc -Ofast -m64 -Wall -c -Id:\3rdparty_include k2pdfopt.c
4. g++ -Ofast -m64 -Wall -o k2pdfopt.exe k2pdfopt.o resfile.o -static-libgcc -static-libstdc++ d:\mingw\x64\lib\crt_noglob.o -Ld:\3rdparty_lib -lk2pdfopt -lwillus -lgocr -ltesseract -lleptonica -ldjvu -llcms -lgumbo -lmupdf -lfreetype -ljbig2 -ljpeglib -lopenjpeg -lpng -lzlib -lpthread -lgdi32 -luuid -lole32 -lcomdlg32 -lshlwapi
32-bit
------
1. echo k2pdfopt ICON k2pdfopt.ico > k2pdfopt.rc
2. windres --target=pe-i386 -o resfile.o k2pdfopt.rc
3. gcc -Ofast -m32 -Wall -c -Id:\3rdparty_include k2pdfopt.c
4. g++ -Ofast -m32 -Wall -o k2pdfopt.exe k2pdfopt.o resfile.o -static-libgcc -static-libstdc++ d:\mingw\i386\lib\crt_noglob.o -Ld:\3rdparty_lib -lk2pdfopt -lwillus -lgocr -ltesseract -lleptonica -ldjvu -llcms -lgumbo -lmupdf -lfreetype -ljbig2 -ljpeglib -lopenjpeg -lpng -lzlib -lpthread -lgdi32 -luuid -lole32 -lcomdlg32 -lshlwapi
Build Steps on Linux (64-bit, gcc 13.2.1, compiled on Fedora 39)
----------------------------------------------------------------
1. gcc -Wall -Ofast -m64 -o k2pdfopt.o -c k2pdfopt.c
2. g++ $CFLAGS -m64 -o k2pdfopt k2pdfopt.o -static -static-libgcc -static-libstdc++ -L$LIBDIR -lk2pdfopt -lwillus -lgocr -ltesseract -lleptonica -ldjvu -lmupdf -llcms -lgumbo -lfreetype -ljbig2 -ljpeglib -lopenjpeg -lpng -lzlib -lpthread
Build Steps on Mac (64-bit, homebrew clang 17.0.6, built on M1 CPU mac min under macOS 14 Sonoma)
-------------------------------------------------------------------------------------------------
1. clang-17 -Ofast -Wall -o k2pdfopt.o -c k2pdfopt.c -I$C_INCLUDE_PATH
2. clang++ -Ofast -Wall -o k2pdfopt k2pdfopt.o -static-libstdc++ -I$C_INCLUDE_PATH -L$C_LIBRARY_PATH -lk2pdfopt -lmupdf -llcms -lgumbo -lfreetype -lopenjpeg -ljbig2 -ljpeglib -lpng -lwillus -lzlib -ltesseract -lleptonica -ldjvu -lgocr