Giter Site home page Giter Site logo

Change cpp doxygen style about neogen HOT 3 CLOSED

Perry3D avatar Perry3D commented on August 17, 2024 3
Change cpp doxygen style

from neogen.

Comments (3)

danymat avatar danymat commented on August 17, 2024 2

Hello ! I'm currently in the process of refactoring the codebase to expose more easily the annotation standards, and providing better docs for it !
But now, you can take a look Neogen works in c:

doxygen = {
{ nil, "/**", { no_results = true, type = { "func", "file" } } },
{ nil, " * @file", { no_results = true, type = { "file" } } },
{ nil, " * @brief $1", { no_results = true, type = { "func", "file" } } },
{ nil, " */", { no_results = true, type = { "func", "file" } } },
{ nil, "", { no_results = true, type = { "file" } } },
{ nil, "/**", { type = { "func" } } },
{ nil, " * @brief $1", { type = { "func" } } },
{ nil, " *", { type = { "func" } } },
{ "tparam", " * @tparam %s $1" },
{ "parameters", " * @param %s $1" },
{ "return_statement", " * @return $1" },
{ nil, " */" },
},

This is the template responsible for generating Doxygen in C. You can see that every second parameter of each table is a string, and note that:

  • $1 is the cursor placement
  • %s will be replaced by the value

So for you, the Doxygen table could be something like:

        custom = {
            { nil, "/// @file", { no_results = true, type = { "file" } } },
            { nil, "/// @brief $1", { no_results = true, type = { "func", "file" } } },
            { nil, "", { no_results = true, type = { "file" } } },

            { nil, "/// @brief $1", { type = { "func" } } },
            { "tparam", "/// @tparam %s $1" },
            { "parameters", "/// @param %s $1" },
            { "return_statement", "/// @return $1" },
        },

And to use in your Neogen setup:

require('neogen').setup {
    enabled = true,
	languages = {
	    c = {
	        template = {
                    annotation_convention = "custom",
                    custom =  {
                      { nil, "/// @file", { no_results = true, type = { "file" } } },
                      { nil, "/// @brief $1", { no_results = true, type = { "func", "file" } } },
                      { nil, "", { no_results = true, type = { "file" } } },

                       { nil, "/// @brief $1", { type = { "func" } } },
                       { "tparam", "/// @tparam %s $1" },
                        { "parameters", "/// @param %s $1" },
                        { "return_statement", "/// @return $1" },
                    },
		}
	    },
	    ...
    }
}

Tell me if it works !

from neogen.

Perry3D avatar Perry3D commented on August 17, 2024

Thank you very much for the detailed answer. Works fine for me.
Except one copy paste thing: you set the template for lua instead of c or cpp.

require('neogen').setup {
  enabled = true,
  languages = {
    cpp = {
      template = {
        annotation_convention = "custom",
        custom =  {
          { nil, "/// @file", { no_results = true, type = { "file" } } },
          { nil, "/// @brief $1", { no_results = true, type = { "func", "file" } } },
          { nil, "", { no_results = true, type = { "file" } } },

          { nil, "/// @brief $1", { type = { "func" } } },
          { "tparam", "/// @tparam %s $1" },
          { "parameters", "/// @param %s $1" },
          { "return_statement", "/// @return $1" },
        },
      }
    },
  }
}

from neogen.

danymat avatar danymat commented on August 17, 2024

Oh yeah right, fixed

from neogen.

Related Issues (20)

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.