Skip to content

charltoa/mpc_demo

 
 

Repository files navigation

meesign client

A new Flutter project.

Build

  1. Install Flutter, be sure to also follow the instructions for the platform you want to build for, i.e. enable desktop support or set up Android SDK (all described on the same page). At the moment, the following targets are supported: Linux, Windows, Android

  2. Install Rust

    1. Android only:
      1. Add Android targets for cross-compilation

        rustup target add aarch64-linux-android armv7-linux-androideabi x86_64-linux-android i686-linux-android
      2. Point cargo to the linker provided by Android NDK, a helper script for generating the necessary configuration is provided in tool/cargo-config-gen-android.sh, append the output to your cargo configuration file, e.g. by:

        ANDROID_NDK_HOME="path/to/ndk/version" ANDROID_API="30" bash ./tool/cargo-config-gen-android.sh >> ~/.cargo/config.toml
  3. Clone the repository with submodules:

    git clone --recurse-submodules https://github.com/crocs-muni/meesign-client
  4. Build the app:

    flutter build

    or run it directly:

    flutter run

Contributing

Regenerate Dart-C bindings

If you modify native libraries in lib-native, update Dart bindings by running:

flutter pub run ffigen --config ffigen/changed-lib.yaml

This regenerates the files as specified by the provided ffigen configuration. (Note that ffigen requires LLVM.)

Regenerate gRPC code

If you modify a file in proto, regenerate the Dart gRPC code:

  1. Install Protocol buffers compiler

  2. Install Dart plugin for protoc:

    flutter pub global activate protoc_plugin

    Note the path to the plugin executable or make sure it is available through PATH.

  3. Generate Dart code:

    protoc --experimental_allow_proto3_optional --plugin=/path/to/bin/protoc-gen-dart --dart_out=grpc:lib/grpc/generated/ -I proto proto/mpc.proto

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Dart 69.2%
  • C++ 15.9%
  • CMake 13.3%
  • C 1.2%
  • Other 0.4%