Skip to content

Latest commit

 

History

History
63 lines (44 loc) · 2.46 KB

README.md

File metadata and controls

63 lines (44 loc) · 2.46 KB

aimake

Make AI make code
… while you just tell it where and how.

Demo

  1. Make sure you have OPENAI_API_KEY in your env.
  2. Clone, go build.
  3. ./aimake clean cmd/clean.go
  4. git diff to see the code that just went missing.
  5. ./aimake gen cmd/clean.go to see it come back in some form.
  6. (And maybe another ./aimake gen cmd/clean.go to give the llm another stab at it.)

This code is terrible

Yes.

Usage

Making edits

  1. Edit prompt in some_file.
  2. aimake generate some_file

Regenerating the whole codebase

  1. aimake clean --all
  2. Not sure yet.

Development

Contributing

  • Until we get to Milestone 2, it won't be possible to fully develop aimake using aimake. What I'm doing instead is using the function prompts/definitions in each file and feeding that to GH Copilot.
  • PRs must contain prompts that generated the code. Human-only code edits would be cheating.
    • You can pretend code changes have been fully generated using the attached prompt. I won't notice.

License

Do licenses make sense if the whole thing is AI-generated? And AI-regeneratable?

What happens if you AI-rewrite the existing prompts and then AI-generate fresh code based on them?

Milestones

M1 The Basics

  • Working clean
  • Working generate, at least for basic use cases

M2 Next Generation

  • generate is advanced enough to regenerate all files in this project, including ones with external dependencies (like main.go)

Feature Ideas

  • Multi-shot gen (-i arg?); feeds the prompt+code N times with same or slightly modified prompts
    • Defaults to >=2 for more reliable gen?
  • Support other models (anthropic, self-hosted, etc.)
  • Come up with automatic evaluation of generated code
  • Once automatic evaluation works, come up with automatic iterative optimization (generate code in multiple ways, automatically figure out which seems like the best one)
  • Automated multi-shot if first try doesn't build/work (related to previous point)
  • Automatic dependency analysis and interface extraction for generate
    • Example: generate main.go notices it depends on a function in cmd.go, that function declaration is extracted and injected into the prompt for generating main.go
  • Full codebase analysis for generate --all that can figure out the file generation order (starts with standalone files with no external dependencies)
  • Single-shot prompts: generate --prompt or maybe a separate command like go