kittycad.models.annotation_options
Classes
| 
 | Options for annotations | 
- class kittycad.models.annotation_options.AnnotationOptions(**data)[source][source]
- Options for annotations - Create a new model by parsing and validating input data from keyword arguments. - Raises [ - ValidationError][pydantic_core.ValidationError] if the input data cannot be validated to form a valid model.- selfis explicitly positional-only to allow- selfas a field name.- __annotations__ = {'__class_vars__': 'ClassVar[set[str]]', '__private_attributes__': 'ClassVar[Dict[str, ModelPrivateAttr]]', '__pydantic_complete__': 'ClassVar[bool]', '__pydantic_computed_fields__': 'ClassVar[Dict[str, ComputedFieldInfo]]', '__pydantic_core_schema__': 'ClassVar[CoreSchema]', '__pydantic_custom_init__': 'ClassVar[bool]', '__pydantic_decorators__': 'ClassVar[_decorators.DecoratorInfos]', '__pydantic_extra__': 'dict[str, Any] | None', '__pydantic_fields__': 'ClassVar[Dict[str, FieldInfo]]', '__pydantic_fields_set__': 'set[str]', '__pydantic_generic_metadata__': 'ClassVar[_generics.PydanticGenericMetadata]', '__pydantic_parent_namespace__': 'ClassVar[Dict[str, Any] | None]', '__pydantic_post_init__': "ClassVar[None | Literal['model_post_init']]", '__pydantic_private__': 'dict[str, Any] | None', '__pydantic_root_model__': 'ClassVar[bool]', '__pydantic_serializer__': 'ClassVar[SchemaSerializer]', '__pydantic_validator__': 'ClassVar[SchemaValidator | PluggableSchemaValidator]', '__signature__': 'ClassVar[Signature]', 'color': typing.Optional[kittycad.models.color.Color], 'line_ends': typing.Optional[kittycad.models.annotation_line_end_options.AnnotationLineEndOptions], 'line_width': typing.Optional[float], 'model_computed_fields': 'ClassVar[dict[str, ComputedFieldInfo]]', 'model_config': 'ClassVar[ConfigDict]', 'model_fields': 'ClassVar[dict[str, FieldInfo]]', 'position': typing.Optional[kittycad.models.point3d.Point3d], 'text': typing.Optional[kittycad.models.annotation_text_options.AnnotationTextOptions]}[source]
 - classmethod __class_getitem__(typevar_values)[source]
- Return type:
- type[- BaseModel] |- PydanticRecursiveRef
 
 - __class_vars__: ClassVar[set[str]] = {}[source]
- The names of the class variables defined on the model. 
 - classmethod __get_pydantic_core_schema__(source, handler, /)[source]
- Hook into generating the model’s CoreSchema. - Parameters:
- source ( - type[- BaseModel]) – The class we are generating a schema for. This will generally be the same as the- clsargument if this is a classmethod.
- handler ( - GetCoreSchemaHandler) – A callable that calls into Pydantic’s internal CoreSchema generation logic.
 
- Return type:
- Union[- InvalidSchema,- AnySchema,- NoneSchema,- BoolSchema,- IntSchema,- FloatSchema,- DecimalSchema,- StringSchema,- BytesSchema,- DateSchema,- TimeSchema,- DatetimeSchema,- TimedeltaSchema,- LiteralSchema,- EnumSchema,- IsInstanceSchema,- IsSubclassSchema,- CallableSchema,- ListSchema,- TupleSchema,- SetSchema,- FrozenSetSchema,- GeneratorSchema,- DictSchema,- AfterValidatorFunctionSchema,- BeforeValidatorFunctionSchema,- WrapValidatorFunctionSchema,- PlainValidatorFunctionSchema,- WithDefaultSchema,- NullableSchema,- UnionSchema,- TaggedUnionSchema,- ChainSchema,- LaxOrStrictSchema,- JsonOrPythonSchema,- TypedDictSchema,- ModelFieldsSchema,- ModelSchema,- DataclassArgsSchema,- DataclassSchema,- ArgumentsSchema,- CallSchema,- CustomErrorSchema,- JsonSchema,- UrlSchema,- MultiHostUrlSchema,- DefinitionsSchema,- DefinitionReferenceSchema,- UuidSchema,- ComplexSchema]
- Returns:
- A - pydantic-core- CoreSchema.
 
 - classmethod __get_pydantic_json_schema__(core_schema, handler, /)[source]
- Hook into generating the model’s JSON schema. - Parameters:
- core_schema ( - Union[- InvalidSchema,- AnySchema,- NoneSchema,- BoolSchema,- IntSchema,- FloatSchema,- DecimalSchema,- StringSchema,- BytesSchema,- DateSchema,- TimeSchema,- DatetimeSchema,- TimedeltaSchema,- LiteralSchema,- EnumSchema,- IsInstanceSchema,- IsSubclassSchema,- CallableSchema,- ListSchema,- TupleSchema,- SetSchema,- FrozenSetSchema,- GeneratorSchema,- DictSchema,- AfterValidatorFunctionSchema,- BeforeValidatorFunctionSchema,- WrapValidatorFunctionSchema,- PlainValidatorFunctionSchema,- WithDefaultSchema,- NullableSchema,- UnionSchema,- TaggedUnionSchema,- ChainSchema,- LaxOrStrictSchema,- JsonOrPythonSchema,- TypedDictSchema,- ModelFieldsSchema,- ModelSchema,- DataclassArgsSchema,- DataclassSchema,- ArgumentsSchema,- CallSchema,- CustomErrorSchema,- JsonSchema,- UrlSchema,- MultiHostUrlSchema,- DefinitionsSchema,- DefinitionReferenceSchema,- UuidSchema,- ComplexSchema]) – A- pydantic-coreCoreSchema. You can ignore this argument and call the handler with a new CoreSchema, wrap this CoreSchema (- {'type': 'nullable', 'schema': current_schema}), or just call the handler with the original schema.
- handler ( - GetJsonSchemaHandler) – Call into Pydantic’s internal JSON schema generation. This will raise a- pydantic.errors.PydanticInvalidForJsonSchemaif JSON schema generation fails. Since this gets called by- BaseModel.model_json_schemayou can override the- schema_generatorargument to that function to change JSON schema generation globally for a type.
 
