mirror of
https://github.com/Dushistov/sdcv.git
synced 2026-01-09 20:04:28 +00:00
Compare commits
11 Commits
488ec68854
...
v0.5.4
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
eeee360fb0 | ||
|
|
f69973e1fa | ||
|
|
931fc98478 | ||
|
|
6f30be7815 | ||
|
|
1a926d1b69 | ||
|
|
e89cfa18b1 | ||
|
|
12d9ea5b97 | ||
|
|
920c2bafb9 | ||
|
|
5d2332b0cb | ||
|
|
452a4e07fb | ||
|
|
59ef936288 |
9
NEWS
9
NEWS
@@ -1,10 +1,3 @@
|
||||
Version 0.5.4
|
||||
- Use binary search for synonyms
|
||||
- Various improvments in work with synonyms
|
||||
- Added --json (same as --json-output) to match man
|
||||
- Show all matched result
|
||||
- More robust parsing of ifo file
|
||||
- Prevent crash if file size of files not matched expecting one for .oft files
|
||||
Version 0.5.3
|
||||
- Use single quotes around JSON data to reduce need for escaping
|
||||
- Store integer magic in cache file
|
||||
@@ -43,7 +36,7 @@ Version 0.4.2
|
||||
* Russian translation update
|
||||
|
||||
Version 0.4.1
|
||||
* Recreate cache if idx file was modified
|
||||
* Recreate cache if idx file was modified
|
||||
* Abbility to use pager(SDCV_PAGER)
|
||||
* Add Chinese (traditional) translation
|
||||
* Add Ukrainian translation
|
||||
|
||||
@@ -1,9 +1,6 @@
|
||||
#+OPTIONS: ^:nil
|
||||
[[https://github.com/Dushistov/sdcv/actions?query=workflow%3ACI+branch%3Amaster][https://github.com/Dushistov/sdcv/workflows/CI/badge.svg]]
|
||||
[[https://github.com/Dushistov/sdcv/blob/master/LICENSE][https://img.shields.io/badge/license-GPL%202-brightgreen.svg]]
|
||||
|
||||
* sdcv
|
||||
*sdcv* is a simple, cross-platform, text-based utility for working with dictionaries in [[http://stardict-4.sourceforge.net/][StarDict]] format.
|
||||
* How to compile and install
|
||||
#+BEGIN_SRC sh
|
||||
mkdir /tmp/build-sdcv
|
||||
|
||||
@@ -27,7 +27,7 @@ public:
|
||||
private:
|
||||
const char *start; /* start of mmap'd area */
|
||||
const char *end; /* end of mmap'd area */
|
||||
off_t size; /* size of mmap */
|
||||
unsigned long size; /* size of mmap */
|
||||
|
||||
int type;
|
||||
z_stream zStream;
|
||||
@@ -47,7 +47,7 @@ private:
|
||||
std::string origFilename;
|
||||
std::string comment;
|
||||
unsigned long crc;
|
||||
off_t length;
|
||||
unsigned long length;
|
||||
unsigned long compressedLength;
|
||||
DictCache cache[DICT_CACHE_SIZE];
|
||||
MapFile mapfile;
|
||||
|
||||
@@ -22,13 +22,13 @@ public:
|
||||
~MapFile();
|
||||
MapFile(const MapFile &) = delete;
|
||||
MapFile &operator=(const MapFile &) = delete;
|
||||
bool open(const char *file_name, off_t file_size);
|
||||
bool open(const char *file_name, unsigned long file_size);
|
||||
gchar *begin() { return data; }
|
||||
|
||||
private:
|
||||
char *data = nullptr;
|
||||
unsigned long size = 0ul;
|
||||
#ifdef HAVE_MMAP
|
||||
size_t size = 0u;
|
||||
int mmap_fd = -1;
|
||||
#elif defined(_WIN32)
|
||||
HANDLE hFile = 0;
|
||||
@@ -36,8 +36,9 @@ private:
|
||||
#endif
|
||||
};
|
||||
|
||||
inline bool MapFile::open(const char *file_name, off_t file_size)
|
||||
inline bool MapFile::open(const char *file_name, unsigned long file_size)
|
||||
{
|
||||
size = file_size;
|
||||
#ifdef HAVE_MMAP
|
||||
if ((mmap_fd = ::open(file_name, O_RDONLY)) < 0) {
|
||||
// g_print("Open file %s failed!\n",fullfilename);
|
||||
@@ -45,16 +46,14 @@ inline bool MapFile::open(const char *file_name, off_t file_size)
|
||||
}
|
||||
struct stat st;
|
||||
if (fstat(mmap_fd, &st) == -1 || st.st_size < 0 || (st.st_size == 0 && S_ISREG(st.st_mode))
|
||||
|| st.st_size != file_size) {
|
||||
|| sizeof(st.st_size) > sizeof(file_size) || static_cast<unsigned long>(st.st_size) != file_size) {
|
||||
close(mmap_fd);
|
||||
return false;
|
||||
}
|
||||
|
||||
size = static_cast<size_t>(st.st_size);
|
||||
data = (gchar *)mmap(nullptr, size, PROT_READ, MAP_SHARED, mmap_fd, 0);
|
||||
data = (gchar *)mmap(nullptr, file_size, PROT_READ, MAP_SHARED, mmap_fd, 0);
|
||||
if ((void *)data == (void *)(-1)) {
|
||||
// g_print("mmap file %s failed!\n",idxfilename);
|
||||
size = 0u;
|
||||
data = nullptr;
|
||||
return false;
|
||||
}
|
||||
|
||||
@@ -429,7 +429,7 @@ public:
|
||||
if (idxfile)
|
||||
fclose(idxfile);
|
||||
}
|
||||
bool load(const std::string &url, gulong wc, off_t fsize, bool verbose) override;
|
||||
bool load(const std::string &url, gulong wc, gulong fsize, bool verbose) override;
|
||||
const gchar *get_key(glong idx) override;
|
||||
void get_data(glong idx) override { get_key(idx); }
|
||||
const gchar *get_key_and_data(glong idx) override
|
||||
@@ -489,7 +489,7 @@ public:
|
||||
{
|
||||
}
|
||||
~WordListIndex() { g_free(idxdatabuf); }
|
||||
bool load(const std::string &url, gulong wc, off_t fsize, bool verbose) override;
|
||||
bool load(const std::string &url, gulong wc, gulong fsize, bool verbose) override;
|
||||
const gchar *get_key(glong idx) override { return wordlist[idx]; }
|
||||
void get_data(glong idx) override;
|
||||
const gchar *get_key_and_data(glong idx) override
|
||||
@@ -615,7 +615,7 @@ bool OffsetIndex::save_cache(const std::string &url, bool verbose)
|
||||
return false;
|
||||
}
|
||||
|
||||
bool OffsetIndex::load(const std::string &url, gulong wc, off_t fsize, bool verbose)
|
||||
bool OffsetIndex::load(const std::string &url, gulong wc, gulong fsize, bool verbose)
|
||||
{
|
||||
wordcount = wc;
|
||||
gulong npages = (wc - 1) / ENTR_PER_PAGE + 2;
|
||||
@@ -758,7 +758,7 @@ bool OffsetIndex::lookup(const char *str, std::set<glong> &idxs, glong &next_idx
|
||||
return bFound;
|
||||
}
|
||||
|
||||
bool WordListIndex::load(const std::string &url, gulong wc, off_t fsize, bool)
|
||||
bool WordListIndex::load(const std::string &url, gulong wc, gulong fsize, bool)
|
||||
{
|
||||
gzFile in = gzopen(url.c_str(), "rb");
|
||||
if (in == nullptr)
|
||||
@@ -771,7 +771,7 @@ bool WordListIndex::load(const std::string &url, gulong wc, off_t fsize, bool)
|
||||
if (len < 0)
|
||||
return false;
|
||||
|
||||
if (static_cast<off_t>(len) != fsize)
|
||||
if (gulong(len) != fsize)
|
||||
return false;
|
||||
|
||||
wordlist.resize(wc + 1);
|
||||
@@ -920,7 +920,7 @@ bool Dict::Lookup(const char *str, std::set<glong> &idxs, glong &next_idx)
|
||||
|
||||
bool Dict::load(const std::string &ifofilename, bool verbose)
|
||||
{
|
||||
off_t idxfilesize;
|
||||
gulong idxfilesize;
|
||||
if (!load_ifofile(ifofilename, idxfilesize))
|
||||
return false;
|
||||
|
||||
@@ -964,7 +964,7 @@ bool Dict::load(const std::string &ifofilename, bool verbose)
|
||||
return true;
|
||||
}
|
||||
|
||||
bool Dict::load_ifofile(const std::string &ifofilename, off_t &idxfilesize)
|
||||
bool Dict::load_ifofile(const std::string &ifofilename, gulong &idxfilesize)
|
||||
{
|
||||
DictInfo dict_info;
|
||||
if (!dict_info.load_from_ifo_file(ifofilename, false))
|
||||
|
||||
@@ -77,8 +77,8 @@ struct DictInfo {
|
||||
std::string website;
|
||||
std::string date;
|
||||
std::string description;
|
||||
off_t index_file_size;
|
||||
off_t syn_file_size;
|
||||
guint32 index_file_size;
|
||||
guint32 syn_file_size;
|
||||
std::string sametypesequence;
|
||||
|
||||
bool load_from_ifo_file(const std::string &ifofilename, bool istreedict);
|
||||
@@ -91,7 +91,7 @@ public:
|
||||
guint32 wordentry_size;
|
||||
|
||||
virtual ~IIndexFile() {}
|
||||
virtual bool load(const std::string &url, gulong wc, off_t fsize, bool verbose) = 0;
|
||||
virtual bool load(const std::string &url, gulong wc, gulong fsize, bool verbose) = 0;
|
||||
virtual const gchar *get_key(glong idx) = 0;
|
||||
virtual void get_data(glong idx) = 0;
|
||||
virtual const gchar *get_key_and_data(glong idx) = 0;
|
||||
@@ -160,7 +160,7 @@ private:
|
||||
std::unique_ptr<IIndexFile> idx_file;
|
||||
std::unique_ptr<SynFile> syn_file;
|
||||
|
||||
bool load_ifofile(const std::string &ifofilename, off_t &idxfilesize);
|
||||
bool load_ifofile(const std::string &ifofilename, gulong &idxfilesize);
|
||||
};
|
||||
|
||||
class Libs
|
||||
|
||||
Reference in New Issue
Block a user