.. index:: single: rfc_metric .. _rfc_metric/0: .. rst-class:: right **object** ``rfc_metric`` ============== Response For a Class (RFC) metric. The score is the number of distinct predicates in the response set: the locally defined (non-auxiliary) predicates plus all distinct predicates they directly call or update. Protocols are not scored as they cannot define predicates. The score is represented by a non-negative integer. | **Availability:** | ``logtalk_load(code_metrics(loader))`` | **Author:** Paulo Moura | **Version:** 1:0:0 | **Date:** 2026-03-13 | **Compilation flags:** | ``static, context_switching_calls`` | **Imports:** | ``public`` :ref:`code_metrics_utilities ` | ``public`` :ref:`code_metric ` | **Provides:** | :ref:`logtalk::message_tokens//2 ` | **Uses:** | :ref:`list ` | :ref:`logtalk ` | :ref:`numberlist ` | **Remarks:** - Response set: The response set RS(E) for an entity E is the union of its locally defined (non-auxiliary) predicates and all predicates directly called or updated by those predicates. - Score interpretation: Higher scores indicate entities with more potential execution paths in response to a message, which may increase testing effort. - Aggregation: When computing scores for files, directories, and libraries, the individual entity scores are summed. | **Inherited public predicates:** |  :ref:`code_metric/0::all/0`  :ref:`code_metric/0::all/1`  :ref:`code_metric/0::all_score/1`  :ref:`options_protocol/0::check_option/1`  :ref:`options_protocol/0::check_options/1`  :ref:`options_protocol/0::default_option/1`  :ref:`options_protocol/0::default_options/1`  :ref:`code_metric/0::directory/1`  :ref:`code_metric/0::directory/2`  :ref:`code_metric/0::directory_score/2`  :ref:`code_metric/0::entity/1`  :ref:`code_metric/0::entity_score/2`  :ref:`code_metric/0::file/1`  :ref:`code_metric/0::file/2`  :ref:`code_metric/0::file_score/2`  :ref:`code_metric/0::format_entity_score//2`  :ref:`code_metric/0::library/1`  :ref:`code_metric/0::library/2`  :ref:`code_metric/0::library_score/2`  :ref:`options_protocol/0::option/2`  :ref:`options_protocol/0::option/3`  :ref:`code_metric/0::rdirectory/1`  :ref:`code_metric/0::rdirectory/2`  :ref:`code_metric/0::rdirectory_score/2`  :ref:`code_metric/0::rlibrary/1`  :ref:`code_metric/0::rlibrary/2`  :ref:`code_metric/0::rlibrary_score/2`  :ref:`options_protocol/0::valid_option/1`  :ref:`options_protocol/0::valid_options/1`   .. contents:: :local: :backlinks: top Public predicates ----------------- (no local declarations; see entity ancestors if any) Protected predicates -------------------- (no local declarations; see entity ancestors if any) Private predicates ------------------ (no local declarations; see entity ancestors if any) Operators --------- (none)