/**
   * This returns the property descriptors for the adapted class.
   * <!-- begin-user-doc -->
   * <!-- end-user-doc -->
   *
   * @generated
   */
  @Override
  public List<IItemPropertyDescriptor> getPropertyDescriptors(Object object) {
    if (itemPropertyDescriptors == null) {
      super.getPropertyDescriptors(object);

      addComponentsPropertyDescriptor(object);
    }
    return itemPropertyDescriptors;
  }
  /**
   * This returns the property descriptors for the adapted class.
   * <!-- begin-user-doc -->
   * <!-- end-user-doc -->
   *
   * @generated
   */
  @Override
  public List<IItemPropertyDescriptor> getPropertyDescriptors(Object object) {
    if (itemPropertyDescriptors == null) {
      super.getPropertyDescriptors(object);

      addAnnotatedModelElementsPropertyDescriptor(object);
    }
    return itemPropertyDescriptors;
  }
  /**
   * This handles model notifications by calling {@link #updateChildren} to update any cached
   * children and by creating a viewer notification, which it passes to {@link #fireNotifyChanged}.
   * <!-- begin-user-doc -->
   * <!-- end-user-doc
   * -->
   *
   * @generated
   */
  @Override
  public void notifyChanged(Notification notification) {
    updateChildren(notification);

    switch (notification.getFeatureID(UseCase.class)) {
      case RequirementPackage.USE_CASE__PRECONDITION:
      case RequirementPackage.USE_CASE__POSTCONDITION:
      case RequirementPackage.USE_CASE__RULES:
      case RequirementPackage.USE_CASE__EXCEPTION:
        fireNotifyChanged(
            new ViewerNotification(notification, notification.getNotifier(), false, true));
        return;
    }
    super.notifyChanged(notification);
  }
  /**
   * This returns the property descriptors for the adapted class.
   * <!-- begin-user-doc -->
   * <!-- end-user-doc -->
   *
   * @generated
   */
  @Override
  public List<IItemPropertyDescriptor> getPropertyDescriptors(Object object) {
    if (itemPropertyDescriptors == null) {
      super.getPropertyDescriptors(object);

      addInitiatingActorPropertyDescriptor(object);
      addParticipatingActorsPropertyDescriptor(object);
      addRealizedUserTaskPropertyDescriptor(object);
      addPreconditionPropertyDescriptor(object);
      addUseCaseStepsPropertyDescriptor(object);
      addPostconditionPropertyDescriptor(object);
      addScenariosPropertyDescriptor(object);
      addFunctionalRequirementsPropertyDescriptor(object);
      addNonFunctionalRequirementsPropertyDescriptor(object);
      addIdentifiedClassesPropertyDescriptor(object);
      addIncludedUseCasesPropertyDescriptor(object);
      addExtendedUseCasesPropertyDescriptor(object);
      addSystemFunctionsPropertyDescriptor(object);
    }
    return itemPropertyDescriptors;
  }
 /**
  * This adds {@link org.eclipse.emf.edit.command.CommandParameter}s describing the children that
  * can be created under this object.
  * <!-- begin-user-doc -->
  * <!-- end-user-doc -->
  *
  * @generated
  */
 @Override
 protected void collectNewChildDescriptors(Collection<Object> newChildDescriptors, Object object) {
   super.collectNewChildDescriptors(newChildDescriptors, object);
 }
 /**
  * This handles model notifications by calling {@link #updateChildren} to update any cached
  * children and by creating a viewer notification, which it passes to {@link #fireNotifyChanged}.
  * <!-- begin-user-doc -->
  * <!-- end-user-doc
  * -->
  *
  * @generated
  */
 @Override
 public void notifyChanged(Notification notification) {
   updateChildren(notification);
   super.notifyChanged(notification);
 }