diff options
author | George Hazan <george.hazan@gmail.com> | 2024-03-09 13:23:13 +0300 |
---|---|---|
committer | George Hazan <george.hazan@gmail.com> | 2024-03-09 13:23:13 +0300 |
commit | 6641d0fd12e381e998f6c0e24a037f9aebb9fd60 (patch) | |
tree | 68a1777902385ea011a02e7ea41d07066233b445 /plugins/Import | |
parent | 3538aa32babc7aa8bfaf5de4a0068300d14ea0dc (diff) |
no need to create empty JSON files if there're no events to export
Diffstat (limited to 'plugins/Import')
-rw-r--r-- | plugins/Import/src/textjson.cpp | 24 |
1 files changed, 13 insertions, 11 deletions
diff --git a/plugins/Import/src/textjson.cpp b/plugins/Import/src/textjson.cpp index d5818357e2..f660e8f173 100644 --- a/plugins/Import/src/textjson.cpp +++ b/plugins/Import/src/textjson.cpp @@ -43,13 +43,15 @@ class CDbxJson : public MDatabaseExport, public MZeroedObject LIST<JSONNode> m_events;
LIST<char> m_modules;
bool m_bAppend = true;
- HANDLE m_out = nullptr;
+ HANDLE m_out = INVALID_HANDLE_VALUE;
+ ptrW m_wszFileName;
CMStringA m_szId, m_szReplyId, m_szUserId;
public:
- CDbxJson() :
+ CDbxJson(const wchar_t *pwszFileName = nullptr) :
m_events(100),
- m_modules(10, CompareModules)
+ m_modules(10, CompareModules),
+ m_wszFileName(mir_wstrdup(pwszFileName))
{}
~CDbxJson()
@@ -243,9 +245,9 @@ public: //////////////////////////////////////////////////////////////////////////////////////
// Export interface
- int Create(const wchar_t *profile)
+ int Create()
{
- m_out = CreateFileW(profile, GENERIC_WRITE | GENERIC_READ, FILE_SHARE_READ, nullptr, OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, nullptr);
+ m_out = CreateFileW(m_wszFileName, GENERIC_WRITE | GENERIC_READ, FILE_SHARE_READ, nullptr, OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, nullptr);
if (m_out == INVALID_HANDLE_VALUE)
return EGROKPRF_CANTREAD;
@@ -255,6 +257,9 @@ public: STDMETHODIMP_(int) BeginExport() override
{
+ if (m_out == INVALID_HANDLE_VALUE)
+ Create();
+
return GetFileSize(m_out, 0) != 0;
}
@@ -395,12 +400,9 @@ static MDatabaseCommon* json_load(const wchar_t *profile, BOOL) static MDatabaseExport *json_export(const wchar_t *profile)
{
- std::unique_ptr<CDbxJson> db(new CDbxJson());
- if (db->Create(profile))
- return nullptr;
-
- db->Load();
- return db.release();
+ auto *pDB = new CDbxJson(profile);
+ pDB->Load();
+ return pDB;
}
static DATABASELINK dblink =
|