- Return type:
- Returns:
- A JSON schema, as a Python object. 
 
 - __init__(**data)[source]
- Create a new model by parsing and validating input data from keyword arguments. - Raises [ - ValidationError][pydantic_core.ValidationError] if the input data cannot be validated to form a valid model.- selfis explicitly positional-only to allow- selfas a field name.
 - __pretty__(fmt, **kwargs)[source]
- Used by devtools (https://python-devtools.helpmanual.io/) to pretty print objects. 
 - __private_attributes__: ClassVar[Dict[str, ModelPrivateAttr]] = {}[source]
- Metadata about the private attributes of the model. 
 - __pydantic_complete__: ClassVar[bool] = True[source]
- Whether model building is completed, or if there are still undefined fields. 
 - __pydantic_computed_fields__: ClassVar[Dict[str, ComputedFieldInfo]] = {}[source]
- A dictionary of computed field names and their corresponding [ - ComputedFieldInfo][pydantic.fields.ComputedFieldInfo] objects.
 - __pydantic_core_schema__: ClassVar[CoreSchema] = {'definitions': [{'cls': <enum 'AnnotationLineEnd'>, 'members': [AnnotationLineEnd.NONE, AnnotationLineEnd.ARROW], 'metadata': {'pydantic_js_functions': [<function GenerateSchema._enum_schema.<locals>.get_json_schema>]}, 'ref': 'kittycad.models.annotation_line_end.AnnotationLineEnd:94250672862080', 'sub_type': 'str', 'type': 'enum'}], 'schema': {'cls': <class 'kittycad.models.annotation_options.AnnotationOptions'>, 'config': {'title': 'AnnotationOptions'}, 'custom_init': False, 'metadata': {'pydantic_js_functions': [<bound method BaseModel.__get_pydantic_json_schema__ of <class 'kittycad.models.annotation_options.AnnotationOptions'>>]}, 'ref': 'kittycad.models.annotation_options.AnnotationOptions:94250662440880', 'root_model': False, 'schema': {'computed_fields': [], 'fields': {'color': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'cls': <class 'kittycad.models.color.Color'>, 'config': {'title': 'Color'}, 'custom_init': False, 'metadata': {'pydantic_js_functions': [<bound method BaseModel.__get_pydantic_json_schema__ of <class 'kittycad.models.color.Color'>>]}, 'ref': 'kittycad.models.color.Color:94250672655760', 'root_model': False, 'schema': {'computed_fields': [], 'fields': {'a': {'metadata': {}, 'schema': {'type': 'float'}, 'type': 'model-field'}, 'b': {'metadata': {}, 'schema': {'type': 'float'}, 'type': 'model-field'}, 'g': {'metadata': {}, 'schema': {'type': 'float'}, 'type': 'model-field'}, 'r': {'metadata': {}, 'schema': {'type': 'float'}, 'type': 'model-field'}}, 'model_name': 'Color', 'type': 'model-fields'}, 'type': 'model'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}, 'line_ends': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'cls': <class 'kittycad.models.annotation_line_end_options.AnnotationLineEndOptions'>, 'config': {'title': 'AnnotationLineEndOptions'}, 'custom_init': False, 'metadata': {'pydantic_js_functions': [<bound method BaseModel.__get_pydantic_json_schema__ of <class 'kittycad.models.annotation_line_end_options.AnnotationLineEndOptions'>>]}, 'ref': 'kittycad.models.annotation_line_end_options.AnnotationLineEndOptions:94250672591920', 'root_model': False, 'schema': {'computed_fields': [], 'fields': {'end': {'metadata': {}, 'schema': {'schema_ref': 'kittycad.models.annotation_line_end.AnnotationLineEnd:94250672862080', 'type': 'definition-ref'}, 'type': 'model-field'}, 'start': {'metadata': {}, 'schema': {'schema_ref': 'kittycad.models.annotation_line_end.AnnotationLineEnd:94250672862080', 'type': 'definition-ref'}, 'type': 'model-field'}}, 'model_name': 'AnnotationLineEndOptions', 'type': 'model-fields'}, 'type': 'model'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}, 'line_width': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'type': 'float'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}, 'position': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'cls': <class 'kittycad.models.point3d.Point3d'>, 'config': {'title': 'Point3d'}, 'custom_init': False, 'metadata': {'pydantic_js_functions': [<bound method BaseModel.__get_pydantic_json_schema__ of <class 'kittycad.models.point3d.Point3d'>>]}, 'ref': 'kittycad.models.point3d.Point3d:94250662434656', 'root_model': False, 'schema': {'computed_fields': [], 'fields': {'x': {'metadata': {}, 'schema': {'type': 'float'}, 'type': 'model-field'}, 'y': {'metadata': {}, 'schema': {'type': 'float'}, 'type': 'model-field'}, 'z': {'metadata': {}, 'schema': {'type': 'float'}, 'type': 'model-field'}}, 'model_name': 'Point3d', 'type': 'model-fields'}, 'type': 'model'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}, 'text': {'metadata': {}, 'schema': {'default': None, 'schema': {'schema': {'cls': <class 'kittycad.models.annotation_text_options.AnnotationTextOptions'>, 'config': {'title': 'AnnotationTextOptions'}, 'custom_init': False, 'metadata': {'pydantic_js_functions': [<bound method BaseModel.__get_pydantic_json_schema__ of <class 'kittycad.models.annotation_text_options.AnnotationTextOptions'>>]}, 'ref': 'kittycad.models.annotation_text_options.AnnotationTextOptions:94250672183440', 'root_model': False, 'schema': {'computed_fields': [], 'fields': {'point_size': {'metadata': {}, 'schema': {'type': 'int'}, 'type': 'model-field'}, 'text': {'metadata': {}, 'schema': {'type': 'str'}, 'type': 'model-field'}, 'x': {'metadata': {}, 'schema': {'cls': <enum 'AnnotationTextAlignmentX'>, 'members': [AnnotationTextAlignmentX.LEFT, AnnotationTextAlignmentX.CENTER, AnnotationTextAlignmentX.RIGHT], 'metadata': {'pydantic_js_functions': [<function GenerateSchema._enum_schema.<locals>.get_json_schema>]}, 'ref': 'kittycad.models.annotation_text_alignment_x.AnnotationTextAlignmentX:94250672179104', 'sub_type': 'str', 'type': 'enum'}, 'type': 'model-field'}, 'y': {'metadata': {}, 'schema': {'cls': <enum 'AnnotationTextAlignmentY'>, 'members': [AnnotationTextAlignmentY.BOTTOM, AnnotationTextAlignmentY.CENTER, AnnotationTextAlignmentY.TOP], 'metadata': {'pydantic_js_functions': [<function GenerateSchema._enum_schema.<locals>.get_json_schema>]}, 'ref': 'kittycad.models.annotation_text_alignment_y.AnnotationTextAlignmentY:94250672181664', 'sub_type': 'str', 'type': 'enum'}, 'type': 'model-field'}}, 'model_name': 'AnnotationTextOptions', 'type': 'model-fields'}, 'type': 'model'}, 'type': 'nullable'}, 'type': 'default'}, 'type': 'model-field'}}, 'model_name': 'AnnotationOptions', 'type': 'model-fields'}, 'type': 'model'}, 'type': 'definitions'}[source]
