File: NodeFileManager.cpp

package info (click to toggle)
codelite 14.0%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 112,816 kB
  • sloc: cpp: 483,662; ansic: 150,144; php: 9,569; lex: 4,186; python: 3,417; yacc: 2,820; sh: 1,147; makefile: 52; xml: 13
file content (83 lines) | stat: -rw-r--r-- 2,617 bytes parent folder | download | duplicates (4)
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
#include "NodeFileManager.h"
#include "file_logger.h"
#include "fileutils.h"
#include <algorithm>
#include <wx/filename.h>
#include <wx/uri.h>
#include <wx/regex.h>
#include <wx/filesys.h>

NodeFileManager::NodeFileManager() {}

NodeFileManager::~NodeFileManager() {}

NodeFileManager& NodeFileManager::Get()
{
    static NodeFileManager mgr;
    return mgr;
}

#define FILE_SCHEME "file://"

void NodeFileManager::Clear()
{
    m_files.clear();
    // Loop over the m_remoteFiles cache and delete the files from the file system
    std::for_each(m_remoteFiles.begin(), m_remoteFiles.end(),
                  [&](const std::unordered_map<wxString, wxString>::value_type& vt) {
                      FileUtils::RemoveFile(vt.second, "NodeFileManager::Clear()");
                  });
    m_remoteFiles.clear();
}

void NodeFileManager::AddFile(const wxString& id, const wxString& url)
{
    wxString filepath = URIToFileName(url);
    m_files.insert({ id, filepath });
}

wxString NodeFileManager::GetFilePath(const wxString& id) const
{
    wxString filePath = DoGetFilePath(id);
    if(!IsFileExists(filePath)) {
        // try the cache
        if(m_remoteFiles.count(id)) { filePath = m_remoteFiles.find(id)->second; }
    }
    return filePath;
}

bool NodeFileManager::IsFileExists(const wxString& id) const
{
    wxFileName fn(DoGetFilePath(id));
    return fn.Exists();
}

void NodeFileManager::CacheRemoteCopy(const wxString& id, const wxString& fileContent)
{
    // remove old content
    if(m_remoteFiles.count(id)) { m_remoteFiles.erase(id); }

    wxString local_copy;
    wxString filePath = DoGetFilePath(id);
    local_copy << clStandardPaths::Get().GetUserDataDir() << "/tmp/webtools/" << filePath;
    wxFileName fn(local_copy);
    // Make sure that the path to the file exists
    fn.Mkdir(wxS_DIR_DEFAULT, wxPATH_MKDIR_FULL);
    if(FileUtils::WriteFileContent(fn, fileContent, wxConvUTF8)) {
        clDEBUG() << "Localy copy of file" << filePath << "-->" << fn.GetFullPath();
        m_remoteFiles.insert({ id, fn.GetFullPath() });
    } else {
        clWARNING() << "Failed to write file content:" << fn.GetFullPath();
    }
}

wxString NodeFileManager::DoGetFilePath(const wxString& id) const
{
    std::unordered_map<wxString, wxString>::const_iterator iter = m_files.find(id);
    if(iter == m_files.end()) { return ""; }
    return iter->second;
}

wxString NodeFileManager::URIToFileName(const wxString& uri) { return wxFileSystem::URLToFileName(uri).GetFullPath(); }

wxString NodeFileManager::FileNameToURI(const wxString& uri) { return wxFileSystem::FileNameToURL(wxFileName(uri)); }