facebookincubator / velox
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 (22 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 22 components.
  • 855 files, 139,848 lines of code (100.0% vs. main code).
  • "velox/dwio" is biggest, containing 22.9% of code.
  • "velox/flag_definitions" is smallest, containing 0.02% of code.


velox/dwio32022 LOC (22%) 190 files
velox/functions24354 LOC (17%) 181 files
velox/exec15166 LOC (10%) 87 files
velox/common11583 LOC (8%) 92 files
velox/type8878 LOC (6%) 23 files
build/fbcode_builder8792 LOC (6%) 49 files
velox/vector8220 LOC (5%) 43 files
velox/experimental7658 LOC (5%) 68 files
velox/expression7423 LOC (5%) 29 files
velox/core3394 LOC (2%) 12 files
velox/row2513 LOC (1%) 9 files
velox/substrait1980 LOC (1%) 16 files
velox/connectors1717 LOC (1%) 16 files
velox/duckdb1556 LOC (1%) 8 files
velox/serializers1440 LOC (1%) 2 files
velox/parse804 LOC (<1%) 9 files
scripts774 LOC (<1%) 6 files
velox/benchmarks649 LOC (<1%) 5 files
velox/buffer513 LOC (<1%) 3 files
CMake320 LOC (<1%) 2 files
velox/codegen63 LOC (<1%) 4 files
velox/flag_definitions29 LOC (<1%) 1 files
Dependencies
Dependencies among components are static code dependencies among files in different components.

No component dependencies found.



2022-04-15 05:08