Giter Club home page Giter Club logo

djinni-intellij-plugin's Introduction

djinni-intellij-plugin

Build Version Downloads

➡️ Documentation: djinni.xlcpp.dev

Adds basic navigation, code-completion and error highlighting support for .djinni IDL files.

Djinni is a tool for generating cross-language type declarations and interface bindings. It's designed to connect C++ with either Java or Objective-C.

Installation

  • Using IDE built-in plugin system:

    Preferences > Plugins > Marketplace > Search for "djinni-intellij-plugin" > Install Plugin

  • Manually:

    Download the latest release and install it manually using Preferences > Plugins > ⚙️ > Install plugin from disk...

Plugin development

If you want to make changes to the plugin, read the Developer Guide


Plugin based on the IntelliJ Platform Plugin Template.

djinni-intellij-plugin's People

Contributors

a4z avatar actions-user avatar jothepro avatar

Stargazers

 avatar  avatar

Watchers

 avatar  avatar  avatar  avatar

Forkers

jothepro a4z

djinni-intellij-plugin's Issues

clarify general licensing conditions

The code is currently licensed with Apache 2.0 and a Copyright to Dropbox.

The cross-language-cpp organization does not intend to just fork the original software from dropbox, but rather gain ownership of it as dropbox has stopped maintaining it.

Yet still all files have a Copyright notice that claims Dropbox as the owner.

The Apache License states:

In every licensed file, original copyright, patent, trademark, and attribution notices must be preserved (excluding notices that do not pertain to any part of the derivative works). In every licensed file changed, a notification must be added stating that changes have been made to that file.

As a project maintainer I want to clarify if this applies to the code that was derived from the original dropbox repository and is now maintained under the cross-langugage-cpp organization.

Personally I would prefer to re-license all files to the cross-language-cpp organization, if this is a legal option.

This question also applies to the djinni-generator & djinni-support-lib repos.

Remove usage of deprecated & internal API calls

The Compatibility verification of the newly published plugin warns about

Compatible. 9 usages of deprecated API. 1 usage of internal API

As a maintainer I'd like to update the plugin to not use internal & deprecated API calls, to reduce the risk of incompatibility in the future.

remove gradle.properties pluginUntilBuild property

As seen in #21 and #22 , the Plugin is currently configured to work with a "maximum" Version of IntelliJ.
As a maintainer I want to remove or change this restriction to be more generous (pluginUntilBuild=*?), because the current configuration will regularly break the plugin if we don't act fast enough, while API changes in new IntelliJ versions just may lead to a broken plugin.

Update basic documentation

  • How to build and install the plugin?
  • How does the release to the plugin-repository work?
  • How is the code structured?
  • How is all the code in src/gen generated?

investigate if an improvement of the release pipeline is possible

as staten in #7 and the side effect of the current solution, a release requires some know how in how to write the change log, and what to do .
If this know how exits, the release is pretty much straight forward, but not very intuitive.

Let's investigate if this could be improved, base on an action that runs on tag release creation, instead of and action that creates an (draft release) tag

Improve plugin description for plugin approval

During approval process, I got this e-mail:

Hello,

Thank you for submitting your plugin.

Please provide a more detailed plugin description and usage instructions. You can update it in the plugin.xml file and upload it to the Marketplace again.

We are looking forward to approving your plugin.

Fix Readme badges linking to Jetbrains Marketplace

The Readme contains 2 badges linking to the Jetbrains Marketplace. They are not yet set up correctly, attemts to locally set the required plugin-id have failed (the badge still shows "not found"):

Version
Downloads

Reasons why the badges may fail:

  • because the plugin has not been approved yet and therefore is not publicly listed in the marketplace?
  • because I set the wrong plugin-id?

fix pipeline to work with protected main branch

The main branch of this repository is protected & merging into it requires at least 1 approval from another user. This seems to collide with the release process of the intellij plugin used as a template for this repo: On release it tries to modify the CHANGELOG.md file in main.

We need to figure out a way around this.

  • Is it possible to give the github action special rights, so it can also manipulate main?
  • ...?

Example on what goes wrong: https://github.com/cross-language-cpp/djinni-intellij-plugin/runs/1339227838?check_suite_focus=true

remove upper limit for IDE comptibility?

Some time ago the IntelliJ platform got a major update to 2020.3

The plugin refused to work on this new version because the until-build property was set to 202.*.

As a maintainer I'd like to get rid of this "upper version limit", as it will repeatedly make our plugin uncompatible with newer versions of IntelliJ, while it may still be working.

Release new version for latest CLion

Plugin error: Plugin 'Djinni IDL file support' (version '0.10.2') is not compatible with the current
version of the IDE, because it requires build 202.* or older but the current build is CL-203.5981.166

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.