The documentation for the AgentNotificationActivity.as_model method contains broken links to <xref:microsoft_agents_a365.notifications.models.agent_notification_activity.TModel>
Cause according to Claude:
The DocFx generator sees the TypeVar in the type annotation and tries to build a cross-reference link to it — just like it would for a real class. But TModel is a TypeVar, not a documented type, so there's no page to link to and the xref renders as broken text:
Type[<xref:microsoft_agents_a365.notifications.models.agent_notification_activity.TModel>]
TypeVar is defined at module level (agent_notification_activity.py:10):
TModel = TypeVar("TModel")
DocFx doesn't have special handling for TypeVar instances — it treats them like class references. This is a doc generator limitation, but the underlying cause is that TypeVar at module scope bleeds into the doc generation as if it were a public documented type.
Claude's recommendation to fix:
Rename TModel to _TModel (underscore prefix) at [agent_notification_activity.py:10].
The underscore convention marks it as private/internal. Doc generators respect this and won't try to generate a cross-reference link for it — they'll render it as plain text instead.
before
TModel = TypeVar("TModel")
def as_model(self, model: Type[TModel]) -> Optional[TModel]:
after
_TModel = TypeVar("_TModel")
def as_model(self, model: Type[_TModel]) -> Optional[_TModel]:
This is also the standard Python convention — TypeVars that aren't part of a public generic API (e.g., on a public generic class) should always be underscore-prefixed.
The documentation for the AgentNotificationActivity.as_model method contains broken links to
<xref:microsoft_agents_a365.notifications.models.agent_notification_activity.TModel>Cause according to Claude:
The DocFx generator sees the
TypeVarin the type annotation and tries to build a cross-reference link to it — just like it would for a real class. ButTModelis aTypeVar, not a documented type, so there's no page to link to and the xref renders as broken text:Type[<xref:microsoft_agents_a365.notifications.models.agent_notification_activity.TModel>]TypeVaris defined at module level (agent_notification_activity.py:10):TModel = TypeVar("TModel")DocFx doesn't have special handling for
TypeVarinstances — it treats them like class references. This is a doc generator limitation, but the underlying cause is thatTypeVarat module scope bleeds into the doc generation as if it were a public documented type.Claude's recommendation to fix:
Rename
TModelto_TModel(underscore prefix) at [agent_notification_activity.py:10].The underscore convention marks it as private/internal. Doc generators respect this and won't try to generate a cross-reference link for it — they'll render it as plain text instead.
before
after
This is also the standard Python convention — TypeVars that aren't part of a public generic API (e.g., on a public generic class) should always be underscore-prefixed.