microsoft / Trill
Duplication

Places in code with 6 or more lines that are exactly the same.

Intro
  • For duplication, we look at places in code where there are 6 or more lines of code that are exactly the same.
  • Before duplication is calculated, the code is cleaned to remove empty lines, comments, and frequently duplicated constructs such as imports.
  • You should aim at having as little as possible (<5%) of duplicated code as high-level of duplication can lead to maintenance difficulties, poor factoring, and logical contradictions.
Learn more...
Duplication Overall
  • 53% duplication:
    • 63,195 cleaned lines of cleaned code (without empty lines, comments, and frequently duplicated constructs such as imports)
    • 33,659 duplicated lines
  • 10,633 duplicates
system53% (33,659 lines)
Duplication per Extension
cs53% (33,659 lines)
Duplication per Component (primary)
Sources/Core/Microsoft.StreamProcessing/Operators61% (16,735 lines)
Sources/Core/Microsoft.StreamProcessing/Ingress84% (8,757 lines)
Sources/Core/Microsoft.StreamProcessing/Aggregates54% (2,488 lines)
Sources/Core/Microsoft.StreamProcessing/StreamableAPI50% (2,032 lines)
Sources/Core/Microsoft.StreamProcessing/Egress54% (1,253 lines)
Sources/Core/Microsoft.StreamProcessing/Collections21% (690 lines)
Sources/Core/Microsoft.StreamProcessing/Utilities18% (585 lines)
Sources/Core/Microsoft.StreamProcessing/StringHandling29% (460 lines)
Sources/Core/Microsoft.StreamProcessing/Fusible41% (247 lines)
Sources/Core/Microsoft.StreamProcessing/Serializer8% (116 lines)
Sources/Core/Microsoft.StreamProcessing/StreamProperties12% (98 lines)
Sources/Core/Microsoft.StreamProcessing/Events43% (80 lines)
Sources/Core/Microsoft.StreamProcessing.Provider/Core34% (48 lines)
Sources/Core/Microsoft.StreamProcessing/Transformer2% (30 lines)
Sources/Core/Microsoft.StreamProcessing/Pipes5% (28 lines)
Sources/Core/Microsoft.StreamProcessing/Windows1% (12 lines)
Sources0% (0 lines)
Sources/Core0% (0 lines)
Sources/Core/Microsoft.StreamProcessing.Provider/Extensions0% (0 lines)
Sources/Core/Microsoft.StreamProcessing.Provider0% (0 lines)
Sources/Core/Microsoft.StreamProcessing/CacheUtilities0% (0 lines)
Sources/Core/Microsoft.StreamProcessing0% (0 lines)
Sources/Core/Microsoft.StreamProcessing/Properties0% (0 lines)
Sources/Core/Microsoft.StreamProcessing/Scheduler0% (0 lines)
Sources/Core/Microsoft.StreamProcessing/Sharding0% (0 lines)
Sources/Core/Microsoft.StreamProcessing/Streamables0% (0 lines)
ROOT0% (0 lines)
Longest Duplicates
The list of 20 longest duplicates.
See data for all 10,633 duplicates...
Size#FoldersFilesLinesCode
192 x 2 Sources/Core/Microsoft.S...rocessing/Operators/Afa
Sources/Core/Microsoft.S...rocessing/Operators/Afa
CompiledGroupedAfaPipe_MultiEventList.cs
CompiledPartitionedAfaPipe_MultiEvent...
203:534 (55%)
199:530 (53%)
view
182 x 2 Sources/Core/Microsoft.StreamProcessing/Aggregates
Sources/Core/Microsoft.StreamProcessing/Aggregates
AggregateFunctionsTemplate.cs
AggregateFunctionsTemplate.cs
3198:3560 (7%)
3770:4132 (7%)
view
171 x 2 Sources/Core/Microsoft.S...rocessing/Operators/Afa
Sources/Core/Microsoft.S...rocessing/Operators/Afa
CompiledGroupedAfaPipe_EventList.cs
CompiledPartitionedAfaPipe_EventList.cs
63:355 (72%)
60:353 (68%)
view
160 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
3682:3980 (3%)
4176:4474 (3%)
view
156 x 2 Sources/Core/Microsoft.StreamProcessing/Aggregates
Sources/Core/Microsoft.StreamProcessing/Aggregates
AggregateFunctionsTemplate.cs
AggregateFunctionsTemplate.cs
2689:2999 (6%)
3770:4080 (6%)
view
156 x 2 Sources/Core/Microsoft.StreamProcessing/Aggregates
Sources/Core/Microsoft.StreamProcessing/Aggregates
AggregateFunctionsTemplate.cs
AggregateFunctionsTemplate.cs
2689:2999 (6%)
3198:3508 (6%)
view
141 x 2 Sources/Core/Microsoft.S.../SnapshotWindow/Hopping
Sources/Core/Microsoft.S.../SnapshotWindow/Sliding
SnapshotWindowHoppingPipe.cs
SnapshotWindowSlidingPipe.cs
106:353 (60%)
105:352 (60%)
view
132 x 2 Sources/Core/Microsoft.StreamProcessing/Aggregates
Sources/Core/Microsoft.StreamProcessing/Aggregates
AggregateFunctionsTemplate.cs
AggregateFunctionsTemplate.cs
2239:2501 (5%)
3770:4032 (5%)
view
132 x 2 Sources/Core/Microsoft.StreamProcessing/Aggregates
Sources/Core/Microsoft.StreamProcessing/Aggregates
AggregateFunctionsTemplate.cs
AggregateFunctionsTemplate.cs
2239:2501 (5%)
2689:2951 (5%)
view
132 x 2 Sources/Core/Microsoft.StreamProcessing/Aggregates
Sources/Core/Microsoft.StreamProcessing/Aggregates
AggregateFunctionsTemplate.cs
AggregateFunctionsTemplate.cs
2239:2501 (5%)
3198:3460 (5%)
view
131 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
258:492 (2%)
641:875 (2%)
view
121 x 2 Sources/Core/Microsoft.S.../SnapshotWindow/Hopping
Sources/Core/Microsoft.S.../SnapshotWindow/Sliding
SnapshotWindowHoppingPipeSimple.cs
SnapshotWindowSlidingPipeSimple.cs
90:305 (66%)
89:304 (67%)
view
110 x 2 Sources/Core/Microsoft.StreamProcessing/Aggregates
Sources/Core/Microsoft.StreamProcessing/Aggregates
AggregateFunctionsTemplate.cs
AggregateFunctionsTemplate.cs
1844:2062 (4%)
3198:3416 (4%)
view
110 x 2 Sources/Core/Microsoft.StreamProcessing/Aggregates
Sources/Core/Microsoft.StreamProcessing/Aggregates
AggregateFunctionsTemplate.cs
AggregateFunctionsTemplate.cs
1844:2062 (4%)
2689:2907 (4%)
view
110 x 2 Sources/Core/Microsoft.StreamProcessing/Aggregates
Sources/Core/Microsoft.StreamProcessing/Aggregates
AggregateFunctionsTemplate.cs
AggregateFunctionsTemplate.cs
1844:2062 (4%)
2239:2457 (4%)
view
110 x 2 Sources/Core/Microsoft.StreamProcessing/Aggregates
Sources/Core/Microsoft.StreamProcessing/Aggregates
AggregateFunctionsTemplate.cs
AggregateFunctionsTemplate.cs
1844:2062 (4%)
3770:3988 (4%)
view
107 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
5147:5341 (2%)
5464:5658 (2%)
view
107 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
4808:5003 (2%)
5815:6010 (2%)
view
107 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
3822:4017 (2%)
5183:5378 (2%)
view
105 x 2 Sources/Core/Microsoft.StreamProcessing/Ingress
Sources/Core/Microsoft.StreamProcessing/Ingress
SubscriptionBase.cs
SubscriptionBase.cs
1395:1660 (10%)
2016:2281 (10%)
view
Duplicated Units
The list of top 20 duplicated units.
See data for all 195 unit duplicates...
Size#FoldersFilesLinesCode
88 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
3693:3805 
4187:4299 
view
82 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
6110:6214 
6510:6614 
view
77 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
4015:4108 
4504:4597 
view
69 x 2 Sources/Core/Microsoft.S.../SnapshotWindow/Hopping
Sources/Core/Microsoft.S.../SnapshotWindow/Sliding
PartitionedSnapshotWindowHoppingPipe.cs
PartitionedSnapshotWindowSlidingPipe.cs
319:406 
317:404 
view
67 x 2 Sources/Core/Microsoft.S.../SnapshotWindow/Hopping
Sources/Core/Microsoft.S.../SnapshotWindow/Sliding
SnapshotWindowHoppingPipe.cs
SnapshotWindowSlidingPipe.cs
257:342 
256:341 
view
58 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
1033:1106 
2832:2905 
view
58 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
2237:2310 
2536:2609 
view
58 x 2 Sources/Core/Microsoft.S.../SnapshotWindow/Hopping
Sources/Core/Microsoft.S.../SnapshotWindow/Sliding
SnapshotWindowHoppingPipeSimple.cs
SnapshotWindowSlidingPipeSimple.cs
206:277 
205:276 
view
57 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
270:342 
653:725 
view
56 x 2 Sources/Core/Microsoft.S...perators/EquiJoin/Basic
Sources/Core/Microsoft.S...perators/EquiJoin/Basic
PartitionedEquiJoinPipe.cs
PartitionedEquiJoinPipeCompound.cs
591:652 
595:656 
view
55 x 2 Sources/Core/Microsoft.S...ocessing/Operators/Clip
Sources/Core/Microsoft.S...rators/LeftAntiSemiJoin
ClipJoinPipe.cs
LeftAntiSemiJoinPipe.cs
86:151 
130:197 
view
54 x 2 Sources/Core/Microsoft.S...perators/EquiJoin/Basic
Sources/Core/Microsoft.S...perators/EquiJoin/Basic
PartitionedEquiJoinPipe.cs
PartitionedEquiJoinPipeCompound.cs
459:522 
463:526 
view
54 x 2 Sources/Core/Microsoft.S...perators/EquiJoin/Basic
Sources/Core/Microsoft.S...perators/EquiJoin/Basic
PartitionedEquiJoinPipe.cs
PartitionedEquiJoinPipeCompound.cs
525:588 
529:592 
view
49 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
525:586 
903:964 
view
44 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
6453:6497 
7473:7517 
view
41 x 2 Sources/Core/Microsoft.S...ocessing/Operators/Clip
Sources/Core/Microsoft.S...perators/EquiJoin/Basic
PartitionedClipJoinPipe.cs
PartitionedEquiJoinPipe.cs
93:137 
150:195 
view
41 x 2 Sources/Core/Microsoft.S...tors/EquiJoin/StartEdge
Sources/Core/Microsoft.S...rators/LeftAntiSemiJoin
PartitionedStartEdgeEquiJoinPipe.cs
PartitionedLeftAntiSemiJoinPipe.cs
125:170 
117:162 
view
39 x 2 Sources/Core/Microsoft.StreamProcessing/Ingress
Sources/Core/Microsoft.StreamProcessing/Ingress
SubscriptionBase.cs
SubscriptionBase.cs
1330:1373 
1951:1994 
view
39 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
2483:2522 
3265:3304 
view
37 x 2 Sources/Core/Microsoft.S...essing/Ingress/Temporal
Sources/Core/Microsoft.S...essing/Ingress/Temporal
TemporalIngressSubscription.cs
TemporalIngressSubscription.cs
6848:6885 
7706:7743 
view