Git Product home page Git Product logo

gui_tool's Introduction

UAVCAN GUI Tool

Travis CI Gitter

UAVCAN GUI Tool is a cross-platform (Windows/Linux/OSX) application for UAVCAN bus management and diagnostics.

READ THE DOCUMENTATION HERE.

Read installation instructions:

UAVCAN GUI Tool screenshot

Installing on Linux

The general approach is simple:

  1. Install PyQt5 for Python 3 using your OS' package manager (e.g. APT).
  2. Install the application itself from Git via PIP: pip3 install git+https://github.com/UAVCAN/gui_tool@master (it is not necessary to clone this repository manually). Alternatively, if you're a developer and you want to install your local copy, use pip3 install ..

It also may be necessary to install additional dependencies, depending on your distribution (see details below).

Once the application is installed, you should see new desktop entries available in your desktop menu; also a new executable uavcan_gui_tool will be available in your PATH. If your desktop environment doesn't update the menu automatically, you may want to do it manually, e.g. by invoking sudo update-desktop-database (command depends on the distribution).

It is also recommended to install Matplotlib - it is not used by the application itself, but it may come in handy when using the embedded IPython console.

Debian-based distributions

sudo apt-get install -y python3-pip python3-setuptools python3-numpy python3-pyqt5 python3-pyqt5.qtsvg git-core
sudo pip3 install git+https://github.com/UAVCAN/gui_tool@master

Troubleshooting

If installation fails with an error like below, try to install IPython directly with sudo pip3 install ipython:

error: Setup script exited with error in ipython setup command: Invalid environment marker: sys_platform == "darwin" and platform_python_implementation == "CPython"

If you're still unable to install the package, please open a ticket.

RPM-based distributions

Maintainers wanted

Installing on Windows

In order to install this application, download and install the latest .msi package from here: https://files.zubax.com/products/org.uavcan.gui_tool/.

Building the MSI package

These instructions are for developers only. End users should use pre-built MSI packages (see the link above).

First, install dependencies:

Then, place the *.pfx file containing the code signing certificate in the outer directory (the build script will search for ../*.pfx). Having done that, execute the following (the script will prompt you for password to read the certificate file):

python -m pip uninstall -y uavcan
python -m pip uninstall -y uavcan_gui_tool
python setup.py install
python setup.py bdist_msi

Collect the resulting signed MSI from dist/.

Installing on OSX

OSX support is a bit lacking in the way that installation doesn't create an entry in the applications menu, but this issue should be fixed someday in the future. Other than that, everything appears to function more or less correctly. If you have a choice, it is recommended to use Linux or Windows instead, as these ports are supported much better at the moment.

Homebrew option

  • Install the Homebrew package manager for OSX.
  • Run the following commands:
brew install python3
pip3 install PyQt5
pip3 install git+https://github.com/UAVCAN/gui_tool@master
uavcan_gui_tool

MacPorts option

Install XCode from App Store, install MacPorts from https://www.macports.org/install.php, then run the commands below. If you're prompted to install Command Line Developer Tools, agree.

sudo port selfupdate
sudo port install curl-ca-bundle py35-pip py35-pyqt5 py35-numpy
sudo python3.5 -m pip install git+https://github.com/UAVCAN/gui_tool@master

We would like to provide prebuilt application packages instead of the mess above. Contributions adding this capability would be welcome.

Development

Releasing new version

First, deploy the new version to PyPI. In order to do that, perform the following steps:

  1. Update the version tuple in version.py, e.g. 1, 0, and commit this change.
  2. Create a new tag with the same version number as in the version file, e.g. git tag -a 1.0 -m v1.0.
  3. Push to master: git push && git push --tags

Then, build a Windows MSI package using the instructions above, and upload the resulting MSI to the distribution server.

Code style

Please follow the Zubax Python Coding Conventions.

gui_tool's People

Contributors

jschall avatar mkeeter avatar pavel-kirienko avatar tstellanova avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.