pyghdl is a language server for VHDL based on ghdl.
It implements the Language Server Protocol.
The server is implemented in Python (3.x) but relies on libghdl for parsing.
It also provides a python interface to libghdl, which could be used to
develop tools around the parser and analyzer.
To install:
1) First install ghdl (add --enable-python during configuration).
This is needed so that the libraries are available
2) In ghdl/python, install pyghdl. There is a setup.py script, so you can do:
$ pip install .
To install for development: pip install -e .
Add --user to install in your home directory.
The executable is named 'ghdl-ls'. It uses stdin/stdout to communicate with
its client.
le='iCE40/nextpnr' href='/cgit/iCE40/nextpnr/'>iCE40/nextpnr
blob: 6beb157be619b2cd32cb160ea295c76c77dc3fe5 (
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
|
#include <map>
#if defined(WIN32)
#include <windows.h>
#endif
#include <boost/filesystem.hpp>
#include <boost/iostreams/device/mapped_file.hpp>
#include "embed.h"
#include "nextpnr.h"
NEXTPNR_NAMESPACE_BEGIN
#if defined(EXTERNAL_CHIPDB_ROOT)
const void *get_chipdb(const std::string &filename)
{
static std::map<std::string, boost::iostreams::mapped_file> files;
if (!files.count(filename)) {
std::string full_filename = EXTERNAL_CHIPDB_ROOT "/" + filename;
if (boost::filesystem::exists(full_filename))
files[filename].open(full_filename, boost::iostreams::mapped_file::priv);
}
if (files.count(filename))
return files.at(filename).data();
return nullptr;
}
#elif defined(WIN32)
const void *get_chipdb(const std::string &filename)
{
HRSRC rc = ::FindResource(nullptr, filename.c_str(), RT_RCDATA);
HGLOBAL rcData = ::LoadResource(nullptr, rc);
return ::LockResource(rcData);
}
#else
EmbeddedFile *EmbeddedFile::head = nullptr;
const void *get_chipdb(const std::string &filename)
{
for (EmbeddedFile *file = EmbeddedFile::head; file; file = file->next)
if (file->filename == filename)
return file->content;
return nullptr;
}
#endif
NEXTPNR_NAMESPACE_END
|