{
  "metadata" : {
    "name" : "Uber / RemoteShuffleService",
    "description" : "Remote shuffle service for Apache Spark to store shuffle data on remote servers. ",
    "tooltip" : "",
    "logoLink" : "https://avatars.githubusercontent.com/Uber",
    "links" : [ {
      "label" : "GitHub Repo",
      "href" : "https://github.com/uber/RemoteShuffleService.git"
    } ]
  },
  "metricsList" : {
    "metrics" : [ {
      "id" : "TOTAL_NUMBER_OF_FILES",
      "value" : 373,
      "description" : "Total number of files in the source folder"
    }, {
      "id" : "NUMBER_OF_FILES_MAIN",
      "value" : 271,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_MAIN",
      "value" : 17066,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_MAIN_EXT_JAVA",
      "value" : 249,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_MAIN_EXT_JAVA",
      "value" : 14925,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_MAIN_EXT_SCALA",
      "value" : 22,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_MAIN_EXT_SCALA",
      "value" : 2141,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_TEST",
      "value" : 89,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_TEST",
      "value" : 11420,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_TEST_EXT_JAVA",
      "value" : 64,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_TEST_EXT_JAVA",
      "value" : 8987,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_TEST_EXT_SCALA",
      "value" : 25,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_TEST_EXT_SCALA",
      "value" : 2433,
      "description" : null
    }, {
      "id" : "TEST_VS_MAIN_LINES_OF_CODE_PERCENTAGE",
      "value" : 66.91,
      "description" : "Test / main code ratio"
    }, {
      "id" : "NUMBER_OF_FILES_GENERATED",
      "value" : 0,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_GENERATED",
      "value" : 0,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_BUILD_AND_DEPLOYMENT",
      "value" : 1,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_BUILD_AND_DEPLOYMENT",
      "value" : 518,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_BUILD_AND_DEPLOYMENT_EXT_XML",
      "value" : 1,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_BUILD_AND_DEPLOYMENT_EXT_XML",
      "value" : 518,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_OTHER",
      "value" : 3,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_OTHER",
      "value" : 87,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_OTHER_EXT_MD",
      "value" : 1,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_OTHER_EXT_MD",
      "value" : 61,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_OTHER_EXT_PROPERTIES",
      "value" : 2,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_OTHER_EXT_PROPERTIES",
      "value" : 26,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_DECOMPOSITION_PRIMARY_SRC",
      "value" : 271,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_DECOMPOSITION_PRIMARY_SRC",
      "value" : 17066,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_DECOMPOSITION_PRIMARY_SRC_EXT_JAVA",
      "value" : 249,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_DECOMPOSITION_PRIMARY_SRC_EXT_JAVA",
      "value" : 14925,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_DECOMPOSITION_PRIMARY_SRC_EXT_SCALA",
      "value" : 22,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_DECOMPOSITION_PRIMARY_SRC_EXT_SCALA",
      "value" : 2141,
      "description" : null
    }, {
      "id" : "NUMBER_OF_DEPENDENCY_LINKS_DECOMPOSITION_PRIMARY",
      "value" : 73,
      "description" : "Number of anchor dependencies"
    }, {
      "id" : "NUMBER_OF_DEPENDENCIES_DECOMPOSITION_PRIMARY",
      "value" : 0,
      "description" : null
    }, {
      "id" : "NUMBER_OF_PLACES_WITH_CYCLIC_DEPENDENCIES_DECOMPOSITION_PRIMARY",
      "value" : 0,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_CONCERN_GENERAL_TODOS",
      "value" : 24,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_CONCERN_GENERAL_TODOS",
      "value" : 4833,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_CONCERN_GENERAL_TODOS_EXT_JAVA",
      "value" : 21,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_CONCERN_GENERAL_TODOS_EXT_JAVA",
      "value" : 4136,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_CONCERN_GENERAL_TODOS_EXT_SCALA",
      "value" : 3,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_CONCERN_GENERAL_TODOS_EXT_SCALA",
      "value" : 697,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_CONCERN_GENERAL_UNCLASSIFIED",
      "value" : 247,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_CONCERN_GENERAL_UNCLASSIFIED",
      "value" : 12233,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_CONCERN_GENERAL_UNCLASSIFIED_EXT_JAVA",
      "value" : 228,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_CONCERN_GENERAL_UNCLASSIFIED_EXT_JAVA",
      "value" : 10789,
      "description" : null
    }, {
      "id" : "NUMBER_OF_FILES_CONCERN_GENERAL_UNCLASSIFIED_EXT_SCALA",
      "value" : 19,
      "description" : null
    }, {
      "id" : "LINES_OF_CODE_CONCERN_GENERAL_UNCLASSIFIED_EXT_SCALA",
      "value" : 1444,
      "description" : null
    }, {
      "id" : "NEGLIGIBLE_RISK_FILE_SIZE_COUNT",
      "value" : 227,
      "description" : "Number of  files with 100 or less lines of code"
    }, {
      "id" : "LOW_RISK_FILE_SIZE_COUNT",
      "value" : 30,
      "description" : "Number of  files with 100 to 200 lines of code"
    }, {
      "id" : "MEDIUM_RISK_FILE_SIZE_COUNT",
      "value" : 12,
      "description" : "Number of  files with 200 to 500 lines of code"
    }, {
      "id" : "HIGH_RISK_FILE_SIZE_COUNT",
      "value" : 2,
      "description" : "Number of  files with 500 to 1000 lines of code"
    }, {
      "id" : "VERY_HIGH_RISK_FILE_SIZE_COUNT",
      "value" : 0,
      "description" : "Number of  files with more than 1000 lines of code"
    }, {
      "id" : "NEGLIGIBLE_RISK_FILE_SIZE_LOC",
      "value" : 8036,
      "description" : "Lines of code in  files with 100 or less lines of code"
    }, {
      "id" : "LOW_RISK_FILE_SIZE_LOC",
      "value" : 4273,
      "description" : "Lines of code in  files with 100 to 200 lines of code"
    }, {
      "id" : "MEDIUM_RISK_FILE_SIZE_LOC",
      "value" : 3595,
      "description" : "Lines of code in  files with 200 to 500 lines of code"
    }, {
      "id" : "HIGH_RISK_FILE_SIZE_LOC",
      "value" : 1162,
      "description" : "Lines of code in  files with 500 to 1000 lines of code"
    }, {
      "id" : "VERY_HIGH_RISK_FILE_SIZE_LOC",
      "value" : 0,
      "description" : "Lines of code in  files with more than 1000 lines of code"
    }, {
      "id" : "NUMBER_OF_UNITS",
      "value" : 1545,
      "description" : "Number of units"
    }, {
      "id" : "LINES_OF_CODE_IN_UNITS",
      "value" : 12539,
      "description" : "Lines of code in units"
    }, {
      "id" : "LINES_OF_CODE_OUTSIDE_UNITS",
      "value" : 4527,
      "description" : "Lines of code in units"
    }, {
      "id" : "UNIT_SIZE_NEGLIGIBLE_RISK_LOC",
      "value" : 5623,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_NEGLIGIBLE_RISK_PERCENTAGE",
      "value" : 44.84408645027514,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_NEGLIGIBLE_RISK_COUNT",
      "value" : 1283,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_LOW_RISK_LOC",
      "value" : 2185,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_LOW_RISK_PERCENTAGE",
      "value" : 17.425632028072414,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_LOW_RISK_COUNT",
      "value" : 152,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_MEDIUM_RISK_LOC",
      "value" : 2687,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_MEDIUM_RISK_PERCENTAGE",
      "value" : 21.429141079830927,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_MEDIUM_RISK_COUNT",
      "value" : 84,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_HIGH_RISK_LOC",
      "value" : 1334,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_HIGH_RISK_PERCENTAGE",
      "value" : 10.638806922402106,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_HIGH_RISK_COUNT",
      "value" : 21,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_VERY_HIGH_RISK_LOC",
      "value" : 710,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_VERY_HIGH_RISK_PERCENTAGE",
      "value" : 5.662333519419412,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_VERY_HIGH_RISK_COUNT",
      "value" : 5,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_NEGLIGIBLE_RISK_LOC",
      "value" : 5623,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_NEGLIGIBLE_RISK_PERCENTAGE",
      "value" : 44.84408645027514,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_NEGLIGIBLE_RISK_COUNT",
      "value" : 1283,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_LOW_RISK_LOC",
      "value" : 2185,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_LOW_RISK_PERCENTAGE",
      "value" : 17.425632028072414,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_LOW_RISK_COUNT",
      "value" : 152,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_MEDIUM_RISK_LOC",
      "value" : 2687,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_MEDIUM_RISK_PERCENTAGE",
      "value" : 21.429141079830927,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_MEDIUM_RISK_COUNT",
      "value" : 84,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_HIGH_RISK_LOC",
      "value" : 1334,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_HIGH_RISK_PERCENTAGE",
      "value" : 10.638806922402106,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_HIGH_RISK_COUNT",
      "value" : 21,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_VERY_HIGH_RISK_LOC",
      "value" : 710,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_VERY_HIGH_RISK_PERCENTAGE",
      "value" : 5.662333519419412,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_COMPONENT_SRC_VERY_HIGH_RISK_COUNT",
      "value" : 5,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_NEGLIGIBLE_RISK_LOC",
      "value" : 5430,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_NEGLIGIBLE_RISK_PERCENTAGE",
      "value" : 48.68645207567471,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_NEGLIGIBLE_RISK_COUNT",
      "value" : 1239,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_LOW_RISK_LOC",
      "value" : 1959,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_LOW_RISK_PERCENTAGE",
      "value" : 17.5647807764727,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_LOW_RISK_COUNT",
      "value" : 137,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_MEDIUM_RISK_LOC",
      "value" : 2293,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_MEDIUM_RISK_PERCENTAGE",
      "value" : 20.559490719985654,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_MEDIUM_RISK_COUNT",
      "value" : 72,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_HIGH_RISK_LOC",
      "value" : 908,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_HIGH_RISK_PERCENTAGE",
      "value" : 8.14130727158612,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_HIGH_RISK_COUNT",
      "value" : 14,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_VERY_HIGH_RISK_LOC",
      "value" : 563,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_VERY_HIGH_RISK_PERCENTAGE",
      "value" : 5.047969156280821,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_JAVA_VERY_HIGH_RISK_COUNT",
      "value" : 4,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_NEGLIGIBLE_RISK_LOC",
      "value" : 193,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_NEGLIGIBLE_RISK_PERCENTAGE",
      "value" : 13.924963924963924,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_NEGLIGIBLE_RISK_COUNT",
      "value" : 44,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_LOW_RISK_LOC",
      "value" : 226,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_LOW_RISK_PERCENTAGE",
      "value" : 16.305916305916305,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_LOW_RISK_COUNT",
      "value" : 15,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_MEDIUM_RISK_LOC",
      "value" : 394,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_MEDIUM_RISK_PERCENTAGE",
      "value" : 28.427128427128427,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_MEDIUM_RISK_COUNT",
      "value" : 12,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_HIGH_RISK_LOC",
      "value" : 426,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_HIGH_RISK_PERCENTAGE",
      "value" : 30.735930735930737,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_HIGH_RISK_COUNT",
      "value" : 7,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_VERY_HIGH_RISK_LOC",
      "value" : 147,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_VERY_HIGH_RISK_PERCENTAGE",
      "value" : 10.606060606060606,
      "description" : null
    }, {
      "id" : "UNIT_SIZE_EXTENSION_SCALA_VERY_HIGH_RISK_COUNT",
      "value" : 1,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_NEGLIGIBLE_RISK_LOC",
      "value" : 8978,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_NEGLIGIBLE_RISK_PERCENTAGE",
      "value" : 71.60060610894011,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_NEGLIGIBLE_RISK_COUNT",
      "value" : 1464,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_LOW_RISK_LOC",
      "value" : 2037,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_LOW_RISK_PERCENTAGE",
      "value" : 16.245314618390623,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_LOW_RISK_COUNT",
      "value" : 63,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_MEDIUM_RISK_LOC",
      "value" : 1290,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_MEDIUM_RISK_PERCENTAGE",
      "value" : 10.287901746550762,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_MEDIUM_RISK_COUNT",
      "value" : 16,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_HIGH_RISK_LOC",
      "value" : 234,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_HIGH_RISK_PERCENTAGE",
      "value" : 1.8661775261185103,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_HIGH_RISK_COUNT",
      "value" : 2,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_VERY_HIGH_RISK_LOC",
      "value" : 0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_VERY_HIGH_RISK_PERCENTAGE",
      "value" : 0.0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_VERY_HIGH_RISK_COUNT",
      "value" : 0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_HIGH_PLUS_RISK_COUNT",
      "value" : 2,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_HIGH_PLUS_RISK_LOC",
      "value" : 234,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_NEGLIGIBLE_RISK_LOC",
      "value" : 8978,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_NEGLIGIBLE_RISK_PERCENTAGE",
      "value" : 71.60060610894011,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_NEGLIGIBLE_RISK_COUNT",
      "value" : 1464,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_LOW_RISK_LOC",
      "value" : 2037,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_LOW_RISK_PERCENTAGE",
      "value" : 16.245314618390623,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_LOW_RISK_COUNT",
      "value" : 63,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_MEDIUM_RISK_LOC",
      "value" : 1290,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_MEDIUM_RISK_PERCENTAGE",
      "value" : 10.287901746550762,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_MEDIUM_RISK_COUNT",
      "value" : 16,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_HIGH_RISK_LOC",
      "value" : 234,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_HIGH_RISK_PERCENTAGE",
      "value" : 1.8661775261185103,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_HIGH_RISK_COUNT",
      "value" : 2,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_VERY_HIGH_RISK_LOC",
      "value" : 0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_VERY_HIGH_RISK_PERCENTAGE",
      "value" : 0.0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SRC_VERY_HIGH_RISK_COUNT",
      "value" : 0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_NEGLIGIBLE_RISK_LOC",
      "value" : 8191,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_NEGLIGIBLE_RISK_PERCENTAGE",
      "value" : 73.44212319555277,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_NEGLIGIBLE_RISK_COUNT",
      "value" : 1395,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_LOW_RISK_LOC",
      "value" : 1585,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_LOW_RISK_PERCENTAGE",
      "value" : 14.21142293553304,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_LOW_RISK_COUNT",
      "value" : 54,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_MEDIUM_RISK_LOC",
      "value" : 1143,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_MEDIUM_RISK_PERCENTAGE",
      "value" : 10.248363668967992,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_MEDIUM_RISK_COUNT",
      "value" : 15,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_HIGH_RISK_LOC",
      "value" : 234,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_HIGH_RISK_PERCENTAGE",
      "value" : 2.0980901999462027,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_HIGH_RISK_COUNT",
      "value" : 2,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_VERY_HIGH_RISK_LOC",
      "value" : 0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_VERY_HIGH_RISK_PERCENTAGE",
      "value" : 0.0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_JAVA_VERY_HIGH_RISK_COUNT",
      "value" : 0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_NEGLIGIBLE_RISK_LOC",
      "value" : 787,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_NEGLIGIBLE_RISK_PERCENTAGE",
      "value" : 56.78210678210678,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_NEGLIGIBLE_RISK_COUNT",
      "value" : 69,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_LOW_RISK_LOC",
      "value" : 452,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_LOW_RISK_PERCENTAGE",
      "value" : 32.61183261183261,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_LOW_RISK_COUNT",
      "value" : 9,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_MEDIUM_RISK_LOC",
      "value" : 147,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_MEDIUM_RISK_PERCENTAGE",
      "value" : 10.606060606060606,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_MEDIUM_RISK_COUNT",
      "value" : 1,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_HIGH_RISK_LOC",
      "value" : 0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_HIGH_RISK_PERCENTAGE",
      "value" : 0.0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_HIGH_RISK_COUNT",
      "value" : 0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_VERY_HIGH_RISK_LOC",
      "value" : 0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_VERY_HIGH_RISK_PERCENTAGE",
      "value" : 0.0,
      "description" : null
    }, {
      "id" : "CONDITIONAL_COMPLEXITY_COMPONENT_SCALA_VERY_HIGH_RISK_COUNT",
      "value" : 0,
      "description" : null
    }, {
      "id" : "FILE_CHANGE_HISTORY_TOTAL_AGE_DAYS",
      "value" : 1323,
      "description" : "The age of the repository in days"
    }, {
      "id" : "FILE_CHANGE_HISTORY_ACTIVE_DAYS",
      "value" : 47,
      "description" : "The number of days with at least one file change"
    }, {
      "id" : "FILE_CHANGE_HISTORY_WEEKS",
      "value" : 127,
      "description" : "The number of weeks"
    }, {
      "id" : "FILE_CHANGE_HISTORY_ESTIMATED_WORKING_DAYS",
      "value" : 635,
      "description" : "The number of estimated working days in the period"
    }, {
      "id" : "FILE_AGE_NEGLIGIBLE_RISK_COUNT",
      "value" : 0,
      "description" : "Number of files 1-30 days days old"
    }, {
      "id" : "FILE_AGE_LOW_RISK_COUNT",
      "value" : 0,
      "description" : "Number of files 31-90 days days old"
    }, {
      "id" : "FILE_AGE_MEDIUM_RISK_COUNT",
      "value" : 0,
      "description" : "Number of files 91-180 days days old"
    }, {
      "id" : "FILE_AGE_HIGH_RISK_COUNT",
      "value" : 0,
      "description" : "Number of files 181-365 days days old"
    }, {
      "id" : "FILE_AGE_VERY_HIGH_RISK_COUNT",
      "value" : 271,
      "description" : "Number of files 366+ days days old"
    }, {
      "id" : "FILE_AGE_NEGLIGIBLE_RISK_LOC",
      "value" : 0,
      "description" : "Number of files 1-30 days days old"
    }, {
      "id" : "FILE_AGE_LOW_RISK_LOC",
      "value" : 0,
      "description" : "Number of files 31-90 days days old"
    }, {
      "id" : "FILE_AGE_MEDIUM_RISK_LOC",
      "value" : 0,
      "description" : "Number of files 91-180 days days old"
    }, {
      "id" : "FILE_AGE_HIGH_RISK_LOC",
      "value" : 0,
      "description" : "Number of files 181-365 days days old"
    }, {
      "id" : "FILE_AGE_VERY_HIGH_RISK_LOC",
      "value" : 17066,
      "description" : "Number of files 366+ days days old"
    }, {
      "id" : "NUMBER_OF_CONTRIBUTORS",
      "value" : 8,
      "description" : "Number of contributors"
    }, {
      "id" : "DUPLICATION_NUMBER_OF_DUPLICATES",
      "value" : 100,
      "description" : "Number of duplicates"
    }, {
      "id" : "DUPLICATION_NUMBER_OF_FILES_WITH_DUPLICATES",
      "value" : 59,
      "description" : "Number of files with duplicates"
    }, {
      "id" : "DUPLICATION_NUMBER_OF_DUPLICATED_LINES",
      "value" : 1037,
      "description" : "Number of duplicated lines"
    }, {
      "id" : "DUPLICATION_NUMBER_OF_CLEANED_LINES",
      "value" : 12304,
      "description" : "Number of lines after cleaning for duplication calculations"
    }, {
      "id" : "DUPLICATION_PERCENTAGE",
      "value" : 8.42815344603381,
      "description" : "Duplication percentage"
    }, {
      "id" : "UNIT_DUPLICATES_COUNT",
      "value" : 11,
      "description" : "Unit duplicates"
    }, {
      "id" : "DUPLICATION_NUMBER_OF_DUPLICATED_LINES_PRIMARY_SRC",
      "value" : 1037,
      "description" : "Number of duplicated lines"
    }, {
      "id" : "DUPLICATION_NUMBER_OF_CLEANED_LINES_PRIMARY_SRC",
      "value" : 1037,
      "description" : "Number of lines after cleaning for duplication calculations"
    }, {
      "id" : "DUPLICATION_PERCENTAGE_PRIMARY_SRC",
      "value" : 100.0,
      "description" : "Duplication percentage"
    }, {
      "id" : "DUPLICATION_NUMBER_OF_DUPLICATED_LINES_JAVA",
      "value" : 969,
      "description" : "Number of duplicated lines"
    }, {
      "id" : "DUPLICATION_NUMBER_OF_CLEANED_LINES_JAVA",
      "value" : 10619,
      "description" : "Number of lines after cleaning for duplication calculations"
    }, {
      "id" : "DUPLICATION_PERCENTAGE_JAVA",
      "value" : 9.125153027592052,
      "description" : "Duplication percentage"
    }, {
      "id" : "DUPLICATION_NUMBER_OF_DUPLICATED_LINES_SCALA",
      "value" : 68,
      "description" : "Number of duplicated lines"
    }, {
      "id" : "DUPLICATION_NUMBER_OF_CLEANED_LINES_SCALA",
      "value" : 1685,
      "description" : "Number of lines after cleaning for duplication calculations"
    }, {
      "id" : "DUPLICATION_PERCENTAGE_SCALA",
      "value" : 4.035608308605341,
      "description" : "Duplication percentage"
    }, {
      "id" : "TOTAL_ANALYSIS_TIME_IN_MILLIS",
      "value" : 1079,
      "description" : "Total analysis time in milliseconds"
    } ]
  },
  "controlResults" : {
    "goalsAnalysisResults" : [ {
      "metricsWithGoal" : {
        "goal" : "Keep the system simple and easy to change",
        "description" : "Aim at keeping the system size modest (less than 200,000 LOC is good), duplication low (less than 5% is good), files small (no files longer than 1000 LOC is good), and units simple (no units with more than 25 decision points is good).",
        "controls" : [ {
          "metric" : "LINES_OF_CODE_MAIN",
          "description" : "Total number of lines of main code",
          "desiredRange" : {
            "min" : "0",
            "max" : "200000",
            "tolerance" : "20000"
          }
        }, {
          "metric" : "DUPLICATION_PERCENTAGE",
          "description" : "System duplication",
          "desiredRange" : {
            "min" : "0",
            "max" : "5",
            "tolerance" : "1"
          }
        }, {
          "metric" : "VERY_HIGH_RISK_FILE_SIZE_COUNT",
          "description" : "The number of very large files",
          "desiredRange" : {
            "min" : "0",
            "max" : "0",
            "tolerance" : "1"
          }
        }, {
          "metric" : "CONDITIONAL_COMPLEXITY_VERY_HIGH_RISK_COUNT",
          "description" : "Number of very complex units",
          "desiredRange" : {
            "min" : "0",
            "max" : "0",
            "tolerance" : "1"
          }
        } ]
      },
      "controlStatuses" : [ {
        "control" : {
          "metric" : "LINES_OF_CODE_MAIN",
          "description" : "Total number of lines of main code",
          "desiredRange" : {
            "min" : "0",
            "max" : "200000",
            "tolerance" : "20000"
          }
        },
        "metric" : {
          "id" : "LINES_OF_CODE_MAIN",
          "value" : 17066,
          "description" : null
        },
        "status" : "OK"
      }, {
        "control" : {
          "metric" : "DUPLICATION_PERCENTAGE",
          "description" : "System duplication",
          "desiredRange" : {
            "min" : "0",
            "max" : "5",
            "tolerance" : "1"
          }
        },
        "metric" : {
          "id" : "DUPLICATION_PERCENTAGE",
          "value" : 8.42815344603381,
          "description" : "Duplication percentage"
        },
        "status" : "FAILED"
      }, {
        "control" : {
          "metric" : "VERY_HIGH_RISK_FILE_SIZE_COUNT",
          "description" : "The number of very large files",
          "desiredRange" : {
            "min" : "0",
            "max" : "0",
            "tolerance" : "1"
          }
        },
        "metric" : {
          "id" : "VERY_HIGH_RISK_FILE_SIZE_COUNT",
          "value" : 0,
          "description" : "Number of  files with more than 1000 lines of code"
        },
        "status" : "OK"
      }, {
        "control" : {
          "metric" : "CONDITIONAL_COMPLEXITY_VERY_HIGH_RISK_COUNT",
          "description" : "Number of very complex units",
          "desiredRange" : {
            "min" : "0",
            "max" : "0",
            "tolerance" : "1"
          }
        },
        "metric" : {
          "id" : "CONDITIONAL_COMPLEXITY_VERY_HIGH_RISK_COUNT",
          "value" : 0,
          "description" : null
        },
        "status" : "OK"
      } ]
    } ]
  },
  "totalNumberOfFilesInScope" : 373,
  "mainAspectAnalysisResults" : {
    "name" : null,
    "filesCount" : 271,
    "linesOfCode" : 17066,
    "numberOfRegexLineMatches" : 0,
    "fileCountPerExtension" : [ {
      "name" : "  *.java",
      "value" : 249,
      "description" : [ ]
    }, {
      "name" : "  *.scala",
      "value" : 22,
      "description" : [ ]
    } ],
    "linesOfCodePerExtension" : [ {
      "name" : "  *.java",
      "value" : 14925,
      "description" : [ ]
    }, {
      "name" : "  *.scala",
      "value" : 2141,
      "description" : [ ]
    } ]
  },
  "testAspectAnalysisResults" : {
    "name" : null,
    "filesCount" : 89,
    "linesOfCode" : 11420,
    "numberOfRegexLineMatches" : 0,
    "fileCountPerExtension" : [ {
      "name" : "  *.java",
      "value" : 64,
      "description" : [ ]
    }, {
      "name" : "  *.scala",
      "value" : 25,
      "description" : [ ]
    } ],
    "linesOfCodePerExtension" : [ {
      "name" : "  *.java",
      "value" : 8987,
      "description" : [ ]
    }, {
      "name" : "  *.scala",
      "value" : 2433,
      "description" : [ ]
    } ]
  },
  "generatedAspectAnalysisResults" : {
    "name" : null,
    "filesCount" : 0,
    "linesOfCode" : 0,
    "numberOfRegexLineMatches" : 0,
    "fileCountPerExtension" : [ ],
    "linesOfCodePerExtension" : [ ]
  },
  "buildAndDeployAspectAnalysisResults" : {
    "name" : null,
    "filesCount" : 1,
    "linesOfCode" : 518,
    "numberOfRegexLineMatches" : 0,
    "fileCountPerExtension" : [ {
      "name" : "  *.xml",
      "value" : 1,
      "description" : [ ]
    } ],
    "linesOfCodePerExtension" : [ {
      "name" : "  *.xml",
      "value" : 518,
      "description" : [ ]
    } ]
  },
  "otherAspectAnalysisResults" : {
    "name" : null,
    "filesCount" : 3,
    "linesOfCode" : 87,
    "numberOfRegexLineMatches" : 0,
    "fileCountPerExtension" : [ {
      "name" : "  *.md",
      "value" : 1,
      "description" : [ ]
    }, {
      "name" : "  *.properties",
      "value" : 2,
      "description" : [ ]
    } ],
    "linesOfCodePerExtension" : [ {
      "name" : "  *.md",
      "value" : 61,
      "description" : [ ]
    }, {
      "name" : "  *.properties",
      "value" : 26,
      "description" : [ ]
    } ]
  },
  "logicalDecompositionsAnalysisResults" : [ {
    "key" : "primary",
    "components" : [ {
      "name" : "src",
      "filesCount" : 271,
      "linesOfCode" : 17066,
      "numberOfRegexLineMatches" : 0,
      "fileCountPerExtension" : [ {
        "name" : "  *.java",
        "value" : 249,
        "description" : [ ]
      }, {
        "name" : "  *.scala",
        "value" : 22,
        "description" : [ ]
      } ],
      "linesOfCodePerExtension" : [ {
        "name" : "  *.java",
        "value" : 14925,
        "description" : [ ]
      }, {
        "name" : "  *.scala",
        "value" : 2141,
        "description" : [ ]
      } ]
    } ],
    "componentDependencies" : [ ],
    "componentDependenciesErrors" : [ ],
    "logicalDecomposition" : {
      "name" : "primary",
      "scope" : "main",
      "filters" : [ ],
      "componentsFolderDepth" : 1,
      "minComponentsCount" : 0,
      "components" : [ {
        "name" : "src",
        "sourceFileFilters" : [ {
          "pathPattern" : "./src/.*",
          "contentPattern" : "",
          "exception" : false,
          "note" : ""
        } ],
        "files" : [ ]
      } ],
      "metaComponents" : [ ],
      "groups" : [ ],
      "includeRemainingFiles" : true,
      "dependenciesFinder" : {
        "useBuiltInDependencyFinders" : true,
        "rules" : [ ],
        "metaRules" : [ ]
      },
      "renderingOptions" : {
        "orientation" : "TB",
        "maxNumberOfDependencies" : 100,
        "renderComponentsWithoutDependencies" : true,
        "renderIndirectDependencies" : false,
        "renderInternalIndirectDependencies" : false,
        "reverseDirection" : false
      },
      "includeExternalComponents" : true,
      "dependencyLinkThreshold" : 1,
      "duplicationLinkThreshold" : 50,
      "temporalLinkThreshold" : 1,
      "maxSearchDepthLines" : 200
    },
    "linesOfCodePerComponent" : [ {
      "name" : "src",
      "value" : 17066,
      "description" : [ ]
    } ],
    "fileCountPerComponent" : [ {
      "name" : "src",
      "value" : 271,
      "description" : [ ]
    } ]
  } ],
  "concernsAnalysisResults" : [ {
    "key" : "general",
    "concerns" : [ {
      "name" : "TODOs",
      "filesCount" : 24,
      "linesOfCode" : 4833,
      "numberOfRegexLineMatches" : 35,
      "fileCountPerExtension" : [ {
        "name" : "  *.java",
        "value" : 21,
        "description" : [ ]
      }, {
        "name" : "  *.scala",
        "value" : 3,
        "description" : [ ]
      } ],
      "linesOfCodePerExtension" : [ {
        "name" : "  *.java",
        "value" : 4136,
        "description" : [ ]
      }, {
        "name" : "  *.scala",
        "value" : 697,
        "description" : [ ]
      } ]
    }, {
      "name" : "Unclassified",
      "filesCount" : 247,
      "linesOfCode" : 12233,
      "numberOfRegexLineMatches" : 0,
      "fileCountPerExtension" : [ {
        "name" : "  *.java",
        "value" : 228,
        "description" : [ ]
      }, {
        "name" : "  *.scala",
        "value" : 19,
        "description" : [ ]
      } ],
      "linesOfCodePerExtension" : [ {
        "name" : "  *.java",
        "value" : 10789,
        "description" : [ ]
      }, {
        "name" : "  *.scala",
        "value" : 1444,
        "description" : [ ]
      } ]
    } ],
    "concernsGroup" : null,
    "fileCountPerConcern" : [ {
      "name" : "TODOs",
      "value" : 24,
      "description" : [ ]
    }, {
      "name" : "Unclassified",
      "value" : 247,
      "description" : [ ]
    } ],
    "linesOfCodePerConcern" : [ {
      "name" : "TODOs",
      "value" : 4833,
      "description" : [ ]
    }, {
      "name" : "Unclassified",
      "value" : 12233,
      "description" : [ ]
    } ]
  } ],
  "foundTags" : [ {
    "tagRule" : {
      "tag" : "travis",
      "color" : "#7CB9E8",
      "pathPatterns" : [ "(|.*/)[.]travis[.]ya?ml" ],
      "excludePathPatterns" : [ ]
    },
    "evidence" : ".travis.yml"
  }, {
    "tagRule" : {
      "tag" : "github actions",
      "color" : "#7CB9E8",
      "pathPatterns" : [ "(|.*/)[.]github[/]workflows[/].*" ],
      "excludePathPatterns" : [ ]
    },
    "evidence" : ".github/workflows/maven.yml"
  }, {
    "tagRule" : {
      "tag" : "maven",
      "color" : "#B9D9EB",
      "pathPatterns" : [ "(|.*/)pom[.]xml" ],
      "excludePathPatterns" : [ ]
    },
    "evidence" : "pom.xml"
  } ],
  "filesAnalysisResults" : {
    "overallFileSizeDistribution" : {
      "key" : "",
      "lowRiskThreshold" : 100,
      "mediumRiskThreshold" : 200,
      "highRiskThreshold" : 500,
      "veryHighRiskThreshold" : 1000,
      "negligibleRiskValue" : 8036,
      "lowRiskValue" : 4273,
      "mediumRiskValue" : 3595,
      "highRiskValue" : 1162,
      "veryHighRiskValue" : 0,
      "lowRiskCount" : 30,
      "negligibleRiskCount" : 227,
      "mediumRiskCount" : 12,
      "highRiskCount" : 2,
      "veryHighRiskCount" : 0,
      "negligibleRiskLabel" : "1-100",
      "lowRiskLabel" : "101-200",
      "mediumRiskLabel" : "201-500",
      "highRiskLabel" : "501-1000",
      "veryHighRiskLabel" : "1001+",
      "negligibleRiskPercentage" : 47.08777686628384,
      "veryHighRiskPercentage" : 0.0,
      "highRiskPercentage" : 6.808859721082855,
      "mediumRiskPercentage" : 21.065275987343256,
      "lowRiskPercentage" : 25.03808742529005,
      "totalValue" : 17066,
      "totalCount" : 271
    },
    "fileSizeDistributionPerExtension" : [ {
      "key" : "java",
      "lowRiskThreshold" : 100,
      "mediumRiskThreshold" : 200,
      "highRiskThreshold" : 500,
      "veryHighRiskThreshold" : 1000,
      "negligibleRiskValue" : 7528,
      "lowRiskValue" : 3352,
      "mediumRiskValue" : 2883,
      "highRiskValue" : 1162,
      "veryHighRiskValue" : 0,
      "lowRiskCount" : 24,
      "negligibleRiskCount" : 213,
      "mediumRiskCount" : 10,
      "highRiskCount" : 2,
      "veryHighRiskCount" : 0,
      "negligibleRiskLabel" : "1-100",
      "lowRiskLabel" : "101-200",
      "mediumRiskLabel" : "201-500",
      "highRiskLabel" : "501-1000",
      "veryHighRiskLabel" : "1001+",
      "negligibleRiskPercentage" : 50.438860971524285,
      "veryHighRiskPercentage" : 0.0,
      "highRiskPercentage" : 7.785594639865996,
      "mediumRiskPercentage" : 19.316582914572866,
      "lowRiskPercentage" : 22.45896147403685,
      "totalValue" : 14925,
      "totalCount" : 249
    }, {
      "key" : "scala",
      "lowRiskThreshold" : 100,
      "mediumRiskThreshold" : 200,
      "highRiskThreshold" : 500,
      "veryHighRiskThreshold" : 1000,
      "negligibleRiskValue" : 508,
      "lowRiskValue" : 921,
      "mediumRiskValue" : 712,
      "highRiskValue" : 0,
      "veryHighRiskValue" : 0,
      "lowRiskCount" : 6,
      "negligibleRiskCount" : 14,
      "mediumRiskCount" : 2,
      "highRiskCount" : 0,
      "veryHighRiskCount" : 0,
      "negligibleRiskLabel" : "1-100",
      "lowRiskLabel" : "101-200",
      "mediumRiskLabel" : "201-500",
      "highRiskLabel" : "501-1000",
      "veryHighRiskLabel" : "1001+",
      "negligibleRiskPercentage" : 23.727230266230734,
      "veryHighRiskPercentage" : 0.0,
      "highRiskPercentage" : 0.0,
      "mediumRiskPercentage" : 33.25548808967772,
      "lowRiskPercentage" : 43.01728164409155,
      "totalValue" : 2141,
      "totalCount" : 22
    } ],
    "fileSizeDistributionPerLogicalDecomposition" : [ {
      "name" : "primary",
      "fileSizeDistributionPerComponent" : [ {
        "key" : "src",
        "lowRiskThreshold" : 100,
        "mediumRiskThreshold" : 200,
        "highRiskThreshold" : 500,
        "veryHighRiskThreshold" : 1000,
        "negligibleRiskValue" : 8036,
        "lowRiskValue" : 4273,
        "mediumRiskValue" : 3595,
        "highRiskValue" : 1162,
        "veryHighRiskValue" : 0,
        "lowRiskCount" : 30,
        "negligibleRiskCount" : 227,
        "mediumRiskCount" : 12,
        "highRiskCount" : 2,
        "veryHighRiskCount" : 0,
        "negligibleRiskLabel" : "1-100",
        "lowRiskLabel" : "101-200",
        "mediumRiskLabel" : "201-500",
        "highRiskLabel" : "501-1000",
        "veryHighRiskLabel" : "1001+",
        "negligibleRiskPercentage" : 47.08777686628384,
        "veryHighRiskPercentage" : 0.0,
        "highRiskPercentage" : 6.808859721082855,
        "mediumRiskPercentage" : 21.065275987343256,
        "lowRiskPercentage" : 25.03808742529005,
        "totalValue" : 17066,
        "totalCount" : 271
      } ]
    } ],
    "longestFiles" : [ {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
      "extension" : "java",
      "linesOfCode" : 615,
      "unitsCount" : 36,
      "unitsMcCabeIndexSum" : 101,
      "linesOfCodeInUnits" : 524
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
      "extension" : "java",
      "linesOfCode" : 547,
      "unitsCount" : 31,
      "unitsMcCabeIndexSum" : 85,
      "linesOfCodeInUnits" : 486
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedReadClient.java",
      "extension" : "java",
      "linesOfCode" : 365,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 63,
      "linesOfCodeInUnits" : 312
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
      "extension" : "scala",
      "linesOfCode" : 364,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 35,
      "linesOfCodeInUnits" : 311
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssStressTool.scala",
      "extension" : "scala",
      "linesOfCode" : 348,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 31,
      "linesOfCodeInUnits" : 287
    }, {
      "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerMessageDecoder.java",
      "extension" : "java",
      "linesOfCode" : 347,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 57,
      "linesOfCodeInUnits" : 278
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 332,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 56,
      "linesOfCodeInUnits" : 260
    }, {
      "relativePath" : "src/main/java/com/uber/rss/StreamServer.java",
      "extension" : "java",
      "linesOfCode" : 303,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 43,
      "linesOfCodeInUnits" : 251
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 299,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 50,
      "linesOfCodeInUnits" : 236
    }, {
      "relativePath" : "src/main/java/com/uber/rss/StreamServerConfig.java",
      "extension" : "java",
      "linesOfCode" : 283,
      "unitsCount" : 50,
      "unitsMcCabeIndexSum" : 77,
      "linesOfCodeInUnits" : 234
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ClientBase.java",
      "extension" : "java",
      "linesOfCode" : 268,
      "unitsCount" : 17,
      "unitsMcCabeIndexSum" : 47,
      "linesOfCodeInUnits" : 214
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/PooledWriteClientFactory.java",
      "extension" : "java",
      "linesOfCode" : 253,
      "unitsCount" : 30,
      "unitsMcCabeIndexSum" : 52,
      "linesOfCodeInUnits" : 202
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ExecutorShuffleStageState.java",
      "extension" : "java",
      "linesOfCode" : 229,
      "unitsCount" : 27,
      "unitsMcCabeIndexSum" : 49,
      "linesOfCodeInUnits" : 194
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/LocalFileStateStore.java",
      "extension" : "java",
      "linesOfCode" : 204,
      "unitsCount" : 15,
      "unitsMcCabeIndexSum" : 28,
      "linesOfCodeInUnits" : 153
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ZooKeeperServiceRegistry.java",
      "extension" : "java",
      "linesOfCode" : 191,
      "unitsCount" : 15,
      "unitsMcCabeIndexSum" : 36,
      "linesOfCodeInUnits" : 158
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 184,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 20,
      "linesOfCodeInUnits" : 127
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleWriter.scala",
      "extension" : "scala",
      "linesOfCode" : 181,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 124
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssOpts.scala",
      "extension" : "scala",
      "linesOfCode" : 175,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRangeRecordIterator.scala",
      "extension" : "scala",
      "linesOfCode" : 175,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 124
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRecordIterator.scala",
      "extension" : "scala",
      "linesOfCode" : 174,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 22,
      "linesOfCodeInUnits" : 106
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/LocalFileStateStoreIterator.java",
      "extension" : "java",
      "linesOfCode" : 173,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 29,
      "linesOfCodeInUnits" : 120
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/SerializerBenchmark.java",
      "extension" : "java",
      "linesOfCode" : 164,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 134
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 160,
      "unitsCount" : 14,
      "unitsMcCabeIndexSum" : 24,
      "linesOfCodeInUnits" : 114
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 159,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 19,
      "linesOfCodeInUnits" : 111
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamReadClientVerify.java",
      "extension" : "java",
      "linesOfCode" : 156,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 25,
      "linesOfCodeInUnits" : 119
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 155,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 114
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 153,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 33,
      "linesOfCodeInUnits" : 122
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ServiceRegistryUtils.java",
      "extension" : "java",
      "linesOfCode" : 151,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 123
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 149,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 118
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShufflePartitionWriter.java",
      "extension" : "java",
      "linesOfCode" : 147,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 26,
      "linesOfCodeInUnits" : 111
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 142,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 110
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/FsyncPerfTest.java",
      "extension" : "java",
      "linesOfCode" : 131,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 99
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerIdAwareSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 127,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 19,
      "linesOfCodeInUnits" : 95
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/FileUtils.java",
      "extension" : "java",
      "linesOfCode" : 119,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 26,
      "linesOfCodeInUnits" : 98
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressToolLongRun.java",
      "extension" : "java",
      "linesOfCode" : 118,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 97
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/StreamDecoderBase.java",
      "extension" : "java",
      "linesOfCode" : 117,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 27,
      "linesOfCodeInUnits" : 104
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerHeartbeatClient.java",
      "extension" : "java",
      "linesOfCode" : 115,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 25,
      "linesOfCodeInUnits" : 89
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/PooledShuffleDataSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 113,
      "unitsCount" : 16,
      "unitsMcCabeIndexSum" : 22,
      "linesOfCodeInUnits" : 85
    }, {
      "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerVersionDecoder.java",
      "extension" : "java",
      "linesOfCode" : 113,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 86
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssSparkListener.scala",
      "extension" : "scala",
      "linesOfCode" : 111,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 23,
      "linesOfCodeInUnits" : 86
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/M3Stats.java",
      "extension" : "java",
      "linesOfCode" : 106,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 69
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerBusyRetriableWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 106,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterBufferManager.scala",
      "extension" : "scala",
      "linesOfCode" : 105,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 77
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 103,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterAggregationImpl.scala",
      "extension" : "scala",
      "linesOfCode" : 99,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 65
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/PartitionFileChecker.java",
      "extension" : "java",
      "linesOfCode" : 98,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/ScheduledMetricCollector.java",
      "extension" : "java",
      "linesOfCode" : 97,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 60
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/RetryUtils.java",
      "extension" : "java",
      "linesOfCode" : 96,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 19,
      "linesOfCodeInUnits" : 86
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/StringUtils.java",
      "extension" : "java",
      "linesOfCode" : 95,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 25,
      "linesOfCodeInUnits" : 87
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ServiceRegistryWrapper.java",
      "extension" : "java",
      "linesOfCode" : 93,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 68
    } ],
    "filesWithMostUnits" : [ {
      "relativePath" : "src/main/java/com/uber/rss/StreamServerConfig.java",
      "extension" : "java",
      "linesOfCode" : 283,
      "unitsCount" : 50,
      "unitsMcCabeIndexSum" : 77,
      "linesOfCodeInUnits" : 234
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
      "extension" : "java",
      "linesOfCode" : 615,
      "unitsCount" : 36,
      "unitsMcCabeIndexSum" : 101,
      "linesOfCodeInUnits" : 524
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
      "extension" : "java",
      "linesOfCode" : 547,
      "unitsCount" : 31,
      "unitsMcCabeIndexSum" : 85,
      "linesOfCodeInUnits" : 486
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/PooledWriteClientFactory.java",
      "extension" : "java",
      "linesOfCode" : 253,
      "unitsCount" : 30,
      "unitsMcCabeIndexSum" : 52,
      "linesOfCodeInUnits" : 202
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ExecutorShuffleStageState.java",
      "extension" : "java",
      "linesOfCode" : 229,
      "unitsCount" : 27,
      "unitsMcCabeIndexSum" : 49,
      "linesOfCodeInUnits" : 194
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 332,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 56,
      "linesOfCodeInUnits" : 260
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedReadClient.java",
      "extension" : "java",
      "linesOfCode" : 365,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 63,
      "linesOfCodeInUnits" : 312
    }, {
      "relativePath" : "src/main/java/com/uber/rss/StreamServer.java",
      "extension" : "java",
      "linesOfCode" : 303,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 43,
      "linesOfCodeInUnits" : 251
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ClientBase.java",
      "extension" : "java",
      "linesOfCode" : 268,
      "unitsCount" : 17,
      "unitsMcCabeIndexSum" : 47,
      "linesOfCodeInUnits" : 214
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/PooledShuffleDataSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 113,
      "unitsCount" : 16,
      "unitsMcCabeIndexSum" : 22,
      "linesOfCodeInUnits" : 85
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/LocalFileStateStore.java",
      "extension" : "java",
      "linesOfCode" : 204,
      "unitsCount" : 15,
      "unitsMcCabeIndexSum" : 28,
      "linesOfCodeInUnits" : 153
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ZooKeeperServiceRegistry.java",
      "extension" : "java",
      "linesOfCode" : 191,
      "unitsCount" : 15,
      "unitsMcCabeIndexSum" : 36,
      "linesOfCodeInUnits" : 158
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ShuffleDataSyncWriteClientBase.java",
      "extension" : "java",
      "linesOfCode" : 86,
      "unitsCount" : 14,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 60
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 160,
      "unitsCount" : 14,
      "unitsMcCabeIndexSum" : 24,
      "linesOfCodeInUnits" : 114
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/AppTaskAttemptId.java",
      "extension" : "java",
      "linesOfCode" : 71,
      "unitsCount" : 14,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 59
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 299,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 50,
      "linesOfCodeInUnits" : 236
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShufflePartitionWriter.java",
      "extension" : "java",
      "linesOfCode" : 147,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 26,
      "linesOfCodeInUnits" : 111
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/MockTaskContext.scala",
      "extension" : "scala",
      "linesOfCode" : 50,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 35
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerHeartbeatClient.java",
      "extension" : "java",
      "linesOfCode" : 115,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 25,
      "linesOfCodeInUnits" : 89
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 153,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 33,
      "linesOfCodeInUnits" : 122
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequest.java",
      "extension" : "java",
      "linesOfCode" : 85,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 67
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequestMessage.java",
      "extension" : "java",
      "linesOfCode" : 89,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 71
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/StartUploadMessage.java",
      "extension" : "java",
      "linesOfCode" : 78,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 63
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/FixedLengthInputStream.java",
      "extension" : "java",
      "linesOfCode" : 86,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 68
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 103,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadResponse.java",
      "extension" : "java",
      "linesOfCode" : 81,
      "unitsCount" : 11,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 66
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/FinishApplicationJobRequestMessage.java",
      "extension" : "java",
      "linesOfCode" : 70,
      "unitsCount" : 11,
      "unitsMcCabeIndexSum" : 11,
      "linesOfCodeInUnits" : 56
    }, {
      "relativePath" : "src/main/java/com/uber/rss/storage/ShuffleFileStorage.java",
      "extension" : "java",
      "linesOfCode" : 82,
      "unitsCount" : 11,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 54
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerIdAwareSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 127,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 19,
      "linesOfCodeInUnits" : 95
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 142,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 110
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/RegisterServerRequestMessage.java",
      "extension" : "java",
      "linesOfCode" : 62,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 10,
      "linesOfCodeInUnits" : 49
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/StageInfoStateItem.java",
      "extension" : "java",
      "linesOfCode" : 72,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 10,
      "linesOfCodeInUnits" : 57
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/AppMapId.java",
      "extension" : "java",
      "linesOfCode" : 55,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 44
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/ServerDetail.java",
      "extension" : "java",
      "linesOfCode" : 65,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 53
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/AppShufflePartitionId.java",
      "extension" : "java",
      "linesOfCode" : 62,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 51
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssStressTool.scala",
      "extension" : "scala",
      "linesOfCode" : 348,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 31,
      "linesOfCodeInUnits" : 287
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/StreamDecoderBase.java",
      "extension" : "java",
      "linesOfCode" : 117,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 27,
      "linesOfCodeInUnits" : 104
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/LazyWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 70,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 45
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerBusyRetriableWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 106,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 149,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 118
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamReadClientVerify.java",
      "extension" : "java",
      "linesOfCode" : 156,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 25,
      "linesOfCodeInUnits" : 119
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/HeartbeatMessage.java",
      "extension" : "java",
      "linesOfCode" : 54,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 9,
      "linesOfCodeInUnits" : 42
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/MapTaskRssInfo.java",
      "extension" : "java",
      "linesOfCode" : 62,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 9,
      "linesOfCodeInUnits" : 52
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/StateStoreLoadResult.java",
      "extension" : "java",
      "linesOfCode" : 52,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 9,
      "linesOfCodeInUnits" : 41
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ServiceRegistryWrapper.java",
      "extension" : "java",
      "linesOfCode" : 93,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 68
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/WriteClientMetrics.java",
      "extension" : "java",
      "linesOfCode" : 49,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 8,
      "linesOfCodeInUnits" : 33
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/MetadataClientMetricsKey.java",
      "extension" : "java",
      "linesOfCode" : 41,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 32
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/M3DummyScope.java",
      "extension" : "java",
      "linesOfCode" : 92,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 8,
      "linesOfCodeInUnits" : 69
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ConnectUploadRequest.java",
      "extension" : "java",
      "linesOfCode" : 46,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 8,
      "linesOfCodeInUnits" : 35
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/FinishUploadMessage.java",
      "extension" : "java",
      "linesOfCode" : 47,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 8,
      "linesOfCodeInUnits" : 35
    } ]
  },
  "filesHistoryAnalysisResults" : {
    "overallFileLastModifiedDistribution" : {
      "key" : "",
      "lowRiskThreshold" : 30,
      "mediumRiskThreshold" : 90,
      "highRiskThreshold" : 180,
      "veryHighRiskThreshold" : 365,
      "negligibleRiskValue" : 0,
      "lowRiskValue" : 0,
      "mediumRiskValue" : 0,
      "highRiskValue" : 0,
      "veryHighRiskValue" : 17066,
      "lowRiskCount" : 0,
      "negligibleRiskCount" : 0,
      "mediumRiskCount" : 0,
      "highRiskCount" : 0,
      "veryHighRiskCount" : 271,
      "negligibleRiskLabel" : "1-30 days",
      "lowRiskLabel" : "31-90 days",
      "mediumRiskLabel" : "91-180 days",
      "highRiskLabel" : "181-365 days",
      "veryHighRiskLabel" : "366+ days",
      "negligibleRiskPercentage" : 0.0,
      "veryHighRiskPercentage" : 100.0,
      "highRiskPercentage" : 0.0,
      "mediumRiskPercentage" : 0.0,
      "lowRiskPercentage" : 0.0,
      "totalValue" : 17066,
      "totalCount" : 271
    },
    "overallFileFirstModifiedDistribution" : {
      "key" : "",
      "lowRiskThreshold" : 30,
      "mediumRiskThreshold" : 90,
      "highRiskThreshold" : 180,
      "veryHighRiskThreshold" : 365,
      "negligibleRiskValue" : 0,
      "lowRiskValue" : 0,
      "mediumRiskValue" : 0,
      "highRiskValue" : 0,
      "veryHighRiskValue" : 17066,
      "lowRiskCount" : 0,
      "negligibleRiskCount" : 0,
      "mediumRiskCount" : 0,
      "highRiskCount" : 0,
      "veryHighRiskCount" : 271,
      "negligibleRiskLabel" : "1-30 days",
      "lowRiskLabel" : "31-90 days",
      "mediumRiskLabel" : "91-180 days",
      "highRiskLabel" : "181-365 days",
      "veryHighRiskLabel" : "366+ days",
      "negligibleRiskPercentage" : 0.0,
      "veryHighRiskPercentage" : 100.0,
      "highRiskPercentage" : 0.0,
      "mediumRiskPercentage" : 0.0,
      "lowRiskPercentage" : 0.0,
      "totalValue" : 17066,
      "totalCount" : 271
    },
    "overallFileChangeDistribution" : {
      "key" : "",
      "lowRiskThreshold" : 5,
      "mediumRiskThreshold" : 20,
      "highRiskThreshold" : 50,
      "veryHighRiskThreshold" : 100,
      "negligibleRiskValue" : 10000,
      "lowRiskValue" : 7066,
      "mediumRiskValue" : 0,
      "highRiskValue" : 0,
      "veryHighRiskValue" : 0,
      "lowRiskCount" : 39,
      "negligibleRiskCount" : 232,
      "mediumRiskCount" : 0,
      "highRiskCount" : 0,
      "veryHighRiskCount" : 0,
      "negligibleRiskLabel" : "1-5",
      "lowRiskLabel" : "6-20",
      "mediumRiskLabel" : "21-50",
      "highRiskLabel" : "51-100",
      "veryHighRiskLabel" : "101+",
      "negligibleRiskPercentage" : 58.59603890776984,
      "veryHighRiskPercentage" : 0.0,
      "highRiskPercentage" : 0.0,
      "mediumRiskPercentage" : 0.0,
      "lowRiskPercentage" : 41.40396109223016,
      "totalValue" : 17066,
      "totalCount" : 271
    },
    "overallContributorsCountDistribution" : {
      "key" : "",
      "lowRiskThreshold" : 1,
      "mediumRiskThreshold" : 5,
      "highRiskThreshold" : 10,
      "veryHighRiskThreshold" : 25,
      "negligibleRiskValue" : 5047,
      "lowRiskValue" : 10951,
      "mediumRiskValue" : 1068,
      "highRiskValue" : 0,
      "veryHighRiskValue" : 0,
      "lowRiskCount" : 112,
      "negligibleRiskCount" : 155,
      "mediumRiskCount" : 4,
      "highRiskCount" : 0,
      "veryHighRiskCount" : 0,
      "negligibleRiskLabel" : "1",
      "lowRiskLabel" : "2-5",
      "mediumRiskLabel" : "6-10",
      "highRiskLabel" : "11-25",
      "veryHighRiskLabel" : "26+",
      "negligibleRiskPercentage" : 29.573420836751435,
      "veryHighRiskPercentage" : 0.0,
      "highRiskPercentage" : 0.0,
      "mediumRiskPercentage" : 6.258056955349819,
      "lowRiskPercentage" : 64.16852220789875,
      "totalValue" : 17066,
      "totalCount" : 271
    },
    "filesWithoutCommitHistoryCount" : 0,
    "filesWithoutCommitHistoryLinesOfCode" : 0,
    "changeDistributionPerExtension" : [ {
      "key" : "java",
      "lowRiskThreshold" : 5,
      "mediumRiskThreshold" : 20,
      "highRiskThreshold" : 50,
      "veryHighRiskThreshold" : 100,
      "negligibleRiskValue" : 9457,
      "lowRiskValue" : 5468,
      "mediumRiskValue" : 0,
      "highRiskValue" : 0,
      "veryHighRiskValue" : 0,
      "lowRiskCount" : 30,
      "negligibleRiskCount" : 219,
      "mediumRiskCount" : 0,
      "highRiskCount" : 0,
      "veryHighRiskCount" : 0,
      "negligibleRiskLabel" : "1-5",
      "lowRiskLabel" : "6-20",
      "mediumRiskLabel" : "21-50",
      "highRiskLabel" : "51-100",
      "veryHighRiskLabel" : "101+",
      "negligibleRiskPercentage" : 63.36348408710218,
      "veryHighRiskPercentage" : 0.0,
      "highRiskPercentage" : 0.0,
      "mediumRiskPercentage" : 0.0,
      "lowRiskPercentage" : 36.63651591289782,
      "totalValue" : 14925,
      "totalCount" : 249
    }, {
      "key" : "scala",
      "lowRiskThreshold" : 5,
      "mediumRiskThreshold" : 20,
      "highRiskThreshold" : 50,
      "veryHighRiskThreshold" : 100,
      "negligibleRiskValue" : 543,
      "lowRiskValue" : 1598,
      "mediumRiskValue" : 0,
      "highRiskValue" : 0,
      "veryHighRiskValue" : 0,
      "lowRiskCount" : 9,
      "negligibleRiskCount" : 13,
      "mediumRiskCount" : 0,
      "highRiskCount" : 0,
      "veryHighRiskCount" : 0,
      "negligibleRiskLabel" : "1-5",
      "lowRiskLabel" : "6-20",
      "mediumRiskLabel" : "21-50",
      "highRiskLabel" : "51-100",
      "veryHighRiskLabel" : "101+",
      "negligibleRiskPercentage" : 25.3619803829986,
      "veryHighRiskPercentage" : 0.0,
      "highRiskPercentage" : 0.0,
      "mediumRiskPercentage" : 0.0,
      "lowRiskPercentage" : 74.6380196170014,
      "totalValue" : 2141,
      "totalCount" : 22
    } ],
    "lastModifiedDistributionPerExtension" : [ {
      "key" : "java",
      "lowRiskThreshold" : 30,
      "mediumRiskThreshold" : 90,
      "highRiskThreshold" : 180,
      "veryHighRiskThreshold" : 365,
      "negligibleRiskValue" : 0,
      "lowRiskValue" : 0,
      "mediumRiskValue" : 0,
      "highRiskValue" : 0,
      "veryHighRiskValue" : 14925,
      "lowRiskCount" : 0,
      "negligibleRiskCount" : 0,
      "mediumRiskCount" : 0,
      "highRiskCount" : 0,
      "veryHighRiskCount" : 249,
      "negligibleRiskLabel" : "1-30 days",
      "lowRiskLabel" : "31-90 days",
      "mediumRiskLabel" : "91-180 days",
      "highRiskLabel" : "181-365 days",
      "veryHighRiskLabel" : "366+ days",
      "negligibleRiskPercentage" : 0.0,
      "veryHighRiskPercentage" : 100.0,
      "highRiskPercentage" : 0.0,
      "mediumRiskPercentage" : 0.0,
      "lowRiskPercentage" : 0.0,
      "totalValue" : 14925,
      "totalCount" : 249
    }, {
      "key" : "scala",
      "lowRiskThreshold" : 30,
      "mediumRiskThreshold" : 90,
      "highRiskThreshold" : 180,
      "veryHighRiskThreshold" : 365,
      "negligibleRiskValue" : 0,
      "lowRiskValue" : 0,
      "mediumRiskValue" : 0,
      "highRiskValue" : 0,
      "veryHighRiskValue" : 2141,
      "lowRiskCount" : 0,
      "negligibleRiskCount" : 0,
      "mediumRiskCount" : 0,
      "highRiskCount" : 0,
      "veryHighRiskCount" : 22,
      "negligibleRiskLabel" : "1-30 days",
      "lowRiskLabel" : "31-90 days",
      "mediumRiskLabel" : "91-180 days",
      "highRiskLabel" : "181-365 days",
      "veryHighRiskLabel" : "366+ days",
      "negligibleRiskPercentage" : 0.0,
      "veryHighRiskPercentage" : 100.0,
      "highRiskPercentage" : 0.0,
      "mediumRiskPercentage" : 0.0,
      "lowRiskPercentage" : 0.0,
      "totalValue" : 2141,
      "totalCount" : 22
    } ],
    "firstModifiedDistributionPerExtension" : [ {
      "key" : "java",
      "lowRiskThreshold" : 30,
      "mediumRiskThreshold" : 90,
      "highRiskThreshold" : 180,
      "veryHighRiskThreshold" : 365,
      "negligibleRiskValue" : 0,
      "lowRiskValue" : 0,
      "mediumRiskValue" : 0,
      "highRiskValue" : 0,
      "veryHighRiskValue" : 14925,
      "lowRiskCount" : 0,
      "negligibleRiskCount" : 0,
      "mediumRiskCount" : 0,
      "highRiskCount" : 0,
      "veryHighRiskCount" : 249,
      "negligibleRiskLabel" : "1-30 days",
      "lowRiskLabel" : "31-90 days",
      "mediumRiskLabel" : "91-180 days",
      "highRiskLabel" : "181-365 days",
      "veryHighRiskLabel" : "366+ days",
      "negligibleRiskPercentage" : 0.0,
      "veryHighRiskPercentage" : 100.0,
      "highRiskPercentage" : 0.0,
      "mediumRiskPercentage" : 0.0,
      "lowRiskPercentage" : 0.0,
      "totalValue" : 14925,
      "totalCount" : 249
    }, {
      "key" : "scala",
      "lowRiskThreshold" : 30,
      "mediumRiskThreshold" : 90,
      "highRiskThreshold" : 180,
      "veryHighRiskThreshold" : 365,
      "negligibleRiskValue" : 0,
      "lowRiskValue" : 0,
      "mediumRiskValue" : 0,
      "highRiskValue" : 0,
      "veryHighRiskValue" : 2141,
      "lowRiskCount" : 0,
      "negligibleRiskCount" : 0,
      "mediumRiskCount" : 0,
      "highRiskCount" : 0,
      "veryHighRiskCount" : 22,
      "negligibleRiskLabel" : "1-30 days",
      "lowRiskLabel" : "31-90 days",
      "mediumRiskLabel" : "91-180 days",
      "highRiskLabel" : "181-365 days",
      "veryHighRiskLabel" : "366+ days",
      "negligibleRiskPercentage" : 0.0,
      "veryHighRiskPercentage" : 100.0,
      "highRiskPercentage" : 0.0,
      "mediumRiskPercentage" : 0.0,
      "lowRiskPercentage" : 0.0,
      "totalValue" : 2141,
      "totalCount" : 22
    } ],
    "changeDistributionPerLogicalDecomposition" : [ {
      "name" : "primary",
      "distributionPerComponent" : [ {
        "key" : "src",
        "lowRiskThreshold" : 5,
        "mediumRiskThreshold" : 20,
        "highRiskThreshold" : 50,
        "veryHighRiskThreshold" : 100,
        "negligibleRiskValue" : 10000,
        "lowRiskValue" : 7066,
        "mediumRiskValue" : 0,
        "highRiskValue" : 0,
        "veryHighRiskValue" : 0,
        "lowRiskCount" : 39,
        "negligibleRiskCount" : 232,
        "mediumRiskCount" : 0,
        "highRiskCount" : 0,
        "veryHighRiskCount" : 0,
        "negligibleRiskLabel" : "1-5",
        "lowRiskLabel" : "6-20",
        "mediumRiskLabel" : "21-50",
        "highRiskLabel" : "51-100",
        "veryHighRiskLabel" : "101+",
        "negligibleRiskPercentage" : 58.59603890776984,
        "veryHighRiskPercentage" : 0.0,
        "highRiskPercentage" : 0.0,
        "mediumRiskPercentage" : 0.0,
        "lowRiskPercentage" : 41.40396109223016,
        "totalValue" : 17066,
        "totalCount" : 271
      } ]
    } ],
    "firstModifiedDistributionPerLogicalDecomposition" : [ {
      "name" : "primary",
      "distributionPerComponent" : [ {
        "key" : "src",
        "lowRiskThreshold" : 30,
        "mediumRiskThreshold" : 90,
        "highRiskThreshold" : 180,
        "veryHighRiskThreshold" : 365,
        "negligibleRiskValue" : 0,
        "lowRiskValue" : 0,
        "mediumRiskValue" : 0,
        "highRiskValue" : 0,
        "veryHighRiskValue" : 17066,
        "lowRiskCount" : 0,
        "negligibleRiskCount" : 0,
        "mediumRiskCount" : 0,
        "highRiskCount" : 0,
        "veryHighRiskCount" : 271,
        "negligibleRiskLabel" : "1-30 days",
        "lowRiskLabel" : "31-90 days",
        "mediumRiskLabel" : "91-180 days",
        "highRiskLabel" : "181-365 days",
        "veryHighRiskLabel" : "366+ days",
        "negligibleRiskPercentage" : 0.0,
        "veryHighRiskPercentage" : 100.0,
        "highRiskPercentage" : 0.0,
        "mediumRiskPercentage" : 0.0,
        "lowRiskPercentage" : 0.0,
        "totalValue" : 17066,
        "totalCount" : 271
      } ]
    } ],
    "lastModifiedDistributionPerLogicalDecomposition" : [ {
      "name" : "primary",
      "distributionPerComponent" : [ {
        "key" : "src",
        "lowRiskThreshold" : 30,
        "mediumRiskThreshold" : 90,
        "highRiskThreshold" : 180,
        "veryHighRiskThreshold" : 365,
        "negligibleRiskValue" : 0,
        "lowRiskValue" : 0,
        "mediumRiskValue" : 0,
        "highRiskValue" : 0,
        "veryHighRiskValue" : 17066,
        "lowRiskCount" : 0,
        "negligibleRiskCount" : 0,
        "mediumRiskCount" : 0,
        "highRiskCount" : 0,
        "veryHighRiskCount" : 271,
        "negligibleRiskLabel" : "1-30 days",
        "lowRiskLabel" : "31-90 days",
        "mediumRiskLabel" : "91-180 days",
        "highRiskLabel" : "181-365 days",
        "veryHighRiskLabel" : "366+ days",
        "negligibleRiskPercentage" : 0.0,
        "veryHighRiskPercentage" : 100.0,
        "highRiskPercentage" : 0.0,
        "mediumRiskPercentage" : 0.0,
        "lowRiskPercentage" : 0.0,
        "totalValue" : 17066,
        "totalCount" : 271
      } ]
    } ],
    "oldestFiles" : [ {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
      "extension" : "java",
      "linesOfCode" : 615,
      "unitsCount" : 36,
      "unitsMcCabeIndexSum" : 101,
      "linesOfCodeInUnits" : 524
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
      "extension" : "java",
      "linesOfCode" : 547,
      "unitsCount" : 31,
      "unitsMcCabeIndexSum" : 85,
      "linesOfCodeInUnits" : 486
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedReadClient.java",
      "extension" : "java",
      "linesOfCode" : 365,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 63,
      "linesOfCodeInUnits" : 312
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
      "extension" : "scala",
      "linesOfCode" : 364,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 35,
      "linesOfCodeInUnits" : 311
    }, {
      "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerMessageDecoder.java",
      "extension" : "java",
      "linesOfCode" : 347,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 57,
      "linesOfCodeInUnits" : 278
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 332,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 56,
      "linesOfCodeInUnits" : 260
    }, {
      "relativePath" : "src/main/java/com/uber/rss/StreamServer.java",
      "extension" : "java",
      "linesOfCode" : 303,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 43,
      "linesOfCodeInUnits" : 251
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 299,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 50,
      "linesOfCodeInUnits" : 236
    }, {
      "relativePath" : "src/main/java/com/uber/rss/StreamServerConfig.java",
      "extension" : "java",
      "linesOfCode" : 283,
      "unitsCount" : 50,
      "unitsMcCabeIndexSum" : 77,
      "linesOfCodeInUnits" : 234
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ClientBase.java",
      "extension" : "java",
      "linesOfCode" : 268,
      "unitsCount" : 17,
      "unitsMcCabeIndexSum" : 47,
      "linesOfCodeInUnits" : 214
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/PooledWriteClientFactory.java",
      "extension" : "java",
      "linesOfCode" : 253,
      "unitsCount" : 30,
      "unitsMcCabeIndexSum" : 52,
      "linesOfCodeInUnits" : 202
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ExecutorShuffleStageState.java",
      "extension" : "java",
      "linesOfCode" : 229,
      "unitsCount" : 27,
      "unitsMcCabeIndexSum" : 49,
      "linesOfCodeInUnits" : 194
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/LocalFileStateStore.java",
      "extension" : "java",
      "linesOfCode" : 204,
      "unitsCount" : 15,
      "unitsMcCabeIndexSum" : 28,
      "linesOfCodeInUnits" : 153
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ZooKeeperServiceRegistry.java",
      "extension" : "java",
      "linesOfCode" : 191,
      "unitsCount" : 15,
      "unitsMcCabeIndexSum" : 36,
      "linesOfCodeInUnits" : 158
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 184,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 20,
      "linesOfCodeInUnits" : 127
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleWriter.scala",
      "extension" : "scala",
      "linesOfCode" : 181,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 124
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssOpts.scala",
      "extension" : "scala",
      "linesOfCode" : 175,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRangeRecordIterator.scala",
      "extension" : "scala",
      "linesOfCode" : 175,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 124
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRecordIterator.scala",
      "extension" : "scala",
      "linesOfCode" : 174,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 22,
      "linesOfCodeInUnits" : 106
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/LocalFileStateStoreIterator.java",
      "extension" : "java",
      "linesOfCode" : 173,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 29,
      "linesOfCodeInUnits" : 120
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/SerializerBenchmark.java",
      "extension" : "java",
      "linesOfCode" : 164,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 134
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 160,
      "unitsCount" : 14,
      "unitsMcCabeIndexSum" : 24,
      "linesOfCodeInUnits" : 114
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 159,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 19,
      "linesOfCodeInUnits" : 111
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamReadClientVerify.java",
      "extension" : "java",
      "linesOfCode" : 156,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 25,
      "linesOfCodeInUnits" : 119
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 155,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 114
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 153,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 33,
      "linesOfCodeInUnits" : 122
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ServiceRegistryUtils.java",
      "extension" : "java",
      "linesOfCode" : 151,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 123
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 149,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 118
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShufflePartitionWriter.java",
      "extension" : "java",
      "linesOfCode" : 147,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 26,
      "linesOfCodeInUnits" : 111
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 142,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 110
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/FsyncPerfTest.java",
      "extension" : "java",
      "linesOfCode" : 131,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 99
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerIdAwareSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 127,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 19,
      "linesOfCodeInUnits" : 95
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/FileUtils.java",
      "extension" : "java",
      "linesOfCode" : 119,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 26,
      "linesOfCodeInUnits" : 98
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressToolLongRun.java",
      "extension" : "java",
      "linesOfCode" : 118,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 97
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/StreamDecoderBase.java",
      "extension" : "java",
      "linesOfCode" : 117,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 27,
      "linesOfCodeInUnits" : 104
    }, {
      "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerVersionDecoder.java",
      "extension" : "java",
      "linesOfCode" : 113,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 86
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssSparkListener.scala",
      "extension" : "scala",
      "linesOfCode" : 111,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 23,
      "linesOfCodeInUnits" : 86
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/M3Stats.java",
      "extension" : "java",
      "linesOfCode" : 106,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 69
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerBusyRetriableWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 106,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 103,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/PartitionFileChecker.java",
      "extension" : "java",
      "linesOfCode" : 98,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/ScheduledMetricCollector.java",
      "extension" : "java",
      "linesOfCode" : 97,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 60
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/RetryUtils.java",
      "extension" : "java",
      "linesOfCode" : 96,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 19,
      "linesOfCodeInUnits" : 86
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/StringUtils.java",
      "extension" : "java",
      "linesOfCode" : 95,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 25,
      "linesOfCodeInUnits" : 87
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ServiceRegistryWrapper.java",
      "extension" : "java",
      "linesOfCode" : 93,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 68
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/M3DummyScope.java",
      "extension" : "java",
      "linesOfCode" : 92,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 8,
      "linesOfCodeInUnits" : 69
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/RetriableSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 92,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 11,
      "linesOfCodeInUnits" : 72
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleReader.scala",
      "extension" : "scala",
      "linesOfCode" : 90,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 60
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequest.java",
      "extension" : "java",
      "linesOfCode" : 85,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 67
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/BlockingQueueReadClient.java",
      "extension" : "java",
      "linesOfCode" : 84,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 62
    } ],
    "youngestFiles" : [ {
      "relativePath" : "src/main/java/com/uber/rss/clients/LazyWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 70,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 45
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssServiceRegistry.scala",
      "extension" : "scala",
      "linesOfCode" : 63,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 15
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterAggregationImpl.scala",
      "extension" : "scala",
      "linesOfCode" : 99,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 65
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterAggregationManager.scala",
      "extension" : "scala",
      "linesOfCode" : 32,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 7
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterNoAggregationManager.scala",
      "extension" : "scala",
      "linesOfCode" : 14,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 1,
      "linesOfCodeInUnits" : 4
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/BlockingShuffleDataReader.java",
      "extension" : "java",
      "linesOfCode" : 6,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/BlockingSingleServerReadClient.java",
      "extension" : "java",
      "linesOfCode" : 5,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequestMessage.java",
      "extension" : "java",
      "linesOfCode" : 89,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 71
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/GetDataAvailabilityRequestMessage.java",
      "extension" : "java",
      "linesOfCode" : 21,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 14
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/ChannelIdleCheck.java",
      "extension" : "java",
      "linesOfCode" : 52,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 10,
      "linesOfCodeInUnits" : 36
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/ChannelFutureCloseListener.java",
      "extension" : "java",
      "linesOfCode" : 17,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 7
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/GetBusyStatusResponse.java",
      "extension" : "java",
      "linesOfCode" : 60,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 11,
      "linesOfCodeInUnits" : 48
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/MovingAverageCalculator.java",
      "extension" : "java",
      "linesOfCode" : 33,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 8,
      "linesOfCodeInUnits" : 25
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/BusyStatusSocketClient.java",
      "extension" : "java",
      "linesOfCode" : 32,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 4,
      "linesOfCodeInUnits" : 20
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/GetBusyStatusRequest.java",
      "extension" : "java",
      "linesOfCode" : 30,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 6,
      "linesOfCodeInUnits" : 21
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/ServerCandidate.java",
      "extension" : "java",
      "linesOfCode" : 28,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 21
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/PooledShuffleDataSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 113,
      "unitsCount" : 16,
      "unitsMcCabeIndexSum" : 22,
      "linesOfCodeInUnits" : 85
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ShuffleDataSyncWriteClientBase.java",
      "extension" : "java",
      "linesOfCode" : 86,
      "unitsCount" : 14,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 60
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ShuffleDataSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 83,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 59
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/TaskDataBlock.java",
      "extension" : "java",
      "linesOfCode" : 48,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 33
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/PlainShuffleDataSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 26,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 14
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/PlainShuffleDataSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 18,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ShuffleDataSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 16,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ShuffleDataWriter.java",
      "extension" : "java",
      "linesOfCode" : 10,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ShuffleDataReader.java",
      "extension" : "java",
      "linesOfCode" : 6,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/TaskByteArrayDataBlock.java",
      "extension" : "java",
      "linesOfCode" : 48,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 33
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssStressTool.scala",
      "extension" : "scala",
      "linesOfCode" : 348,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 31,
      "linesOfCodeInUnits" : 287
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerHeartbeatClient.java",
      "extension" : "java",
      "linesOfCode" : 115,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 25,
      "linesOfCodeInUnits" : 89
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterBufferManager.scala",
      "extension" : "scala",
      "linesOfCode" : 105,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 77
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/FixedLengthInputStream.java",
      "extension" : "java",
      "linesOfCode" : 86,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 68
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/ServerHostAndPort.java",
      "extension" : "java",
      "linesOfCode" : 57,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 47
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/HeartbeatMessage.java",
      "extension" : "java",
      "linesOfCode" : 54,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 9,
      "linesOfCodeInUnits" : 42
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/MockTaskContext.scala",
      "extension" : "scala",
      "linesOfCode" : 50,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 35
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/HeartbeatSocketClient.java",
      "extension" : "java",
      "linesOfCode" : 34,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 4,
      "linesOfCodeInUnits" : 20
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/MapTaskRssInfo.java",
      "extension" : "java",
      "linesOfCode" : 62,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 9,
      "linesOfCodeInUnits" : 52
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
      "extension" : "java",
      "linesOfCode" : 615,
      "unitsCount" : 36,
      "unitsMcCabeIndexSum" : 101,
      "linesOfCodeInUnits" : 524
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
      "extension" : "java",
      "linesOfCode" : 547,
      "unitsCount" : 31,
      "unitsMcCabeIndexSum" : 85,
      "linesOfCodeInUnits" : 486
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedReadClient.java",
      "extension" : "java",
      "linesOfCode" : 365,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 63,
      "linesOfCodeInUnits" : 312
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
      "extension" : "scala",
      "linesOfCode" : 364,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 35,
      "linesOfCodeInUnits" : 311
    }, {
      "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerMessageDecoder.java",
      "extension" : "java",
      "linesOfCode" : 347,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 57,
      "linesOfCodeInUnits" : 278
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 332,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 56,
      "linesOfCodeInUnits" : 260
    }, {
      "relativePath" : "src/main/java/com/uber/rss/StreamServer.java",
      "extension" : "java",
      "linesOfCode" : 303,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 43,
      "linesOfCodeInUnits" : 251
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 299,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 50,
      "linesOfCodeInUnits" : 236
    }, {
      "relativePath" : "src/main/java/com/uber/rss/StreamServerConfig.java",
      "extension" : "java",
      "linesOfCode" : 283,
      "unitsCount" : 50,
      "unitsMcCabeIndexSum" : 77,
      "linesOfCodeInUnits" : 234
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ClientBase.java",
      "extension" : "java",
      "linesOfCode" : 268,
      "unitsCount" : 17,
      "unitsMcCabeIndexSum" : 47,
      "linesOfCodeInUnits" : 214
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/PooledWriteClientFactory.java",
      "extension" : "java",
      "linesOfCode" : 253,
      "unitsCount" : 30,
      "unitsMcCabeIndexSum" : 52,
      "linesOfCodeInUnits" : 202
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ExecutorShuffleStageState.java",
      "extension" : "java",
      "linesOfCode" : 229,
      "unitsCount" : 27,
      "unitsMcCabeIndexSum" : 49,
      "linesOfCodeInUnits" : 194
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/LocalFileStateStore.java",
      "extension" : "java",
      "linesOfCode" : 204,
      "unitsCount" : 15,
      "unitsMcCabeIndexSum" : 28,
      "linesOfCodeInUnits" : 153
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ZooKeeperServiceRegistry.java",
      "extension" : "java",
      "linesOfCode" : 191,
      "unitsCount" : 15,
      "unitsMcCabeIndexSum" : 36,
      "linesOfCodeInUnits" : 158
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 184,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 20,
      "linesOfCodeInUnits" : 127
    } ],
    "mostRecentlyChangedFiles" : [ {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
      "extension" : "scala",
      "linesOfCode" : 364,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 35,
      "linesOfCodeInUnits" : 311
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssStressTool.scala",
      "extension" : "scala",
      "linesOfCode" : 348,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 31,
      "linesOfCodeInUnits" : 287
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleWriter.scala",
      "extension" : "scala",
      "linesOfCode" : 181,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 124
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssOpts.scala",
      "extension" : "scala",
      "linesOfCode" : 175,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRangeRecordIterator.scala",
      "extension" : "scala",
      "linesOfCode" : 175,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 124
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRecordIterator.scala",
      "extension" : "scala",
      "linesOfCode" : 174,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 22,
      "linesOfCodeInUnits" : 106
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/PartitionFileChecker.java",
      "extension" : "java",
      "linesOfCode" : 98,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleReader.scala",
      "extension" : "scala",
      "linesOfCode" : 90,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 60
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/Compression.java",
      "extension" : "java",
      "linesOfCode" : 56,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 36
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/LazyWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 70,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 45
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ZooKeeperServiceRegistry.java",
      "extension" : "java",
      "linesOfCode" : 191,
      "unitsCount" : 15,
      "unitsMcCabeIndexSum" : 36,
      "linesOfCodeInUnits" : 158
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ServiceRegistryWrapper.java",
      "extension" : "java",
      "linesOfCode" : 93,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 68
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssServiceRegistry.scala",
      "extension" : "scala",
      "linesOfCode" : 63,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 15
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/MetadataClientMetrics.java",
      "extension" : "java",
      "linesOfCode" : 39,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 6,
      "linesOfCodeInUnits" : 25
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterBufferManager.scala",
      "extension" : "scala",
      "linesOfCode" : 105,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 77
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterAggregationImpl.scala",
      "extension" : "scala",
      "linesOfCode" : 99,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 65
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterAggregationManager.scala",
      "extension" : "scala",
      "linesOfCode" : 32,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 7
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterNoAggregationManager.scala",
      "extension" : "scala",
      "linesOfCode" : 14,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 1,
      "linesOfCodeInUnits" : 4
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
      "extension" : "java",
      "linesOfCode" : 615,
      "unitsCount" : 36,
      "unitsMcCabeIndexSum" : 101,
      "linesOfCodeInUnits" : 524
    }, {
      "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerMessageDecoder.java",
      "extension" : "java",
      "linesOfCode" : 347,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 57,
      "linesOfCodeInUnits" : 278
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 184,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 20,
      "linesOfCodeInUnits" : 127
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 155,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 114
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ServiceRegistryUtils.java",
      "extension" : "java",
      "linesOfCode" : 151,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 123
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/M3Stats.java",
      "extension" : "java",
      "linesOfCode" : 106,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 69
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/BlockingQueueReadClient.java",
      "extension" : "java",
      "linesOfCode" : 84,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 62
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/RecordSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 83,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 59
    }, {
      "relativePath" : "src/main/java/com/uber/rss/storage/ShuffleFileOutputStream.java",
      "extension" : "java",
      "linesOfCode" : 71,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 11,
      "linesOfCodeInUnits" : 48
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/MemoryMonitor.java",
      "extension" : "java",
      "linesOfCode" : 70,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 47
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/TaskByteArrayDataBlock.java",
      "extension" : "java",
      "linesOfCode" : 48,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 33
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/ServerHandlerMetrics.java",
      "extension" : "java",
      "linesOfCode" : 35,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 21
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/FailedFetchRecordKeyValuePair.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 7
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/EofRecordKeyValuePair.java",
      "extension" : "java",
      "linesOfCode" : 6,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 1,
      "linesOfCodeInUnits" : 3
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/BlockingShuffleDataReader.java",
      "extension" : "java",
      "linesOfCode" : 6,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/BlockingSingleServerReadClient.java",
      "extension" : "java",
      "linesOfCode" : 5,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/StreamDecoderBase.java",
      "extension" : "java",
      "linesOfCode" : 117,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 27,
      "linesOfCodeInUnits" : 104
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerBusyRetriableWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 106,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequestMessage.java",
      "extension" : "java",
      "linesOfCode" : 89,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 71
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/MessageConstants.java",
      "extension" : "java",
      "linesOfCode" : 46,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/GetDataAvailabilityRequestMessage.java",
      "extension" : "java",
      "linesOfCode" : 21,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 14
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 299,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 50,
      "linesOfCodeInUnits" : 236
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 159,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 19,
      "linesOfCodeInUnits" : 111
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 142,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 110
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/HeartbeatSocketClient.java",
      "extension" : "java",
      "linesOfCode" : 34,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 4,
      "linesOfCodeInUnits" : 20
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/LocalFileStateStore.java",
      "extension" : "java",
      "linesOfCode" : 204,
      "unitsCount" : 15,
      "unitsMcCabeIndexSum" : 28,
      "linesOfCodeInUnits" : 153
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/LocalFileStateStoreIterator.java",
      "extension" : "java",
      "linesOfCode" : 173,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 29,
      "linesOfCodeInUnits" : 120
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/BusyStatusSocketClient.java",
      "extension" : "java",
      "linesOfCode" : 32,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 4,
      "linesOfCodeInUnits" : 20
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/ServerCandidate.java",
      "extension" : "java",
      "linesOfCode" : 28,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 21
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
      "extension" : "java",
      "linesOfCode" : 547,
      "unitsCount" : 31,
      "unitsMcCabeIndexSum" : 85,
      "linesOfCodeInUnits" : 486
    }, {
      "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerVersionDecoder.java",
      "extension" : "java",
      "linesOfCode" : 113,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 86
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 103,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 78
    } ],
    "mostPreviouslyChangedFiles" : [ {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssServerSelectionResult.scala",
      "extension" : "scala",
      "linesOfCode" : 3,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/SocketAsyncWriteCallback.java",
      "extension" : "java",
      "linesOfCode" : 3,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ControlMessage.java",
      "extension" : "java",
      "linesOfCode" : 3,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/LowMemoryListener.java",
      "extension" : "java",
      "linesOfCode" : 4,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/BaseMessage.java",
      "extension" : "java",
      "linesOfCode" : 4,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/SerializableMessage.java",
      "extension" : "java",
      "linesOfCode" : 5,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerConnectionStringResolver.java",
      "extension" : "java",
      "linesOfCode" : 5,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerConnectionRefresher.java",
      "extension" : "java",
      "linesOfCode" : 5,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/ServerRole.java",
      "extension" : "java",
      "linesOfCode" : 6,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleServerHandle.scala",
      "extension" : "scala",
      "linesOfCode" : 7,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 1,
      "linesOfCodeInUnits" : 3
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssServerDownException.java",
      "extension" : "java",
      "linesOfCode" : 8,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 5
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssNoServerAvailableException.java",
      "extension" : "java",
      "linesOfCode" : 8,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 5
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssServerBusyException.java",
      "extension" : "java",
      "linesOfCode" : 8,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 5
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssInvalidMapStatusException.java",
      "extension" : "java",
      "linesOfCode" : 8,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 5
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssTooMuchDataException.java",
      "extension" : "java",
      "linesOfCode" : 8,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 5
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssShuffleStageNotStartedException.java",
      "extension" : "java",
      "linesOfCode" : 9,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 6
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssShuffleCorruptedException.java",
      "extension" : "java",
      "linesOfCode" : 9,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 6
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssMissingShuffleWriteConfigException.java",
      "extension" : "java",
      "linesOfCode" : 9,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 6
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssStaleTaskAttemptException.java",
      "extension" : "java",
      "linesOfCode" : 9,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 6
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssFileCorruptedException.java",
      "extension" : "java",
      "linesOfCode" : 9,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 6
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssShuffleDataNotAvailableException.java",
      "extension" : "java",
      "linesOfCode" : 9,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 6
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/LogUtils.java",
      "extension" : "java",
      "linesOfCode" : 9,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 6
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleBlockResolver.scala",
      "extension" : "scala",
      "linesOfCode" : 10,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 5
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/EmptyRecordIterator.scala",
      "extension" : "scala",
      "linesOfCode" : 11,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 1,
      "linesOfCodeInUnits" : 3
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssRetryableSparkTaskException.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssUberEnvironmentException.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssWriteRecordException.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssRetryTimeoutException.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssFinishUploadException.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssNonRecoverableException.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssNoActiveReadClientException.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssQueueNotReadyException.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssInvalidServerVersionException.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssServerResolveException.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssInconsistentReplicaException.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssInvalidServerIdException.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/MetadataClientMetricsContainer.java",
      "extension" : "java",
      "linesOfCode" : 12,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/ExceptionMetricGroupContainer.java",
      "extension" : "java",
      "linesOfCode" : 12,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ServerResponseMessage.java",
      "extension" : "java",
      "linesOfCode" : 13,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 9
    }, {
      "relativePath" : "src/main/java/com/uber/rss/storage/ShuffleStorage.java",
      "extension" : "java",
      "linesOfCode" : 14,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/NettyUtils.java",
      "extension" : "java",
      "linesOfCode" : 14,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 9
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/SystemUtils.java",
      "extension" : "java",
      "linesOfCode" : 14,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 8
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/NettyServerSideMetricGroupContainer.java",
      "extension" : "java",
      "linesOfCode" : 14,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 9
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/ThreadUtils.java",
      "extension" : "java",
      "linesOfCode" : 15,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 7
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/MetricGroup.java",
      "extension" : "java",
      "linesOfCode" : 15,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 7
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/ExceptionWrapper.java",
      "extension" : "java",
      "linesOfCode" : 16,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 3,
      "linesOfCodeInUnits" : 11
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssStreamReadException.java",
      "extension" : "java",
      "linesOfCode" : 17,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 14
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssEndOfStreamException.java",
      "extension" : "java",
      "linesOfCode" : 17,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 14
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssInvalidDataException.java",
      "extension" : "java",
      "linesOfCode" : 17,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 14
    }, {
      "relativePath" : "src/main/java/com/uber/rss/exceptions/RssException.java",
      "extension" : "java",
      "linesOfCode" : 17,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 14
    } ],
    "mostChangedFiles" : [ {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssOpts.scala",
      "extension" : "scala",
      "linesOfCode" : 175,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 184,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 20,
      "linesOfCodeInUnits" : 127
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
      "extension" : "scala",
      "linesOfCode" : 364,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 35,
      "linesOfCodeInUnits" : 311
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRangeRecordIterator.scala",
      "extension" : "scala",
      "linesOfCode" : 175,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 124
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleWriter.scala",
      "extension" : "scala",
      "linesOfCode" : 181,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 124
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssStressTool.scala",
      "extension" : "scala",
      "linesOfCode" : 348,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 31,
      "linesOfCodeInUnits" : 287
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 159,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 19,
      "linesOfCodeInUnits" : 111
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
      "extension" : "java",
      "linesOfCode" : 547,
      "unitsCount" : 31,
      "unitsMcCabeIndexSum" : 85,
      "linesOfCodeInUnits" : 486
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
      "extension" : "java",
      "linesOfCode" : 615,
      "unitsCount" : 36,
      "unitsMcCabeIndexSum" : 101,
      "linesOfCodeInUnits" : 524
    }, {
      "relativePath" : "src/main/java/com/uber/rss/StreamServer.java",
      "extension" : "java",
      "linesOfCode" : 303,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 43,
      "linesOfCodeInUnits" : 251
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/MessageConstants.java",
      "extension" : "java",
      "linesOfCode" : 46,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 155,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 114
    }, {
      "relativePath" : "src/main/java/com/uber/rss/StreamServerConfig.java",
      "extension" : "java",
      "linesOfCode" : 283,
      "unitsCount" : 50,
      "unitsMcCabeIndexSum" : 77,
      "linesOfCodeInUnits" : 234
    }, {
      "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerMessageDecoder.java",
      "extension" : "java",
      "linesOfCode" : 347,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 57,
      "linesOfCodeInUnits" : 278
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssUtils.scala",
      "extension" : "scala",
      "linesOfCode" : 82,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 70
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleReader.scala",
      "extension" : "scala",
      "linesOfCode" : 90,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 60
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 103,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 299,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 50,
      "linesOfCodeInUnits" : 236
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/RecordSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 83,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 59
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRecordIterator.scala",
      "extension" : "scala",
      "linesOfCode" : 174,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 22,
      "linesOfCodeInUnits" : 106
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ServiceRegistryUtils.java",
      "extension" : "java",
      "linesOfCode" : 151,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 123
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/MapOutputRssInfo.scala",
      "extension" : "scala",
      "linesOfCode" : 9,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/MapTaskCommitStatus.java",
      "extension" : "java",
      "linesOfCode" : 64,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 10,
      "linesOfCodeInUnits" : 50
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerIdAwareSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 69,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 11,
      "linesOfCodeInUnits" : 49
    }, {
      "relativePath" : "src/main/java/com/uber/rss/storage/ShuffleFileOutputStream.java",
      "extension" : "java",
      "linesOfCode" : 71,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 11,
      "linesOfCodeInUnits" : 48
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/RetriableSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 92,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 11,
      "linesOfCodeInUnits" : 72
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 142,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 110
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShufflePartitionWriter.java",
      "extension" : "java",
      "linesOfCode" : 147,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 26,
      "linesOfCodeInUnits" : 111
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 149,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 118
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamReadClientVerify.java",
      "extension" : "java",
      "linesOfCode" : 156,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 25,
      "linesOfCodeInUnits" : 119
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ExecutorShuffleStageState.java",
      "extension" : "java",
      "linesOfCode" : 229,
      "unitsCount" : 27,
      "unitsMcCabeIndexSum" : 49,
      "linesOfCodeInUnits" : 194
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedReadClient.java",
      "extension" : "java",
      "linesOfCode" : 365,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 63,
      "linesOfCodeInUnits" : 312
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/EofRecordKeyValuePair.java",
      "extension" : "java",
      "linesOfCode" : 6,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 1,
      "linesOfCodeInUnits" : 3
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/FailedFetchRecordKeyValuePair.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 7
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/NetworkUtils.java",
      "extension" : "java",
      "linesOfCode" : 57,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 43
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/BlockingQueueReadClient.java",
      "extension" : "java",
      "linesOfCode" : 84,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 62
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerBusyRetriableWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 106,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerVersionDecoder.java",
      "extension" : "java",
      "linesOfCode" : 113,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 86
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 332,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 56,
      "linesOfCodeInUnits" : 260
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ReadClientDataOptions.java",
      "extension" : "java",
      "linesOfCode" : 31,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 21
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadChannelManager.java",
      "extension" : "java",
      "linesOfCode" : 37,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 6,
      "linesOfCodeInUnits" : 17
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/MemoryMonitor.java",
      "extension" : "java",
      "linesOfCode" : 70,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 47
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/StageInfoStateItem.java",
      "extension" : "java",
      "linesOfCode" : 72,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 10,
      "linesOfCodeInUnits" : 57
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressToolLongRun.java",
      "extension" : "java",
      "linesOfCode" : 118,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 97
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerIdAwareSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 127,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 19,
      "linesOfCodeInUnits" : 95
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 153,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 33,
      "linesOfCodeInUnits" : 122
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 160,
      "unitsCount" : 14,
      "unitsMcCabeIndexSum" : 24,
      "linesOfCodeInUnits" : 114
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/WriteClientFactory.java",
      "extension" : "java",
      "linesOfCode" : 4,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/MonitorUtils.java",
      "extension" : "java",
      "linesOfCode" : 20,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 6,
      "linesOfCodeInUnits" : 15
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/UnpooledWriteClientFactory.java",
      "extension" : "java",
      "linesOfCode" : 23,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 15
    } ],
    "filesWithMostContributors" : [ {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
      "extension" : "scala",
      "linesOfCode" : 364,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 35,
      "linesOfCodeInUnits" : 311
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssStressTool.scala",
      "extension" : "scala",
      "linesOfCode" : 348,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 31,
      "linesOfCodeInUnits" : 287
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleWriter.scala",
      "extension" : "scala",
      "linesOfCode" : 181,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 124
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssOpts.scala",
      "extension" : "scala",
      "linesOfCode" : 175,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRangeRecordIterator.scala",
      "extension" : "scala",
      "linesOfCode" : 175,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 124
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleReader.scala",
      "extension" : "scala",
      "linesOfCode" : 90,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 60
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRecordIterator.scala",
      "extension" : "scala",
      "linesOfCode" : 174,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 22,
      "linesOfCodeInUnits" : 106
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterBufferManager.scala",
      "extension" : "scala",
      "linesOfCode" : 105,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 77
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 184,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 20,
      "linesOfCodeInUnits" : 127
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
      "extension" : "java",
      "linesOfCode" : 615,
      "unitsCount" : 36,
      "unitsMcCabeIndexSum" : 101,
      "linesOfCodeInUnits" : 524
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
      "extension" : "java",
      "linesOfCode" : 547,
      "unitsCount" : 31,
      "unitsMcCabeIndexSum" : 85,
      "linesOfCodeInUnits" : 486
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 159,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 19,
      "linesOfCodeInUnits" : 111
    }, {
      "relativePath" : "src/main/java/com/uber/rss/StreamServer.java",
      "extension" : "java",
      "linesOfCode" : 303,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 43,
      "linesOfCodeInUnits" : 251
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/MessageConstants.java",
      "extension" : "java",
      "linesOfCode" : 46,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/StreamServerConfig.java",
      "extension" : "java",
      "linesOfCode" : 283,
      "unitsCount" : 50,
      "unitsMcCabeIndexSum" : 77,
      "linesOfCodeInUnits" : 234
    }, {
      "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerMessageDecoder.java",
      "extension" : "java",
      "linesOfCode" : 347,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 57,
      "linesOfCodeInUnits" : 278
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 155,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 114
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 103,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssUtils.scala",
      "extension" : "scala",
      "linesOfCode" : 82,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 70
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/RecordSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 83,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 59
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ServiceRegistryUtils.java",
      "extension" : "java",
      "linesOfCode" : 151,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 123
    }, {
      "relativePath" : "src/main/java/com/uber/rss/storage/ShuffleFileOutputStream.java",
      "extension" : "java",
      "linesOfCode" : 71,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 11,
      "linesOfCodeInUnits" : 48
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/EofRecordKeyValuePair.java",
      "extension" : "java",
      "linesOfCode" : 6,
      "unitsCount" : 1,
      "unitsMcCabeIndexSum" : 1,
      "linesOfCodeInUnits" : 3
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/BlockingQueueReadClient.java",
      "extension" : "java",
      "linesOfCode" : 84,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 62
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerBusyRetriableWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 106,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/FailedFetchRecordKeyValuePair.java",
      "extension" : "java",
      "linesOfCode" : 11,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 2,
      "linesOfCodeInUnits" : 7
    }, {
      "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerVersionDecoder.java",
      "extension" : "java",
      "linesOfCode" : 113,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 86
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/MemoryMonitor.java",
      "extension" : "java",
      "linesOfCode" : 70,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 47
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/UploadChannelManager.java",
      "extension" : "java",
      "linesOfCode" : 37,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 6,
      "linesOfCodeInUnits" : 17
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/M3Stats.java",
      "extension" : "java",
      "linesOfCode" : 106,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 69
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/MetadataClientMetrics.java",
      "extension" : "java",
      "linesOfCode" : 39,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 6,
      "linesOfCodeInUnits" : 25
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/ServerHandlerMetrics.java",
      "extension" : "java",
      "linesOfCode" : 35,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 21
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/TaskByteArrayDataBlock.java",
      "extension" : "java",
      "linesOfCode" : 48,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 33
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/PartitionFileChecker.java",
      "extension" : "java",
      "linesOfCode" : 98,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 17,
      "linesOfCodeInUnits" : 78
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/Compression.java",
      "extension" : "java",
      "linesOfCode" : 56,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 36
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ZooKeeperServiceRegistry.java",
      "extension" : "java",
      "linesOfCode" : 191,
      "unitsCount" : 15,
      "unitsMcCabeIndexSum" : 36,
      "linesOfCodeInUnits" : 158
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ServiceRegistryWrapper.java",
      "extension" : "java",
      "linesOfCode" : 93,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 68
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/ServerCandidate.java",
      "extension" : "java",
      "linesOfCode" : 28,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 21
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/BusyStatusSocketClient.java",
      "extension" : "java",
      "linesOfCode" : 32,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 4,
      "linesOfCodeInUnits" : 20
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 299,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 50,
      "linesOfCodeInUnits" : 236
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/RetriableSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 92,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 11,
      "linesOfCodeInUnits" : 72
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedReadClient.java",
      "extension" : "java",
      "linesOfCode" : 365,
      "unitsCount" : 21,
      "unitsMcCabeIndexSum" : 63,
      "linesOfCodeInUnits" : 312
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerIdAwareSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 69,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 11,
      "linesOfCodeInUnits" : 49
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSyncWriteClient.java",
      "extension" : "java",
      "linesOfCode" : 142,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 18,
      "linesOfCodeInUnits" : 110
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSocketReadClient.java",
      "extension" : "java",
      "linesOfCode" : 149,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 118
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/StreamReadClientVerify.java",
      "extension" : "java",
      "linesOfCode" : 156,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 25,
      "linesOfCodeInUnits" : 119
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/MapTaskCommitStatus.java",
      "extension" : "java",
      "linesOfCode" : 64,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 10,
      "linesOfCodeInUnits" : 50
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ExecutorShuffleStageState.java",
      "extension" : "java",
      "linesOfCode" : 229,
      "unitsCount" : 27,
      "unitsMcCabeIndexSum" : 49,
      "linesOfCodeInUnits" : 194
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShufflePartitionWriter.java",
      "extension" : "java",
      "linesOfCode" : 147,
      "unitsCount" : 13,
      "unitsMcCabeIndexSum" : 26,
      "linesOfCodeInUnits" : 111
    }, {
      "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/MapOutputRssInfo.scala",
      "extension" : "scala",
      "linesOfCode" : 9,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    } ],
    "filesWithLeastContributors" : [ {
      "relativePath" : "src/main/java/com/uber/rss/clients/ClientBase.java",
      "extension" : "java",
      "linesOfCode" : 268,
      "unitsCount" : 17,
      "unitsMcCabeIndexSum" : 47,
      "linesOfCodeInUnits" : 214
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/SerializerBenchmark.java",
      "extension" : "java",
      "linesOfCode" : 164,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 134
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/FsyncPerfTest.java",
      "extension" : "java",
      "linesOfCode" : 131,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 99
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/FileUtils.java",
      "extension" : "java",
      "linesOfCode" : 119,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 26,
      "linesOfCodeInUnits" : 98
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/RetryUtils.java",
      "extension" : "java",
      "linesOfCode" : 96,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 19,
      "linesOfCodeInUnits" : 86
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequestMessage.java",
      "extension" : "java",
      "linesOfCode" : 89,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 71
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/StartUploadMessage.java",
      "extension" : "java",
      "linesOfCode" : 78,
      "unitsCount" : 12,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 63
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/ByteBufUtils.java",
      "extension" : "java",
      "linesOfCode" : 77,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 10,
      "linesOfCodeInUnits" : 59
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/HttpChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 76,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 8,
      "linesOfCodeInUnits" : 51
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/AppTaskAttemptId.java",
      "extension" : "java",
      "linesOfCode" : 71,
      "unitsCount" : 14,
      "unitsMcCabeIndexSum" : 21,
      "linesOfCodeInUnits" : 59
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/FinishApplicationJobRequestMessage.java",
      "extension" : "java",
      "linesOfCode" : 70,
      "unitsCount" : 11,
      "unitsMcCabeIndexSum" : 11,
      "linesOfCodeInUnits" : 56
    }, {
      "relativePath" : "src/main/java/com/uber/rss/tools/FileDescriptorStressTest.java",
      "extension" : "java",
      "linesOfCode" : 68,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 56
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/ZooKeeperFaultTolerantServiceRegistry.java",
      "extension" : "java",
      "linesOfCode" : 63,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 42
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/NotifyClient.java",
      "extension" : "java",
      "linesOfCode" : 62,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 9,
      "linesOfCodeInUnits" : 43
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/RegisterServerRequestMessage.java",
      "extension" : "java",
      "linesOfCode" : 62,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 10,
      "linesOfCodeInUnits" : 49
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/AppShufflePartitionId.java",
      "extension" : "java",
      "linesOfCode" : 62,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 51
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metadata/InMemoryServiceRegistry.java",
      "extension" : "java",
      "linesOfCode" : 62,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 14,
      "linesOfCodeInUnits" : 43
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ShuffleStageStatus.java",
      "extension" : "java",
      "linesOfCode" : 59,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 46
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/ServerDetailCollection.java",
      "extension" : "java",
      "linesOfCode" : 56,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 38
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerReplicationGroupUtil.java",
      "extension" : "java",
      "linesOfCode" : 55,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 10,
      "linesOfCodeInUnits" : 42
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/ServerList.java",
      "extension" : "java",
      "linesOfCode" : 55,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 34
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/AppMapId.java",
      "extension" : "java",
      "linesOfCode" : 55,
      "unitsCount" : 10,
      "unitsMcCabeIndexSum" : 16,
      "linesOfCodeInUnits" : 44
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/RegistryChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 55,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 9,
      "linesOfCodeInUnits" : 34
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/NotifyChannelInboundHandler.java",
      "extension" : "java",
      "linesOfCode" : 54,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 9,
      "linesOfCodeInUnits" : 34
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/StateStoreLoadResult.java",
      "extension" : "java",
      "linesOfCode" : 52,
      "unitsCount" : 9,
      "unitsMcCabeIndexSum" : 9,
      "linesOfCodeInUnits" : 41
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/WriteClientMetrics.java",
      "extension" : "java",
      "linesOfCode" : 49,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 8,
      "linesOfCodeInUnits" : 33
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/NotifyServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 49,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 6,
      "linesOfCodeInUnits" : 29
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/RegistryClient.java",
      "extension" : "java",
      "linesOfCode" : 47,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 29
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/GetDataAvailabilityResponse.java",
      "extension" : "java",
      "linesOfCode" : 47,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 9,
      "linesOfCodeInUnits" : 37
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/HandlerUtil.java",
      "extension" : "java",
      "linesOfCode" : 47,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 36
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ConnectUploadRequest.java",
      "extension" : "java",
      "linesOfCode" : 46,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 8,
      "linesOfCodeInUnits" : 35
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/ConnectUploadResponse.java",
      "extension" : "java",
      "linesOfCode" : 46,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 8,
      "linesOfCodeInUnits" : 35
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/GetServersRequestMessage.java",
      "extension" : "java",
      "linesOfCode" : 46,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 8,
      "linesOfCodeInUnits" : 35
    }, {
      "relativePath" : "src/main/java/com/uber/rss/handlers/RegistryServerHandler.java",
      "extension" : "java",
      "linesOfCode" : 46,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 5,
      "linesOfCodeInUnits" : 26
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/ReadClientMetrics.java",
      "extension" : "java",
      "linesOfCode" : 44,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 29
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/GetServersResponseMessage.java",
      "extension" : "java",
      "linesOfCode" : 44,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 9,
      "linesOfCodeInUnits" : 33
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/ExceptionUtils.java",
      "extension" : "java",
      "linesOfCode" : 43,
      "unitsCount" : 5,
      "unitsMcCabeIndexSum" : 13,
      "linesOfCodeInUnits" : 36
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/PartitionFilePathAndLength.java",
      "extension" : "java",
      "linesOfCode" : 42,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 32
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/AppShuffleId.java",
      "extension" : "java",
      "linesOfCode" : 42,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 32
    }, {
      "relativePath" : "src/main/java/com/uber/rss/common/ShuffleMapTaskAttemptId.java",
      "extension" : "java",
      "linesOfCode" : 42,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 32
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/MetadataClientMetricsKey.java",
      "extension" : "java",
      "linesOfCode" : 41,
      "unitsCount" : 8,
      "unitsMcCabeIndexSum" : 12,
      "linesOfCodeInUnits" : 32
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/RateCounter.java",
      "extension" : "java",
      "linesOfCode" : 40,
      "unitsCount" : 4,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 31
    }, {
      "relativePath" : "src/main/java/com/uber/rss/clients/ServerConnectionCacheUpdateRefresher.java",
      "extension" : "java",
      "linesOfCode" : 39,
      "unitsCount" : 2,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 29
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/AsyncSocketCompletionHandler.java",
      "extension" : "java",
      "linesOfCode" : 39,
      "unitsCount" : 3,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 30
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/FinishApplicationAttemptRequestMessage.java",
      "extension" : "java",
      "linesOfCode" : 38,
      "unitsCount" : 7,
      "unitsMcCabeIndexSum" : 7,
      "linesOfCodeInUnits" : 28
    }, {
      "relativePath" : "src/main/java/com/uber/rss/util/StreamUtils.java",
      "extension" : "java",
      "linesOfCode" : 37,
      "unitsCount" : 0,
      "unitsMcCabeIndexSum" : 0,
      "linesOfCodeInUnits" : 0
    }, {
      "relativePath" : "src/main/java/com/uber/rss/messages/StageCorruptionStateItem.java",
      "extension" : "java",
      "linesOfCode" : 36,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 6,
      "linesOfCodeInUnits" : 25
    }, {
      "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleDataWrapper.java",
      "extension" : "java",
      "linesOfCode" : 36,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 6,
      "linesOfCodeInUnits" : 26
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/ReadClientMetricsKey.java",
      "extension" : "java",
      "linesOfCode" : 35,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 10,
      "linesOfCodeInUnits" : 26
    }, {
      "relativePath" : "src/main/java/com/uber/rss/metrics/WriteClientMetricsKey.java",
      "extension" : "java",
      "linesOfCode" : 35,
      "unitsCount" : 6,
      "unitsMcCabeIndexSum" : 10,
      "linesOfCodeInUnits" : 26
    } ],
    "firstDate" : "2020-08-20",
    "latestDate" : "2023-01-31",
    "daysBetweenFirstAndLastDate" : 895,
    "weeks" : 127,
    "estimatedWorkindDays" : 635,
    "activeDays" : 47,
    "ageInDays" : 1323,
    "historyPerExtensionPerYear" : [ {
      "extension" : "java",
      "year" : "2021",
      "commitsCount" : 16,
      "contributors" : [ "mabansal@uber.com", "harshvardhan5795@gmail.com", "mayurb@uber.com" ]
    }, {
      "extension" : "properties",
      "year" : "2020",
      "commitsCount" : 1,
      "contributors" : [ "boy@uber.com" ]
    }, {
      "extension" : "java",
      "year" : "2020",
      "commitsCount" : 57,
      "contributors" : [ "mabansal@uber.com", "boy-uber@users.noreply.github.com", "boy@uber.com" ]
    }, {
      "extension" : "md",
      "year" : "2020",
      "commitsCount" : 14,
      "contributors" : [ "boy-uber@users.noreply.github.com", "boy@uber.com" ]
    }, {
      "extension" : "md",
      "year" : "2021",
      "commitsCount" : 2,
      "contributors" : [ "mabansal@uber.com" ]
    }, {
      "extension" : "xml",
      "year" : "2020",
      "commitsCount" : 9,
      "contributors" : [ "boy-uber@users.noreply.github.com", "boy@uber.com" ]
    }, {
      "extension" : "scala",
      "year" : "2022",
      "commitsCount" : 3,
      "contributors" : [ "14280154+hiboyang@users.noreply.github.com" ]
    }, {
      "extension" : "scala",
      "year" : "2023",
      "commitsCount" : 2,
      "contributors" : [ "mabansal@uber.com", "14280154+hiboyang@users.noreply.github.com" ]
    }, {
      "extension" : "scala",
      "year" : "2020",
      "commitsCount" : 34,
      "contributors" : [ "jkai@uber.com", "mabansal@uber.com", "boy-uber@users.noreply.github.com", "boy@uber.com" ]
    }, {
      "extension" : "scala",
      "year" : "2021",
      "commitsCount" : 11,
      "contributors" : [ "mabansal@uber.com", "mayurdb31@gmail.com", "harshvardhan5795@gmail.com", "mayurb@uber.com" ]
    }, {
      "extension" : "yml",
      "year" : "2020",
      "commitsCount" : 6,
      "contributors" : [ "boy-uber@users.noreply.github.com", "boy@uber.com" ]
    }, {
      "extension" : "png",
      "year" : "2020",
      "commitsCount" : 2,
      "contributors" : [ "boy-uber@users.noreply.github.com", "boy@uber.com" ]
    }, {
      "extension" : "gitignore",
      "year" : "2020",
      "commitsCount" : 3,
      "contributors" : [ "boy@uber.com" ]
    }, {
      "extension" : "",
      "year" : "2020",
      "commitsCount" : 2,
      "contributors" : [ "boy@uber.com" ]
    }, {
      "extension" : "java",
      "year" : "2023",
      "commitsCount" : 1,
      "contributors" : [ "mabansal@uber.com" ]
    }, {
      "extension" : "java",
      "year" : "2022",
      "commitsCount" : 1,
      "contributors" : [ "14280154+hiboyang@users.noreply.github.com" ]
    } ]
  },
  "unitsAnalysisResults" : {
    "totalNumberOfUnits" : 1545,
    "linesOfCodeInUnits" : 12539,
    "unitSizeRiskDistribution" : {
      "key" : "",
      "lowRiskThreshold" : 10,
      "mediumRiskThreshold" : 20,
      "highRiskThreshold" : 50,
      "veryHighRiskThreshold" : 100,
      "negligibleRiskValue" : 5623,
      "lowRiskValue" : 2185,
      "mediumRiskValue" : 2687,
      "highRiskValue" : 1334,
      "veryHighRiskValue" : 710,
      "lowRiskCount" : 152,
      "negligibleRiskCount" : 1283,
      "mediumRiskCount" : 84,
      "highRiskCount" : 21,
      "veryHighRiskCount" : 5,
      "negligibleRiskLabel" : "1-10",
      "lowRiskLabel" : "11-20",
      "mediumRiskLabel" : "21-50",
      "highRiskLabel" : "51-100",
      "veryHighRiskLabel" : "101+",
      "negligibleRiskPercentage" : 44.84408645027514,
      "veryHighRiskPercentage" : 5.662333519419412,
      "highRiskPercentage" : 10.638806922402106,
      "mediumRiskPercentage" : 21.429141079830927,
      "lowRiskPercentage" : 17.425632028072414,
      "totalValue" : 12539,
      "totalCount" : 1545
    },
    "conditionalComplexityRiskDistribution" : {
      "key" : "",
      "lowRiskThreshold" : 5,
      "mediumRiskThreshold" : 10,
      "highRiskThreshold" : 25,
      "veryHighRiskThreshold" : 50,
      "negligibleRiskValue" : 8978,
      "lowRiskValue" : 2037,
      "mediumRiskValue" : 1290,
      "highRiskValue" : 234,
      "veryHighRiskValue" : 0,
      "lowRiskCount" : 63,
      "negligibleRiskCount" : 1464,
      "mediumRiskCount" : 16,
      "highRiskCount" : 2,
      "veryHighRiskCount" : 0,
      "negligibleRiskLabel" : "1-5",
      "lowRiskLabel" : "6-10",
      "mediumRiskLabel" : "11-25",
      "highRiskLabel" : "26-50",
      "veryHighRiskLabel" : "51+",
      "negligibleRiskPercentage" : 71.60060610894011,
      "veryHighRiskPercentage" : 0.0,
      "highRiskPercentage" : 1.8661775261185103,
      "mediumRiskPercentage" : 10.287901746550762,
      "lowRiskPercentage" : 16.245314618390623,
      "totalValue" : 12539,
      "totalCount" : 1545
    },
    "unitSizeRiskDistributionPerExtension" : [ {
      "key" : "java",
      "lowRiskThreshold" : 10,
      "mediumRiskThreshold" : 20,
      "highRiskThreshold" : 50,
      "veryHighRiskThreshold" : 100,
      "negligibleRiskValue" : 5430,
      "lowRiskValue" : 1959,
      "mediumRiskValue" : 2293,
      "highRiskValue" : 908,
      "veryHighRiskValue" : 563,
      "lowRiskCount" : 137,
      "negligibleRiskCount" : 1239,
      "mediumRiskCount" : 72,
      "highRiskCount" : 14,
      "veryHighRiskCount" : 4,
      "negligibleRiskLabel" : "1-10",
      "lowRiskLabel" : "11-20",
      "mediumRiskLabel" : "21-50",
      "highRiskLabel" : "51-100",
      "veryHighRiskLabel" : "101+",
      "negligibleRiskPercentage" : 48.68645207567471,
      "veryHighRiskPercentage" : 5.047969156280821,
      "highRiskPercentage" : 8.14130727158612,
      "mediumRiskPercentage" : 20.559490719985654,
      "lowRiskPercentage" : 17.5647807764727,
      "totalValue" : 11153,
      "totalCount" : 1466
    }, {
      "key" : "scala",
      "lowRiskThreshold" : 10,
      "mediumRiskThreshold" : 20,
      "highRiskThreshold" : 50,
      "veryHighRiskThreshold" : 100,
      "negligibleRiskValue" : 193,
      "lowRiskValue" : 226,
      "mediumRiskValue" : 394,
      "highRiskValue" : 426,
      "veryHighRiskValue" : 147,
      "lowRiskCount" : 15,
      "negligibleRiskCount" : 44,
      "mediumRiskCount" : 12,
      "highRiskCount" : 7,
      "veryHighRiskCount" : 1,
      "negligibleRiskLabel" : "1-10",
      "lowRiskLabel" : "11-20",
      "mediumRiskLabel" : "21-50",
      "highRiskLabel" : "51-100",
      "veryHighRiskLabel" : "101+",
      "negligibleRiskPercentage" : 13.924963924963924,
      "veryHighRiskPercentage" : 10.606060606060606,
      "highRiskPercentage" : 30.735930735930737,
      "mediumRiskPercentage" : 28.427128427128427,
      "lowRiskPercentage" : 16.305916305916305,
      "totalValue" : 1386,
      "totalCount" : 79
    } ],
    "unitSizeRiskDistributionPerComponent" : [ [ {
      "key" : "src",
      "lowRiskThreshold" : 10,
      "mediumRiskThreshold" : 20,
      "highRiskThreshold" : 50,
      "veryHighRiskThreshold" : 100,
      "negligibleRiskValue" : 5623,
      "lowRiskValue" : 2185,
      "mediumRiskValue" : 2687,
      "highRiskValue" : 1334,
      "veryHighRiskValue" : 710,
      "lowRiskCount" : 152,
      "negligibleRiskCount" : 1283,
      "mediumRiskCount" : 84,
      "highRiskCount" : 21,
      "veryHighRiskCount" : 5,
      "negligibleRiskLabel" : "1-10",
      "lowRiskLabel" : "11-20",
      "mediumRiskLabel" : "21-50",
      "highRiskLabel" : "51-100",
      "veryHighRiskLabel" : "101+",
      "negligibleRiskPercentage" : 44.84408645027514,
      "veryHighRiskPercentage" : 5.662333519419412,
      "highRiskPercentage" : 10.638806922402106,
      "mediumRiskPercentage" : 21.429141079830927,
      "lowRiskPercentage" : 17.425632028072414,
      "totalValue" : 12539,
      "totalCount" : 1545
    } ] ],
    "longestUnits" : [ {
      "shortName" : "private void decodeImpl()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerMessageDecoder.java",
        "extension" : "java",
        "linesOfCode" : 347,
        "unitsCount" : 8,
        "unitsMcCabeIndexSum" : 57,
        "linesOfCodeInUnits" : 278
      },
      "startLine" : 131,
      "endLine" : 304,
      "linesOfCode" : 172,
      "mcCabeIndex" : 30,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
        "extension" : "java",
        "linesOfCode" : 615,
        "unitsCount" : 36,
        "unitsMcCabeIndexSum" : 101,
        "linesOfCodeInUnits" : 524
      },
      "startLine" : 297,
      "endLine" : 506,
      "linesOfCode" : 159,
      "mcCabeIndex" : 20,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "override def getWriter[K, V]()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
        "extension" : "scala",
        "linesOfCode" : 364,
        "unitsCount" : 8,
        "unitsMcCabeIndexSum" : 35,
        "linesOfCodeInUnits" : 311
      },
      "startLine" : 149,
      "endLine" : 312,
      "linesOfCode" : 147,
      "mcCabeIndex" : 14,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void simulateMapperTask()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
        "extension" : "java",
        "linesOfCode" : 615,
        "unitsCount" : 36,
        "unitsMcCabeIndexSum" : 101,
        "linesOfCodeInUnits" : 524
      },
      "startLine" : 552,
      "endLine" : 704,
      "linesOfCode" : 125,
      "mcCabeIndex" : 20,
      "numberOfParameters" : 7,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/SerializerBenchmark.java",
        "extension" : "java",
        "linesOfCode" : 164,
        "unitsCount" : 4,
        "unitsMcCabeIndexSum" : 21,
        "linesOfCodeInUnits" : 134
      },
      "startLine" : 81,
      "endLine" : 224,
      "linesOfCode" : 107,
      "mcCabeIndex" : 17,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void loadStateImpl()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
        "extension" : "java",
        "linesOfCode" : 547,
        "unitsCount" : 31,
        "unitsMcCabeIndexSum" : 85,
        "linesOfCodeInUnits" : 486
      },
      "startLine" : 648,
      "endLine" : 741,
      "linesOfCode" : 90,
      "mcCabeIndex" : 14,
      "numberOfParameters" : 5,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void channelRead()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/handlers/UploadChannelInboundHandler.java",
        "extension" : "java",
        "linesOfCode" : 184,
        "unitsCount" : 6,
        "unitsMcCabeIndexSum" : 20,
        "linesOfCodeInUnits" : 127
      },
      "startLine" : 124,
      "endLine" : 224,
      "linesOfCode" : 89,
      "mcCabeIndex" : 14,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static List getReachableServers()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/metadata/ServiceRegistryUtils.java",
        "extension" : "java",
        "linesOfCode" : 151,
        "unitsCount" : 5,
        "unitsMcCabeIndexSum" : 21,
        "linesOfCodeInUnits" : 123
      },
      "startLine" : 55,
      "endLine" : 142,
      "linesOfCode" : 75,
      "mcCabeIndex" : 11,
      "numberOfParameters" : 6,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "def run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssStressTool.scala",
        "extension" : "scala",
        "linesOfCode" : 348,
        "unitsCount" : 10,
        "unitsMcCabeIndexSum" : 31,
        "linesOfCodeInUnits" : 287
      },
      "startLine" : 171,
      "endLine" : 259,
      "linesOfCode" : 74,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void verifyRecords()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/StreamReadClientVerify.java",
        "extension" : "java",
        "linesOfCode" : 156,
        "unitsCount" : 9,
        "unitsMcCabeIndexSum" : 25,
        "linesOfCodeInUnits" : 119
      },
      "startLine" : 98,
      "endLine" : 175,
      "linesOfCode" : 68,
      "mcCabeIndex" : 11,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static void main()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
        "extension" : "java",
        "linesOfCode" : 615,
        "unitsCount" : 36,
        "unitsMcCabeIndexSum" : 101,
        "linesOfCodeInUnits" : 524
      },
      "startLine" : 758,
      "endLine" : 829,
      "linesOfCode" : 68,
      "mcCabeIndex" : 24,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/PartitionFileChecker.java",
        "extension" : "java",
        "linesOfCode" : 98,
        "unitsCount" : 2,
        "unitsMcCabeIndexSum" : 17,
        "linesOfCodeInUnits" : 78
      },
      "startLine" : 41,
      "endLine" : 111,
      "linesOfCode" : 65,
      "mcCabeIndex" : 14,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private def createBlockDownloaderPartitionRecordIteratorWithoutRetry()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRangeRecordIterator.scala",
        "extension" : "scala",
        "linesOfCode" : 175,
        "unitsCount" : 5,
        "unitsMcCabeIndexSum" : 21,
        "linesOfCodeInUnits" : 124
      },
      "startLine" : 95,
      "endLine" : 163,
      "linesOfCode" : 64,
      "mcCabeIndex" : 7,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "override def write()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleWriter.scala",
        "extension" : "scala",
        "linesOfCode" : 181,
        "unitsCount" : 6,
        "unitsMcCabeIndexSum" : 17,
        "linesOfCodeInUnits" : 124
      },
      "startLine" : 90,
      "endLine" : 168,
      "linesOfCode" : 63,
      "mcCabeIndex" : 4,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static StreamServerConfig buildFromArgs()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/StreamServerConfig.java",
        "extension" : "java",
        "linesOfCode" : 283,
        "unitsCount" : 50,
        "unitsMcCabeIndexSum" : 77,
        "linesOfCodeInUnits" : 234
      },
      "startLine" : 101,
      "endLine" : 169,
      "linesOfCode" : 62,
      "mcCabeIndex" : 26,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private Object getControlMessage()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerMessageDecoder.java",
        "extension" : "java",
        "linesOfCode" : 347,
        "unitsCount" : 8,
        "unitsMcCabeIndexSum" : 57,
        "linesOfCodeInUnits" : 278
      },
      "startLine" : 317,
      "endLine" : 376,
      "linesOfCode" : 60,
      "mcCabeIndex" : 20,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "override def read()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleReader.scala",
        "extension" : "scala",
        "linesOfCode" : 90,
        "unitsCount" : 1,
        "unitsMcCabeIndexSum" : 7,
        "linesOfCodeInUnits" : 60
      },
      "startLine" : 48,
      "endLine" : 122,
      "linesOfCode" : 60,
      "mcCabeIndex" : 7,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public synchronized TaskDataBlock readDataBlock()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedReadClient.java",
        "extension" : "java",
        "linesOfCode" : 365,
        "unitsCount" : 21,
        "unitsMcCabeIndexSum" : 63,
        "linesOfCodeInUnits" : 312
      },
      "startLine" : 185,
      "endLine" : 259,
      "linesOfCode" : 58,
      "mcCabeIndex" : 13,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "protected void connectSocket()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ClientBase.java",
        "extension" : "java",
        "linesOfCode" : 268,
        "unitsCount" : 17,
        "unitsMcCabeIndexSum" : 47,
        "linesOfCodeInUnits" : 214
      },
      "startLine" : 142,
      "endLine" : 205,
      "linesOfCode" : 58,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private def fetchNextDeserializationIterator()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRecordIterator.scala",
        "extension" : "scala",
        "linesOfCode" : 174,
        "unitsCount" : 4,
        "unitsMcCabeIndexSum" : 22,
        "linesOfCodeInUnits" : 106
      },
      "startLine" : 131,
      "endLine" : 198,
      "linesOfCode" : 58,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private[rss] def addRecordImpl()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterBufferManager.scala",
        "extension" : "scala",
        "linesOfCode" : 105,
        "unitsCount" : 5,
        "unitsMcCabeIndexSum" : 14,
        "linesOfCodeInUnits" : 77
      },
      "startLine" : 55,
      "endLine" : 115,
      "linesOfCode" : 56,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public GetDataAvailabilityResponse waitDataAvailable()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
        "extension" : "java",
        "linesOfCode" : 299,
        "unitsCount" : 13,
        "unitsMcCabeIndexSum" : 50,
        "linesOfCodeInUnits" : 236
      },
      "startLine" : 169,
      "endLine" : 233,
      "linesOfCode" : 55,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressToolLongRun.java",
        "extension" : "java",
        "linesOfCode" : 118,
        "unitsCount" : 2,
        "unitsMcCabeIndexSum" : 17,
        "linesOfCodeInUnits" : 97
      },
      "startLine" : 43,
      "endLine" : 107,
      "linesOfCode" : 55,
      "mcCabeIndex" : 4,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public ChannelFuture sendFiles()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadServerHandler.java",
        "extension" : "java",
        "linesOfCode" : 155,
        "unitsCount" : 7,
        "unitsMcCabeIndexSum" : 17,
        "linesOfCodeInUnits" : 114
      },
      "startLine" : 137,
      "endLine" : 197,
      "linesOfCode" : 54,
      "mcCabeIndex" : 3,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private ConnectUploadResponse connectImpl()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ServerIdAwareSyncWriteClient.java",
        "extension" : "java",
        "linesOfCode" : 127,
        "unitsCount" : 10,
        "unitsMcCabeIndexSum" : 19,
        "linesOfCodeInUnits" : 95
      },
      "startLine" : 98,
      "endLine" : 153,
      "linesOfCode" : 51,
      "mcCabeIndex" : 8,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "override def registerShuffle[K, V, C]()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
        "extension" : "scala",
        "linesOfCode" : 364,
        "unitsCount" : 8,
        "unitsMcCabeIndexSum" : 35,
        "linesOfCodeInUnits" : 311
      },
      "startLine" : 78,
      "endLine" : 146,
      "linesOfCode" : 51,
      "mcCabeIndex" : 3,
      "numberOfParameters" : 5,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static  String toString4SortedIntList()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/util/StringUtils.java",
        "extension" : "java",
        "linesOfCode" : 95,
        "unitsCount" : 2,
        "unitsMcCabeIndexSum" : 25,
        "linesOfCodeInUnits" : 87
      },
      "startLine" : 75,
      "endLine" : 129,
      "linesOfCode" : 50,
      "mcCabeIndex" : 14,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/StreamServer.java",
        "extension" : "java",
        "linesOfCode" : 303,
        "unitsCount" : 21,
        "unitsMcCabeIndexSum" : 43,
        "linesOfCodeInUnits" : 251
      },
      "startLine" : 188,
      "endLine" : 249,
      "linesOfCode" : 50,
      "mcCabeIndex" : 5,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public synchronized void registerServer()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/metadata/ZooKeeperServiceRegistry.java",
        "extension" : "java",
        "linesOfCode" : 191,
        "unitsCount" : 15,
        "unitsMcCabeIndexSum" : 36,
        "linesOfCodeInUnits" : 158
      },
      "startLine" : 91,
      "endLine" : 151,
      "linesOfCode" : 50,
      "mcCabeIndex" : 12,
      "numberOfParameters" : 5,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private def simulateMapperTask()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssStressTool.scala",
        "extension" : "scala",
        "linesOfCode" : 348,
        "unitsCount" : 10,
        "unitsMcCabeIndexSum" : 31,
        "linesOfCodeInUnits" : 287
      },
      "startLine" : 293,
      "endLine" : 352,
      "linesOfCode" : 50,
      "mcCabeIndex" : 4,
      "numberOfParameters" : 4,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void collectMetrics()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/metrics/ScheduledMetricCollector.java",
        "extension" : "java",
        "linesOfCode" : 97,
        "unitsCount" : 3,
        "unitsMcCabeIndexSum" : 12,
        "linesOfCodeInUnits" : 60
      },
      "startLine" : 72,
      "endLine" : 129,
      "linesOfCode" : 49,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private StateStoreLoadResult loadStateStoreImpl()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
        "extension" : "java",
        "linesOfCode" : 547,
        "unitsCount" : 31,
        "unitsMcCabeIndexSum" : 85,
        "linesOfCodeInUnits" : 486
      },
      "startLine" : 591,
      "endLine" : 646,
      "linesOfCode" : 49,
      "mcCabeIndex" : 8,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void connect()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
        "extension" : "java",
        "linesOfCode" : 332,
        "unitsCount" : 21,
        "unitsMcCabeIndexSum" : 56,
        "linesOfCodeInUnits" : 260
      },
      "startLine" : 126,
      "endLine" : 180,
      "linesOfCode" : 48,
      "mcCabeIndex" : 9,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void shutdown()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/StreamServer.java",
        "extension" : "java",
        "linesOfCode" : 303,
        "unitsCount" : 21,
        "unitsMcCabeIndexSum" : 43,
        "linesOfCodeInUnits" : 251
      },
      "startLine" : 288,
      "endLine" : 344,
      "linesOfCode" : 48,
      "mcCabeIndex" : 9,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private ConnectDownloadResponse connectImpl()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
        "extension" : "java",
        "linesOfCode" : 299,
        "unitsCount" : 13,
        "unitsMcCabeIndexSum" : 50,
        "linesOfCodeInUnits" : 236
      },
      "startLine" : 108,
      "endLine" : 167,
      "linesOfCode" : 47,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/FsyncPerfTest.java",
        "extension" : "java",
        "linesOfCode" : 131,
        "unitsCount" : 4,
        "unitsMcCabeIndexSum" : 16,
        "linesOfCodeInUnits" : 99
      },
      "startLine" : 91,
      "endLine" : 148,
      "linesOfCode" : 47,
      "mcCabeIndex" : 4,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private BaseMessage readDataItem()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/execution/LocalFileStateStoreIterator.java",
        "extension" : "java",
        "linesOfCode" : 173,
        "unitsCount" : 8,
        "unitsMcCabeIndexSum" : 29,
        "linesOfCodeInUnits" : 120
      },
      "startLine" : 124,
      "endLine" : 174,
      "linesOfCode" : 47,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void addVersionDecoder()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerVersionDecoder.java",
        "extension" : "java",
        "linesOfCode" : 113,
        "unitsCount" : 3,
        "unitsMcCabeIndexSum" : 16,
        "linesOfCodeInUnits" : 86
      },
      "startLine" : 64,
      "endLine" : 110,
      "linesOfCode" : 46,
      "mcCabeIndex" : 9,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void removeExpiredApplications()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
        "extension" : "java",
        "linesOfCode" : 547,
        "unitsCount" : 31,
        "unitsMcCabeIndexSum" : 85,
        "linesOfCodeInUnits" : 486
      },
      "startLine" : 537,
      "endLine" : 589,
      "linesOfCode" : 43,
      "mcCabeIndex" : 7,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public List getNonEmptyPartitionFiles()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadServerHandler.java",
        "extension" : "java",
        "linesOfCode" : 155,
        "unitsCount" : 7,
        "unitsMcCabeIndexSum" : 17,
        "linesOfCodeInUnits" : 114
      },
      "startLine" : 83,
      "endLine" : 131,
      "linesOfCode" : 43,
      "mcCabeIndex" : 9,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static void main()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressToolLongRun.java",
        "extension" : "java",
        "linesOfCode" : 118,
        "unitsCount" : 2,
        "unitsMcCabeIndexSum" : 17,
        "linesOfCodeInUnits" : 97
      },
      "startLine" : 109,
      "endLine" : 155,
      "linesOfCode" : 42,
      "mcCabeIndex" : 13,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void channelRead()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadChannelInboundHandler.java",
        "extension" : "java",
        "linesOfCode" : 159,
        "unitsCount" : 7,
        "unitsMcCabeIndexSum" : 19,
        "linesOfCodeInUnits" : 111
      },
      "startLine" : 111,
      "endLine" : 161,
      "linesOfCode" : 42,
      "mcCabeIndex" : 7,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public ConnectUploadResponse connect()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ServerBusyRetriableWriteClient.java",
        "extension" : "java",
        "linesOfCode" : 106,
        "unitsCount" : 9,
        "unitsMcCabeIndexSum" : 18,
        "linesOfCodeInUnits" : 78
      },
      "startLine" : 53,
      "endLine" : 100,
      "linesOfCode" : 41,
      "mcCabeIndex" : 8,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void channelRead()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/handlers/HttpChannelInboundHandler.java",
        "extension" : "java",
        "linesOfCode" : 76,
        "unitsCount" : 3,
        "unitsMcCabeIndexSum" : 8,
        "linesOfCodeInUnits" : 51
      },
      "startLine" : 45,
      "endLine" : 91,
      "linesOfCode" : 41,
      "mcCabeIndex" : 6,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void connectAndInitializeClient()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSocketReadClient.java",
        "extension" : "java",
        "linesOfCode" : 149,
        "unitsCount" : 9,
        "unitsMcCabeIndexSum" : 21,
        "linesOfCodeInUnits" : 118
      },
      "startLine" : 135,
      "endLine" : 179,
      "linesOfCode" : 40,
      "mcCabeIndex" : 6,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/FileDescriptorStressTest.java",
        "extension" : "java",
        "linesOfCode" : 68,
        "unitsCount" : 3,
        "unitsMcCabeIndexSum" : 13,
        "linesOfCodeInUnits" : 56
      },
      "startLine" : 36,
      "endLine" : 77,
      "linesOfCode" : 40,
      "mcCabeIndex" : 7,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "override def getReader[K, C]()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
        "extension" : "scala",
        "linesOfCode" : 364,
        "unitsCount" : 8,
        "unitsMcCabeIndexSum" : 35,
        "linesOfCodeInUnits" : 311
      },
      "startLine" : 315,
      "endLine" : 357,
      "linesOfCode" : 40,
      "mcCabeIndex" : 2,
      "numberOfParameters" : 4,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "def getRssInfoFromMapOutputTracker()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssUtils.scala",
        "extension" : "scala",
        "linesOfCode" : 82,
        "unitsCount" : 5,
        "unitsMcCabeIndexSum" : 12,
        "linesOfCodeInUnits" : 70
      },
      "startLine" : 83,
      "endLine" : 123,
      "linesOfCode" : 40,
      "mcCabeIndex" : 6,
      "numberOfParameters" : 4,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void createServiceRegistry()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/StreamServer.java",
        "extension" : "java",
        "linesOfCode" : 303,
        "unitsCount" : 21,
        "unitsMcCabeIndexSum" : 43,
        "linesOfCodeInUnits" : 251
      },
      "startLine" : 121,
      "endLine" : 159,
      "linesOfCode" : 39,
      "mcCabeIndex" : 8,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private NotificationListener createListener()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/common/MemoryMonitor.java",
        "extension" : "java",
        "linesOfCode" : 70,
        "unitsCount" : 2,
        "unitsMcCabeIndexSum" : 7,
        "linesOfCodeInUnits" : 47
      },
      "startLine" : 52,
      "endLine" : 92,
      "linesOfCode" : 38,
      "mcCabeIndex" : 5,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    } ],
    "conditionalComplexityRiskDistributionPerExtension" : [ {
      "key" : "java",
      "lowRiskThreshold" : 5,
      "mediumRiskThreshold" : 10,
      "highRiskThreshold" : 25,
      "veryHighRiskThreshold" : 50,
      "negligibleRiskValue" : 8191,
      "lowRiskValue" : 1585,
      "mediumRiskValue" : 1143,
      "highRiskValue" : 234,
      "veryHighRiskValue" : 0,
      "lowRiskCount" : 54,
      "negligibleRiskCount" : 1395,
      "mediumRiskCount" : 15,
      "highRiskCount" : 2,
      "veryHighRiskCount" : 0,
      "negligibleRiskLabel" : "1-5",
      "lowRiskLabel" : "6-10",
      "mediumRiskLabel" : "11-25",
      "highRiskLabel" : "26-50",
      "veryHighRiskLabel" : "51+",
      "negligibleRiskPercentage" : 73.44212319555277,
      "veryHighRiskPercentage" : 0.0,
      "highRiskPercentage" : 2.0980901999462027,
      "mediumRiskPercentage" : 10.248363668967992,
      "lowRiskPercentage" : 14.21142293553304,
      "totalValue" : 11153,
      "totalCount" : 1466
    }, {
      "key" : "scala",
      "lowRiskThreshold" : 5,
      "mediumRiskThreshold" : 10,
      "highRiskThreshold" : 25,
      "veryHighRiskThreshold" : 50,
      "negligibleRiskValue" : 787,
      "lowRiskValue" : 452,
      "mediumRiskValue" : 147,
      "highRiskValue" : 0,
      "veryHighRiskValue" : 0,
      "lowRiskCount" : 9,
      "negligibleRiskCount" : 69,
      "mediumRiskCount" : 1,
      "highRiskCount" : 0,
      "veryHighRiskCount" : 0,
      "negligibleRiskLabel" : "1-5",
      "lowRiskLabel" : "6-10",
      "mediumRiskLabel" : "11-25",
      "highRiskLabel" : "26-50",
      "veryHighRiskLabel" : "51+",
      "negligibleRiskPercentage" : 56.78210678210678,
      "veryHighRiskPercentage" : 0.0,
      "highRiskPercentage" : 0.0,
      "mediumRiskPercentage" : 10.606060606060606,
      "lowRiskPercentage" : 32.61183261183261,
      "totalValue" : 1386,
      "totalCount" : 79
    } ],
    "conditionalComplexityRiskDistributionPerComponent" : [ [ {
      "key" : "src",
      "lowRiskThreshold" : 5,
      "mediumRiskThreshold" : 10,
      "highRiskThreshold" : 25,
      "veryHighRiskThreshold" : 50,
      "negligibleRiskValue" : 8978,
      "lowRiskValue" : 2037,
      "mediumRiskValue" : 1290,
      "highRiskValue" : 234,
      "veryHighRiskValue" : 0,
      "lowRiskCount" : 63,
      "negligibleRiskCount" : 1464,
      "mediumRiskCount" : 16,
      "highRiskCount" : 2,
      "veryHighRiskCount" : 0,
      "negligibleRiskLabel" : "1-5",
      "lowRiskLabel" : "6-10",
      "mediumRiskLabel" : "11-25",
      "highRiskLabel" : "26-50",
      "veryHighRiskLabel" : "51+",
      "negligibleRiskPercentage" : 71.60060610894011,
      "veryHighRiskPercentage" : 0.0,
      "highRiskPercentage" : 1.8661775261185103,
      "mediumRiskPercentage" : 10.287901746550762,
      "lowRiskPercentage" : 16.245314618390623,
      "totalValue" : 12539,
      "totalCount" : 1545
    } ] ],
    "mostComplexUnits" : [ {
      "shortName" : "private void decodeImpl()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerMessageDecoder.java",
        "extension" : "java",
        "linesOfCode" : 347,
        "unitsCount" : 8,
        "unitsMcCabeIndexSum" : 57,
        "linesOfCodeInUnits" : 278
      },
      "startLine" : 131,
      "endLine" : 304,
      "linesOfCode" : 172,
      "mcCabeIndex" : 30,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static StreamServerConfig buildFromArgs()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/StreamServerConfig.java",
        "extension" : "java",
        "linesOfCode" : 283,
        "unitsCount" : 50,
        "unitsMcCabeIndexSum" : 77,
        "linesOfCodeInUnits" : 234
      },
      "startLine" : 101,
      "endLine" : 169,
      "linesOfCode" : 62,
      "mcCabeIndex" : 26,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static void main()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
        "extension" : "java",
        "linesOfCode" : 615,
        "unitsCount" : 36,
        "unitsMcCabeIndexSum" : 101,
        "linesOfCodeInUnits" : 524
      },
      "startLine" : 758,
      "endLine" : 829,
      "linesOfCode" : 68,
      "mcCabeIndex" : 24,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
        "extension" : "java",
        "linesOfCode" : 615,
        "unitsCount" : 36,
        "unitsMcCabeIndexSum" : 101,
        "linesOfCodeInUnits" : 524
      },
      "startLine" : 297,
      "endLine" : 506,
      "linesOfCode" : 159,
      "mcCabeIndex" : 20,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void simulateMapperTask()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressTool.java",
        "extension" : "java",
        "linesOfCode" : 615,
        "unitsCount" : 36,
        "unitsMcCabeIndexSum" : 101,
        "linesOfCodeInUnits" : 524
      },
      "startLine" : 552,
      "endLine" : 704,
      "linesOfCode" : 125,
      "mcCabeIndex" : 20,
      "numberOfParameters" : 7,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private Object getControlMessage()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerMessageDecoder.java",
        "extension" : "java",
        "linesOfCode" : 347,
        "unitsCount" : 8,
        "unitsMcCabeIndexSum" : 57,
        "linesOfCodeInUnits" : 278
      },
      "startLine" : 317,
      "endLine" : 376,
      "linesOfCode" : 60,
      "mcCabeIndex" : 20,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/SerializerBenchmark.java",
        "extension" : "java",
        "linesOfCode" : 164,
        "unitsCount" : 4,
        "unitsMcCabeIndexSum" : 21,
        "linesOfCodeInUnits" : 134
      },
      "startLine" : 81,
      "endLine" : 224,
      "linesOfCode" : 107,
      "mcCabeIndex" : 17,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/PartitionFileChecker.java",
        "extension" : "java",
        "linesOfCode" : 98,
        "unitsCount" : 2,
        "unitsMcCabeIndexSum" : 17,
        "linesOfCodeInUnits" : 78
      },
      "startLine" : 41,
      "endLine" : 111,
      "linesOfCode" : 65,
      "mcCabeIndex" : 14,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static  String toString4SortedIntList()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/util/StringUtils.java",
        "extension" : "java",
        "linesOfCode" : 95,
        "unitsCount" : 2,
        "unitsMcCabeIndexSum" : 25,
        "linesOfCodeInUnits" : 87
      },
      "startLine" : 75,
      "endLine" : 129,
      "linesOfCode" : 50,
      "mcCabeIndex" : 14,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void loadStateImpl()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
        "extension" : "java",
        "linesOfCode" : 547,
        "unitsCount" : 31,
        "unitsMcCabeIndexSum" : 85,
        "linesOfCodeInUnits" : 486
      },
      "startLine" : 648,
      "endLine" : 741,
      "linesOfCode" : 90,
      "mcCabeIndex" : 14,
      "numberOfParameters" : 5,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void channelRead()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/handlers/UploadChannelInboundHandler.java",
        "extension" : "java",
        "linesOfCode" : 184,
        "unitsCount" : 6,
        "unitsMcCabeIndexSum" : 20,
        "linesOfCodeInUnits" : 127
      },
      "startLine" : 124,
      "endLine" : 224,
      "linesOfCode" : 89,
      "mcCabeIndex" : 14,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "override def getWriter[K, V]()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
        "extension" : "scala",
        "linesOfCode" : 364,
        "unitsCount" : 8,
        "unitsMcCabeIndexSum" : 35,
        "linesOfCodeInUnits" : 311
      },
      "startLine" : 149,
      "endLine" : 312,
      "linesOfCode" : 147,
      "mcCabeIndex" : 14,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public synchronized TaskDataBlock readDataBlock()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedReadClient.java",
        "extension" : "java",
        "linesOfCode" : 365,
        "unitsCount" : 21,
        "unitsMcCabeIndexSum" : 63,
        "linesOfCodeInUnits" : 312
      },
      "startLine" : 185,
      "endLine" : 259,
      "linesOfCode" : 58,
      "mcCabeIndex" : 13,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static void main()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressToolLongRun.java",
        "extension" : "java",
        "linesOfCode" : 118,
        "unitsCount" : 2,
        "unitsMcCabeIndexSum" : 17,
        "linesOfCodeInUnits" : 97
      },
      "startLine" : 109,
      "endLine" : 155,
      "linesOfCode" : 42,
      "mcCabeIndex" : 13,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public synchronized void registerServer()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/metadata/ZooKeeperServiceRegistry.java",
        "extension" : "java",
        "linesOfCode" : 191,
        "unitsCount" : 15,
        "unitsMcCabeIndexSum" : 36,
        "linesOfCodeInUnits" : 158
      },
      "startLine" : 91,
      "endLine" : 151,
      "linesOfCode" : 50,
      "mcCabeIndex" : 12,
      "numberOfParameters" : 5,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void verifyRecords()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/StreamReadClientVerify.java",
        "extension" : "java",
        "linesOfCode" : 156,
        "unitsCount" : 9,
        "unitsMcCabeIndexSum" : 25,
        "linesOfCodeInUnits" : 119
      },
      "startLine" : 98,
      "endLine" : 175,
      "linesOfCode" : 68,
      "mcCabeIndex" : 11,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static Long getBytesValue()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/util/StringUtils.java",
        "extension" : "java",
        "linesOfCode" : 95,
        "unitsCount" : 2,
        "unitsMcCabeIndexSum" : 25,
        "linesOfCodeInUnits" : 87
      },
      "startLine" : 26,
      "endLine" : 67,
      "linesOfCode" : 37,
      "mcCabeIndex" : 11,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static List getReachableServers()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/metadata/ServiceRegistryUtils.java",
        "extension" : "java",
        "linesOfCode" : 151,
        "unitsCount" : 5,
        "unitsMcCabeIndexSum" : 21,
        "linesOfCodeInUnits" : 123
      },
      "startLine" : 55,
      "endLine" : 142,
      "linesOfCode" : 75,
      "mcCabeIndex" : 11,
      "numberOfParameters" : 6,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void collectMetrics()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/metrics/ScheduledMetricCollector.java",
        "extension" : "java",
        "linesOfCode" : 97,
        "unitsCount" : 3,
        "unitsMcCabeIndexSum" : 12,
        "linesOfCodeInUnits" : 60
      },
      "startLine" : 72,
      "endLine" : 129,
      "linesOfCode" : 49,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private ConnectDownloadResponse connectImpl()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
        "extension" : "java",
        "linesOfCode" : 299,
        "unitsCount" : 13,
        "unitsMcCabeIndexSum" : 50,
        "linesOfCodeInUnits" : 236
      },
      "startLine" : 108,
      "endLine" : 167,
      "linesOfCode" : 47,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public GetDataAvailabilityResponse waitDataAvailable()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
        "extension" : "java",
        "linesOfCode" : 299,
        "unitsCount" : 13,
        "unitsMcCabeIndexSum" : 50,
        "linesOfCodeInUnits" : 236
      },
      "startLine" : 169,
      "endLine" : 233,
      "linesOfCode" : 55,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void close()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ClientBase.java",
        "extension" : "java",
        "linesOfCode" : 268,
        "unitsCount" : 17,
        "unitsMcCabeIndexSum" : 47,
        "linesOfCodeInUnits" : 214
      },
      "startLine" : 89,
      "endLine" : 131,
      "linesOfCode" : 37,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "protected void connectSocket()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ClientBase.java",
        "extension" : "java",
        "linesOfCode" : 268,
        "unitsCount" : 17,
        "unitsMcCabeIndexSum" : 47,
        "linesOfCodeInUnits" : 214
      },
      "startLine" : 142,
      "endLine" : 205,
      "linesOfCode" : 58,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private BaseMessage readDataItem()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/execution/LocalFileStateStoreIterator.java",
        "extension" : "java",
        "linesOfCode" : 173,
        "unitsCount" : 8,
        "unitsMcCabeIndexSum" : 29,
        "linesOfCodeInUnits" : 120
      },
      "startLine" : 124,
      "endLine" : 174,
      "linesOfCode" : 47,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private[rss] def addRecordImpl()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/WriterBufferManager.scala",
        "extension" : "scala",
        "linesOfCode" : 105,
        "unitsCount" : 5,
        "unitsMcCabeIndexSum" : 14,
        "linesOfCodeInUnits" : 77
      },
      "startLine" : 55,
      "endLine" : 115,
      "linesOfCode" : 56,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "def run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssStressTool.scala",
        "extension" : "scala",
        "linesOfCode" : 348,
        "unitsCount" : 10,
        "unitsMcCabeIndexSum" : 31,
        "linesOfCodeInUnits" : 287
      },
      "startLine" : 171,
      "endLine" : 259,
      "linesOfCode" : 74,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private def fetchNextDeserializationIterator()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRecordIterator.scala",
        "extension" : "scala",
        "linesOfCode" : 174,
        "unitsCount" : 4,
        "unitsMcCabeIndexSum" : 22,
        "linesOfCodeInUnits" : 106
      },
      "startLine" : 131,
      "endLine" : 198,
      "linesOfCode" : 58,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "override def onJobEnd()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/RssSparkListener.scala",
        "extension" : "scala",
        "linesOfCode" : 111,
        "unitsCount" : 6,
        "unitsMcCabeIndexSum" : 23,
        "linesOfCodeInUnits" : 86
      },
      "startLine" : 90,
      "endLine" : 123,
      "linesOfCode" : 32,
      "mcCabeIndex" : 10,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void connect()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
        "extension" : "java",
        "linesOfCode" : 332,
        "unitsCount" : 21,
        "unitsMcCabeIndexSum" : 56,
        "linesOfCodeInUnits" : 260
      },
      "startLine" : 126,
      "endLine" : 180,
      "linesOfCode" : 48,
      "mcCabeIndex" : 9,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void writeDataBlock()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
        "extension" : "java",
        "linesOfCode" : 332,
        "unitsCount" : 21,
        "unitsMcCabeIndexSum" : 56,
        "linesOfCodeInUnits" : 260
      },
      "startLine" : 189,
      "endLine" : 226,
      "linesOfCode" : 34,
      "mcCabeIndex" : 9,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void connectAndInitializeClient()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedReadClient.java",
        "extension" : "java",
        "linesOfCode" : 365,
        "unitsCount" : 21,
        "unitsMcCabeIndexSum" : 63,
        "linesOfCodeInUnits" : 312
      },
      "startLine" : 291,
      "endLine" : 332,
      "linesOfCode" : 37,
      "mcCabeIndex" : 9,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static void checkDiskFreeSpace()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/util/FileUtils.java",
        "extension" : "java",
        "linesOfCode" : 119,
        "unitsCount" : 5,
        "unitsMcCabeIndexSum" : 26,
        "linesOfCodeInUnits" : 98
      },
      "startLine" : 66,
      "endLine" : 105,
      "linesOfCode" : 37,
      "mcCabeIndex" : 9,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void shutdown()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/StreamServer.java",
        "extension" : "java",
        "linesOfCode" : 303,
        "unitsCount" : 21,
        "unitsMcCabeIndexSum" : 43,
        "linesOfCodeInUnits" : 251
      },
      "startLine" : 288,
      "endLine" : 344,
      "linesOfCode" : 48,
      "mcCabeIndex" : 9,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void addVersionDecoder()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerVersionDecoder.java",
        "extension" : "java",
        "linesOfCode" : 113,
        "unitsCount" : 3,
        "unitsMcCabeIndexSum" : 16,
        "linesOfCodeInUnits" : 86
      },
      "startLine" : 64,
      "endLine" : 110,
      "linesOfCode" : 46,
      "mcCabeIndex" : 9,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public List getNonEmptyPartitionFiles()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/handlers/DownloadServerHandler.java",
        "extension" : "java",
        "linesOfCode" : 155,
        "unitsCount" : 7,
        "unitsMcCabeIndexSum" : 17,
        "linesOfCodeInUnits" : 114
      },
      "startLine" : 83,
      "endLine" : 131,
      "linesOfCode" : 43,
      "mcCabeIndex" : 9,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public boolean equals()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/PooledWriteClientFactory.java",
        "extension" : "java",
        "linesOfCode" : 253,
        "unitsCount" : 30,
        "unitsMcCabeIndexSum" : 52,
        "linesOfCodeInUnits" : 202
      },
      "startLine" : 158,
      "endLine" : 167,
      "linesOfCode" : 10,
      "mcCabeIndex" : 8,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private ConnectUploadResponse connectImpl()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ServerIdAwareSyncWriteClient.java",
        "extension" : "java",
        "linesOfCode" : 127,
        "unitsCount" : 10,
        "unitsMcCabeIndexSum" : 19,
        "linesOfCodeInUnits" : 95
      },
      "startLine" : 98,
      "endLine" : 153,
      "linesOfCode" : 51,
      "mcCabeIndex" : 8,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void runAllActiveClients()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedWriteClient.java",
        "extension" : "java",
        "linesOfCode" : 153,
        "unitsCount" : 12,
        "unitsMcCabeIndexSum" : 33,
        "linesOfCodeInUnits" : 122
      },
      "startLine" : 145,
      "endLine" : 181,
      "linesOfCode" : 34,
      "mcCabeIndex" : 8,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public ConnectUploadResponse connect()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ServerBusyRetriableWriteClient.java",
        "extension" : "java",
        "linesOfCode" : 106,
        "unitsCount" : 9,
        "unitsMcCabeIndexSum" : 18,
        "linesOfCodeInUnits" : 78
      },
      "startLine" : 53,
      "endLine" : 100,
      "linesOfCode" : 41,
      "mcCabeIndex" : 8,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private void createServiceRegistry()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/StreamServer.java",
        "extension" : "java",
        "linesOfCode" : 303,
        "unitsCount" : 21,
        "unitsMcCabeIndexSum" : 43,
        "linesOfCodeInUnits" : 251
      },
      "startLine" : 121,
      "endLine" : 159,
      "linesOfCode" : 39,
      "mcCabeIndex" : 8,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public boolean equals()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/common/AppTaskAttemptId.java",
        "extension" : "java",
        "linesOfCode" : 71,
        "unitsCount" : 14,
        "unitsMcCabeIndexSum" : 21,
        "linesOfCodeInUnits" : 59
      },
      "startLine" : 78,
      "endLine" : 87,
      "linesOfCode" : 10,
      "mcCabeIndex" : 8,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private StateStoreLoadResult loadStateStoreImpl()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
        "extension" : "java",
        "linesOfCode" : 547,
        "unitsCount" : 31,
        "unitsMcCabeIndexSum" : 85,
        "linesOfCodeInUnits" : 486
      },
      "startLine" : 591,
      "endLine" : 646,
      "linesOfCode" : 49,
      "mcCabeIndex" : 8,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private def getRssServers()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
        "extension" : "scala",
        "linesOfCode" : 364,
        "unitsCount" : 8,
        "unitsMcCabeIndexSum" : 35,
        "linesOfCodeInUnits" : 311
      },
      "startLine" : 376,
      "endLine" : 424,
      "linesOfCode" : 37,
      "mcCabeIndex" : 8,
      "numberOfParameters" : 3,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static List createReplicationGroups()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ServerReplicationGroupUtil.java",
        "extension" : "java",
        "linesOfCode" : 55,
        "unitsCount" : 2,
        "unitsMcCabeIndexSum" : 10,
        "linesOfCodeInUnits" : 42
      },
      "startLine" : 37,
      "endLine" : 66,
      "linesOfCode" : 24,
      "mcCabeIndex" : 7,
      "numberOfParameters" : 2,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public TDecodeResult decode()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/StreamDecoderBase.java",
        "extension" : "java",
        "linesOfCode" : 117,
        "unitsCount" : 9,
        "unitsMcCabeIndexSum" : 27,
        "linesOfCodeInUnits" : 104
      },
      "startLine" : 40,
      "endLine" : 62,
      "linesOfCode" : 21,
      "mcCabeIndex" : 7,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private DataBlock readDataBlockNoCheckTaskAttemptId()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
        "extension" : "java",
        "linesOfCode" : 299,
        "unitsCount" : 13,
        "unitsMcCabeIndexSum" : 50,
        "linesOfCodeInUnits" : 236
      },
      "startLine" : 307,
      "endLine" : 336,
      "linesOfCode" : 24,
      "mcCabeIndex" : 7,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public synchronized long getShuffleWriteBytes()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ReplicatedWriteClient.java",
        "extension" : "java",
        "linesOfCode" : 153,
        "unitsCount" : 12,
        "unitsMcCabeIndexSum" : 33,
        "linesOfCodeInUnits" : 122
      },
      "startLine" : 92,
      "endLine" : 120,
      "linesOfCode" : 25,
      "mcCabeIndex" : 7,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "private final void checkOKResponseStatus()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/clients/ClientBase.java",
        "extension" : "java",
        "linesOfCode" : 268,
        "unitsCount" : 17,
        "unitsMcCabeIndexSum" : 47,
        "linesOfCodeInUnits" : 214
      },
      "startLine" : 286,
      "endLine" : 303,
      "linesOfCode" : 18,
      "mcCabeIndex" : 7,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public static void main()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/StreamReadClientVerify.java",
        "extension" : "java",
        "linesOfCode" : 156,
        "unitsCount" : 9,
        "unitsMcCabeIndexSum" : 25,
        "linesOfCodeInUnits" : 119
      },
      "startLine" : 177,
      "endLine" : 206,
      "linesOfCode" : 27,
      "mcCabeIndex" : 7,
      "numberOfParameters" : 1,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    }, {
      "shortName" : "public void run()",
      "longName" : "",
      "sourceFile" : {
        "relativePath" : "src/main/java/com/uber/rss/tools/FileDescriptorStressTest.java",
        "extension" : "java",
        "linesOfCode" : 68,
        "unitsCount" : 3,
        "unitsMcCabeIndexSum" : 13,
        "linesOfCodeInUnits" : 56
      },
      "startLine" : 36,
      "endLine" : 77,
      "linesOfCode" : 40,
      "mcCabeIndex" : 7,
      "numberOfParameters" : 0,
      "numberOfLiterals" : 0,
      "numberOfStatements" : 0,
      "numberOfExpressions" : 0,
      "children" : [ ]
    } ]
  },
  "duplicationAnalysisResults" : {
    "overallDuplication" : {
      "key" : "system",
      "numberOfDuplicates" : 100,
      "cleanedLinesOfCode" : 12304,
      "duplicatedLinesOfCode" : 1037,
      "numberOfFilesWithDuplicates" : 59,
      "duplicationPercentage" : 8.42815344603381
    },
    "duplicationPerComponent" : [ [ {
      "key" : "src",
      "numberOfDuplicates" : 0,
      "cleanedLinesOfCode" : 12304,
      "duplicatedLinesOfCode" : 1037,
      "numberOfFilesWithDuplicates" : 0,
      "duplicationPercentage" : 8.42815344603381
    } ] ],
    "duplicationPerConcern" : [ ],
    "duplicationPerExtension" : [ {
      "key" : "java",
      "numberOfDuplicates" : 0,
      "cleanedLinesOfCode" : 10619,
      "duplicatedLinesOfCode" : 969,
      "numberOfFilesWithDuplicates" : 0,
      "duplicationPercentage" : 9.125153027592052
    }, {
      "key" : "scala",
      "numberOfDuplicates" : 0,
      "cleanedLinesOfCode" : 1685,
      "duplicatedLinesOfCode" : 68,
      "numberOfFilesWithDuplicates" : 0,
      "duplicationPercentage" : 4.035608308605341
    } ],
    "longestDuplicates" : [ {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/RecordSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 83,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 13,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 57,
        "startLine" : 44,
        "endLine" : 111,
        "cleanedStartLine" : 8,
        "cleanedEndLine" : 57,
        "percentage" : 87.71929824561404,
        "blockSize" : 50
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/ShuffleDataSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 83,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 13,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 57,
        "startLine" : 44,
        "endLine" : 111,
        "cleanedStartLine" : 8,
        "cleanedEndLine" : 57,
        "percentage" : 87.71929824561404,
        "blockSize" : 50
      } ],
      "blockSize" : 50
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequest.java",
          "extension" : "java",
          "linesOfCode" : 85,
          "unitsCount" : 12,
          "unitsMcCabeIndexSum" : 14,
          "linesOfCodeInUnits" : 67
        },
        "sourceFileCleanedLinesOfCode" : 63,
        "startLine" : 54,
        "endLine" : 115,
        "cleanedStartLine" : 20,
        "cleanedEndLine" : 63,
        "percentage" : 69.84126984126983,
        "blockSize" : 44
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequestMessage.java",
          "extension" : "java",
          "linesOfCode" : 89,
          "unitsCount" : 12,
          "unitsMcCabeIndexSum" : 14,
          "linesOfCodeInUnits" : 71
        },
        "sourceFileCleanedLinesOfCode" : 67,
        "startLine" : 58,
        "endLine" : 119,
        "cleanedStartLine" : 24,
        "cleanedEndLine" : 67,
        "percentage" : 65.67164179104478,
        "blockSize" : 44
      } ],
      "blockSize" : 44
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 332,
          "unitsCount" : 21,
          "unitsMcCabeIndexSum" : 56,
          "linesOfCodeInUnits" : 260
        },
        "sourceFileCleanedLinesOfCode" : 243,
        "startLine" : 368,
        "endLine" : 391,
        "cleanedStartLine" : 210,
        "cleanedEndLine" : 227,
        "percentage" : 7.407407407407407,
        "blockSize" : 18
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 160,
          "unitsCount" : 14,
          "unitsMcCabeIndexSum" : 24,
          "linesOfCodeInUnits" : 114
        },
        "sourceFileCleanedLinesOfCode" : 115,
        "startLine" : 185,
        "endLine" : 208,
        "cleanedStartLine" : 98,
        "cleanedEndLine" : 115,
        "percentage" : 15.652173913043478,
        "blockSize" : 18
      } ],
      "blockSize" : 18
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/TaskByteArrayDataBlock.java",
          "extension" : "java",
          "linesOfCode" : 48,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 12,
          "linesOfCodeInUnits" : 33
        },
        "sourceFileCleanedLinesOfCode" : 35,
        "startLine" : 31,
        "endLine" : 55,
        "cleanedStartLine" : 5,
        "cleanedEndLine" : 20,
        "percentage" : 45.714285714285715,
        "blockSize" : 16
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/TaskDataBlock.java",
          "extension" : "java",
          "linesOfCode" : 48,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 12,
          "linesOfCodeInUnits" : 33
        },
        "sourceFileCleanedLinesOfCode" : 35,
        "startLine" : 31,
        "endLine" : 55,
        "cleanedStartLine" : 5,
        "cleanedEndLine" : 20,
        "percentage" : 45.714285714285715,
        "blockSize" : 16
      } ],
      "blockSize" : 16
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/TaskByteArrayDataBlock.java",
          "extension" : "java",
          "linesOfCode" : 48,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 12,
          "linesOfCodeInUnits" : 33
        },
        "sourceFileCleanedLinesOfCode" : 35,
        "startLine" : 57,
        "endLine" : 74,
        "cleanedStartLine" : 22,
        "cleanedEndLine" : 35,
        "percentage" : 40.0,
        "blockSize" : 14
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/TaskDataBlock.java",
          "extension" : "java",
          "linesOfCode" : 48,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 12,
          "linesOfCodeInUnits" : 33
        },
        "sourceFileCleanedLinesOfCode" : 35,
        "startLine" : 57,
        "endLine" : 74,
        "cleanedStartLine" : 22,
        "cleanedEndLine" : 35,
        "percentage" : 40.0,
        "blockSize" : 14
      } ],
      "blockSize" : 14
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 332,
          "unitsCount" : 21,
          "unitsMcCabeIndexSum" : 56,
          "linesOfCodeInUnits" : 260
        },
        "sourceFileCleanedLinesOfCode" : 243,
        "startLine" : 91,
        "endLine" : 104,
        "cleanedStartLine" : 30,
        "cleanedEndLine" : 42,
        "percentage" : 5.349794238683128,
        "blockSize" : 13
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 160,
          "unitsCount" : 14,
          "unitsMcCabeIndexSum" : 24,
          "linesOfCodeInUnits" : 114
        },
        "sourceFileCleanedLinesOfCode" : 115,
        "startLine" : 66,
        "endLine" : 79,
        "cleanedStartLine" : 21,
        "cleanedEndLine" : 33,
        "percentage" : 11.304347826086957,
        "blockSize" : 13
      } ],
      "blockSize" : 13
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 332,
          "unitsCount" : 21,
          "unitsMcCabeIndexSum" : 56,
          "linesOfCodeInUnits" : 260
        },
        "sourceFileCleanedLinesOfCode" : 243,
        "startLine" : 297,
        "endLine" : 315,
        "cleanedStartLine" : 170,
        "cleanedEndLine" : 181,
        "percentage" : 4.938271604938271,
        "blockSize" : 12
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 160,
          "unitsCount" : 14,
          "unitsMcCabeIndexSum" : 24,
          "linesOfCodeInUnits" : 114
        },
        "sourceFileCleanedLinesOfCode" : 115,
        "startLine" : 164,
        "endLine" : 181,
        "cleanedStartLine" : 86,
        "cleanedEndLine" : 97,
        "percentage" : 10.434782608695652,
        "blockSize" : 12
      } ],
      "blockSize" : 12
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 332,
          "unitsCount" : 21,
          "unitsMcCabeIndexSum" : 56,
          "linesOfCodeInUnits" : 260
        },
        "sourceFileCleanedLinesOfCode" : 243,
        "startLine" : 256,
        "endLine" : 273,
        "cleanedStartLine" : 145,
        "cleanedEndLine" : 155,
        "percentage" : 4.526748971193416,
        "blockSize" : 11
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 160,
          "unitsCount" : 14,
          "unitsMcCabeIndexSum" : 24,
          "linesOfCodeInUnits" : 114
        },
        "sourceFileCleanedLinesOfCode" : 115,
        "startLine" : 132,
        "endLine" : 149,
        "cleanedStartLine" : 66,
        "cleanedEndLine" : 76,
        "percentage" : 9.565217391304348,
        "blockSize" : 11
      } ],
      "blockSize" : 11
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/handlers/NotifyChannelInboundHandler.java",
          "extension" : "java",
          "linesOfCode" : 54,
          "unitsCount" : 5,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 34
        },
        "sourceFileCleanedLinesOfCode" : 33,
        "startLine" : 40,
        "endLine" : 55,
        "cleanedStartLine" : 7,
        "cleanedEndLine" : 17,
        "percentage" : 33.333333333333336,
        "blockSize" : 11
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/handlers/RegistryChannelInboundHandler.java",
          "extension" : "java",
          "linesOfCode" : 55,
          "unitsCount" : 5,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 34
        },
        "sourceFileCleanedLinesOfCode" : 33,
        "startLine" : 41,
        "endLine" : 56,
        "cleanedStartLine" : 7,
        "cleanedEndLine" : 17,
        "percentage" : 33.333333333333336,
        "blockSize" : 11
      } ],
      "blockSize" : 11
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/handlers/NotifyChannelInboundHandler.java",
          "extension" : "java",
          "linesOfCode" : 54,
          "unitsCount" : 5,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 34
        },
        "sourceFileCleanedLinesOfCode" : 33,
        "startLine" : 64,
        "endLine" : 77,
        "cleanedStartLine" : 24,
        "cleanedEndLine" : 33,
        "percentage" : 30.303030303030305,
        "blockSize" : 10
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/handlers/UploadChannelInboundHandler.java",
          "extension" : "java",
          "linesOfCode" : 184,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 20,
          "linesOfCodeInUnits" : 127
        },
        "sourceFileCleanedLinesOfCode" : 134,
        "startLine" : 218,
        "endLine" : 231,
        "cleanedStartLine" : 125,
        "cleanedEndLine" : 134,
        "percentage" : 7.462686567164179,
        "blockSize" : 10
      } ],
      "blockSize" : 10
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/NotifyClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 24,
        "endLine" : 39,
        "cleanedStartLine" : 5,
        "cleanedEndLine" : 14,
        "percentage" : 38.46153846153846,
        "blockSize" : 10
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/WriteClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 24,
        "endLine" : 39,
        "cleanedStartLine" : 5,
        "cleanedEndLine" : 14,
        "percentage" : 38.46153846153846,
        "blockSize" : 10
      } ],
      "blockSize" : 10
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleReader.scala",
          "extension" : "scala",
          "linesOfCode" : 90,
          "unitsCount" : 1,
          "unitsMcCabeIndexSum" : 7,
          "linesOfCodeInUnits" : 60
        },
        "sourceFileCleanedLinesOfCode" : 76,
        "startLine" : 34,
        "endLine" : 43,
        "cleanedStartLine" : 10,
        "cleanedEndLine" : 19,
        "percentage" : 13.157894736842104,
        "blockSize" : 10
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRangeRecordIterator.scala",
          "extension" : "scala",
          "linesOfCode" : 175,
          "unitsCount" : 5,
          "unitsMcCabeIndexSum" : 21,
          "linesOfCodeInUnits" : 124
        },
        "sourceFileCleanedLinesOfCode" : 133,
        "startLine" : 41,
        "endLine" : 50,
        "cleanedStartLine" : 10,
        "cleanedEndLine" : 19,
        "percentage" : 7.518796992481203,
        "blockSize" : 10
      } ],
      "blockSize" : 10
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/handlers/NotifyChannelInboundHandler.java",
          "extension" : "java",
          "linesOfCode" : 54,
          "unitsCount" : 5,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 34
        },
        "sourceFileCleanedLinesOfCode" : 33,
        "startLine" : 64,
        "endLine" : 77,
        "cleanedStartLine" : 24,
        "cleanedEndLine" : 33,
        "percentage" : 30.303030303030305,
        "blockSize" : 10
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/handlers/RegistryChannelInboundHandler.java",
          "extension" : "java",
          "linesOfCode" : 55,
          "unitsCount" : 5,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 34
        },
        "sourceFileCleanedLinesOfCode" : 33,
        "startLine" : 65,
        "endLine" : 78,
        "cleanedStartLine" : 24,
        "cleanedEndLine" : 33,
        "percentage" : 30.303030303030305,
        "blockSize" : 10
      } ],
      "blockSize" : 10
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/handlers/RegistryChannelInboundHandler.java",
          "extension" : "java",
          "linesOfCode" : 55,
          "unitsCount" : 5,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 34
        },
        "sourceFileCleanedLinesOfCode" : 33,
        "startLine" : 65,
        "endLine" : 78,
        "cleanedStartLine" : 24,
        "cleanedEndLine" : 33,
        "percentage" : 30.303030303030305,
        "blockSize" : 10
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/handlers/UploadChannelInboundHandler.java",
          "extension" : "java",
          "linesOfCode" : 184,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 20,
          "linesOfCodeInUnits" : 127
        },
        "sourceFileCleanedLinesOfCode" : 134,
        "startLine" : 218,
        "endLine" : 231,
        "cleanedStartLine" : 125,
        "cleanedEndLine" : 134,
        "percentage" : 7.462686567164179,
        "blockSize" : 10
      } ],
      "blockSize" : 10
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/ReadClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 24,
        "endLine" : 39,
        "cleanedStartLine" : 5,
        "cleanedEndLine" : 14,
        "percentage" : 38.46153846153846,
        "blockSize" : 10
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/WriteClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 24,
        "endLine" : 39,
        "cleanedStartLine" : 5,
        "cleanedEndLine" : 14,
        "percentage" : 38.46153846153846,
        "blockSize" : 10
      } ],
      "blockSize" : 10
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/NotifyClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 24,
        "endLine" : 39,
        "cleanedStartLine" : 5,
        "cleanedEndLine" : 14,
        "percentage" : 38.46153846153846,
        "blockSize" : 10
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/ReadClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 24,
        "endLine" : 39,
        "cleanedStartLine" : 5,
        "cleanedEndLine" : 14,
        "percentage" : 38.46153846153846,
        "blockSize" : 10
      } ],
      "blockSize" : 10
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
          "extension" : "scala",
          "linesOfCode" : 364,
          "unitsCount" : 8,
          "unitsMcCabeIndexSum" : 35,
          "linesOfCodeInUnits" : 311
        },
        "sourceFileCleanedLinesOfCode" : 303,
        "startLine" : 200,
        "endLine" : 214,
        "cleanedStartLine" : 120,
        "cleanedEndLine" : 129,
        "percentage" : 3.3003300330033003,
        "blockSize" : 10
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
          "extension" : "scala",
          "linesOfCode" : 364,
          "unitsCount" : 8,
          "unitsMcCabeIndexSum" : 35,
          "linesOfCodeInUnits" : 311
        },
        "sourceFileCleanedLinesOfCode" : 303,
        "startLine" : 437,
        "endLine" : 448,
        "cleanedStartLine" : 292,
        "cleanedEndLine" : 301,
        "percentage" : 3.3003300330033003,
        "blockSize" : 10
      } ],
      "blockSize" : 10
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
          "extension" : "java",
          "linesOfCode" : 547,
          "unitsCount" : 31,
          "unitsMcCabeIndexSum" : 85,
          "linesOfCodeInUnits" : 486
        },
        "sourceFileCleanedLinesOfCode" : 428,
        "startLine" : 397,
        "endLine" : 410,
        "cleanedStartLine" : 188,
        "cleanedEndLine" : 196,
        "percentage" : 2.102803738317757,
        "blockSize" : 9
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/execution/ShuffleExecutor.java",
          "extension" : "java",
          "linesOfCode" : 547,
          "unitsCount" : 31,
          "unitsMcCabeIndexSum" : 85,
          "linesOfCodeInUnits" : 486
        },
        "sourceFileCleanedLinesOfCode" : 428,
        "startLine" : 429,
        "endLine" : 442,
        "cleanedStartLine" : 204,
        "cleanedEndLine" : 212,
        "percentage" : 2.102803738317757,
        "blockSize" : 9
      } ],
      "blockSize" : 9
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 299,
          "unitsCount" : 13,
          "unitsMcCabeIndexSum" : 50,
          "linesOfCodeInUnits" : 236
        },
        "sourceFileCleanedLinesOfCode" : 208,
        "startLine" : 285,
        "endLine" : 295,
        "cleanedStartLine" : 154,
        "cleanedEndLine" : 161,
        "percentage" : 3.8461538461538463,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/ShuffleDataSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 83,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 13,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 57,
        "startLine" : 100,
        "endLine" : 110,
        "cleanedStartLine" : 49,
        "cleanedEndLine" : 56,
        "percentage" : 14.035087719298245,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/common/AppShufflePartitionId.java",
          "extension" : "java",
          "linesOfCode" : 62,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 16,
          "linesOfCodeInUnits" : 51
        },
        "sourceFileCleanedLinesOfCode" : 49,
        "startLine" : 46,
        "endLine" : 59,
        "cleanedStartLine" : 20,
        "cleanedEndLine" : 27,
        "percentage" : 16.3265306122449,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequest.java",
          "extension" : "java",
          "linesOfCode" : 85,
          "unitsCount" : 12,
          "unitsMcCabeIndexSum" : 14,
          "linesOfCodeInUnits" : 67
        },
        "sourceFileCleanedLinesOfCode" : 63,
        "startLine" : 86,
        "endLine" : 99,
        "cleanedStartLine" : 44,
        "cleanedEndLine" : 51,
        "percentage" : 12.698412698412698,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 299,
          "unitsCount" : 13,
          "unitsMcCabeIndexSum" : 50,
          "linesOfCodeInUnits" : 236
        },
        "sourceFileCleanedLinesOfCode" : 208,
        "startLine" : 288,
        "endLine" : 296,
        "cleanedStartLine" : 155,
        "cleanedEndLine" : 162,
        "percentage" : 3.8461538461538463,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 142,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 18,
          "linesOfCodeInUnits" : 110
        },
        "sourceFileCleanedLinesOfCode" : 103,
        "startLine" : 181,
        "endLine" : 189,
        "cleanedStartLine" : 96,
        "cleanedEndLine" : 103,
        "percentage" : 7.766990291262136,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/GetDataAvailabilityRequest.java",
          "extension" : "java",
          "linesOfCode" : 21,
          "unitsCount" : 5,
          "unitsMcCabeIndexSum" : 5,
          "linesOfCodeInUnits" : 14
        },
        "sourceFileCleanedLinesOfCode" : 13,
        "startLine" : 32,
        "endLine" : 43,
        "cleanedStartLine" : 6,
        "cleanedEndLine" : 13,
        "percentage" : 61.53846153846154,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/GetDataAvailabilityRequestMessage.java",
          "extension" : "java",
          "linesOfCode" : 21,
          "unitsCount" : 5,
          "unitsMcCabeIndexSum" : 5,
          "linesOfCodeInUnits" : 14
        },
        "sourceFileCleanedLinesOfCode" : 13,
        "startLine" : 32,
        "endLine" : 43,
        "cleanedStartLine" : 6,
        "cleanedEndLine" : 13,
        "percentage" : 61.53846153846154,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 332,
          "unitsCount" : 21,
          "unitsMcCabeIndexSum" : 56,
          "linesOfCodeInUnits" : 260
        },
        "sourceFileCleanedLinesOfCode" : 243,
        "startLine" : 111,
        "endLine" : 119,
        "cleanedStartLine" : 47,
        "cleanedEndLine" : 54,
        "percentage" : 3.292181069958848,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 160,
          "unitsCount" : 14,
          "unitsMcCabeIndexSum" : 24,
          "linesOfCodeInUnits" : 114
        },
        "sourceFileCleanedLinesOfCode" : 115,
        "startLine" : 81,
        "endLine" : 89,
        "cleanedStartLine" : 34,
        "cleanedEndLine" : 41,
        "percentage" : 6.956521739130435,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 299,
          "unitsCount" : 13,
          "unitsMcCabeIndexSum" : 50,
          "linesOfCodeInUnits" : 236
        },
        "sourceFileCleanedLinesOfCode" : 208,
        "startLine" : 285,
        "endLine" : 295,
        "cleanedStartLine" : 154,
        "cleanedEndLine" : 161,
        "percentage" : 3.8461538461538463,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/RecordSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 83,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 13,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 57,
        "startLine" : 100,
        "endLine" : 110,
        "cleanedStartLine" : 49,
        "cleanedEndLine" : 56,
        "percentage" : 14.035087719298245,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/common/AppMapId.java",
          "extension" : "java",
          "linesOfCode" : 55,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 16,
          "linesOfCodeInUnits" : 44
        },
        "sourceFileCleanedLinesOfCode" : 42,
        "startLine" : 39,
        "endLine" : 52,
        "cleanedStartLine" : 13,
        "cleanedEndLine" : 20,
        "percentage" : 19.047619047619047,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/common/AppTaskAttemptId.java",
          "extension" : "java",
          "linesOfCode" : 71,
          "unitsCount" : 14,
          "unitsMcCabeIndexSum" : 21,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 54,
        "startLine" : 45,
        "endLine" : 58,
        "cleanedStartLine" : 17,
        "cleanedEndLine" : 24,
        "percentage" : 14.814814814814815,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metadata/InMemoryServiceRegistry.java",
          "extension" : "java",
          "linesOfCode" : 62,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 14,
          "linesOfCodeInUnits" : 43
        },
        "sourceFileCleanedLinesOfCode" : 38,
        "startLine" : 48,
        "endLine" : 61,
        "cleanedStartLine" : 12,
        "cleanedEndLine" : 19,
        "percentage" : 21.05263157894737,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metadata/ZooKeeperServiceRegistry.java",
          "extension" : "java",
          "linesOfCode" : 191,
          "unitsCount" : 15,
          "unitsMcCabeIndexSum" : 36,
          "linesOfCodeInUnits" : 158
        },
        "sourceFileCleanedLinesOfCode" : 136,
        "startLine" : 92,
        "endLine" : 105,
        "cleanedStartLine" : 31,
        "cleanedEndLine" : 38,
        "percentage" : 5.882352941176471,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/common/FilePathAndLength.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 28,
        "endLine" : 39,
        "cleanedStartLine" : 7,
        "cleanedEndLine" : 14,
        "percentage" : 30.76923076923077,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/common/PartitionFilePathAndLength.java",
          "extension" : "java",
          "linesOfCode" : 42,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 12,
          "linesOfCodeInUnits" : 32
        },
        "sourceFileCleanedLinesOfCode" : 32,
        "startLine" : 34,
        "endLine" : 45,
        "cleanedStartLine" : 11,
        "cleanedEndLine" : 18,
        "percentage" : 25.0,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/M3DummyScope.java",
          "extension" : "java",
          "linesOfCode" : 92,
          "unitsCount" : 8,
          "unitsMcCabeIndexSum" : 8,
          "linesOfCodeInUnits" : 69
        },
        "sourceFileCleanedLinesOfCode" : 60,
        "startLine" : 56,
        "endLine" : 65,
        "cleanedStartLine" : 19,
        "cleanedEndLine" : 26,
        "percentage" : 13.333333333333334,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/M3DummyScope.java",
          "extension" : "java",
          "linesOfCode" : 92,
          "unitsCount" : 8,
          "unitsMcCabeIndexSum" : 8,
          "linesOfCodeInUnits" : 69
        },
        "sourceFileCleanedLinesOfCode" : 60,
        "startLine" : 80,
        "endLine" : 89,
        "cleanedStartLine" : 35,
        "cleanedEndLine" : 42,
        "percentage" : 13.333333333333334,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 142,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 18,
          "linesOfCodeInUnits" : 110
        },
        "sourceFileCleanedLinesOfCode" : 103,
        "startLine" : 181,
        "endLine" : 189,
        "cleanedStartLine" : 96,
        "cleanedEndLine" : 103,
        "percentage" : 7.766990291262136,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/NotifyClient.java",
          "extension" : "java",
          "linesOfCode" : 62,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 43
        },
        "sourceFileCleanedLinesOfCode" : 40,
        "startLine" : 89,
        "endLine" : 97,
        "cleanedStartLine" : 33,
        "cleanedEndLine" : 40,
        "percentage" : 20.0,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/common/AppShufflePartitionId.java",
          "extension" : "java",
          "linesOfCode" : 62,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 16,
          "linesOfCodeInUnits" : 51
        },
        "sourceFileCleanedLinesOfCode" : 49,
        "startLine" : 46,
        "endLine" : 59,
        "cleanedStartLine" : 20,
        "cleanedEndLine" : 27,
        "percentage" : 16.3265306122449,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequestMessage.java",
          "extension" : "java",
          "linesOfCode" : 89,
          "unitsCount" : 12,
          "unitsMcCabeIndexSum" : 14,
          "linesOfCodeInUnits" : 71
        },
        "sourceFileCleanedLinesOfCode" : 67,
        "startLine" : 90,
        "endLine" : 103,
        "cleanedStartLine" : 48,
        "cleanedEndLine" : 55,
        "percentage" : 11.940298507462687,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequest.java",
          "extension" : "java",
          "linesOfCode" : 85,
          "unitsCount" : 12,
          "unitsMcCabeIndexSum" : 14,
          "linesOfCodeInUnits" : 67
        },
        "sourceFileCleanedLinesOfCode" : 63,
        "startLine" : 41,
        "endLine" : 50,
        "cleanedStartLine" : 11,
        "cleanedEndLine" : 18,
        "percentage" : 12.698412698412698,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequestMessage.java",
          "extension" : "java",
          "linesOfCode" : 89,
          "unitsCount" : 12,
          "unitsMcCabeIndexSum" : 14,
          "linesOfCodeInUnits" : 71
        },
        "sourceFileCleanedLinesOfCode" : 67,
        "startLine" : 45,
        "endLine" : 54,
        "cleanedStartLine" : 15,
        "cleanedEndLine" : 22,
        "percentage" : 11.940298507462687,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/ServerIdAwareSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 127,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 19,
          "linesOfCodeInUnits" : 95
        },
        "sourceFileCleanedLinesOfCode" : 99,
        "startLine" : 106,
        "endLine" : 113,
        "cleanedStartLine" : 53,
        "cleanedEndLine" : 60,
        "percentage" : 8.080808080808081,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/ServerIdAwareSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 127,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 19,
          "linesOfCodeInUnits" : 95
        },
        "sourceFileCleanedLinesOfCode" : 99,
        "startLine" : 116,
        "endLine" : 123,
        "cleanedStartLine" : 63,
        "cleanedEndLine" : 70,
        "percentage" : 8.080808080808081,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 299,
          "unitsCount" : 13,
          "unitsMcCabeIndexSum" : 50,
          "linesOfCodeInUnits" : 236
        },
        "sourceFileCleanedLinesOfCode" : 208,
        "startLine" : 288,
        "endLine" : 296,
        "cleanedStartLine" : 155,
        "cleanedEndLine" : 162,
        "percentage" : 3.8461538461538463,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/NotifyClient.java",
          "extension" : "java",
          "linesOfCode" : 62,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 43
        },
        "sourceFileCleanedLinesOfCode" : 40,
        "startLine" : 89,
        "endLine" : 97,
        "cleanedStartLine" : 33,
        "cleanedEndLine" : 40,
        "percentage" : 20.0,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 299,
          "unitsCount" : 13,
          "unitsMcCabeIndexSum" : 50,
          "linesOfCodeInUnits" : 236
        },
        "sourceFileCleanedLinesOfCode" : 208,
        "startLine" : 154,
        "endLine" : 162,
        "cleanedStartLine" : 62,
        "cleanedEndLine" : 69,
        "percentage" : 3.8461538461538463,
        "blockSize" : 8
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 299,
          "unitsCount" : 13,
          "unitsMcCabeIndexSum" : 50,
          "linesOfCodeInUnits" : 236
        },
        "sourceFileCleanedLinesOfCode" : 208,
        "startLine" : 221,
        "endLine" : 229,
        "cleanedStartLine" : 108,
        "cleanedEndLine" : 115,
        "percentage" : 3.8461538461538463,
        "blockSize" : 8
      } ],
      "blockSize" : 8
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerAsyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 332,
          "unitsCount" : 21,
          "unitsMcCabeIndexSum" : 56,
          "linesOfCodeInUnits" : 260
        },
        "sourceFileCleanedLinesOfCode" : 243,
        "startLine" : 125,
        "endLine" : 135,
        "cleanedStartLine" : 56,
        "cleanedEndLine" : 62,
        "percentage" : 2.880658436213992,
        "blockSize" : 7
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/MultiServerSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 160,
          "unitsCount" : 14,
          "unitsMcCabeIndexSum" : 24,
          "linesOfCodeInUnits" : 114
        },
        "sourceFileCleanedLinesOfCode" : 115,
        "startLine" : 95,
        "endLine" : 105,
        "cleanedStartLine" : 43,
        "cleanedEndLine" : 49,
        "percentage" : 6.086956521739131,
        "blockSize" : 7
      } ],
      "blockSize" : 7
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/ReadClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 41,
        "endLine" : 51,
        "cleanedStartLine" : 16,
        "cleanedEndLine" : 22,
        "percentage" : 26.923076923076923,
        "blockSize" : 7
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/WriteClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 41,
        "endLine" : 51,
        "cleanedStartLine" : 16,
        "cleanedEndLine" : 22,
        "percentage" : 26.923076923076923,
        "blockSize" : 7
      } ],
      "blockSize" : 7
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/NotifyClient.java",
          "extension" : "java",
          "linesOfCode" : 62,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 43
        },
        "sourceFileCleanedLinesOfCode" : 40,
        "startLine" : 89,
        "endLine" : 96,
        "cleanedStartLine" : 33,
        "cleanedEndLine" : 39,
        "percentage" : 17.5,
        "blockSize" : 7
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/ShuffleDataSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 83,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 13,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 57,
        "startLine" : 103,
        "endLine" : 110,
        "cleanedStartLine" : 50,
        "cleanedEndLine" : 56,
        "percentage" : 12.280701754385966,
        "blockSize" : 7
      } ],
      "blockSize" : 7
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
          "extension" : "scala",
          "linesOfCode" : 364,
          "unitsCount" : 8,
          "unitsMcCabeIndexSum" : 35,
          "linesOfCodeInUnits" : 311
        },
        "sourceFileCleanedLinesOfCode" : 303,
        "startLine" : 239,
        "endLine" : 245,
        "cleanedStartLine" : 148,
        "cleanedEndLine" : 154,
        "percentage" : 2.31023102310231,
        "blockSize" : 7
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/scala/org/apache/spark/shuffle/RssShuffleManager.scala",
          "extension" : "scala",
          "linesOfCode" : 364,
          "unitsCount" : 8,
          "unitsMcCabeIndexSum" : 35,
          "linesOfCodeInUnits" : 311
        },
        "sourceFileCleanedLinesOfCode" : 303,
        "startLine" : 257,
        "endLine" : 263,
        "cleanedStartLine" : 166,
        "cleanedEndLine" : 172,
        "percentage" : 2.31023102310231,
        "blockSize" : 7
      } ],
      "blockSize" : 7
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/NotifyClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 41,
        "endLine" : 51,
        "cleanedStartLine" : 16,
        "cleanedEndLine" : 22,
        "percentage" : 26.923076923076923,
        "blockSize" : 7
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/WriteClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 41,
        "endLine" : 51,
        "cleanedStartLine" : 16,
        "cleanedEndLine" : 22,
        "percentage" : 26.923076923076923,
        "blockSize" : 7
      } ],
      "blockSize" : 7
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 142,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 18,
          "linesOfCodeInUnits" : 110
        },
        "sourceFileCleanedLinesOfCode" : 103,
        "startLine" : 181,
        "endLine" : 188,
        "cleanedStartLine" : 96,
        "cleanedEndLine" : 102,
        "percentage" : 6.796116504854369,
        "blockSize" : 7
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/RecordSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 83,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 13,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 57,
        "startLine" : 103,
        "endLine" : 110,
        "cleanedStartLine" : 50,
        "cleanedEndLine" : 56,
        "percentage" : 12.280701754385966,
        "blockSize" : 7
      } ],
      "blockSize" : 7
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressToolLongRun.java",
          "extension" : "java",
          "linesOfCode" : 118,
          "unitsCount" : 2,
          "unitsMcCabeIndexSum" : 17,
          "linesOfCodeInUnits" : 97
        },
        "sourceFileCleanedLinesOfCode" : 102,
        "startLine" : 109,
        "endLine" : 116,
        "cleanedStartLine" : 65,
        "cleanedEndLine" : 71,
        "percentage" : 6.862745098039215,
        "blockSize" : 7
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/tools/StreamServerStressToolWrite64GB.java",
          "extension" : "java",
          "linesOfCode" : 29,
          "unitsCount" : 1,
          "unitsMcCabeIndexSum" : 1,
          "linesOfCodeInUnits" : 22
        },
        "sourceFileCleanedLinesOfCode" : 21,
        "startLine" : 27,
        "endLine" : 34,
        "cleanedStartLine" : 3,
        "cleanedEndLine" : 9,
        "percentage" : 33.333333333333336,
        "blockSize" : 7
      } ],
      "blockSize" : 7
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/NotifyClient.java",
          "extension" : "java",
          "linesOfCode" : 62,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 43
        },
        "sourceFileCleanedLinesOfCode" : 40,
        "startLine" : 89,
        "endLine" : 96,
        "cleanedStartLine" : 33,
        "cleanedEndLine" : 39,
        "percentage" : 17.5,
        "blockSize" : 7
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/RecordSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 83,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 13,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 57,
        "startLine" : 103,
        "endLine" : 110,
        "cleanedStartLine" : 50,
        "cleanedEndLine" : 56,
        "percentage" : 12.280701754385966,
        "blockSize" : 7
      } ],
      "blockSize" : 7
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/NotifyClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 41,
        "endLine" : 51,
        "cleanedStartLine" : 16,
        "cleanedEndLine" : 22,
        "percentage" : 26.923076923076923,
        "blockSize" : 7
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/ReadClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 41,
        "endLine" : 51,
        "cleanedStartLine" : 16,
        "cleanedEndLine" : 22,
        "percentage" : 26.923076923076923,
        "blockSize" : 7
      } ],
      "blockSize" : 7
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRangeRecordIterator.scala",
          "extension" : "scala",
          "linesOfCode" : 175,
          "unitsCount" : 5,
          "unitsMcCabeIndexSum" : 21,
          "linesOfCodeInUnits" : 124
        },
        "sourceFileCleanedLinesOfCode" : 133,
        "startLine" : 151,
        "endLine" : 158,
        "cleanedStartLine" : 92,
        "cleanedEndLine" : 98,
        "percentage" : 5.2631578947368425,
        "blockSize" : 7
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/scala/org/apache/spark/shuffle/rss/BlockDownloaderPartitionRecordIterator.scala",
          "extension" : "scala",
          "linesOfCode" : 174,
          "unitsCount" : 4,
          "unitsMcCabeIndexSum" : 22,
          "linesOfCodeInUnits" : 106
        },
        "sourceFileCleanedLinesOfCode" : 133,
        "startLine" : 149,
        "endLine" : 155,
        "cleanedStartLine" : 75,
        "cleanedEndLine" : 81,
        "percentage" : 5.2631578947368425,
        "blockSize" : 7
      } ],
      "blockSize" : 7
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 142,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 18,
          "linesOfCodeInUnits" : 110
        },
        "sourceFileCleanedLinesOfCode" : 103,
        "startLine" : 181,
        "endLine" : 188,
        "cleanedStartLine" : 96,
        "cleanedEndLine" : 102,
        "percentage" : 6.796116504854369,
        "blockSize" : 7
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/ShuffleDataSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 83,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 13,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 57,
        "startLine" : 103,
        "endLine" : 110,
        "cleanedStartLine" : 50,
        "cleanedEndLine" : 56,
        "percentage" : 12.280701754385966,
        "blockSize" : 7
      } ],
      "blockSize" : 7
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/ServerIdAwareSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 127,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 19,
          "linesOfCodeInUnits" : 95
        },
        "sourceFileCleanedLinesOfCode" : 99,
        "startLine" : 108,
        "endLine" : 113,
        "cleanedStartLine" : 55,
        "cleanedEndLine" : 60,
        "percentage" : 6.0606060606060606,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/UnpooledWriteClientFactory.java",
          "extension" : "java",
          "linesOfCode" : 23,
          "unitsCount" : 2,
          "unitsMcCabeIndexSum" : 2,
          "linesOfCodeInUnits" : 15
        },
        "sourceFileCleanedLinesOfCode" : 17,
        "startLine" : 37,
        "endLine" : 42,
        "cleanedStartLine" : 11,
        "cleanedEndLine" : 16,
        "percentage" : 35.294117647058826,
        "blockSize" : 6
      } ],
      "blockSize" : 6
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/RetriableSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 92,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 11,
          "linesOfCodeInUnits" : 72
        },
        "sourceFileCleanedLinesOfCode" : 72,
        "startLine" : 44,
        "endLine" : 49,
        "cleanedStartLine" : 14,
        "cleanedEndLine" : 19,
        "percentage" : 8.333333333333334,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/RetriableSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 92,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 11,
          "linesOfCodeInUnits" : 72
        },
        "sourceFileCleanedLinesOfCode" : 72,
        "startLine" : 54,
        "endLine" : 59,
        "cleanedStartLine" : 23,
        "cleanedEndLine" : 28,
        "percentage" : 8.333333333333334,
        "blockSize" : 6
      } ],
      "blockSize" : 6
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequest.java",
          "extension" : "java",
          "linesOfCode" : 85,
          "unitsCount" : 12,
          "unitsMcCabeIndexSum" : 14,
          "linesOfCodeInUnits" : 67
        },
        "sourceFileCleanedLinesOfCode" : 63,
        "startLine" : 82,
        "endLine" : 91,
        "cleanedStartLine" : 42,
        "cleanedEndLine" : 47,
        "percentage" : 9.523809523809524,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/ConnectUploadRequest.java",
          "extension" : "java",
          "linesOfCode" : 46,
          "unitsCount" : 8,
          "unitsMcCabeIndexSum" : 8,
          "linesOfCodeInUnits" : 35
        },
        "sourceFileCleanedLinesOfCode" : 34,
        "startLine" : 50,
        "endLine" : 59,
        "cleanedStartLine" : 22,
        "cleanedEndLine" : 27,
        "percentage" : 17.647058823529413,
        "blockSize" : 6
      } ],
      "blockSize" : 6
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequestMessage.java",
          "extension" : "java",
          "linesOfCode" : 89,
          "unitsCount" : 12,
          "unitsMcCabeIndexSum" : 14,
          "linesOfCodeInUnits" : 71
        },
        "sourceFileCleanedLinesOfCode" : 67,
        "startLine" : 86,
        "endLine" : 95,
        "cleanedStartLine" : 46,
        "cleanedEndLine" : 51,
        "percentage" : 8.955223880597014,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/HeartbeatMessage.java",
          "extension" : "java",
          "linesOfCode" : 54,
          "unitsCount" : 9,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 42
        },
        "sourceFileCleanedLinesOfCode" : 41,
        "startLine" : 54,
        "endLine" : 63,
        "cleanedStartLine" : 26,
        "cleanedEndLine" : 31,
        "percentage" : 14.634146341463415,
        "blockSize" : 6
      } ],
      "blockSize" : 6
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerMessageDecoder.java",
          "extension" : "java",
          "linesOfCode" : 347,
          "unitsCount" : 8,
          "unitsMcCabeIndexSum" : 57,
          "linesOfCodeInUnits" : 278
        },
        "sourceFileCleanedLinesOfCode" : 277,
        "startLine" : 154,
        "endLine" : 160,
        "cleanedStartLine" : 70,
        "cleanedEndLine" : 75,
        "percentage" : 2.1660649819494586,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/decoders/StreamServerMessageDecoder.java",
          "extension" : "java",
          "linesOfCode" : 347,
          "unitsCount" : 8,
          "unitsMcCabeIndexSum" : 57,
          "linesOfCodeInUnits" : 278
        },
        "sourceFileCleanedLinesOfCode" : 277,
        "startLine" : 180,
        "endLine" : 186,
        "cleanedStartLine" : 94,
        "cleanedEndLine" : 99,
        "percentage" : 2.1660649819494586,
        "blockSize" : 6
      } ],
      "blockSize" : 6
    } ],
    "mostFrequentDuplicates" : [ {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/WriteClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 41,
        "endLine" : 50,
        "cleanedStartLine" : 16,
        "cleanedEndLine" : 21,
        "percentage" : 23.076923076923077,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/NotifyClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 41,
        "endLine" : 50,
        "cleanedStartLine" : 16,
        "cleanedEndLine" : 21,
        "percentage" : 23.076923076923077,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/metrics/ReadClientMetricsKey.java",
          "extension" : "java",
          "linesOfCode" : 35,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 10,
          "linesOfCodeInUnits" : 26
        },
        "sourceFileCleanedLinesOfCode" : 26,
        "startLine" : 41,
        "endLine" : 50,
        "cleanedStartLine" : 16,
        "cleanedEndLine" : 21,
        "percentage" : 23.076923076923077,
        "blockSize" : 6
      } ],
      "blockSize" : 6
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 299,
          "unitsCount" : 13,
          "unitsMcCabeIndexSum" : 50,
          "linesOfCodeInUnits" : 236
        },
        "sourceFileCleanedLinesOfCode" : 208,
        "startLine" : 289,
        "endLine" : 295,
        "cleanedStartLine" : 156,
        "cleanedEndLine" : 161,
        "percentage" : 2.8846153846153846,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/ShuffleDataSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 83,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 13,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 57,
        "startLine" : 104,
        "endLine" : 110,
        "cleanedStartLine" : 51,
        "cleanedEndLine" : 56,
        "percentage" : 10.526315789473685,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/RecordSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 83,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 13,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 57,
        "startLine" : 104,
        "endLine" : 110,
        "cleanedStartLine" : 51,
        "cleanedEndLine" : 56,
        "percentage" : 10.526315789473685,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 142,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 18,
          "linesOfCodeInUnits" : 110
        },
        "sourceFileCleanedLinesOfCode" : 103,
        "startLine" : 182,
        "endLine" : 188,
        "cleanedStartLine" : 97,
        "cleanedEndLine" : 102,
        "percentage" : 5.825242718446602,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/NotifyClient.java",
          "extension" : "java",
          "linesOfCode" : 62,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 43
        },
        "sourceFileCleanedLinesOfCode" : 40,
        "startLine" : 90,
        "endLine" : 96,
        "cleanedStartLine" : 34,
        "cleanedEndLine" : 39,
        "percentage" : 15.0,
        "blockSize" : 6
      } ],
      "blockSize" : 6
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 299,
          "unitsCount" : 13,
          "unitsMcCabeIndexSum" : 50,
          "linesOfCodeInUnits" : 236
        },
        "sourceFileCleanedLinesOfCode" : 208,
        "startLine" : 288,
        "endLine" : 294,
        "cleanedStartLine" : 155,
        "cleanedEndLine" : 160,
        "percentage" : 2.8846153846153846,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/ShuffleDataSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 83,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 13,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 57,
        "startLine" : 103,
        "endLine" : 109,
        "cleanedStartLine" : 50,
        "cleanedEndLine" : 55,
        "percentage" : 10.526315789473685,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/RecordSocketReadClient.java",
          "extension" : "java",
          "linesOfCode" : 83,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 13,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 57,
        "startLine" : 103,
        "endLine" : 109,
        "cleanedStartLine" : 50,
        "cleanedEndLine" : 55,
        "percentage" : 10.526315789473685,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/DataBlockSyncWriteClient.java",
          "extension" : "java",
          "linesOfCode" : 142,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 18,
          "linesOfCodeInUnits" : 110
        },
        "sourceFileCleanedLinesOfCode" : 103,
        "startLine" : 181,
        "endLine" : 187,
        "cleanedStartLine" : 96,
        "cleanedEndLine" : 101,
        "percentage" : 5.825242718446602,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/clients/NotifyClient.java",
          "extension" : "java",
          "linesOfCode" : 62,
          "unitsCount" : 6,
          "unitsMcCabeIndexSum" : 9,
          "linesOfCodeInUnits" : 43
        },
        "sourceFileCleanedLinesOfCode" : 40,
        "startLine" : 89,
        "endLine" : 95,
        "cleanedStartLine" : 33,
        "cleanedEndLine" : 38,
        "percentage" : 15.0,
        "blockSize" : 6
      } ],
      "blockSize" : 6
    }, {
      "displayContent" : "",
      "duplicatedFileBlocks" : [ {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/common/AppShuffleId.java",
          "extension" : "java",
          "linesOfCode" : 42,
          "unitsCount" : 7,
          "unitsMcCabeIndexSum" : 12,
          "linesOfCodeInUnits" : 32
        },
        "sourceFileCleanedLinesOfCode" : 32,
        "startLine" : 33,
        "endLine" : 42,
        "cleanedStartLine" : 9,
        "cleanedEndLine" : 14,
        "percentage" : 18.75,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/common/AppShufflePartitionId.java",
          "extension" : "java",
          "linesOfCode" : 62,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 16,
          "linesOfCodeInUnits" : 51
        },
        "sourceFileCleanedLinesOfCode" : 49,
        "startLine" : 46,
        "endLine" : 55,
        "cleanedStartLine" : 20,
        "cleanedEndLine" : 25,
        "percentage" : 12.244897959183673,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequestMessage.java",
          "extension" : "java",
          "linesOfCode" : 89,
          "unitsCount" : 12,
          "unitsMcCabeIndexSum" : 14,
          "linesOfCodeInUnits" : 71
        },
        "sourceFileCleanedLinesOfCode" : 67,
        "startLine" : 90,
        "endLine" : 99,
        "cleanedStartLine" : 48,
        "cleanedEndLine" : 53,
        "percentage" : 8.955223880597014,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/messages/ConnectDownloadRequest.java",
          "extension" : "java",
          "linesOfCode" : 85,
          "unitsCount" : 12,
          "unitsMcCabeIndexSum" : 14,
          "linesOfCodeInUnits" : 67
        },
        "sourceFileCleanedLinesOfCode" : 63,
        "startLine" : 86,
        "endLine" : 95,
        "cleanedStartLine" : 44,
        "cleanedEndLine" : 49,
        "percentage" : 9.523809523809524,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/common/AppMapId.java",
          "extension" : "java",
          "linesOfCode" : 55,
          "unitsCount" : 10,
          "unitsMcCabeIndexSum" : 16,
          "linesOfCodeInUnits" : 44
        },
        "sourceFileCleanedLinesOfCode" : 42,
        "startLine" : 39,
        "endLine" : 48,
        "cleanedStartLine" : 13,
        "cleanedEndLine" : 18,
        "percentage" : 14.285714285714286,
        "blockSize" : 6
      }, {
        "sourceFile" : {
          "relativePath" : "src/main/java/com/uber/rss/common/AppTaskAttemptId.java",
          "extension" : "java",
          "linesOfCode" : 71,
          "unitsCount" : 14,
          "unitsMcCabeIndexSum" : 21,
          "linesOfCodeInUnits" : 59
        },
        "sourceFileCleanedLinesOfCode" : 54,
        "startLine" : 45,
        "endLine" : 54,
        "cleanedStartLine" : 17,
        "cleanedEndLine" : 22,
        "percentage" : 11.11111111111111,
        "blockSize" : 6
      } ],
      "blockSize" : 6
    } ]
  },
  "contributorsAnalysisResults" : {
    "latestCommitDate" : "2023-01-31",
    "contributors" : [ {
      "email" : "boy@uber.com",
      "commitsCount" : 55,
      "commitsCount30Days" : 0,
      "commitsCount90Days" : 0,
      "commitsCount180Days" : 0,
      "commitsCount365Days" : 0,
      "firstCommitDate" : "2020-08-20",
      "latestCommitDate" : "2020-11-04",
      "activeYears" : [ "2020" ],
      "commitDates" : [ "2020-11-04", "2020-10-30", "2020-10-29", "2020-10-27", "2020-10-26", "2020-10-16", "2020-10-14", "2020-10-13", "2020-10-09", "2020-10-07", "2020-10-06", "2020-10-05", "2020-10-03", "2020-10-01", "2020-09-30", "2020-09-29", "2020-09-08", "2020-09-04", "2020-09-03", "2020-09-02", "2020-08-31", "2020-08-28", "2020-08-26", "2020-08-25", "2020-08-24", "2020-08-22", "2020-08-21", "2020-08-20" ],
      "active" : false,
      "rookie" : false
    }, {
      "email" : "boy-uber@users.noreply.github.com",
      "commitsCount" : 27,
      "commitsCount30Days" : 0,
      "commitsCount90Days" : 0,
      "commitsCount180Days" : 0,
      "commitsCount365Days" : 0,
      "firstCommitDate" : "2020-09-29",
      "latestCommitDate" : "2020-11-04",
      "activeYears" : [ "2020" ],
      "commitDates" : [ "2020-11-04", "2020-10-30", "2020-10-29", "2020-10-27", "2020-10-26", "2020-10-23", "2020-10-16", "2020-10-15", "2020-10-14", "2020-10-13", "2020-10-09", "2020-10-08", "2020-10-07", "2020-10-06", "2020-10-05", "2020-10-01", "2020-09-30", "2020-09-29" ],
      "active" : false,
      "rookie" : false
    }, {
      "email" : "mabansal@uber.com",
      "commitsCount" : 24,
      "commitsCount30Days" : 0,
      "commitsCount90Days" : 0,
      "commitsCount180Days" : 0,
      "commitsCount365Days" : 0,
      "firstCommitDate" : "2020-10-20",
      "latestCommitDate" : "2023-01-31",
      "activeYears" : [ "2020", "2021", "2023" ],
      "commitDates" : [ "2023-01-31", "2021-07-23", "2021-07-21", "2021-06-18", "2021-06-17", "2021-06-16", "2021-06-15", "2021-06-12", "2020-10-29", "2020-10-23", "2020-10-22", "2020-10-21", "2020-10-20" ],
      "active" : false,
      "rookie" : false
    }, {
      "email" : "14280154+hiboyang@users.noreply.github.com",
      "commitsCount" : 5,
      "commitsCount30Days" : 0,
      "commitsCount90Days" : 0,
      "commitsCount180Days" : 0,
      "commitsCount365Days" : 0,
      "firstCommitDate" : "2022-12-07",
      "latestCommitDate" : "2023-01-22",
      "activeYears" : [ "2022", "2023" ],
      "commitDates" : [ "2023-01-22", "2022-12-09", "2022-12-08", "2022-12-07" ],
      "active" : false,
      "rookie" : false
    }, {
      "email" : "mayurb@uber.com",
      "commitsCount" : 3,
      "commitsCount30Days" : 0,
      "commitsCount90Days" : 0,
      "commitsCount180Days" : 0,
      "commitsCount365Days" : 0,
      "firstCommitDate" : "2021-07-19",
      "latestCommitDate" : "2021-07-21",
      "activeYears" : [ "2021" ],
      "commitDates" : [ "2021-07-21", "2021-07-19" ],
      "active" : false,
      "rookie" : false
    }, {
      "email" : "harshvardhan5795@gmail.com",
      "commitsCount" : 1,
      "commitsCount30Days" : 0,
      "commitsCount90Days" : 0,
      "commitsCount180Days" : 0,
      "commitsCount365Days" : 0,
      "firstCommitDate" : "2021-06-17",
      "latestCommitDate" : "2021-06-17",
      "activeYears" : [ "2021" ],
      "commitDates" : [ "2021-06-17" ],
      "active" : false,
      "rookie" : false
    }, {
      "email" : "mayurdb31@gmail.com",
      "commitsCount" : 1,
      "commitsCount30Days" : 0,
      "commitsCount90Days" : 0,
      "commitsCount180Days" : 0,
      "commitsCount365Days" : 0,
      "firstCommitDate" : "2021-06-16",
      "latestCommitDate" : "2021-06-16",
      "activeYears" : [ "2021" ],
      "commitDates" : [ "2021-06-16" ],
      "active" : false,
      "rookie" : false
    }, {
      "email" : "jkai@uber.com",
      "commitsCount" : 1,
      "commitsCount30Days" : 0,
      "commitsCount90Days" : 0,
      "commitsCount180Days" : 0,
      "commitsCount365Days" : 0,
      "firstCommitDate" : "2020-10-14",
      "latestCommitDate" : "2020-10-14",
      "activeYears" : [ "2020" ],
      "commitDates" : [ "2020-10-14" ],
      "active" : false,
      "rookie" : false
    } ],
    "contributorsPerYear" : [ {
      "timeSlot" : "2020",
      "contributorsCount" : 4,
      "commitsCount" : 92
    }, {
      "timeSlot" : "2021",
      "contributorsCount" : 4,
      "commitsCount" : 19
    }, {
      "timeSlot" : "2022",
      "contributorsCount" : 1,
      "commitsCount" : 4
    }, {
      "timeSlot" : "2023",
      "contributorsCount" : 2,
      "commitsCount" : 2
    } ],
    "contributorsPerMonth" : [ {
      "timeSlot" : "2020-08",
      "contributorsCount" : 1,
      "commitsCount" : 22
    }, {
      "timeSlot" : "2020-09",
      "contributorsCount" : 2,
      "commitsCount" : 15
    }, {
      "timeSlot" : "2020-10",
      "contributorsCount" : 4,
      "commitsCount" : 53
    }, {
      "timeSlot" : "2020-11",
      "contributorsCount" : 2,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2021-06",
      "contributorsCount" : 3,
      "commitsCount" : 14
    }, {
      "timeSlot" : "2021-07",
      "contributorsCount" : 2,
      "commitsCount" : 5
    }, {
      "timeSlot" : "2022-12",
      "contributorsCount" : 1,
      "commitsCount" : 4
    }, {
      "timeSlot" : "2023-01",
      "contributorsCount" : 2,
      "commitsCount" : 2
    } ],
    "contributorsPerDay" : [ {
      "timeSlot" : "2020-08-20",
      "contributorsCount" : 1,
      "commitsCount" : 9
    }, {
      "timeSlot" : "2020-08-21",
      "contributorsCount" : 1,
      "commitsCount" : 5
    }, {
      "timeSlot" : "2020-08-22",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2020-08-24",
      "contributorsCount" : 1,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2020-08-25",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2020-08-26",
      "contributorsCount" : 1,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2020-08-28",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2020-08-31",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2020-09-02",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2020-09-03",
      "contributorsCount" : 1,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2020-09-04",
      "contributorsCount" : 1,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2020-09-08",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2020-09-29",
      "contributorsCount" : 2,
      "commitsCount" : 3
    }, {
      "timeSlot" : "2020-09-30",
      "contributorsCount" : 2,
      "commitsCount" : 6
    }, {
      "timeSlot" : "2020-10-01",
      "contributorsCount" : 2,
      "commitsCount" : 5
    }, {
      "timeSlot" : "2020-10-03",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2020-10-05",
      "contributorsCount" : 2,
      "commitsCount" : 3
    }, {
      "timeSlot" : "2020-10-06",
      "contributorsCount" : 2,
      "commitsCount" : 3
    }, {
      "timeSlot" : "2020-10-07",
      "contributorsCount" : 2,
      "commitsCount" : 4
    }, {
      "timeSlot" : "2020-10-08",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2020-10-09",
      "contributorsCount" : 2,
      "commitsCount" : 4
    }, {
      "timeSlot" : "2020-10-13",
      "contributorsCount" : 2,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2020-10-14",
      "contributorsCount" : 3,
      "commitsCount" : 5
    }, {
      "timeSlot" : "2020-10-15",
      "contributorsCount" : 1,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2020-10-16",
      "contributorsCount" : 2,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2020-10-20",
      "contributorsCount" : 1,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2020-10-21",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2020-10-22",
      "contributorsCount" : 1,
      "commitsCount" : 3
    }, {
      "timeSlot" : "2020-10-23",
      "contributorsCount" : 2,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2020-10-26",
      "contributorsCount" : 2,
      "commitsCount" : 5
    }, {
      "timeSlot" : "2020-10-27",
      "contributorsCount" : 2,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2020-10-29",
      "contributorsCount" : 3,
      "commitsCount" : 4
    }, {
      "timeSlot" : "2020-10-30",
      "contributorsCount" : 2,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2020-11-04",
      "contributorsCount" : 2,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2021-06-12",
      "contributorsCount" : 1,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2021-06-15",
      "contributorsCount" : 1,
      "commitsCount" : 3
    }, {
      "timeSlot" : "2021-06-16",
      "contributorsCount" : 2,
      "commitsCount" : 6
    }, {
      "timeSlot" : "2021-06-17",
      "contributorsCount" : 2,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2021-06-18",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2021-07-19",
      "contributorsCount" : 1,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2021-07-21",
      "contributorsCount" : 2,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2021-07-23",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2022-12-07",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2022-12-08",
      "contributorsCount" : 1,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2022-12-09",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2023-01-22",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2023-01-31",
      "contributorsCount" : 1,
      "commitsCount" : 1
    } ],
    "contributorsPerWeek" : [ {
      "timeSlot" : "2020-08-17",
      "contributorsCount" : 1,
      "commitsCount" : 15
    }, {
      "timeSlot" : "2020-08-24",
      "contributorsCount" : 1,
      "commitsCount" : 6
    }, {
      "timeSlot" : "2020-08-31",
      "contributorsCount" : 1,
      "commitsCount" : 6
    }, {
      "timeSlot" : "2020-09-07",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2020-09-28",
      "contributorsCount" : 2,
      "commitsCount" : 15
    }, {
      "timeSlot" : "2020-10-05",
      "contributorsCount" : 2,
      "commitsCount" : 15
    }, {
      "timeSlot" : "2020-10-12",
      "contributorsCount" : 3,
      "commitsCount" : 11
    }, {
      "timeSlot" : "2020-10-19",
      "contributorsCount" : 2,
      "commitsCount" : 8
    }, {
      "timeSlot" : "2020-10-26",
      "contributorsCount" : 3,
      "commitsCount" : 13
    }, {
      "timeSlot" : "2020-11-02",
      "contributorsCount" : 2,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2021-06-07",
      "contributorsCount" : 1,
      "commitsCount" : 2
    }, {
      "timeSlot" : "2021-06-14",
      "contributorsCount" : 3,
      "commitsCount" : 12
    }, {
      "timeSlot" : "2021-07-19",
      "contributorsCount" : 2,
      "commitsCount" : 5
    }, {
      "timeSlot" : "2022-12-05",
      "contributorsCount" : 1,
      "commitsCount" : 4
    }, {
      "timeSlot" : "2023-01-16",
      "contributorsCount" : 1,
      "commitsCount" : 1
    }, {
      "timeSlot" : "2023-01-30",
      "contributorsCount" : 1,
      "commitsCount" : 1
    } ],
    "commitsPerExtensions" : [ {
      "extension" : "scala",
      "commitsCount" : 254,
      "committers" : [ "mabansal@uber.com", "14280154+hiboyang@users.noreply.github.com", "mayurb@uber.com", "harshvardhan5795@gmail.com", "mayurdb31@gmail.com", "boy-uber@users.noreply.github.com", "boy@uber.com", "jkai@uber.com" ],
      "filesCount" : 50,
      "commitsCount30Days" : 0,
      "committers30Days" : [ ],
      "filesCount30Days" : 0,
      "commitsCount90Days" : 0,
      "committers90Days" : [ ],
      "filesCount90Days" : 0,
      "contributorPerExtensionStats" : [ {
        "contributor" : "jkai@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 3
      }, {
        "contributor" : "mabansal@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 36
      }, {
        "contributor" : "mayurdb31@gmail.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 10
      }, {
        "contributor" : "harshvardhan5795@gmail.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 5
      }, {
        "contributor" : "14280154+hiboyang@users.noreply.github.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 13
      }, {
        "contributor" : "mayurb@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 8
      }, {
        "contributor" : "boy-uber@users.noreply.github.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 54
      }, {
        "contributor" : "boy@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 125
      } ]
    }, {
      "extension" : "java",
      "commitsCount" : 1407,
      "committers" : [ "mabansal@uber.com", "14280154+hiboyang@users.noreply.github.com", "mayurb@uber.com", "harshvardhan5795@gmail.com", "boy-uber@users.noreply.github.com", "boy@uber.com" ],
      "filesCount" : 338,
      "commitsCount30Days" : 0,
      "committers30Days" : [ ],
      "filesCount30Days" : 0,
      "commitsCount90Days" : 0,
      "committers90Days" : [ ],
      "filesCount90Days" : 0,
      "contributorPerExtensionStats" : [ {
        "contributor" : "mabansal@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 86
      }, {
        "contributor" : "harshvardhan5795@gmail.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 2
      }, {
        "contributor" : "14280154+hiboyang@users.noreply.github.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 2
      }, {
        "contributor" : "mayurb@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 3
      }, {
        "contributor" : "boy-uber@users.noreply.github.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 329
      }, {
        "contributor" : "boy@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 985
      } ]
    }, {
      "extension" : "md",
      "commitsCount" : 16,
      "committers" : [ "mabansal@uber.com", "boy-uber@users.noreply.github.com", "boy@uber.com" ],
      "filesCount" : 2,
      "commitsCount30Days" : 0,
      "committers30Days" : [ ],
      "filesCount30Days" : 0,
      "commitsCount90Days" : 0,
      "committers90Days" : [ ],
      "filesCount90Days" : 0,
      "contributorPerExtensionStats" : [ {
        "contributor" : "mabansal@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 2
      }, {
        "contributor" : "boy-uber@users.noreply.github.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 7
      }, {
        "contributor" : "boy@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 7
      } ]
    }, {
      "extension" : "xml",
      "commitsCount" : 9,
      "committers" : [ "boy-uber@users.noreply.github.com", "boy@uber.com" ],
      "filesCount" : 1,
      "commitsCount30Days" : 0,
      "committers30Days" : [ ],
      "filesCount30Days" : 0,
      "commitsCount90Days" : 0,
      "committers90Days" : [ ],
      "filesCount90Days" : 0,
      "contributorPerExtensionStats" : [ {
        "contributor" : "boy-uber@users.noreply.github.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 2
      }, {
        "contributor" : "boy@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 7
      } ]
    }, {
      "extension" : "png",
      "commitsCount" : 4,
      "committers" : [ "boy-uber@users.noreply.github.com", "boy@uber.com" ],
      "filesCount" : 2,
      "commitsCount30Days" : 0,
      "committers30Days" : [ ],
      "filesCount30Days" : 0,
      "commitsCount90Days" : 0,
      "committers90Days" : [ ],
      "filesCount90Days" : 0,
      "contributorPerExtensionStats" : [ {
        "contributor" : "boy-uber@users.noreply.github.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 2
      }, {
        "contributor" : "boy@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 2
      } ]
    }, {
      "extension" : "yml",
      "commitsCount" : 6,
      "committers" : [ "boy@uber.com", "boy-uber@users.noreply.github.com" ],
      "filesCount" : 2,
      "commitsCount30Days" : 0,
      "committers30Days" : [ ],
      "filesCount30Days" : 0,
      "commitsCount90Days" : 0,
      "committers90Days" : [ ],
      "filesCount90Days" : 0,
      "contributorPerExtensionStats" : [ {
        "contributor" : "boy-uber@users.noreply.github.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 1
      }, {
        "contributor" : "boy@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 5
      } ]
    }, {
      "extension" : "",
      "commitsCount" : 3,
      "committers" : [ "boy@uber.com" ],
      "filesCount" : 3,
      "commitsCount30Days" : 0,
      "committers30Days" : [ ],
      "filesCount30Days" : 0,
      "commitsCount90Days" : 0,
      "committers90Days" : [ ],
      "filesCount90Days" : 0,
      "contributorPerExtensionStats" : [ {
        "contributor" : "boy@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 3
      } ]
    }, {
      "extension" : "gitignore",
      "commitsCount" : 3,
      "committers" : [ "boy@uber.com" ],
      "filesCount" : 1,
      "commitsCount30Days" : 0,
      "committers30Days" : [ ],
      "filesCount30Days" : 0,
      "commitsCount90Days" : 0,
      "committers90Days" : [ ],
      "filesCount90Days" : 0,
      "contributorPerExtensionStats" : [ {
        "contributor" : "boy@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 3
      } ]
    }, {
      "extension" : "properties",
      "commitsCount" : 2,
      "committers" : [ "boy@uber.com" ],
      "filesCount" : 2,
      "commitsCount30Days" : 0,
      "committers30Days" : [ ],
      "filesCount30Days" : 0,
      "commitsCount90Days" : 0,
      "committers90Days" : [ ],
      "filesCount90Days" : 0,
      "contributorPerExtensionStats" : [ {
        "contributor" : "boy@uber.com",
        "fileUpdates30Days" : 0,
        "fileUpdates90Days" : 0,
        "fileUpdates" : 2
      } ]
    } ]
  },
  "numberOfExcludedFiles" : 9,
  "excludedExtensions" : {
    "" : 3,
    "txt" : 1,
    "gitignore" : 1,
    "md" : 1,
    "json" : 1,
    "yml" : 2
  },
  "analysisStartTimeMs" : 1712148033233,
  "maxLinesOfCode" : 17066,
  "maxFileCount" : 271
}