Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Automatically generate protobuf message documentation #108

Open
Doom4535 opened this issue Sep 7, 2019 · 0 comments
Open

Automatically generate protobuf message documentation #108

Doom4535 opened this issue Sep 7, 2019 · 0 comments

Comments

@Doom4535
Copy link

Doom4535 commented Sep 7, 2019

Is there a way to link this into ex_doc such that the message structure is included in the generated documentation?

For example

defmodule Messages do
  @moduledoc """
  Some documentation
  """
  use Protobuf, """
    message Msg {
      message SubMsg {
        required uint32 value = 1;
      }

      enum Version {
        V1 = 1;
        V2 = 2;
      }

      required Version version = 2;
      optional SubMsg sub = 1;
    }
  """
end

Gives me this:
exprotobuf_test_no_doc

It would be nice if there was a way to trigger behavior that was more like this:

defmodule Messages do
  @moduledoc """
  Some documentation
  """

  @doc """
  message Msg {
    message SubMsg {
      required uint32 value = 1;
    }
  }
  """
  def _submsg do
  end

  @doc """
  enum Version {
    V1 = 1;
    V2 = 2;
  }
  """
  def _version do
  end

  @doc """
  required Version version = 2;
  """
  def version do
  end

  @doc """
  optional SubMsg sub = 1;
  """
  def sub do
  end

  use Protobuf, """
    message Msg {
      message SubMsg {
        required uint32 value = 1;
      }

      enum Version {
        V1 = 1;
        V2 = 2;
      }

      required Version version = 2;
      optional SubMsg sub = 1;
    }
  """
end

Giving an output like this:
exprotobuf_test_expanded_doc

Or like this:

defmodule Messages do
  @moduledoc """
  Some documentation
  """
  @doc """
  message Msg {
    message SubMsg {
      required uint32 value = 1;
    }

    enum Version {
      V1 = 1;
      V2 = 2;
    }
    
    {
      required Version version = 2;
      optional SubMsg sub = 1;
    }
  }
  """
  use Protobuf, """
    message Msg {
      message SubMsg {
        required uint32 value = 1;
      }

      enum Version {
        V1 = 1;
        V2 = 2;
      }

      required Version version = 2;
      optional SubMsg sub = 1;
    }
  """
end

Giving an output like this:
exprotobuf_test_src_doc

The last one is where the protobuf source (and any comments) are copied in to serve as their own documentation.

Something like this would be most useful when used to import *.proto files, allowing the built documents to always reflect the version of the .proto files that are in use.

The closest issue that I found to this was #48; however, I have been unable to get my project to show the imported protobufs (making me think that there is some other code difference between these two).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant