Cron scheduling: add /usr/local/bin or /opt/local/bin to the PATH when built for macports or homebrew
This commit is contained in:
parent
00605f4a3c
commit
e5b74ef4d5
@ -51,8 +51,9 @@ void CronToolW::init()
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
if (checkCrontabUnmanaged(marker, "recollindex")) {
|
if (checkCrontabUnmanaged(marker, "recollindex")) {
|
||||||
QMessageBox::warning(0, "Recoll",
|
QMessageBox::warning(
|
||||||
tr("It seems that manually edited entries exist for recollindex, cannot edit crontab"));
|
0, "Recoll", tr("It seems that manually edited entries exist for "
|
||||||
|
"recollindex, cannot edit crontab"));
|
||||||
QTimer::singleShot(0, this, SLOT(close()));
|
QTimer::singleShot(0, this, SLOT(close()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -81,6 +82,15 @@ void CronToolW::changeCron(bool enable)
|
|||||||
|
|
||||||
string id = idstring(theconfig->getConfDir());
|
string id = idstring(theconfig->getConfDir());
|
||||||
string cmd("recollindex");
|
string cmd("recollindex");
|
||||||
|
#if defined(MACPORTS) || defined(HOMEBREW)
|
||||||
|
// The MACPORTS and HOMEBREW flags are set by the resp. portfile
|
||||||
|
// and recipee. Adjust the path for finding recollindex accordingly
|
||||||
|
#if defined(MACPORTS)
|
||||||
|
cmd = string("PATH=/opt/local/bin/:$PATH ") + cmd;
|
||||||
|
#elif defined(HOMEBREW)
|
||||||
|
cmd = string("PATH=/usr/local/bin/:$PATH ") + cmd;
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
string reason;
|
string reason;
|
||||||
|
|
||||||
@ -95,8 +105,9 @@ void CronToolW::changeCron(bool enable)
|
|||||||
if (editCrontab(marker, id, sched, cmd, reason)) {
|
if (editCrontab(marker, id, sched, cmd, reason)) {
|
||||||
accept();
|
accept();
|
||||||
} else {
|
} else {
|
||||||
QMessageBox::warning(0, "Recoll",
|
QMessageBox::warning(
|
||||||
tr("Error installing cron entry. Bad syntax in fields ?"));
|
0, "Recoll", tr("Error installing cron entry. "
|
||||||
|
"Bad syntax in fields ?"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -39,7 +39,10 @@ AM_CPPFLAGS = -Wall -Wno-unused -std=c++11 \
|
|||||||
$(DEFS)
|
$(DEFS)
|
||||||
|
|
||||||
noinst_PROGRAMS = textsplit utf8iter fstreewalk rclconfig hldata unac mbox \
|
noinst_PROGRAMS = textsplit utf8iter fstreewalk rclconfig hldata unac mbox \
|
||||||
circache wipedir mimetype pathut fileudi x11mon trqrstore
|
circache wipedir mimetype pathut fileudi x11mon trqrstore ecrontab
|
||||||
|
|
||||||
|
ecrontab_SOURCES = trecrontab.cpp
|
||||||
|
ecrontab_LDADD = ../librecoll.la
|
||||||
|
|
||||||
circache_SOURCES = trcircache.cpp
|
circache_SOURCES = trcircache.cpp
|
||||||
circache_LDADD = ../librecoll.la
|
circache_LDADD = ../librecoll.la
|
||||||
|
|||||||
132
src/testmains/trecrontab.cpp
Normal file
132
src/testmains/trecrontab.cpp
Normal file
@ -0,0 +1,132 @@
|
|||||||
|
/* Copyright (C) 2017-2019 J.F.Dockes
|
||||||
|
*
|
||||||
|
* License: GPL 2.1
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public License
|
||||||
|
* along with this program; if not, write to the
|
||||||
|
* Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
#include "ecrontab.h"
|
||||||
|
|
||||||
|
|
||||||
|
static char *thisprog;
|
||||||
|
|
||||||
|
static char usage [] =
|
||||||
|
" -a add or replace crontab line \n"
|
||||||
|
" -d delete crontab line \n"
|
||||||
|
" -s get scheduling \n"
|
||||||
|
" -c <string> check for unmanaged lines for string\n"
|
||||||
|
;
|
||||||
|
|
||||||
|
static void
|
||||||
|
Usage(void)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "%s: usage:\n%s", thisprog, usage);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int op_flags;
|
||||||
|
#define OPT_MOINS 0x1
|
||||||
|
#define OPT_a 0x2
|
||||||
|
#define OPT_d 0x4
|
||||||
|
#define OPT_w 0x8
|
||||||
|
#define OPT_c 0x10
|
||||||
|
#define OPT_s 0x20
|
||||||
|
|
||||||
|
const string& marker("RCLCRON_RCLINDEX=");
|
||||||
|
// Note of course the -w does not make sense for a cron entry
|
||||||
|
const string& cmd0("recollindex -w ");
|
||||||
|
const string& id("RECOLL_CONFDIR=\"/home/dockes/.recoll/\"");
|
||||||
|
const string& sched("30 8 * 1 *");
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
thisprog = argv[0];
|
||||||
|
argc--; argv++;
|
||||||
|
|
||||||
|
string wt = "10";
|
||||||
|
string cmd;
|
||||||
|
|
||||||
|
while (argc > 0 && **argv == '-') {
|
||||||
|
(*argv)++;
|
||||||
|
if (!(**argv))
|
||||||
|
/* Cas du "adb - core" */
|
||||||
|
Usage();
|
||||||
|
while (**argv)
|
||||||
|
switch (*(*argv)++) {
|
||||||
|
case 'a': op_flags |= OPT_a; break;
|
||||||
|
case 'c': op_flags |= OPT_c; if (argc < 2) Usage();
|
||||||
|
cmd = *(++argv); argc--;
|
||||||
|
goto b1;
|
||||||
|
case 'd': op_flags |= OPT_d; break;
|
||||||
|
case 's': op_flags |= OPT_s; break;
|
||||||
|
case 'w': op_flags |= OPT_w; if (argc < 2) Usage();
|
||||||
|
wt = *(++argv); argc--;
|
||||||
|
goto b1;
|
||||||
|
|
||||||
|
default: Usage(); break;
|
||||||
|
}
|
||||||
|
b1: argc--; argv++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (argc != 0)
|
||||||
|
Usage();
|
||||||
|
|
||||||
|
string reason;
|
||||||
|
bool status = false;
|
||||||
|
|
||||||
|
if (op_flags & OPT_a) {
|
||||||
|
cmd = cmd0 + wt;
|
||||||
|
status = editCrontab(marker, id, sched, cmd, reason);
|
||||||
|
} else if (op_flags & OPT_d) {
|
||||||
|
status = editCrontab(marker, id, sched, "", reason);
|
||||||
|
} else if (op_flags & OPT_s) {
|
||||||
|
vector<string> sched;
|
||||||
|
if (!(status = getCrontabSched(marker, id, sched))) {
|
||||||
|
cerr << "getCrontabSched failed: " << reason << endl;
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
cout << "sched vec size " << sched.size() << endl;
|
||||||
|
cout << "mins " << sched[0] << " hours " << sched[1] <<
|
||||||
|
" days of month " << sched[2] << " months " << sched[3] <<
|
||||||
|
" days of week " << sched[4] << endl;
|
||||||
|
exit(0);
|
||||||
|
|
||||||
|
} else if (op_flags & OPT_c) {
|
||||||
|
if ((status = checkCrontabUnmanaged(marker, cmd))) {
|
||||||
|
cerr << "crontab has unmanaged lines for " << cmd << endl;
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
exit(0);
|
||||||
|
} else {
|
||||||
|
Usage();
|
||||||
|
}
|
||||||
|
if (!status) {
|
||||||
|
cerr << "editCrontab failed: " << reason << endl;
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 2004 J.F.Dockes
|
/* Copyright (C) 2004-2021 J.F.Dockes
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
@ -14,7 +14,6 @@
|
|||||||
* Free Software Foundation, Inc.,
|
* Free Software Foundation, Inc.,
|
||||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
*/
|
*/
|
||||||
#ifndef TEST_ECRONTAB
|
|
||||||
#include "autoconfig.h"
|
#include "autoconfig.h"
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@ -37,8 +36,8 @@ static bool eCrontabGetLines(vector<string>& lines)
|
|||||||
// status than for an empty one
|
// status than for an empty one
|
||||||
args.push_back("-l");
|
args.push_back("-l");
|
||||||
if ((status = croncmd.doexec("crontab", args, 0, &crontab))) {
|
if ((status = croncmd.doexec("crontab", args, 0, &crontab))) {
|
||||||
lines.clear();
|
lines.clear();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Split crontab into lines
|
// Split crontab into lines
|
||||||
@ -54,54 +53,51 @@ static bool eCrontabWriteFile(const vector<string>& lines, string& reason)
|
|||||||
vector<string> args;
|
vector<string> args;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
for (vector<string>::const_iterator it = lines.begin();
|
for (const auto& line : lines) {
|
||||||
it != lines.end(); it++) {
|
crontab += line + "\n";
|
||||||
crontab += *it + "\n";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
args.push_back("-");
|
args.push_back("-");
|
||||||
if ((status = croncmd.doexec("crontab", args, &crontab, 0))) {
|
if ((status = croncmd.doexec("crontab", args, &crontab, 0))) {
|
||||||
char nbuf[30];
|
char nbuf[30];
|
||||||
sprintf(nbuf, "0x%x", status);
|
sprintf(nbuf, "0x%x", status);
|
||||||
reason = string("Exec crontab -l failed: status: ") + nbuf;
|
reason = string("Exec crontab -l failed: status: ") + nbuf;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add / change / delete entry identified by marker and id
|
// Add / change / delete entry identified by marker and id
|
||||||
bool editCrontab(const string& marker, const string& id,
|
bool editCrontab(const string& marker, const string& id,
|
||||||
const string& sched, const string& cmd, string& reason)
|
const string& sched, const string& cmd, string& reason)
|
||||||
{
|
{
|
||||||
vector<string> lines;
|
vector<string> lines;
|
||||||
|
|
||||||
if (!eCrontabGetLines(lines)) {
|
if (!eCrontabGetLines(lines)) {
|
||||||
// Special case: cmd is empty, no crontab, don't create one
|
// Special case: cmd is empty, no crontab, don't create one
|
||||||
if (cmd.empty())
|
if (cmd.empty())
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Remove old copy if any
|
// Remove old copy if any
|
||||||
for (vector<string>::iterator it = lines.begin();
|
for (auto it = lines.begin(); it != lines.end(); it++) {
|
||||||
it != lines.end(); it++) {
|
// Skip comment
|
||||||
// Skip comment
|
if (it->find_first_of("#") == it->find_first_not_of(" \t"))
|
||||||
if (it->find_first_of("#") == it->find_first_not_of(" \t"))
|
continue;
|
||||||
continue;
|
|
||||||
|
|
||||||
if (it->find(marker) != string::npos &&
|
if (it->find(marker) != string::npos && it->find(id) != string::npos) {
|
||||||
it->find(id) != string::npos) {
|
lines.erase(it);
|
||||||
lines.erase(it);
|
break;
|
||||||
break;
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!cmd.empty()) {
|
if (!cmd.empty()) {
|
||||||
string nline = sched + " " + marker + " " + id + " " + cmd;
|
string nline = sched + " " + marker + " " + id + " " + cmd;
|
||||||
lines.push_back(nline);
|
lines.push_back(nline);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!eCrontabWriteFile(lines, reason))
|
if (!eCrontabWriteFile(lines, reason))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -110,163 +106,45 @@ bool checkCrontabUnmanaged(const string& marker, const string& data)
|
|||||||
{
|
{
|
||||||
vector<string> lines;
|
vector<string> lines;
|
||||||
if (!eCrontabGetLines(lines)) {
|
if (!eCrontabGetLines(lines)) {
|
||||||
// No crontab, answer is no
|
// No crontab, answer is no
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// Scan crontab
|
// Scan crontab
|
||||||
for (vector<string>::iterator it = lines.begin();
|
for (const auto& line : lines) {
|
||||||
it != lines.end(); it++) {
|
if (line.find(marker) == string::npos &&
|
||||||
if (it->find(marker) == string::npos &&
|
line.find(data) != string::npos) {
|
||||||
it->find(data) != string::npos) {
|
return true;
|
||||||
return true;
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Retrieve the scheduling for a crontab entry */
|
/** Retrieve the scheduling for a crontab entry */
|
||||||
bool getCrontabSched(const string& marker, const string& id,
|
bool getCrontabSched(const string& marker, const string& id,
|
||||||
vector<string>& sched)
|
vector<string>& sched)
|
||||||
{
|
{
|
||||||
LOGDEB0("getCrontabSched: marker[" << (marker) << "], id[" << (id) << "]\n" );
|
LOGDEB0("getCrontabSched: marker[" << marker << "], id[" << id << "]\n");
|
||||||
vector<string> lines;
|
vector<string> lines;
|
||||||
if (!eCrontabGetLines(lines)) {
|
if (!eCrontabGetLines(lines)) {
|
||||||
// No crontab, answer is no
|
// No crontab, answer is no
|
||||||
sched.clear();
|
sched.clear();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
string line;
|
string theline;
|
||||||
|
|
||||||
for (vector<string>::iterator it = lines.begin();
|
for (const auto& line : lines) {
|
||||||
it != lines.end(); it++) {
|
// Skip comment
|
||||||
// Skip comment
|
if (line.find_first_of("#") == line.find_first_not_of(" \t"))
|
||||||
if (it->find_first_of("#") == it->find_first_not_of(" \t"))
|
continue;
|
||||||
continue;
|
|
||||||
|
|
||||||
if (it->find(marker) != string::npos &&
|
if (line.find(marker) != string::npos &&
|
||||||
it->find(id) != string::npos) {
|
line.find(id) != string::npos) {
|
||||||
line = *it;
|
theline = line;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
stringToTokens(line, sched);
|
stringToTokens(theline, sched);
|
||||||
sched.resize(5);
|
sched.resize(5);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
#else // TEST ->
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <errno.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#include <string>
|
|
||||||
#include <iostream>
|
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
#include "ecrontab.h"
|
|
||||||
|
|
||||||
|
|
||||||
static char *thisprog;
|
|
||||||
|
|
||||||
static char usage [] =
|
|
||||||
" -a add or replace crontab line \n"
|
|
||||||
" -d delete crontab line \n"
|
|
||||||
" -s get scheduling \n"
|
|
||||||
" -c <string> check for unmanaged lines for string\n"
|
|
||||||
;
|
|
||||||
static void
|
|
||||||
Usage(void)
|
|
||||||
{
|
|
||||||
fprintf(stderr, "%s: usage:\n%s", thisprog, usage);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int op_flags;
|
|
||||||
#define OPT_MOINS 0x1
|
|
||||||
#define OPT_a 0x2
|
|
||||||
#define OPT_d 0x4
|
|
||||||
#define OPT_w 0x8
|
|
||||||
#define OPT_c 0x10
|
|
||||||
#define OPT_s 0x20
|
|
||||||
|
|
||||||
const string& marker("RCLCRON_RCLINDEX=");
|
|
||||||
// Note of course the -w does not make sense for a cron entry
|
|
||||||
const string& cmd0("recollindex -w ");
|
|
||||||
const string& id("RECOLL_CONFDIR=\"/home/dockes/.recoll/\"");
|
|
||||||
const string& sched("30 8 * 1 *");
|
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
|
||||||
{
|
|
||||||
thisprog = argv[0];
|
|
||||||
argc--; argv++;
|
|
||||||
|
|
||||||
string wt = "10";
|
|
||||||
string cmd;
|
|
||||||
|
|
||||||
while (argc > 0 && **argv == '-') {
|
|
||||||
(*argv)++;
|
|
||||||
if (!(**argv))
|
|
||||||
/* Cas du "adb - core" */
|
|
||||||
Usage();
|
|
||||||
while (**argv)
|
|
||||||
switch (*(*argv)++) {
|
|
||||||
case 'a': op_flags |= OPT_a; break;
|
|
||||||
case 'c': op_flags |= OPT_c; if (argc < 2) Usage();
|
|
||||||
cmd = *(++argv); argc--;
|
|
||||||
goto b1;
|
|
||||||
case 'd': op_flags |= OPT_d; break;
|
|
||||||
case 's': op_flags |= OPT_s; break;
|
|
||||||
case 'w': op_flags |= OPT_w; if (argc < 2) Usage();
|
|
||||||
wt = *(++argv); argc--;
|
|
||||||
goto b1;
|
|
||||||
|
|
||||||
default: Usage(); break;
|
|
||||||
}
|
|
||||||
b1: argc--; argv++;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (argc != 0)
|
|
||||||
Usage();
|
|
||||||
|
|
||||||
string reason;
|
|
||||||
bool status = false;
|
|
||||||
|
|
||||||
if (op_flags & OPT_a) {
|
|
||||||
cmd = cmd0 + wt;
|
|
||||||
status = editCrontab(marker, id, sched, cmd, reason);
|
|
||||||
} else if (op_flags & OPT_d) {
|
|
||||||
status = editCrontab(marker, id, sched, "", reason);
|
|
||||||
} else if (op_flags & OPT_s) {
|
|
||||||
vector<string> sched;
|
|
||||||
if (!(status = getCrontabSched(marker, id, sched))) {
|
|
||||||
cerr << "getCrontabSched failed: " << reason << endl;
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
cout << "sched vec size " << sched.size() << endl;
|
|
||||||
cout << "mins " << sched[0] << " hours " << sched[1] <<
|
|
||||||
" days of month " << sched[2] << " months " << sched[3] <<
|
|
||||||
" days of week " << sched[4] << endl;
|
|
||||||
exit(0);
|
|
||||||
|
|
||||||
} else if (op_flags & OPT_c) {
|
|
||||||
if ((status = checkCrontabUnmanaged(marker, cmd))) {
|
|
||||||
cerr << "crontab has unmanaged lines for " << cmd << endl;
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
exit(0);
|
|
||||||
} else {
|
|
||||||
Usage();
|
|
||||||
}
|
|
||||||
if (!status) {
|
|
||||||
cerr << "editCrontab failed: " << reason << endl;
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
#endif // TEST
|
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user