Forking Without Clicking: on How to Identify Software Repository Forks

dc.contributor.authorAntoine Pietri
dc.contributor.authorGuillaume Rousseau
dc.contributor.authorStefano Zacchiroli
dc.coverage.spatialBolivia
dc.date.accessioned2026-03-22T20:46:08Z
dc.date.available2026-03-22T20:46:08Z
dc.date.issued2020
dc.description.abstractThe notion of software ''fork'' has been shifting over time from the (negative) phenomenon of community disagreements that result in the creation of separate development lines and ultimately software products, to the (positive) practice of using distributed version control system (VCS) repositories to collaboratively improve a single product without stepping on each others toes. In both cases the VCS repositories participating in a fork share parts of a common development history. Studies of software forks generally rely on hosting platform metadata, such as GitHub, as the source of truth for what constitutes a fork. These ''forge forks'' however can only identify as forks repositories that have been created on the platform, e.g., by clicking a ''fork'' button on the platform user interface. The increased diversity in code hosting platforms (e.g., GitLab) and the habits of significant development communities (e.g., the Linux kernel, which is not primarily hosted on any single platform) call into question the reliability of trusting code hosting platforms to identify forks. Doing so might introduce selection and methodological biases in empirical studies. In this article we explore various definitions of ''software forks'', trying to capture forking workflows that exist in the real world. We quantify the differences in how many repositories would be identified as forks on GitHub according to the various definitions, confirming that a significant number could be overlooked by only considering forge forks. We study the structure and size of fork networks , observing how they are affected by the proposed definitions and discuss the potential impact on empirical research.
dc.identifier.doi10.48550/arxiv.2011.07821
dc.identifier.urihttps://doi.org/10.48550/arxiv.2011.07821
dc.identifier.urihttps://andeanlibrary.org/handle/123456789/83957
dc.language.isoen
dc.publisherCornell University
dc.relation.ispartofarXiv (Cornell University)
dc.sourceInstitut national de recherche en informatique et en automatique
dc.subjectFork (system call)
dc.subjectComputer science
dc.subjectLinux kernel
dc.subjectWorkflow
dc.subjectMetadata
dc.subjectWorld Wide Web
dc.subjectSoftware
dc.subjectCode (set theory)
dc.subjectEmpirical research
dc.subjectOpen source software
dc.titleForking Without Clicking: on How to Identify Software Repository Forks
dc.typepreprint

Files