awslabs / amazon-kinesis-client
Unit Size

The distribution of size of units (measured in lines of code).

Intro
  • Unit size measurements show the distribution of size of units of code (methods, functions...).
  • Units are classified in four categories based on their size (lines of code): 1-20 (small units), 20-50 (medium size units), 51-100 (long units), 101+ (very long units).
  • You should aim at keeping units small (< 20 lines). Long units may become "bloaters", code that have increased to such gargantuan proportions that they are hard to work with.
Learn more...
Unit Size Overall
  • There are 1,274 units with 11,699 lines of code in units (65.2% of code).
    • 0 very long units (0 lines of code)
    • 21 long units (1,361 lines of code)
    • 101 medium size units (3,069 lines of code)
    • 194 small units (2,784 lines of code)
    • 958 very small units (4,485 lines of code)
0% | 11% | 26% | 23% | 38%
Legend:
101+
51-100
21-50
11-20
1-10
Unit Size per Extension
101+
51-100
21-50
11-20
1-10
java0% | 11% | 26% | 23% | 38%
Unit Size per Logical Component
primary logical decomposition
101+
51-100
21-50
11-20
1-10
amazon-kinesis-client/src/main/java/software/amazon/kinesis/retrieval0% | 14% | 20% | 28% | 36%
amazon-kinesis-client/src/main/java/software/amazon/kinesis/leases0% | 14% | 35% | 24% | 26%
amazon-kinesis-client/src/main/java/software/amazon/kinesis/coordinator0% | 17% | 37% | 20% | 24%
amazon-kinesis-client-multilang/src/main/java/software/amazon/kinesis/multilang0% | 7% | 24% | 23% | 44%
amazon-kinesis-client-multilang/src/main/java/software/amazon/kinesis/coordinator0% | 23% | 0% | 8% | 68%
amazon-kinesis-client/src/main/java/software/amazon/kinesis/lifecycle0% | 4% | 28% | 24% | 41%
amazon-kinesis-client/src/main/java/software/amazon/kinesis/metrics0% | 0% | 19% | 17% | 63%
amazon-kinesis-client/src/main/java/software/amazon/kinesis/checkpoint0% | 0% | 28% | 26% | 45%
amazon-kinesis-client/src/main/java/software/amazon/kinesis/schemaregistry0% | 0% | 58% | 0% | 41%
amazon-kinesis-client/src/main/java/software/amazon/kinesis/common0% | 0% | 0% | 19% | 80%
amazon-kinesis-client/src/main/java/software/amazon/kinesis/exceptions0% | 0% | 0% | 0% | 100%
amazon-kinesis-client/src/main/java/software/amazon/kinesis/processor0% | 0% | 0% | 0% | 100%
Alternative Visuals
Longest Units
Top 20 longest units
Unit# linesMcCabe index# params
public List deaggregate()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/retrieval/AggregatorUtil.java
93 19 3
protected Scheduler()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/coordinator/Scheduler.java
87 5 8
Set checkAndSyncStreamShardsAndLeases()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/coordinator/Scheduler.java
85 14 0
private Set computeLeasesToTake()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/leases/dynamodb/DynamoDBLeaseTaker.java
85 13 1
public void subscribe()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/retrieval/fanout/FanOutRecordsPublisher.java
76 10 1
synchronized Map takeLeases()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/leases/dynamodb/DynamoDBLeaseTaker.java
72 10 1
private AggregatedRecord()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/retrieval/kpl/Messages.java
70 15 2
static boolean checkIfDescendantAndAddNewLeasesForAncestors()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/leases/HierarchicalShardSyncer.java
68 20 7
public LeaseCleanupResult cleanupLease()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/leases/LeaseCleanupManager.java
61 12 3
private Record()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/retrieval/kpl/Messages.java
61 12 2
public static void resolveFields()
in amazon-kinesis-client-multilang/src/main/java/software/amazon/kinesis/multilang/config/ConfigurationSettableUtils.java
61 21 5
private ListShardsResponse listShards()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/leases/KinesisShardDetector.java
59 13 2
private void errorOccurred()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/retrieval/fanout/FanOutRecordsPublisher.java
56 9 2
private List chooseLeasesToSteal()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/leases/dynamodb/DynamoDBLeaseTaker.java
55 13 3
public KinesisClientLibConfiguration()
in amazon-kinesis-client-multilang/src/main/java/software/amazon/kinesis/coordinator/KinesisClientLibConfiguration.java
55 1 23
public MultiLangDaemonConfiguration()
in amazon-kinesis-client-multilang/src/main/java/software/amazon/kinesis/multilang/config/MultiLangDaemonConfiguration.java
55 1 2
public TaskResult call()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/lifecycle/ProcessTask.java
54 9 0
private void makeRetrievalAttempt()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/retrieval/polling/PrefetchRecordsPublisher.java
53 9 0
private List list()
in amazon-kinesis-client/src/main/java/software/amazon/kinesis/leases/dynamodb/DynamoDBLeaseRefresher.java
52 12 3
public KinesisClientLibConfiguration()
in amazon-kinesis-client-multilang/src/main/java/software/amazon/kinesis/coordinator/KinesisClientLibConfiguration.java
52 1 23