
Security News
NVD Quietly Sweeps 100K+ CVEs Into a “Deferred” Black Hole
NVD now marks all pre-2018 CVEs as "Deferred," signaling it will no longer enrich older vulnerabilities, further eroding trust in its data.
This open-source, MIT-licensed package is a core part of the Mapof ecosystem. This framework allow for representing various features of (computational) problem instances in the context of the instance structure in a visually appealing way. Mapof is a direct successor of mapel, which will be deprecated in the (unforeseen) future.
We've successively substituted mapel packages present when we decided to start Mapof and have abandoned active development of mapel. Here is a map of the old and new projects:
Hence, this package, Mapof, is a direct successor of mapel-core.
There are in principle three (standard to python packages) ways to install Mapof. We strongly recommend installing the package from PyPi but you can also: use the code as a local package or install the package from the local code using some package manager.
We recommend installing Mapof in a separate virtual environment (we use venv
but any reasonable environment manager should do). Installation from Pypi with
one of Python's package managers allows a seamless usage of Mapof with its
remaining modules, that are to come soon, which all declare Mapof as
dependency. A drawback is here that one cannot edit the Mapof code easily. If
you use pip
type pip install mapof
to get the newest version and your are
ready to go. If you use other package managers, do whatever it usually takes to
install packages from PyPi.
[!TIP] You can still patch Mapof using the fact that functions are First-Class Citizens in Python. By separating changes from the actual Mapof code, the changes can later be easily changed to pull requests. And we would be very happy if you contribute to Mapof. For details, see the section below.
To patch function mapof.bar.foo
you can define your own function my_foo
and
then assign it using mapof.bar.foo = mapof.bar.my_foo
. If you do this before
calling mapof.bar.foo
, then each call to mapof.bar.foo
will actually run
your my_foo
function.
Using the code as a local package is another option. Doing so, by downloading the package and importing different modules directly, comes with an easy way to edit Mapof files. However, it enforces usage of all other Mapof packages in the very same way. Trying installing other packages via some package manger will most likely result in that you will be using the manager-downloaded PyPi version of the Mapof module instead of your handcrafted one (there are workarounds, but you probably know these tricks very well if you ever want to take this path).
A somewhat compromise solution is to fork the repo and install the package into the package management system using your locally stored (perhaps edited) code. This might have a drawback that you need to update your installation after every change you make in the Mapof code.
However pip
offers a handy solution here, the editable mode. Overall, using
pip
you can pass to pip install
the path to the project (where
pyproject.toml
resides) and the -e
switch. By this you get the best of two
worlds Mapof is managed by pip and your modifications of the package are
reflected immediately in the code that uses Mapof. This approach also have its
limitations but in most cases it should just work well. In case you experience
troubles, you should see what the pip
documentation has to say about the
editable mode.
The complete documentation is available here.
Feel free to contribute to Mapof using pull requests. We use black to enforce a coherent code style.
This project is part of the PRAGMA project which has received funding from the European Research Council (ERC) under the European Union’s Horizon 2020 research and innovation programme (grant agreement No 101002854).
FAQs
Map of Objects---essential parts
We found that mapof demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
NVD now marks all pre-2018 CVEs as "Deferred," signaling it will no longer enrich older vulnerabilities, further eroding trust in its data.
Research
Security News
Lazarus-linked threat actors expand their npm malware campaign with new RAT loaders, hex obfuscation, and over 5,600 downloads across 11 packages.
Security News
Safari 18.4 adds support for Iterator Helpers and two other TC39 JavaScript features, bringing full cross-browser coverage to key parts of the ECMAScript spec.