2017 © Pedro Peláez
 

library go-code-builder

GO code generation library

image

swaggest/go-code-builder

GO code generation library

  • Tuesday, February 27, 2018
  • by vearutop
  • Repository
  • 0 Watchers
  • 0 Stars
  • 28 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 13 Versions
  • 0 % Grown

The README.md

Swaggest JSON-schema enabled Go code builder

Build Status codecov Code lines Comments, (*1)

This library generates Go mapping structures defined by JSON schema., (*2)

Example

Generated code for schema., (*3)

<?php
namespace MyApp;

use Swaggest\GoCodeBuilder\JsonSchema\GoBuilder;
use Swaggest\GoCodeBuilder\JsonSchema\StructHookCallback;
use Swaggest\GoCodeBuilder\Templates\GoFile;
use Swaggest\GoCodeBuilder\Templates\Struct\StructDef;
use Swaggest\JsonSchema\Schema;

require_once __DIR__ . '/vendor/autoload.php';

$schemaData = json_decode(file_get_contents(__DIR__ . '/swagger-schema.json'));
$schema = Schema::import($schemaData);

$builder = new GoBuilder();
$builder->structCreatedHook = new StructHookCallback(function (StructDef $structDef, $path, $schema) use ($builder) {
    if ('#' === $path) {
        $structDef->setName('SwaggerSchema');
    } elseif (0 === strpos($path, '#/definitions/')) {
        $name = $builder->codeBuilder->exportableName(substr($path, strlen('#/definitions/')));
        $structDef->setName($name);
    }
});
$builder->getType($schema);

$goFile = new GoFile('swagger');
foreach ($builder->getGeneratedStructs() as $generatedStruct) {
    $goFile->getCode()->addSnippet($generatedStruct->structDef);
}
$goFile->getCode()->addSnippet($builder->getCode());

API Documentation

Classes documentation., (*4)

Schema extensions

Magic properties (vendor extensions) defined in schema enable special handling., (*5)

x-go-type

Can have a value string or an object. Contains type reference that can be used instead of generated type., (*6)

If $ignoreXGoType option is true value of vendor extension is disregarded and type is generated., (*7)

Value examples:, (*8)

  • "[]myorg.com/go-null-types::nulltypes.NullString"
  • "myorg.com/my-app/order.Entity"
  • "float64"
  • {"import": {"package": "my-package/domain/orders"}, "type": "Order"}
  • {"import": {"package": "my-package", "alias": "mp"}, "type": "Order"}

x-nullable, nullable

If true schema type is converted to [<type>, "null"]. Requires $enableXNullable option., (*9)

x-omitempty

A boolean value to control ,omitempty presence., (*10)

x-generate

A boolean value to control whether property should be added to generated struct. Property with "x-generate": false will be skipped. If GoBuilder option requireXGenerate is set to true only properties with "x-generate": true will be generated., (*11)

CLI Tool

You can use json-cli to generate Go structures from command line., (*12)

The Versions

27/02 2018

dev-wip-client-2

dev-wip-client-2 https://github.com/swaggest/go-code-builder

GO code generation library

  Sources   Download

MIT

The Requires

 

The Development Requires

library

16/11 2017

dev-master

9999999-dev https://github.com/swaggest/go-code-builder

GO code generation library

  Sources   Download

MIT

The Requires

 

The Development Requires

library

16/11 2017

dev-wip-client

dev-wip-client https://github.com/swaggest/go-code-builder

GO code generation library

  Sources   Download

MIT

The Requires

 

The Development Requires

library

16/11 2017
01/09 2017

dev-wip-swg

dev-wip-swg https://github.com/swaggest/go-code-builder

GO code generation library

  Sources   Download

MIT

The Requires

 

The Development Requires

library

01/06 2017
29/05 2017
29/05 2017
22/05 2017
22/05 2017

dev-mapping

dev-mapping https://github.com/swaggest/go-code-builder

GO code generation library

  Sources   Download

MIT

The Requires

 

The Development Requires

library

28/04 2017
27/04 2017
27/03 2017