Skip to content

create

Static method on Object.

Creates an object that has the specified prototype or that has null prototype.

Creates an object that has the specified prototype, and that optionally contains specified properties.

create(input: { o: object; prompt?: string }): Promise<any>
create(input: { o: object; properties: PropertyDescriptorMap & ThisType<any>; prompt?: string }): Promise<any>

The prompt field is optional. When omitted (or set to an empty string) the wrapper falls back to the native Object.create and returns a resolved Promise without contacting the LLM. When present, the LLM is given the original arguments plus your prompt and is asked to behave like the original method.

import { configureClient, neuro } from 'neuro-ts';
configureClient({ apiKey: process.env.OPENAI_API_KEY });
// Prototype-with-descriptors create. class syntax tried to replace this. It failed.
await neuro.object.create({ o: protoTarget, properties: { id: { value: 1, enumerable: true } }, prompt: 'create a new object with proto as its prototype and properties as initial own properties, the rare path even class syntax couldn\'t kill' });

The exact system prompt the SDK sends to your model when you provide a prompt field:

Generated promptObject.create
You are simulating the JavaScript built-in `Object.create`.
## Original signature(s)
  Overload 1: (o: object) => any
  Overload 2: (o: object, properties: PropertyDescriptorMap & ThisType<any>) => any
## JSDoc
Creates an object that has the specified prototype or that has null prototype.

## How to respond
- Behave EXACTLY as the original `create` would, but use the user's intent to choose any callback / comparator / transform logic that the original would normally accept as an argument.
- Strictly preserve the original return type and shape.
- Output ONLY the JSON-encoded return value of the function call.
- Do NOT include explanations, prose, comments, or markdown fences.
- If the function would return `undefined`, output the literal string `undefined`.
- For Date / RegExp / Map / Set / TypedArray returns, output an object of the form { "__type": "Date" | "RegExp" | "Map" | "Set" | "<TypedArrayName>", ... } so the SDK can rehydrate it.