- The core schema of the model. 
 - __pydantic_custom_init__: ClassVar[bool] = False[source]
- Whether the model has a custom - __init__method.
 - __pydantic_decorators__: ClassVar[_decorators.DecoratorInfos] = DecoratorInfos(validators={}, field_validators={}, root_validators={}, field_serializers={}, model_serializers={}, model_validators={}, computed_fields={})[source]
- Metadata containing the decorators defined on the model. This replaces - Model.__validators__and- Model.__root_validators__from Pydantic V1.
 - __pydantic_extra__: dict[str, Any] | None[source]
- A dictionary containing extra values, if [ - extra][pydantic.config.ConfigDict.extra] is set to- 'allow'.
 - __pydantic_fields__: ClassVar[Dict[str, FieldInfo]] = {'color': FieldInfo(annotation=Union[Color, NoneType], required=False, default=None), 'line_ends': FieldInfo(annotation=Union[AnnotationLineEndOptions, NoneType], required=False, default=None), 'line_width': FieldInfo(annotation=Union[float, NoneType], required=False, default=None), 'position': FieldInfo(annotation=Union[Point3d, NoneType], required=False, default=None), 'text': FieldInfo(annotation=Union[AnnotationTextOptions, NoneType], required=False, default=None)}[source]
- A dictionary of field names and their corresponding [ - FieldInfo][pydantic.fields.FieldInfo] objects. This replaces- Model.__fields__from Pydantic V1.
 - __pydantic_generic_metadata__: ClassVar[_generics.PydanticGenericMetadata] = {'args': (), 'origin': None, 'parameters': ()}[source]
- Metadata for generic models; contains data used for a similar purpose to __args__, __origin__, __parameters__ in typing-module generics. May eventually be replaced by these. 
 - classmethod __pydantic_init_subclass__(**kwargs)[source]
- This is intended to behave just like - __init_subclass__, but is called by- ModelMetaclassonly after the class is actually fully initialized. In particular, attributes like- model_fieldswill be present when this is called.- This is necessary because - __init_subclass__will always be called by- type.__new__, and it would require a prohibitively large refactor to the- ModelMetaclassto ensure that- type.__new__was called in such a manner that the class would already be sufficiently initialized.- This will receive the same - kwargsthat would be passed to the standard- __init_subclass__, namely, any kwargs passed to the class definition that aren’t used internally by pydantic.
 - __pydantic_parent_namespace__: ClassVar[Dict[str, Any] | None] = None[source]
- Parent namespace of the model, used for automatic rebuilding of models. 
 - __pydantic_post_init__: ClassVar[None | Literal['model_post_init']] = None[source]
- The name of the post-init method for the model, if defined. 
 - __pydantic_private__: dict[str, Any] | None[source]
- Values of private attributes set on the model instance. 
 - __pydantic_root_model__: ClassVar[bool] = False[source]
