aws / libfabric
Components & Dependencies

An overview of source code logical components.

Intro

Logical decomposition is a representation of the organization of the main source code, where every and each file is put in exactly one logical component.

  • A software system can have one or more logical decompositions.
  • A logical decomposition can be defined in two ways in Sokrates.
  • First approach is based on the folders structure. Components are mapped to folders at defined folder depth relative to the source code root.
  • Second approach is based on explicit definition of each component. In such explicit definitions, components are explicitly named and their files are selected based on explicitly defined path and content filters.
  • A logical decomposition is considered invalid if a file is selected into two or more components.This constraint is introduced in order to facilitate measuring of dependencies among components.
  • Files not assigned to any component are put into a special "Unclassified" component.
Learn more...
Logical Decompositions Overview

Analyzed system has 1 logical decomposition:

  • primary (47 components)

Logical Decomposition #1: PRIMARY

The decompositions is based on the folder structure (relative to the source code root), with automatically defined folder depth to have at least 10 components.

Bubble Chart | Tree Map
Components
The "primary" logical decomposition has 47 components.
  • 716 files, 197,036 lines of code (100.0% vs. main code).
  • "prov/gni" is biggest, containing 14.17% of code.
  • "include/shared" is smallest, containing 0.01% of code.


prov/gni27919 LOC (14%) 85 files
prov/usnic16715 LOC (8%) 93 files
prov/psm213625 LOC (6%) 33 files
prov/efa12852 LOC (6%) 37 files
prov/bgq12196 LOC (6%) 40 files
prov/sockets12047 LOC (6%) 36 files
prov/verbs9136 LOC (4%) 17 files
prov/util8869 LOC (4%) 21 files
prov/psm7988 LOC (4%) 21 files
prov/rxm7541 LOC (3%) 11 files
prov/netdir6739 LOC (3%) 26 files
include6107 LOC (3%) 32 files
fabtests/functional6007 LOC (3%) 29 files
src5610 LOC (2%) 16 files
prov/rxd4392 LOC (2%) 14 files
fabtests/ubertest3594 LOC (1%) 11 files
fabtests/common3589 LOC (1%) 5 files
prov/shm3558 LOC (1%) 15 files
prov/tcp3361 LOC (1%) 14 files
prov/mrail3096 LOC (1%) 9 files
prov/hook2961 LOC (1%) 15 files
include/rdma2605 LOC (1%) 13 files
ROOT2416 LOC (1%) 12 files
util2169 LOC (1%) 3 files
prov/rstream1701 LOC (<1%) 9 files
fabtests/multinode1246 LOC (<1%) 6 files
include/windows1210 LOC (<1%) 21 files
prov/udp998 LOC (<1%) 8 files
fabtests/benchmarks806 LOC (<1%) 10 files
fabtests/include784 LOC (<1%) 17 files
contrib/intel780 LOC (<1%) 5 files
config748 LOC (<1%) 6 files
util/windows554 LOC (<1%) 2 files
contrib/cray505 LOC (<1%) 3 files
src/windows461 LOC (<1%) 1 files
fabtests459 LOC (<1%) 3 files
fabtests/scripts318 LOC (<1%) 4 files
fabtests/unit273 LOC (<1%) 2 files
src/linux262 LOC (<1%) 2 files
include/unix235 LOC (<1%) 1 files
src/unix204 LOC (<1%) 1 files
src/shared117 LOC (<1%) 1 files
include/linux93 LOC (<1%) 2 files
config/github-webhook73 LOC (<1%) 1 files
include/osx51 LOC (<1%) 1 files
include/freebsd51 LOC (<1%) 1 files
include/shared15 LOC (<1%) 1 files
Dependencies
Dependencies among components are static code dependencies among files in different components.

No component dependencies found.



2022-01-31 14:57