Skip to main content

Python wrapper for the Expedition DLL

Project description

Expedition-Python

Description

Expedition is a Windows-based software application for sailing navigation and racing. It has been used in multiple Volvo Ocean Race, America's Cup and Grand Prix events and is the most advanced and usable software available. It can be purchased from Expedition Marine.

This Expedition-Python library is a module for reading and writing data from Expedition. It provides a simple and intuitive API for reading and writing variables and system variables in Expedition. You can also do basic route and waypoint manipulation.

Installation

To install the Expedition module, you can use pip:

pip install Expedition-Python

Development Installation

For development, use uv to create a virtual environment and install the package in editable mode with dev tools:

git clone https://github.com/TTCMarine/Expedition-Python.git
cd Expedition-Python
uv sync

Alternatively, you can use pip: pip install -e .

Platform Support

  • Windows: Full support with the Expedition DLL
  • macOS/Linux: Mock implementation available for development and testing (see note below)

Note for macOS/Linux users: On non-Windows platforms, the package installs a mock implementation that allows you to develop and test code without the actual Expedition DLL. All methods are available but return dummy values. This is useful for developing code that will run on Windows.

Usage

There is a static method called from_default_location that can be used to create an instance of the ExpeditionDLL class. This method will attempt to locate the Expedition DLL file and create an instance of the ExpeditionDLL. This relies on the installation directory being in a registry key, so it may not work for all installations.

Note on 64 vs 32-bit: If you are using a 32-bit version of Expedition, then you need to use a 32-bit version of Python.

Here's a simple example of how to use the Expedition module:

from Expedition import ExpeditionDLL, Var, SysVar

# Create an instance of the ExpeditionDLL class
expedition = ExpeditionDLL.from_default_location()

# Set and get a variable value
expedition.set_exp_var_value(Var.Bsp, 10.4)
value = expedition.get_exp_var_value(Var.Bsp)
print(value)  # Outputs: 10.4

Contributing

Contributions are welcome! If you would like to contribute to the Expedition module:

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Make your changes
  4. Run tests to ensure everything works
  5. Commit your changes (git commit -m 'Add some amazing feature')
  6. Push to the branch (git push origin feature/amazing-feature)
  7. Open a Pull Request

Please ensure your code follows the project's style guidelines and includes tests for new features.

Development

Requirements

  • Python 3.8 or higher (3.12 recommended for local development; see .python-version)
  • uv for development (optional but recommended)
  • For Windows: Expedition software installed

Running Tests

After uv sync, run tests with:

uv run pytest tests/ -v

You can also use unittest: python -m unittest discover tests

Note: Tests require the Expedition DLL to be installed on Windows. On non-Windows platforms or when the DLL is not found, tests will be automatically skipped. This is expected behavior and allows the test suite to run on CI/CD systems without Expedition installed.

Building the Package

The package uses modern Python packaging with pyproject.toml. To build:

uv build

This will create distribution files in the dist/ directory.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

expedition_python-1.1.9.tar.gz (13.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

expedition_python-1.1.9-py3-none-any.whl (11.9 kB view details)

Uploaded Python 3

File details

Details for the file expedition_python-1.1.9.tar.gz.

File metadata

  • Download URL: expedition_python-1.1.9.tar.gz
  • Upload date:
  • Size: 13.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for expedition_python-1.1.9.tar.gz
Algorithm Hash digest
SHA256 73c9866b14a6d9e2bccb3bc723fa533f465dd063dc779d94ac4d9f7fc9a0e8e9
MD5 ba06e338bacfebcbab428d5906f0b245
BLAKE2b-256 888ce4e43d7b42a1bedc54c32788054080a30cc57160b9c1e4cc351c9998a889

See more details on using hashes here.

Provenance

The following attestation bundles were made for expedition_python-1.1.9.tar.gz:

Publisher: publish.yml on TTCMarine/Expedition-Python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file expedition_python-1.1.9-py3-none-any.whl.

File metadata

File hashes

Hashes for expedition_python-1.1.9-py3-none-any.whl
Algorithm Hash digest
SHA256 44185d183b2e79cb924016d65dfce92d57dc88416b5259b30f82a1cc49b97186
MD5 ca1aa29563c35bdfef27620cf69ab5e0
BLAKE2b-256 34a9b5a155feb0e897b2f07240ee6b06f3af1f6180a1ea249cd00b1bc2beba2e

See more details on using hashes here.

Provenance

The following attestation bundles were made for expedition_python-1.1.9-py3-none-any.whl:

Publisher: publish.yml on TTCMarine/Expedition-Python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page