- Whether the model is a [ - RootModel][pydantic.root_model.RootModel].
 - __pydantic_serializer__: ClassVar[SchemaSerializer] = SchemaSerializer(serializer=Model( ModelSerializer { class: Py( 0x000055b871412fb0, ), serializer: Fields( GeneralFieldsSerializer { fields: { "color": SerField { key_py: Py( 0x00007fc70f61a190, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007fc71052d100, ), ), serializer: Nullable( NullableSerializer { serializer: Model( ModelSerializer { class: Py( 0x000055b871dd0d90, ), serializer: Fields( GeneralFieldsSerializer { fields: { "r": SerField { key_py: Py( 0x00007fc710624300, ), alias: None, alias_py: None, serializer: Some( Float( FloatSerializer { inf_nan_mode: Null, }, ), ), required: true, }, "a": SerField { key_py: Py( 0x00007fc710623fd0, ), alias: None, alias_py: None, serializer: Some( Float( FloatSerializer { inf_nan_mode: Null, }, ), ), required: true, }, "b": SerField { key_py: Py( 0x00007fc710624000, ), alias: None, alias_py: None, serializer: Some( Float( FloatSerializer { inf_nan_mode: Null, }, ), ), required: true, }, "g": SerField { key_py: Py( 0x00007fc7106240f0, ), alias: None, alias_py: None, serializer: Some( Float( FloatSerializer { inf_nan_mode: Null, }, ), ), required: true, }, }, computed_fields: Some( ComputedFields( [], ), ), mode: SimpleDict, extra_serializer: None, filter: SchemaFilter { include: None, exclude: None, }, required_fields: 4, }, ), has_extra: false, root_model: false, name: "Color", }, ), }, ), }, ), ), required: true, }, "line_ends": SerField { key_py: Py( 0x00007fc70bc23830, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007fc71052d100, ), ), serializer: Nullable( NullableSerializer { serializer: Model( ModelSerializer { class: Py( 0x000055b871dc1430, ), serializer: Fields( GeneralFieldsSerializer { fields: { "end": SerField { key_py: Py( 0x00007fc71061e648, ), alias: None, alias_py: None, serializer: Some( Recursive( DefinitionRefSerializer { definition: "...", retry_with_lax_check: false, }, ), ), required: true, }, "start": SerField { key_py: Py( 0x00007fc710621fc8, ), alias: None, alias_py: None, serializer: Some( Recursive( DefinitionRefSerializer { definition: "...", retry_with_lax_check: false, }, ), ), required: true, }, }, computed_fields: Some( ComputedFields( [], ), ), mode: SimpleDict, extra_serializer: None, filter: SchemaFilter { include: None, exclude: None, }, required_fields: 2, }, ), has_extra: false, root_model: false, name: "AnnotationLineEndOptions", }, ), }, ), }, ), ), required: true, }, "position": SerField { key_py: Py( 0x00007fc70ee5ddf0, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007fc71052d100, ), ), serializer: Nullable( NullableSerializer { serializer: Model( ModelSerializer { class: Py( 0x000055b871411760, ), serializer: Fields( GeneralFieldsSerializer { fields: { "x": SerField { key_py: Py( 0x00007fc710624420, ), alias: None, alias_py: None, serializer: Some( Float( FloatSerializer { inf_nan_mode: Null, }, ), ), required: true, }, "y": SerField { key_py: Py( 0x00007fc710624450, ), alias: None, alias_py: None, serializer: Some( Float( FloatSerializer { inf_nan_mode: Null, }, ), ), required: true, }, "z": SerField { key_py: Py( 0x00007fc710624480, ), alias: None, alias_py: None, serializer: Some( Float( FloatSerializer { inf_nan_mode: Null, }, ), ), required: true, }, }, computed_fields: Some( ComputedFields( [], ), ), mode: SimpleDict, extra_serializer: None, filter: SchemaFilter { include: None, exclude: None, }, required_fields: 3, }, ), has_extra: false, root_model: false, name: "Point3d", }, ), }, ), }, ), ), required: true, }, "text": SerField { key_py: Py( 0x00007fc710622578, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007fc71052d100, ), ), serializer: Nullable( NullableSerializer { serializer: Model( ModelSerializer { class: Py( 0x000055b871d5d890, ), serializer: Fields( GeneralFieldsSerializer { fields: { "x": SerField { key_py: Py( 0x00007fc710624420, ), alias: None, alias_py: None, serializer: Some( Enum( EnumSerializer { class: Py( 0x000055b871d5c7a0, ), serializer: Some( Str( StrSerializer, ), ), }, ), ), required: true, }, "y": SerField { key_py: Py( 0x00007fc710624450, ), alias: None, alias_py: None, serializer: Some( Enum( EnumSerializer { class: Py( 0x000055b871d5d1a0, ), serializer: Some( Str( StrSerializer, ), ), }, ), ), required: true, }, "text": SerField { key_py: Py( 0x00007fc710622578, ), alias: None, alias_py: None, serializer: Some( Str( StrSerializer, ), ), required: true, }, "point_size": SerField { key_py: Py( 0x00007fc70bcf6af0, ), alias: None, alias_py: None, serializer: Some( Int( IntSerializer, ), ), required: true, }, }, computed_fields: Some( ComputedFields( [], ), ), mode: SimpleDict, extra_serializer: None, filter: SchemaFilter { include: None, exclude: None, }, required_fields: 4, }, ), has_extra: false, root_model: false, name: "AnnotationTextOptions", }, ), }, ), }, ), ), required: true, }, "line_width": SerField { key_py: Py( 0x00007fc70bc238b0, ), alias: None, alias_py: None, serializer: Some( WithDefault( WithDefaultSerializer { default: Default( Py( 0x00007fc71052d100, ), ), serializer: Nullable( NullableSerializer { serializer: Float( FloatSerializer { inf_nan_mode: Null, }, ), }, ), }, ), ), required: true, }, }, computed_fields: Some( ComputedFields( [], ), ), mode: SimpleDict, extra_serializer: None, filter: SchemaFilter { include: None, exclude: None, }, required_fields: 5, }, ), has_extra: false, root_model: false, name: "AnnotationOptions", }, ), definitions=[Enum(EnumSerializer { class: Py(0x55b871e03380), serializer: Some(Str(StrSerializer)) })])[source]
