@@ -143,7 +143,6 @@ def begin_class(
143
143
idfield : str ,
144
144
optional_fields : set [str ],
145
145
) -> None :
146
- class_uri = classname
147
146
classname = self .safe_name (classname )
148
147
149
148
if extends :
@@ -166,12 +165,7 @@ def begin_class(
166
165
167
166
idfield_safe_name = self .safe_name (idfield ) if idfield != "" else None
168
167
if idfield_safe_name is not None :
169
- self .out .write (f" { idfield_safe_name } : str\n " )
170
- if "class" not in field_names :
171
- self .out .write ("\n " )
172
-
173
- if "class" in field_names :
174
- self .out .write (f' class_uri = "{ class_uri } "\n \n ' )
168
+ self .out .write (f" { idfield_safe_name } : str\n \n " )
175
169
176
170
required_field_names = [f for f in field_names if f not in optional_fields ]
177
171
optional_field_names = [f for f in field_names if f in optional_fields ]
@@ -602,7 +596,8 @@ def declare_field(
602
596
603
597
if shortname (name ) == "class" :
604
598
self .out .write (
605
- """{spc} if {safename} != cls.__name__ and {safename} != cls.class_uri:
599
+ """
600
+ {spc} if {safename} not in (cls.__name__, loadingOptions.vocab.get(cls.__name__)):
606
601
{spc} raise ValidationException(f"tried `{{cls.__name__}}` but")
607
602
{spc} except ValidationException as e:
608
603
{spc} raise e
@@ -667,7 +662,8 @@ def declare_field(
667
662
fmt (
668
663
"""
669
664
if self.{safename} is not None:
670
- if p := self.loadingOptions.rvocab.get(self.class_uri[:-len(self.{safename})]):
665
+ uri = self.loadingOptions.vocab[self.{safename}]
666
+ if p := self.loadingOptions.rvocab.get(uri[:-len(self.{safename})]):
671
667
uri = f"{{p}}:{{self.{safename}}}"
672
668
else:
673
669
uri = self.{safename}
0 commit comments