(
cls, value_list: Optional[Union[Iterable[str], str]]
)
| 209 | delete_orphan: bool |
| 210 | |
| 211 | def __new__( |
| 212 | cls, value_list: Optional[Union[Iterable[str], str]] |
| 213 | ) -> CascadeOptions: |
| 214 | if isinstance(value_list, str) or value_list is None: |
| 215 | return cls.from_string(value_list) # type: ignore |
| 216 | values = set(value_list) |
| 217 | if values.difference(cls._allowed_cascades): |
| 218 | raise sa_exc.ArgumentError( |
| 219 | "Invalid cascade option(s): %s" |
| 220 | % ", ".join( |
| 221 | [ |
| 222 | repr(x) |
| 223 | for x in sorted( |
| 224 | values.difference(cls._allowed_cascades) |
| 225 | ) |
| 226 | ] |
| 227 | ) |
| 228 | ) |
| 229 | |
| 230 | if "all" in values: |
| 231 | values.update(cls._add_w_all_cascades) |
| 232 | if "none" in values: |
| 233 | values.clear() |
| 234 | values.discard("all") |
| 235 | |
| 236 | self = super().__new__(cls, values) |
| 237 | self.save_update = "save-update" in values |
| 238 | self.delete = "delete" in values |
| 239 | self.refresh_expire = "refresh-expire" in values |
| 240 | self.merge = "merge" in values |
| 241 | self.expunge = "expunge" in values |
| 242 | self.delete_orphan = "delete-orphan" in values |
| 243 | |
| 244 | if self.delete_orphan and not self.delete: |
| 245 | util.warn("The 'delete-orphan' cascade option requires 'delete'.") |
| 246 | return self |
| 247 | |
| 248 | def __repr__(self): |
| 249 | return "CascadeOptions(%r)" % (",".join([x for x in sorted(self)])) |
no test coverage detected