|
|
|
@ -85,7 +85,8 @@ extern "C" {
|
|
|
|
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
|
|
|
|
static bool nosearchbarFlag = false;
|
|
|
|
static bool noLibraryButtonFlag = false;
|
|
|
|
|
|
|
|
static bool noSearchBarFlag = false;
|
|
|
|
static string welcomeHTML;
|
|
|
|
static string welcomeHTML;
|
|
|
|
static bool verboseFlag = false;
|
|
|
|
static bool verboseFlag = false;
|
|
|
|
static std::map<std::string, std::string> extMimeTypes;
|
|
|
|
static std::map<std::string, std::string> extMimeTypes;
|
|
|
|
@ -120,12 +121,16 @@ static std::string getMimeTypeForFile(const std::string& filename) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void introduceTaskbar(string &content, const string &humanReadableBookId) {
|
|
|
|
void introduceTaskbar(string &content, const string &humanReadableBookId) {
|
|
|
|
if (!nosearchbarFlag) {
|
|
|
|
if (!noSearchBarFlag) {
|
|
|
|
content = appendToFirstOccurence(content, "<head>",
|
|
|
|
content = appendToFirstOccurence(content, "<head>",
|
|
|
|
replaceRegex(RESOURCE::include_html_part,
|
|
|
|
replaceRegex(RESOURCE::include_html_part,
|
|
|
|
humanReadableBookId, "__CONTENT__"));
|
|
|
|
humanReadableBookId, "__CONTENT__"));
|
|
|
|
content = appendToFirstOccurence(content, "<head>", "<style>" +
|
|
|
|
content = appendToFirstOccurence(content,
|
|
|
|
RESOURCE::taskbar_css + "</style>");
|
|
|
|
"<head>",
|
|
|
|
|
|
|
|
"<style>" +
|
|
|
|
|
|
|
|
RESOURCE::taskbar_css +
|
|
|
|
|
|
|
|
(noLibraryButtonFlag ? " #kiwix_serve_taskbar_library_button { display: none }" : "") +
|
|
|
|
|
|
|
|
"</style>");
|
|
|
|
content = appendToFirstOccurence(content, "<body[^>]*>",
|
|
|
|
content = appendToFirstOccurence(content, "<body[^>]*>",
|
|
|
|
replaceRegex(RESOURCE::taskbar_html_part,
|
|
|
|
replaceRegex(RESOURCE::taskbar_html_part,
|
|
|
|
humanReadableBookId, "__CONTENT__"));
|
|
|
|
humanReadableBookId, "__CONTENT__"));
|
|
|
|
@ -713,6 +718,7 @@ int main(int argc, char **argv) {
|
|
|
|
{"daemon", no_argument, 0, 'd'},
|
|
|
|
{"daemon", no_argument, 0, 'd'},
|
|
|
|
{"verbose", no_argument, 0, 'v'},
|
|
|
|
{"verbose", no_argument, 0, 'v'},
|
|
|
|
{"library", no_argument, 0, 'l'},
|
|
|
|
{"library", no_argument, 0, 'l'},
|
|
|
|
|
|
|
|
{"nolibrarybutton", no_argument, 0, 'm'},
|
|
|
|
{"nosearchbar", no_argument, 0, 'n'},
|
|
|
|
{"nosearchbar", no_argument, 0, 'n'},
|
|
|
|
{"index", required_argument, 0, 'i'},
|
|
|
|
{"index", required_argument, 0, 'i'},
|
|
|
|
{"attachToProcess", required_argument, 0, 'a'},
|
|
|
|
{"attachToProcess", required_argument, 0, 'a'},
|
|
|
|
@ -724,7 +730,7 @@ int main(int argc, char **argv) {
|
|
|
|
/* Argument parsing */
|
|
|
|
/* Argument parsing */
|
|
|
|
while (true) {
|
|
|
|
while (true) {
|
|
|
|
int option_index = 0;
|
|
|
|
int option_index = 0;
|
|
|
|
int c = getopt_long(argc, argv, "ndvli:a:p:f:", long_options, &option_index);
|
|
|
|
int c = getopt_long(argc, argv, "mndvli:a:p:f:", long_options, &option_index);
|
|
|
|
|
|
|
|
|
|
|
|
if (c != -1) {
|
|
|
|
if (c != -1) {
|
|
|
|
|
|
|
|
|
|
|
|
@ -739,7 +745,10 @@ int main(int argc, char **argv) {
|
|
|
|
libraryFlag = true;
|
|
|
|
libraryFlag = true;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case 'n':
|
|
|
|
case 'n':
|
|
|
|
nosearchbarFlag = true;
|
|
|
|
noSearchBarFlag = true;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'm':
|
|
|
|
|
|
|
|
noLibraryButtonFlag = true;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case 'i':
|
|
|
|
case 'i':
|
|
|
|
indexPath = optarg;
|
|
|
|
indexPath = optarg;
|
|
|
|
@ -771,8 +780,8 @@ int main(int argc, char **argv) {
|
|
|
|
|
|
|
|
|
|
|
|
/* Print usage)) if necessary */
|
|
|
|
/* Print usage)) if necessary */
|
|
|
|
if (zimPathes.empty() && libraryPath.empty()) {
|
|
|
|
if (zimPathes.empty() && libraryPath.empty()) {
|
|
|
|
cerr << "Usage: kiwix-serve [--index=INDEX_PATH] [--port=PORT] [--verbose] [--nosearchbar] [--daemon] [--attachToProcess=PID] [--interface=IF_NAME] ZIM_PATH+" << endl;
|
|
|
|
cerr << "Usage: kiwix-serve [--index=INDEX_PATH] [--port=PORT] [--verbose] [--nosearchbar] [--nolibrarybutton] [--daemon] [--attachToProcess=PID] [--interface=IF_NAME] ZIM_PATH+" << endl;
|
|
|
|
cerr << " kiwix-serve --library [--port=PORT] [--verbose] [--daemon] [--nosearchbar] [--attachToProcess=PID] [--interface=IF_NAME] LIBRARY_PATH" << endl;
|
|
|
|
cerr << " kiwix-serve --library [--port=PORT] [--verbose] [--daemon] [--nosearchbar] [--nolibrarybutton] [--attachToProcess=PID] [--interface=IF_NAME] LIBRARY_PATH" << endl;
|
|
|
|
cerr << "\n If you set more than one ZIM_PATH, you cannot set a INDEX_PATH." << endl;
|
|
|
|
cerr << "\n If you set more than one ZIM_PATH, you cannot set a INDEX_PATH." << endl;
|
|
|
|
exit(1);
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|