- The - pydantic-core- SchemaSerializerused to dump instances of the model.
 - __pydantic_validator__: ClassVar[SchemaValidator | PluggableSchemaValidator] = SchemaValidator(title="AnnotationOptions", validator=Model( ModelValidator { revalidate: Never, validator: ModelFields( ModelFieldsValidator { fields: [ Field { name: "color", lookup_key: Simple { key: "color", py_key: Py( 0x00007fc70c7f8720, ), path: LookupPath( [ S( "color", Py( 0x00007fc70c7f8750, ), ), ], ), }, name_py: Py( 0x00007fc70f61a190, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007fc71052d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Model( ModelValidator { revalidate: Never, validator: ModelFields( ModelFieldsValidator { fields: [ Field { name: "a", lookup_key: Simple { key: "a", py_key: Py( 0x00007fc710623fd0, ), path: LookupPath( [ S( "a", Py( 0x00007fc710623fd0, ), ), ], ), }, name_py: Py( 0x00007fc710623fd0, ), validator: Float( FloatValidator { strict: false, allow_inf_nan: true, }, ), frozen: false, }, Field { name: "b", lookup_key: Simple { key: "b", py_key: Py( 0x00007fc710624000, ), path: LookupPath( [ S( "b", Py( 0x00007fc710624000, ), ), ], ), }, name_py: Py( 0x00007fc710624000, ), validator: Float( FloatValidator { strict: false, allow_inf_nan: true, }, ), frozen: false, }, Field { name: "g", lookup_key: Simple { key: "g", py_key: Py( 0x00007fc7106240f0, ), path: LookupPath( [ S( "g", Py( 0x00007fc7106240f0, ), ), ], ), }, name_py: Py( 0x00007fc7106240f0, ), validator: Float( FloatValidator { strict: false, allow_inf_nan: true, }, ), frozen: false, }, Field { name: "r", lookup_key: Simple { key: "r", py_key: Py( 0x00007fc710624300, ), path: LookupPath( [ S( "r", Py( 0x00007fc710624300, ), ), ], ), }, name_py: Py( 0x00007fc710624300, ), validator: Float( FloatValidator { strict: false, allow_inf_nan: true, }, ), frozen: false, }, ], model_name: "Color", extra_behavior: Ignore, extras_validator: None, strict: false, from_attributes: false, loc_by_alias: true, }, ), class: Py( 0x000055b871dd0d90, ), generic_origin: None, post_init: None, frozen: false, custom_init: false, root_model: false, undefined: Py( 0x00007fc70e4ea3d0, ), name: "Color", }, ), name: "nullable[Color]", }, ), validate_default: false, copy_default: false, name: "default[nullable[Color]]", undefined: Py( 0x00007fc70e4ea3d0, ), }, ), frozen: false, }, Field { name: "line_ends", lookup_key: Simple { key: "line_ends", py_key: Py( 0x00007fc70bc16570, ), path: LookupPath( [ S( "line_ends", Py( 0x00007fc70bc168b0, ), ), ], ), }, name_py: Py( 0x00007fc70bc23830, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007fc71052d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Model( ModelValidator { revalidate: Never, validator: ModelFields( ModelFieldsValidator { fields: [ Field { name: "end", lookup_key: Simple { key: "end", py_key: Py( 0x00007fc70c7f8780, ), path: LookupPath( [ S( "end", Py( 0x00007fc70c7f87b0, ), ), ], ), }, name_py: Py( 0x00007fc71061e648, ), validator: DefinitionRef( DefinitionRefValidator { definition: "...", }, ), frozen: false, }, Field { name: "start", lookup_key: Simple { key: "start", py_key: Py( 0x00007fc70c7f87e0, ), path: LookupPath( [ S( "start", Py( 0x00007fc70c7f8810, ), ), ], ), }, name_py: Py( 0x00007fc710621fc8, ), validator: DefinitionRef( DefinitionRefValidator { definition: "...", }, ), frozen: false, }, ], model_name: "AnnotationLineEndOptions", extra_behavior: Ignore, extras_validator: None, strict: false, from_attributes: false, loc_by_alias: true, }, ), class: Py( 0x000055b871dc1430, ), generic_origin: None, post_init: None, frozen: false, custom_init: false, root_model: false, undefined: Py( 0x00007fc70e4ea3d0, ), name: "AnnotationLineEndOptions", }, ), name: "nullable[AnnotationLineEndOptions]", }, ), validate_default: false, copy_default: false, name: "default[nullable[AnnotationLineEndOptions]]", undefined: Py( 0x00007fc70e4ea3d0, ), }, ), frozen: false, }, Field { name: "line_width", lookup_key: Simple { key: "line_width", py_key: Py( 0x00007fc70bc168f0, ), path: LookupPath( [ S( "line_width", Py( 0x00007fc70bc16830, ), ), ], ), }, name_py: Py( 0x00007fc70bc238b0, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007fc71052d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Float( FloatValidator { strict: false, allow_inf_nan: true, }, ), name: "nullable[float]", }, ), validate_default: false, copy_default: false, name: "default[nullable[float]]", undefined: Py( 0x00007fc70e4ea3d0, ), }, ), frozen: false, }, Field { name: "position", lookup_key: Simple { key: "position", py_key: Py( 0x00007fc70bc16870, ), path: LookupPath( [ S( "position", Py( 0x00007fc70bc16970, ), ), ], ), }, name_py: Py( 0x00007fc70ee5ddf0, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007fc71052d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Model( ModelValidator { revalidate: Never, validator: ModelFields( ModelFieldsValidator { fields: [ Field { name: "x", lookup_key: Simple { key: "x", py_key: Py( 0x00007fc710624420, ), path: LookupPath( [ S( "x", Py( 0x00007fc710624420, ), ), ], ), }, name_py: Py( 0x00007fc710624420, ), validator: Float( FloatValidator { strict: false, allow_inf_nan: true, }, ), frozen: false, }, Field { name: "y", lookup_key: Simple { key: "y", py_key: Py( 0x00007fc710624450, ), path: LookupPath( [ S( "y", Py( 0x00007fc710624450, ), ), ], ), }, name_py: Py( 0x00007fc710624450, ), validator: Float( FloatValidator { strict: false, allow_inf_nan: true, }, ), frozen: false, }, Field { name: "z", lookup_key: Simple { key: "z", py_key: Py( 0x00007fc710624480, ), path: LookupPath( [ S( "z", Py( 0x00007fc710624480, ), ), ], ), }, name_py: Py( 0x00007fc710624480, ), validator: Float( FloatValidator { strict: false, allow_inf_nan: true, }, ), frozen: false, }, ], model_name: "Point3d", extra_behavior: Ignore, extras_validator: None, strict: false, from_attributes: false, loc_by_alias: true, }, ), class: Py( 0x000055b871411760, ), generic_origin: None, post_init: None, frozen: false, custom_init: false, root_model: false, undefined: Py( 0x00007fc70e4ea3d0, ), name: "Point3d", }, ), name: "nullable[Point3d]", }, ), validate_default: false, copy_default: false, name: "default[nullable[Point3d]]", undefined: Py( 0x00007fc70e4ea3d0, ), }, ), frozen: false, }, Field { name: "text", lookup_key: Simple { key: "text", py_key: Py( 0x00007fc70c7f88a0, ), path: LookupPath( [ S( "text", Py( 0x00007fc70c7f88d0, ), ), ], ), }, name_py: Py( 0x00007fc710622578, ), validator: WithDefault( WithDefaultValidator { default: Default( Py( 0x00007fc71052d100, ), ), on_error: Raise, validator: Nullable( NullableValidator { validator: Model( ModelValidator { revalidate: Never, validator: ModelFields( ModelFieldsValidator { fields: [ Field { name: "point_size", lookup_key: Simple { key: "point_size", py_key: Py( 0x00007fc70bc16670, ), path: LookupPath( [ S( "point_size", Py( 0x00007fc70bc16630, ), ), ], ), }, name_py: Py( 0x00007fc70bcf6af0, ), validator: Int( IntValidator { strict: false, }, ), frozen: false, }, Field { name: "text", lookup_key: Simple { key: "text", py_key: Py( 0x00007fc70c7f8840, ), path: LookupPath( [ S( "text", Py( 0x00007fc70c7f8870, ), ), ], ), }, name_py: Py( 0x00007fc710622578, ), validator: Str( StrValidator { strict: false, coerce_numbers_to_str: false, }, ), frozen: false, }, Field { name: "x", lookup_key: Simple { key: "x", py_key: Py( 0x00007fc710624420, ), path: LookupPath( [ S( "x", Py( 0x00007fc710624420, ), ), ], ), }, name_py: Py( 0x00007fc710624420, ), validator: StrEnum( EnumValidator { phantom: PhantomData<_pydantic_core::validators::enum_::StrEnumValidator>, class: Py( 0x000055b871d5c7a0, ), lookup: LiteralLookup { expected_bool: None, expected_int: None, expected_str: Some( { "left": 0, "center": 1, "right": 2, }, ), expected_py_dict: None, expected_py_values: None, expected_py_primitives: Some( Py( 0x00007fc70bc16600, ), ), values: [ Py( 0x00007fc70bd73b90, ), Py( 0x00007fc70bd73bf0, ), Py( 0x00007fc70bd73c50, ), ], }, missing: None, expected_repr: "'left', 'center' or 'right'", strict: false, class_repr: "AnnotationTextAlignmentX", name: "str-enum[AnnotationTextAlignmentX]", }, ), frozen: false, }, Field { name: "y", lookup_key: Simple { key: "y", py_key: Py( 0x00007fc710624450, ), path: LookupPath( [ S( "y", Py( 0x00007fc710624450, ), ), ], ), }, name_py: Py( 0x00007fc710624450, ), validator: StrEnum( EnumValidator { phantom: PhantomData<_pydantic_core::validators::enum_::StrEnumValidator>, class: Py( 0x000055b871d5d1a0, ), lookup: LiteralLookup { expected_bool: None, expected_int: None, expected_str: Some( { "top": 2, "center": 1, "bottom": 0, }, ), expected_py_dict: None, expected_py_values: None, expected_py_primitives: Some( Py( 0x00007fc70bc165c0, ), ), values: [ Py( 0x00007fc70bd73d70, ), Py( 0x00007fc70bd73dd0, ), Py( 0x00007fc70bd73e30, ), ], }, missing: None, expected_repr: "'bottom', 'center' or 'top'", strict: false, class_repr: "AnnotationTextAlignmentY", name: "str-enum[AnnotationTextAlignmentY]", }, ), frozen: false, }, ], model_name: "AnnotationTextOptions", extra_behavior: Ignore, extras_validator: None, strict: false, from_attributes: false, loc_by_alias: true, }, ), class: Py( 0x000055b871d5d890, ), generic_origin: None, post_init: None, frozen: false, custom_init: false, root_model: false, undefined: Py( 0x00007fc70e4ea3d0, ), name: "AnnotationTextOptions", }, ), name: "nullable[AnnotationTextOptions]", }, ), validate_default: false, copy_default: false, name: "default[nullable[AnnotationTextOptions]]", undefined: Py( 0x00007fc70e4ea3d0, ), }, ), frozen: false, }, ], model_name: "AnnotationOptions", extra_behavior: Ignore, extras_validator: None, strict: false, from_attributes: false, loc_by_alias: true, }, ), class: Py( 0x000055b871412fb0, ), generic_origin: None, post_init: None, frozen: false, custom_init: false, root_model: false, undefined: Py( 0x00007fc70e4ea3d0, ), name: "AnnotationOptions", }, ), definitions=[StrEnum(EnumValidator { phantom: PhantomData<_pydantic_core::validators::enum_::StrEnumValidator>, class: Py(0x55b871e03380), lookup: LiteralLookup { expected_bool: None, expected_int: None, expected_str: Some({"none": 0, "arrow": 1}), expected_py_dict: None, expected_py_values: None, expected_py_primitives: Some(Py(0x7fc70bc16940)), values: [Py(0x7fc70bd733b0), Py(0x7fc70bd73890)] }, missing: None, expected_repr: "'none' or 'arrow'", strict: false, class_repr: "AnnotationLineEnd", name: "str-enum[AnnotationLineEnd]" })], cache_strings=True)[source]
