597 |
mateuszvis |
1 |
/* This file is part of the svarlang project and is published under the terms
|
|
|
2 |
* of the MIT license.
|
|
|
3 |
*
|
|
|
4 |
* Copyright (C) 2021-2022 Mateusz Viste
|
|
|
5 |
*
|
|
|
6 |
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
7 |
* copy of this software and associated documentation files (the "Software"),
|
|
|
8 |
* to deal in the Software without restriction, including without limitation
|
|
|
9 |
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
|
10 |
* and/or sell copies of the Software, and to permit persons to whom the
|
|
|
11 |
* Software is furnished to do so, subject to the following conditions:
|
|
|
12 |
*
|
|
|
13 |
* The above copyright notice and this permission notice shall be included in
|
|
|
14 |
* all copies or substantial portions of the Software.
|
|
|
15 |
*
|
|
|
16 |
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
17 |
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
18 |
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
19 |
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
20 |
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
|
21 |
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
|
22 |
* DEALINGS IN THE SOFTWARE.
|
|
|
23 |
*/
|
|
|
24 |
|
|
|
25 |
#include <stdio.h> /* FILE */
|
|
|
26 |
#include <stdlib.h> /* NULL */
|
|
|
27 |
#include <string.h> /* memcmp(), strcpy() */
|
|
|
28 |
|
|
|
29 |
#include "svarlang.h"
|
|
|
30 |
|
|
|
31 |
|
599 |
mateuszvis |
32 |
/* supplied through DEFLANG.C */
|
|
|
33 |
extern char svarlang_mem[];
|
|
|
34 |
extern const unsigned short svarlang_memsz;
|
|
|
35 |
|
|
|
36 |
|
597 |
mateuszvis |
37 |
const char *svarlang_strid(unsigned short id) {
|
|
|
38 |
const char *ptr = svarlang_mem;
|
|
|
39 |
/* find the string id in langblock memory */
|
|
|
40 |
for (;;) {
|
|
|
41 |
if (((unsigned short *)ptr)[0] == id) {
|
|
|
42 |
ptr += 3;
|
|
|
43 |
return(ptr);
|
|
|
44 |
}
|
|
|
45 |
if (ptr[2] == 0) return(NULL);
|
|
|
46 |
ptr += ptr[2] + 3;
|
|
|
47 |
}
|
|
|
48 |
}
|
|
|
49 |
|
|
|
50 |
|
|
|
51 |
int svarlang_load(const char *progname, const char *lang, const char *nlspath) {
|
|
|
52 |
unsigned short langid;
|
|
|
53 |
FILE *fd;
|
|
|
54 |
char buff[128];
|
|
|
55 |
unsigned short buff16[2];
|
|
|
56 |
unsigned short i;
|
|
|
57 |
|
|
|
58 |
if ((lang == NULL) || (nlspath == NULL)) return(-1);
|
|
|
59 |
|
|
|
60 |
langid = *((unsigned short *)lang);
|
|
|
61 |
langid &= 0xDFDF; /* make sure lang is upcase */
|
|
|
62 |
|
|
|
63 |
/* copy nlspath to buff and remember len */
|
|
|
64 |
for (i = 0; nlspath[i] != 0; i++) buff[i] = nlspath[i];
|
|
|
65 |
|
|
|
66 |
/* */
|
|
|
67 |
if ((i > 0) && (buff[i - 1] == '\\')) i--;
|
|
|
68 |
|
|
|
69 |
buff[i++] = '\\';
|
|
|
70 |
strcpy(buff + i, progname);
|
|
|
71 |
strcat(buff + i, ".lng");
|
|
|
72 |
|
|
|
73 |
fd = fopen(buff, "rb");
|
|
|
74 |
if (fd == NULL) return(-2);
|
|
|
75 |
|
|
|
76 |
/* read hdr, should be "SvL\33" */
|
|
|
77 |
if ((fread(buff, 1, 4, fd) != 4) || (memcmp(buff, "SvL\33", 4) != 0)) {
|
|
|
78 |
fclose(fd);
|
|
|
79 |
return(-3);
|
|
|
80 |
}
|
|
|
81 |
|
|
|
82 |
/* read next lang id in file */
|
|
|
83 |
while (fread(buff16, 1, 4, fd) == 4) {
|
|
|
84 |
|
|
|
85 |
/* is it the lang I am looking for? */
|
|
|
86 |
if (buff16[0] != langid) { /* skip to next lang */
|
|
|
87 |
fseek(fd, buff16[1], SEEK_CUR);
|
|
|
88 |
continue;
|
|
|
89 |
}
|
|
|
90 |
|
|
|
91 |
/* found - but do I have enough memory space? */
|
599 |
mateuszvis |
92 |
if (buff16[1] >= svarlang_memsz) {
|
597 |
mateuszvis |
93 |
fclose(fd);
|
|
|
94 |
return(-4);
|
|
|
95 |
}
|
|
|
96 |
|
|
|
97 |
/* load strings */
|
|
|
98 |
if (fread(svarlang_mem, 1, buff16[1], fd) != buff16[1]) break;
|
|
|
99 |
fclose(fd);
|
|
|
100 |
return(0);
|
|
|
101 |
}
|
|
|
102 |
|
|
|
103 |
fclose(fd);
|
|
|
104 |
return(-5);
|
|
|
105 |
}
|