facebookincubator / nvdtools
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 (39 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 12 components.

Bubble Chart | Tree Map
Components
The "primary" logical decomposition has 39 components.
  • 151 files, 14,579 lines of code (100.0% vs. main code).
  • "vulndb" is biggest, containing 9.29% of code.
  • "ROOT" is smallest, containing 0.14% of code.


vulndb1355 LOC (9%) 10 files
cvss31090 LOC (7%) 6 files
wfn944 LOC (6%) 6 files
cmd/vulndb849 LOC (5%) 11 files
providers/nvd846 LOC (5%) 7 files
cvefeed768 LOC (5%) 7 files
cvss2713 LOC (4%) 6 files
providers/redhat664 LOC (4%) 8 files
vulndb/sqlutil590 LOC (4%) 8 files
providers/idefense580 LOC (3%) 6 files
providers/vfeed558 LOC (3%) 4 files
providers/fireeye548 LOC (3%) 10 files
cmd/cpe2cve522 LOC (3%) 4 files
providers/lib513 LOC (3%) 10 files
cvefeed/nvd490 LOC (3%) 5 files
providers/flexera423 LOC (2%) 5 files
cmd/wfnconvert408 LOC (2%) 3 files
providers/rbs400 LOC (2%) 3 files
providers/snyk355 LOC (2%) 5 files
cmd/csv2cpe252 LOC (1%) 1 files
providers/rustsec246 LOC (1%) 1 files
rpm243 LOC (1%) 4 files
cmd/rpm2cpe156 LOC (1%) 1 files
cpedict155 LOC (1%) 2 files
stats144 LOC (<1%) 1 files
cmd/redhat_query114 LOC (<1%) 3 files
cmd/redhat_filter95 LOC (<1%) 1 files
cmd/snyk2nvd94 LOC (<1%) 1 files
cmd/rbs2nvd56 LOC (<1%) 1 files
cmd/nvdsync55 LOC (<1%) 1 files
vulndb/mysql51 LOC (<1%) 2 files
cmd/flexera2nvd50 LOC (<1%) 1 files
cmd/fireeye2nvd50 LOC (<1%) 1 files
cmd/idefense2nvd46 LOC (<1%) 1 files
cmd/redhat2nvd41 LOC (<1%) 1 files
cmd/vfeed2nvd38 LOC (<1%) 1 files
cmd/rustsec2nvd29 LOC (<1%) 1 files
vulndb/debug27 LOC (<1%) 1 files
ROOT21 LOC (<1%) 1 files
Dependencies
Dependencies among components are static code dependencies among files in different components.

No component dependencies found.



2022-04-15 03:51