- The - pydantic-core- SchemaValidatorused to validate instances of the model.
 - __repr_recursion__(object)[source]
- Returns the string representation of a recursive object. - Return type:
 
 - __rich_repr__()[source]
- Used by Rich (https://rich.readthedocs.io/en/stable/pretty.html) to pretty print objects. 
 - __signature__: ClassVar[Signature] = <Signature (*, color: Optional[kittycad.models.color.Color] = None, line_ends: Optional[kittycad.models.annotation_line_end_options.AnnotationLineEndOptions] = None, line_width: Optional[float] = None, position: Optional[kittycad.models.point3d.Point3d] = None, text: Optional[kittycad.models.annotation_text_options.AnnotationTextOptions] = None) -> None>[source]
- The synthesized - __init__[- Signature][inspect.Signature] of the model.
 - __slots__ = ('__dict__', '__pydantic_fields_set__', '__pydantic_extra__', '__pydantic_private__')[source]
 - copy(*, include=None, exclude=None, update=None, deep=False)[source]
- Returns a copy of the model. - !!! warning “Deprecated”
- This method is now deprecated; use - model_copyinstead.
 - If you need - includeor- exclude, use:- `python {test="skip" lint="skip"} data = self.model_dump(include=include, exclude=exclude, round_trip=True) data = {**data, **(update or {})} copied = self.model_validate(data) `- Parameters:
- include – Optional set or mapping specifying which fields to include in the copied model. 
- exclude – Optional set or mapping specifying which fields to exclude in the copied model. 
- update – Optional dictionary of field-value pairs to override field values in the copied model. 
- deep – If True, the values of fields that are Pydantic models will be deep-copied. 
 
- Returns:
- A copy of the model with included, excluded and updated fields as specified. 
 
 - dict(*, include=None, exclude=None, by_alias=False, exclude_unset=False, exclude_defaults=False, exclude_none=False)[source]
 - json(*, include=None, exclude=None, by_alias=False, exclude_unset=False, exclude_defaults=False, exclude_none=False, encoder=PydanticUndefined, models_as_dict=PydanticUndefined, **dumps_kwargs)[source]
- Return type:
 
 - 
line_ends: Optional[AnnotationLineEndOptions][source]
 - model_config: ClassVar[ConfigDict] = {'protected_namespaces': ()}[source]
- Configuration for the model, should be a dictionary conforming to [ - ConfigDict][pydantic.config.ConfigDict].
 - classmethod model_construct(_fields_set=None, **values)[source]
- Creates a new instance of the - Modelclass with validated data.- Creates a new model setting - __dict__and- __pydantic_fields_set__from trusted or pre-validated data. Default values are respected, but no other validation is performed.- !!! note
- model_construct()generally respects the- model_config.extrasetting on the provided model. That is, if- model_config.extra == 'allow', then all extra passed values are added to the model instance’s- __dict__and- __pydantic_extra__fields. If- model_config.extra == 'ignore'(the default), then all extra passed values are ignored. Because no validation is performed with a call to- model_construct(), having- model_config.extra == 'forbid'does not result in an error if extra values are passed, but they will be ignored.
 - Parameters:
- _fields_set ( - set[- str] |- None) – A set of field names that were originally explicitly set during instantiation. If provided, this is directly used for the [- model_fields_set][pydantic.BaseModel.model_fields_set] attribute. Otherwise, the field names from the- valuesargument will be used.
- values ( - Any) – Trusted or pre-validated data dictionary.
 
- Return type:
- Self
- Returns:
- A new instance of the - Modelclass with validated data.
 
 - model_copy(*, update=None, deep=False)[source]
- Usage docs: https://docs.pydantic.dev/2.10/concepts/serialization/#model_copy - Returns a copy of the model. 
 - model_dump(*, mode='python', include=None, exclude=None, context=None, by_alias=False, exclude_unset=False, exclude_defaults=False, exclude_none=False, round_trip=False, warnings=True, serialize_as_any=False)[source]
- Usage docs: https://docs.pydantic.dev/2.10/concepts/serialization/#modelmodel_dump - Generate a dictionary representation of the model, optionally specifying which fields to include or exclude. - Parameters:
- mode ( - Union[- Literal[- 'json',- 'python'],- str]) – The mode in which- to_pythonshould run. If mode is ‘json’, the output will only contain JSON serializable types. If mode is ‘python’, the output may contain non-JSON-serializable Python objects.
- include ( - Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- Mapping[- str,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- None]) – A set of fields to include in the output.
- exclude ( - Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- Mapping[- str,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- None]) – A set of fields to exclude from the output.
- context ( - Any|- None) – Additional context to pass to the serializer.
- by_alias ( - bool) – Whether to use the field’s alias in the dictionary key if defined.
- exclude_unset ( - bool) – Whether to exclude fields that have not been explicitly set.
- exclude_defaults ( - bool) – Whether to exclude fields that are set to their default value.
- exclude_none ( - bool) – Whether to exclude fields that have a value of- None.
- round_trip ( - bool) – If True, dumped values should be valid as input for non-idempotent types such as Json[T].
- warnings ( - Union[- bool,- Literal[- 'none',- 'warn',- 'error']]) – How to handle serialization errors. False/”none” ignores them, True/”warn” logs errors, “error” raises a [- PydanticSerializationError][pydantic_core.PydanticSerializationError].
- serialize_as_any ( - bool) – Whether to serialize fields with duck-typing serialization behavior.
 
- Return type:
- Returns:
- A dictionary representation of the model. 
 
 - model_dump_json(*, indent=None, include=None, exclude=None, context=None, by_alias=False, exclude_unset=False, exclude_defaults=False, exclude_none=False, round_trip=False, warnings=True, serialize_as_any=False)[source]
- Usage docs: https://docs.pydantic.dev/2.10/concepts/serialization/#modelmodel_dump_json - Generates a JSON representation of the model using Pydantic’s - to_jsonmethod.- Parameters:
- indent ( - int|- None) – Indentation to use in the JSON output. If None is passed, the output will be compact.
- include ( - Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- Mapping[- str,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- None]) – Field(s) to include in the JSON output.
- exclude ( - Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- Mapping[- str,- Union[- Set[- int],- Set[- str],- Mapping[- int,- Union[IncEx,- bool]],- Mapping[- str,- Union[IncEx,- bool]],- bool]],- None]) – Field(s) to exclude from the JSON output.
- context ( - Any|- None) – Additional context to pass to the serializer.
- by_alias ( - bool) – Whether to serialize using field aliases.
- exclude_unset ( - bool) – Whether to exclude fields that have not been explicitly set.
- exclude_defaults ( - bool) – Whether to exclude fields that are set to their default value.
- exclude_none ( - bool) – Whether to exclude fields that have a value of- None.
- round_trip ( - bool) – If True, dumped values should be valid as input for non-idempotent types such as Json[T].
- warnings ( - Union[- bool,- Literal[- 'none',- 'warn',- 'error']]) – How to handle serialization errors. False/”none” ignores them, True/”warn” logs errors, “error” raises a [- PydanticSerializationError][pydantic_core.PydanticSerializationError].
- serialize_as_any ( - bool) – Whether to serialize fields with duck-typing serialization behavior.
 
