aboutsummaryrefslogtreecommitdiffstats
path: root/sisinstall/sismain.cpp
blob: 21d6f554a96f54c66dec930105e1808349c106de (plain)
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
#include "sisfile.h"
#include "sisinstaller.h"
#include "psion.h"
#include "fakepsion.h"

#include <errno.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>

#define _GNU_SOURCE
#include <getopt.h>

static void error(int line)
{
	fprintf(stderr, "Got errno = %d on line %d\n", errno, line);
	exit(1);
}

static struct option opts[] = {
	{ "help",     no_argument,       0, 'h' },
	{ "version",  no_argument,       0, 'V' },
	{ "loglevel", required_argument, 0, 'l' },
	{ "dry-run",  no_argument,       0, 'n' },
	{ "force",    no_argument,       0, 'f' },
	{ NULL,       0,                 0, 0 },
};

void printHelp()
{
	printf(
	_("Usage: sisinstall [OPTIONS]... SISFILE\n"
	"\n"
	"Supported options:\n"
	"\n"
	" -h, --help              Display this text.\n"
	" -V, --version           Print version and exit.\n"
	" -l, --loglevel=LEVEL    Set the log level, by default 0.\n"
	" -n, --dry-run           Just parse file file.\n"
	" -f, --force             Ignore any earlier installations.\n"
	));
}

void main(int argc, char* argv[])
{
	char* filename = 0;
	char option;
	bool dryrun = false;
	bool forced = false;

#ifdef LC_ALL
	setlocale(LC_ALL, "");
#endif
	textdomain(PACKAGE);

	while (1)
		{
		option = getopt_long(argc, argv, "fhnl:", opts, NULL);
		if (option == -1)
			break;
		switch (option)
			{
			case 'h':
			case '?':
				printHelp();
				exit(0);
			case 'f':
				forced = true;
				break;
			case 'l':
				logLevel = atoi(optarg);
				break;
			case 'n':
				dryrun = true;
				break;
			}
		}
	if (optind < argc)
		{
		filename = argv[optind];
		printf(_("Installing sis file %s%s\n"), filename,
			   dryrun ? _(", not really") : "");
		}
	struct stat st;
	if (-1 == stat(filename, &st))
		error(__LINE__);
	off_t len = st.st_size;
	if (logLevel >= 2)
		printf(_("File is %d bytes long\n"), len);
	uint8_t* buf = new uint8_t[len];
	int fd = open(filename, O_RDONLY);
	if (-1 == fd)
		error(__LINE__);
	if (-1 == read(fd, buf, len))
		error(__LINE__);
	close(fd);
	Psion* psion;
	if (dryrun)
		psion = new FakePsion();
	else
		psion = new Psion();
	if (!psion->connect())
		{
		printf(_("Couldn't connect with the Psion\n"));
		exit(1);
		}
	createCRCTable();
	SISFile sisFile;
	SisRC rc = sisFile.fillFrom(buf, len);
	if (rc == SIS_OK)
		{
		if (!dryrun)
			{
			SISInstaller installer;
			installer.setPsion(psion);
			installer.setForced(forced);
			installer.run(&sisFile, buf, len);
			}
		}
	else
		{
		printf(_("Could not parse the sis file.\n"));
		}
	psion->disconnect();

	exit(0);
}