This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.
When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
You can open this repo in GitHub CodeSpace/Docker to get the build environment needed.
- Go to https://github.com/microsoft/genaiscript
- Click on Code
- Select Create new Codespace
- Install Node.JS LTS
- Run yarn
yarn install --frozen-lockfile --prefer-offline
You can do a full compile using esbuild.
yarn compile
or a typecheck using tsc
.
yarn typecheck
or start a debug session in VSCode.
- Start the Run - sample Debugger to launch the sample project in debugging mode
To run a script using the locally built cli,
yarn genai <scriptid> ...
To run a sample script under the packages/sample
folder:
yarn run:script <scriptid> ...
In this case, it will use the packages/sample/.env
file for the environment variables and workspace will be rooted at packages/sample
.
Open a JavaScript Debug Terminal
and launch the script using
yarn genai:debug <scriptid> ...
or for samples
yarn run:script:debug <scriptid> ...
To run the playground, use the following command:
yarn serve
It will start a local server and rebuild the react client on file changes.
- run
yarn install:force
to refresh the lock file - run
yarn gen:licenses
to refresh the 3rd party licenses
Run docs
to launch the documentation site.
yarn docs
GitHub Pages are automatically updated on new release; or thourh manual trigger at https://github.com/microsoft/genaiscript/actions/workflows/docs.yml .
All files slides/*slides.md
will be compiled and deployed on build.
- run
slides
to launch the slide show (add the file name or it will default toslides.md
)
yarn slides [slides file name]
- visit http://localhost:3030
Learn more about Slidev on documentations. For diagrams, leverage mermaid or use draw.io, tldraw.
- Commit with aut-generated message
yarn gcm
To compile and package the Visual Studio Code extension, run the package
script.
yarn package
You will find the built package files, genaiscript.vsix
,
in the packages/vscode
folder.
Run the release
script.
yarn release
Start local server
yarn docs
If you are lacking a OpenAI API token, you can use LocalAI to simulate OpenAI access.
- Create a new Codespace and make sure to create a larger image,
- launch
localai
to download and start the localai docker image.
yarn run localai
- Launch the localai web ui at http://localhost:8080
- create
.env
file with
# OPENAI_API_KEY=... not needed
OPENAI_API_BASE=http://localhost:8080/v1
- start the debugger and voila!