- Return type:
- Returns:
- A JSON string representation of the model. 
 
 - property model_extra: dict[str, Any] | None[source]
- Get extra fields set during validation. - Returns:
- A dictionary of extra fields, or - Noneif- config.extrais not set to- "allow".
 
 - model_fields: ClassVar[dict[str, FieldInfo]] = {'color': FieldInfo(annotation=Union[Color, NoneType], required=False, default=None), 'line_ends': FieldInfo(annotation=Union[AnnotationLineEndOptions, NoneType], required=False, default=None), 'line_width': FieldInfo(annotation=Union[float, NoneType], required=False, default=None), 'position': FieldInfo(annotation=Union[Point3d, NoneType], required=False, default=None), 'text': FieldInfo(annotation=Union[AnnotationTextOptions, NoneType], required=False, default=None)}[source]
 - property model_fields_set: set[str][source]
- Returns the set of fields that have been explicitly set on this model instance. - Returns:
- A set of strings representing the fields that have been set,
- i.e. that were not filled from defaults. 
 
 
 - classmethod model_json_schema(by_alias=True, ref_template='#/$defs/{model}', schema_generator=<class 'pydantic.json_schema.GenerateJsonSchema'>, mode='validation')[source]
- Generates a JSON schema for a model class. - Parameters:
- by_alias ( - bool) – Whether to use attribute aliases or not.
- ref_template ( - str) – The reference template.
- schema_generator ( - type[- GenerateJsonSchema]) – To override the logic used to generate the JSON schema, as a subclass of- GenerateJsonSchemawith your desired modifications
- mode ( - Literal[- 'validation',- 'serialization']) – The mode in which to generate the schema.
 
