Skip to content

GGenums is a code generation tool that ease use of enums in Go. It automatically generates type-safe enums with built-in string conversion, JSON marshaling/unmarshaling, and validation.

License

Notifications You must be signed in to change notification settings

Gandalf-Le-Dev/ggenums

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

GGenums - Generate Golang Enums

Go Report Card GoDoc

GGenums is a code generation tool that ease use of enums in Go. It automatically generates type-safe enums with built-in string conversion, JSON marshaling/unmarshaling, and validation.

Features

  • 🚀 Simple enum declaration using comments
  • 🔒 Type-safe enum values
  • 📦 JSON marshaling/unmarshaling support
  • ✅ Built-in validation
  • 🔄 String conversion methods
  • 📝 Easy to read generated code

Installation

go install github.com/Gandalf-Le-Dev/ggenums@latest

Note

Make sure you have the go/bin directory in your PATH:

export PATH=$PATH:$(go env GOPATH)/bin

Quick Start

  1. Define your enum using a comment:

    //enum:name=Status values=pending,active,in_progress,completed
  2. Run the generator:

    ggenums ./...
  3. Use your generated enum:

    See the example below or here

Example

package main

import (
    "encoding/json"
    "fmt"
)

//enum:name=Status values=pending,active,in_progress,completed
//enum:name=Role values=admin,user,guest

type User struct {
    ID     string     `json:"id"`
    Status StatusEnum `json:"status"`
    Role   RoleEnum   `json:"role"`
}

func main() {
	var err error
	// JSON marshaling
	user := User{
		ID:     "123",
		Status: StatusPending,
		Role:   RoleAdmin,
	}

	jsonData, _ := json.Marshal(user)
	fmt.Printf("JSON: %s\n", jsonData)

	// JSON unmarshaling
	var parsed User
	json.Unmarshal(jsonData, &parsed)
	fmt.Printf("Parsed: %+v\n", parsed)

	// Parsing from string
	status, _ := ParseStatus("in_progress")
	fmt.Printf("Parsed status: %s\n", status)

	// Validation
	err = status.Validate()
	if err != nil {
		fmt.Printf("Validation error: %v\n", err)
	} else {
		fmt.Printf("Status '%s' is valid\n", status)
	}
	// Comparison
	fmt.Printf("Is status in progress? %v\n", status == StatusInProgress)

	// Error handling
	_, err = ParseStatus("error_status")
	fmt.Printf("Invalid status error: %v\n", err)
}

Output:

JSON: {"id":"123","status":"pending","role":"admin"}
Parsed: {ID:123 Status:pending Role:admin}
Parsed status: in_progress
Status 'in_progress' is valid
Is status in progress? true
Invalid status error: invalid Status: error_status

Generated Code Features

The generated code includes:

  • Type-safe enum constants
  • String conversion methods
  • JSON marshaling/unmarshaling
  • Validation methods
  • Parsing functions
  • Slice of all enum values

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the MIT License - see the LICENSE file for details.

About

GGenums is a code generation tool that ease use of enums in Go. It automatically generates type-safe enums with built-in string conversion, JSON marshaling/unmarshaling, and validation.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages