From 85dc8ab41e0df3267249a1efc4a95f010e52cc73 Mon Sep 17 00:00:00 2001 From: Samuel Lijin Date: Wed, 10 Jul 2024 10:18:26 -0700 Subject: [PATCH] docs: add reference to dynamic types impl (#767) --- docs/docs/calling-baml/dynamic-types.mdx | 53 ++++++++++++++++++++++-- engine/.gitignore | 17 ++++++++ 2 files changed, 67 insertions(+), 3 deletions(-) create mode 100644 engine/.gitignore diff --git a/docs/docs/calling-baml/dynamic-types.mdx b/docs/docs/calling-baml/dynamic-types.mdx index bfc9cb369..db463e658 100644 --- a/docs/docs/calling-baml/dynamic-types.mdx +++ b/docs/docs/calling-baml/dynamic-types.mdx @@ -153,9 +153,7 @@ async def run(): ```typescript TypeScript import TypeBuilder from '../baml_client/type_builder' -import { - b -} from '../baml_client' +import { b } from '../baml_client' async function run() { const tb = new TypeBuilder() @@ -190,4 +188,53 @@ const tb = new TypeBuilder() tb.User.addProperty("email", tb.string()).description("The user's email") ``` + + +### Building dynamic types from JSON schema + +We have a working implementation of this, but are waiting for a concrete use case to merge it. +Please chime in on [the GitHub issue](https://github.com/BoundaryML/baml/issues/765) if this is +something you'd like to use. + + + +```python python +import pydantic +from baml_client import b + +class Person(pydantic.BaseModel): + last_name: list[str] + height: Optional[float] = pydantic.Field(description="Height in meters") + +tb = TypeBuilder() +tb.unstable_features.add_json_schema(Person.model_json_schema()) + +res = await b.ExtractPeople( + "My name is Harrison. My hair is black and I'm 6 feet tall. I'm pretty good around the hoop. I like giraffes.", + {"tb": tb}, +) +``` + +```typescript TypeScript +import 'z' from zod +import 'zodToJsonSchema' from zod-to-json-schema +import { b } from '../baml_client' + +const personSchema = z.object({ + animalLiked: z.object({ + animal: z.string().describe('The animal mentioned, in singular form.'), + }), + hobbies: z.enum(['chess', 'sports', 'music', 'reading']).array(), + height: z.union([z.string(), z.number().int()]).describe('Height in meters'), +}) + +let tb = new TypeBuilder() +tb.unstableFeatures.addJsonSchema(zodToJsonSchema(personSchema, 'Person')) + +const res = await b.ExtractPeople( + "My name is Harrison. My hair is black and I'm 6 feet tall. I'm pretty good around the hoop. I like giraffes.", + { tb }, +) +``` + \ No newline at end of file diff --git a/engine/.gitignore b/engine/.gitignore new file mode 100644 index 000000000..6e771f815 --- /dev/null +++ b/engine/.gitignore @@ -0,0 +1,17 @@ +# Generated by Cargo +# will have compiled files and executables +debug/ +target/ + +# These are backup files generated by rustfmt +**/*.rs.bk + +# MSVC Windows builds of rustc generate these, which store debugging information +*.pdb + +# RustRover +# JetBrains specific template is maintained in a separate JetBrains.gitignore that can +# be found at https://github.com/github/gitignore/blob/main/Global/JetBrains.gitignore +# and can be added to the global gitignore or merged into this file. For a more nuclear +# option (not recommended) you can uncomment the following to ignore the entire idea folder. +#.idea/