- Return type:
- Returns:
- The JSON schema for the given model class. 
 
 - classmethod model_parametrized_name(params)[source]
- Compute the class name for parametrizations of generic classes. - This method can be overridden to achieve a custom naming scheme for generic BaseModels. - Parameters:
- params ( - tuple[- type[- Any],- ...]) – Tuple of types of the class. Given a generic class- Modelwith 2 type variables and a concrete model- Model[str, int], the value- (str, int)would be passed to- params.
- Return type:
- Returns:
- String representing the new class where - paramsare passed to- clsas type variables.
- Raises:
- TypeError – Raised when trying to generate concrete names for non-generic models. 
 
 - model_post_init(_BaseModel__context)[source]
- Override this method to perform additional initialization after - __init__and- model_construct. This is useful if you want to do some validation that requires the entire model to be initialized.- Return type:
 
 - classmethod model_rebuild(*, force=False, raise_errors=True, _parent_namespace_depth=2, _types_namespace=None)[source]
- Try to rebuild the pydantic-core schema for the model. - This may be necessary when one of the annotations is a ForwardRef which could not be resolved during the initial attempt to build the schema, and automatic rebuilding fails. - Parameters:
- force ( - bool) – Whether to force the rebuilding of the model schema, defaults to- False.
- raise_errors ( - bool) – Whether to raise errors, defaults to- True.
- _parent_namespace_depth ( - int) – The depth level of the parent namespace, defaults to 2.
- _types_namespace ( - Optional[- Mapping[- str,- Any]]) – The types namespace, defaults to- None.
 
- Return type:
- Returns:
- Returns - Noneif the schema is already “complete” and rebuilding was not required. If rebuilding _was_ required, returns- Trueif rebuilding was successful, otherwise- False.
 
 - classmethod model_validate(obj, *, strict=None, from_attributes=None, context=None)[source]
- Validate a pydantic model instance. - Parameters:
- Raises:
- ValidationError – If the object could not be validated. 
- Return type:
- Self
- Returns:
- The validated model instance. 
 
 - classmethod model_validate_json(json_data, *, strict=None, context=None)[source]
- Usage docs: https://docs.pydantic.dev/2.10/concepts/json/#json-parsing - Validate the given JSON data against the Pydantic model. - Parameters:
- Return type:
- Self
- Returns:
- The validated Pydantic model. 
- Raises:
- ValidationError – If - json_datais not a JSON string or the object could not be validated.
 
 - classmethod model_validate_strings(obj, *, strict=None, context=None)[source]
- Validate the given object with string data against the Pydantic model. 
 - classmethod parse_file(path, *, content_type=None, encoding='utf8', proto=None, allow_pickle=False)[source]
- Return type:
- Self
 
 - classmethod parse_raw(b, *, content_type=None, encoding='utf8', proto=None, allow_pickle=False)[source]
- Return type:
- Self