diff --git a/.gitignore b/.gitignore index 831b2b5..8a23928 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ .DS_Store -.vscode/ \ No newline at end of file +.vscode/ +build \ No newline at end of file diff --git a/architecture.html b/architecture.html deleted file mode 100644 index bb39a2b..0000000 --- a/architecture.html +++ /dev/null @@ -1,6 +0,0 @@ - - -
- - - \ No newline at end of file diff --git a/book.json b/book.json index 8139a1b..7694b0d 100644 --- a/book.json +++ b/book.json @@ -1,1100 +1,1642 @@ { - "title": "Cooperative Software Development", - "authors": [ "[Amy J. Ko|https://faculty.washington.edu/ajko]"], - "license": "[Creative Commons Attribution-NoDeriviatives 4.0|https://creativecommons.org/licenses/by-nd/4.0/]", - "images": { - "cover": "|cover.jpg|A photograph of a racially and gender diverse team of six making decisions.|Software engineering is inherently social.|Shutterstock|", - "unknown": "|error.png|A screen shot of a Linux operating system kernel panic|Uh oh, something went wrong|William Pina|" - }, - "description": "This book is an introduction to the many human, social, and political aspects of software engineering. It's unique in two ways. First, unlike many software engineering books, it explictly avoids centering technical questions about software engineering, instead focusing on the many ways that software engineering work is cognitive, social, and organizational. Second, it does so by engaging extensively with academic research literature, summarizing key findings, but also questioning them, opening a dialog about the nature of software engineering work and the many factors that shape it. Anyone that reads it will be better prepared to critically engage in creating software in teams.\n\nThis book is a living document. Do you see ways to improve it? [Submit an issue|https://github.com/amyjko/cooperative-software-development/issues] or a [pull request|https://github.com/amyjko/cooperative-software-development/pulls] to its [GitHub repository|https://github.com/amyjko/cooperative-software-development].\n\n_This material is based upon work supported by the National Science Foundation under Grant No. 0952733. Any opinions, findings, and conclusions or recommendations expressed in this material are those of the author(s) and do not necessarily reflect the views of the National Science Foundation._", - "chapters": [ - { "id": "history", "title": "History", "image": "|Hamilton.jpg|Margaret Hamilton working on the Apollo flight software.|Margaret Hamilton working on the Apollo flight software|NASA|" }, - { "id": "organizations", "title": "Organizations", "image": "|team.jpg|A software team hard at work|Early days at the author's software startup in 2012.|Amy J. Ko|" }, - { "id": "communication", "title": "Communication", "image": "|communication.png|A man and a woman having a conversation|Clear and timely communication is at the heart of effective software engineering.|Creative Commons CC0|" }, - { "id": "productivity", "title": "Productivity", "image": "|productivity.jpg|A women working at a laptop|Productivity isn't just about working fast|Creative Commons CC0|" }, - { "id": "quality", "title": "Quality", "image": "|zoho.jpg|A screenshot of the Zoho issue tracker.|Software quality is multidimensional and often coursely measured through issue trackers like this one.|Zoho, Inc.|" }, - { "id": "requirements", "title": "Requirements", "image": "|scaffolding.jpg|An architectural structure showing the framework of a glass structure|Requirements specify what software must do, constraining, focusing, and defining it's successful functioning.|Public domain|" }, - { "id": "architecture", "title": "Architecture", "image": "|church.jpg|A photograph of a church hallway with arches.|Architecture is how code is organized|Creative Commons 0|" }, - { "id": "specifications", "title": "Specifications", "image": "|blueprint.jpg|A blueprint for an architectural plan|Specifications add a layer of detail onto architectural plans.|Public domain|" }, - { "id": "process", "title": "Process", "image": "|flow.jpg|A photograph of a river|Good process is like a river, seamlessly flowing around obstacles|Public domain|" }, - { "id": "comprehension", "title": "Comprehension", "image": "|network.png|A visualization of many interconnected node|Program comprehension is about understanding dependencies|Public domain|" }, - { "id": "verification", "title": "Verification", "image": "|check.png|A check mark|Have you met your requirements? How do you know?|Public domain|" }, - { "id": "monitoring", "title": "Monitoring", "image": "|monitoring.jpg|A photograph of a lifeguide monitoring a beach.|It's not always easy to see software fail.|Public domain|" }, - { "id": "evolution", "title": "Evolution", "image": "|atsign.png|Four variations on an at sign.|Software changes and that requires planning.|Public domain|" }, - { "id": "debugging", "title": "Debugging", "image": "|swatter.png|An illustration of a fly swatter.|Debugging is inevitable because defects are inevitable|Public domain|" } - ], - "revisions": [ - ["September 2020", "Migrated to [Peruse|https://github.com/amyjko/peruse]."], - ["July 2020", "Revised all chapters to address racism, sexism, and ableism in software engineering."], - ["July 2019", "Incorporated newly published work from ICSE, ESEC/FSE, SIGCSE, TSE, and TOSEM."], - ["July 2018", "Incorporated newly published work from ICSE, ESEC/FSE, SIGCSE, TSE, and TOSEM."], - ["July 2017", "First draft of the book release."] - ], - "sources": { - "ASE": "IEEE/ACM International Conference on Automated Software Engineering", - "CACM": "Communications of the ACM", - "ESE": "Empirical Software Engineering", - "ICSE": "ACM/IEEE International Conference on Software Engineering", - "FSE": "ACM SIGSOFT Foundations of Software Engineering (FSE)", - "TSE": "IEEE Transactions on Software Engineering", - "CHI": "ACM SIGCHI Conference on Human Factors in Computing (CHI)", - "CHASE": "International Workshop on Cooperative and Human Aspects of Software Engineering", - "ICPC": "IEEE International Conference on Program Comprehension (ICPC)", - "SED": "Software Engineering Daily Podcast", - "ESECFSE": "ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering (ESEC/FSE)", - "CSCW": "ACM Conference on Computer Supported Cooperative Work (CSCW)", - "Software": "IEEE Software", - "Computer": "IEEE Computer", - "SEN": "ACM SIGSOFT Software Engineering Notes", - "TOSEM": "ACM Transactions on Software Engineering and Methodology (TOSEM)", - "VL/HCC": "IEEE Symposium on Visual Languages and Human-Centric Computing (VL/HCC)", - "SEIP": "ACM/IEEE International Conference on Software Engineering, Software Engineering in Practice", - "SIGCSE": "ACM Technical Symposium on Computer Science Education", - "Surveys": "ACM Computing Surveys" - }, - "references": { - "abbate12": [ - "Janet Abbate", 2012, - "Recoding gender: women's changing participation in computing", "MIT Press", - "https://mitpress.mit.edu/books/recoding-gender" - ], - "abdalkareem17": [ - "Rabe Abdalkareem, Olivier Nourry, Sultan Wehaibi, Suhaib Mujahid, and Emad Shihab", 2017, - "Why do developers use trivial packages? An empirical case study on npm", "#FSE", - "https://doi.org/10.1145/3106237.3106267" - ], - "aghajani20": [ - "Emad Aghajani, Csaba Nagy, Mario Linares-Vásquez, Laura Moreno, Gabriele Bavota, Michele Lanza, David C. Shepherd", 2020, - "Software documentation: the practitioners’ perspective", "#ICSE", - "https://www.inf.usi.ch/phd/aghajani/resources/papers/agha2020a.pdf" - ], - "ahmed16": [ - "Iftekhar Ahmed, Rahul Gopinath, Caius Brindescu, Alex Groce, and Carlos Jensen", 2016, - "Can testedness be effectively measured?", "#FSE", - "https://doi.org/10.1145/2950290.2950324" - ], - "akers09": [ - "David Akers, Matthew Simpson, Robin Jeffries, and Terry Winograd", 2009, - "Undo and erase events as indicators of usability problems", "#CHI", - "http://dx.doi.org/10.1145/1518701.1518804" - ], - "albaik15": [ - "Osama Al-Baik & James Miller", 2015, - "The kanban approach, between agility and leanness: a systematic review", "#ESE", - "https://doi.org/10.1007/s10664-014-9340-x" - ], - "aranda09": [ - "Jorge Aranda and Gina Venolia", 2009, - "The secret life of bugs: Going past the errors and omissions in software repositories", - "#ICSE", - "http://dx.doi.org/10.1109/ICSE.2009.5070530" - ], - "arnold96": [ - "Robert Arnold, Shawn Bohner", 1996, - "Software change impact analysis", "IEEE Computer Society Press" - ], - "atwood16": [ - "Jeff Atwood", 2016, - "The state of programming with Stack Overflow co-founder Jeff Atwood", "#SED", - "https://softwareengineeringdaily.com/2016/03/14/state-programming-jeff-atwood/" - ], - "bacchelli13": [ - "Alberto Bacchelli and Christian Bird", 2013, - "Expectations, outcomes, and challenges of modern code review", "#ICSE", - "https://doi.org/10.1109/ICSE.2013.6606617" - ], - "baecker88": [ - "Ron Baecker", 1988, - "Enhancing program readability and comprehensibility with tools for program visualization", "#ICSE", - "https://doi.org/10.1109/ICSE.1988.93716" - ], - "baltes18": [ - "Sebastian Baltes, Stephan Diehl", 2018, - "Towards a theory of software development expertise", "#ESECFSE", - "https://doi.org/10.1145/3236024.3236061" - ], - "bartram16": [ - "Ammon Bartram", 2016, - "Hiring engineers with Ammon Bartram", "#SED", - "https://softwareengineeringdaily.com/2015/12/23/hiring-engineers-with-ammon-bartram/" - ], - "barua14": [ - "Anton Barua, Stephen W. Thomas & Ahmed E. Hassan", 2014, - "What are developers talking about? an analysis of topics and trends in Stack Overflow", "#ESE", - "http://link.springer.com/article/10.1007/s10664-012-9231-y" - ], - "bass03": [ - "Len Bass, Bonnie E. John", 2003, - "Linking usability to software architecture patterns through general scenarios", "Journal of Systems and Software", - "http://www.sciencedirect.com/science/article/pii/S0164121202000766" - ], - "beck96": [ - "Kent Beck, Ron Crocker, Gerard Meszaros, John Vlissides, James O. Coplien, Lutz Dominick, and Frances Paulisch", 1996, - "Industrial experience with design patterns", "#ICSE", - "https://doi.org/10.1109/ICSE.1996.493406" - ], - "beck99": [ - "Kent Beck", 1999, - "Embracing change with extreme programming", "IEEE Computer", - "https://doi.org/10.1007/s10664-014-9340-x" - ], - "begel08": [ - "Andy Begel, Beth Simon", 2008, - "Novice software developers, all over again", "ICER", - "http://dl.acm.org/citation.cfm?id=1404522" - ], - "begel10": [ - "Andrew Begel, Yit Phang Khoo, and Thomas Zimmermann ", 2010, - "Codebook: discovering and exploiting relationships in software repositories", "#ICSE", - "http://dx.doi.org/10.1145/1806799.1806821" - ], - "begel14": [ - "Andy Begel, Thomas Zimmermann ", 2014, - "Analyze this! 145 questions for data scientists in software engineering", "#ICSE", - "https://doi.org/10.1145/2568225.2568233" - ], - "beller15": [ - "Moritz Beller, Georgios Gousios, Annibale Panichella, and Andy Zaidman", 2015, - "When, how, and why developers (do not) test in their IDEs", "#ESECFSE", - "https://doi.org/10.1145/2786805.2786843" - ], - "beller18": [ - "Beller, M., Spruit, N., Spinellis, D., & Zaidman, A", 2018, - "On the dichotomy of debugging behavior among programmers", "#ICSE", - "https://doi.org/10.1145/3180155.3180175" - ], - "bendifallah89": [ - "Salah Bendifallah and Walt Scacchi", 1989, - "Work structures and shifts: an empirical analysis of software specification teamwork", "#ICSE", - "http://dx.doi.org/10.1145/74587.74624" - ], - "benjamin19": [ - "Ruha Benjamin", 2019, - "Race after technology: Abolitionist tools for the New Jim Code", "Polity Books", - "https://www.ruhabenjamin.com/race-after-technology" - ], - "bertram10": [ - "Dane Bertram, Amy Voida, Saul Greenberg, and Robert Walker", 2010, - "Communication, collaboration, and bugs: the social nature of issue tracking in small, collocated teams", "#CSCW", - "http://dx.doi.org/10.1145/1718918.1718972" - ], - "bettenburg08": [ - "Nicolas Bettenburg, Sascha Just, Adrian Schröter, Cathrin Weiss, Rahul Premraj, and Thomas Zimmermann", 2008, - "What makes a good bug report?", "#FSE", - "http://dx.doi.org/10.1145/1453101.1453146" - ], - "bettenburg13": [ - "Nicolas Bettenburg, Ahmed E. Hassan", 2013, - "Studying the impact of social interactions on software quality", "#ESE", - "https://doi.org/10.1007/s10664-012-9205-0" - ], - "bhattacharya11": [ - "Pamela Bhattacharya and Iulian Neamtiu", 2011, - "Assessing programming language impact on development and maintenance: a study on C and C++", "#ICSE", - "https://doi.org/10.1145/1985793.1985817" - ], - "binkley13": [ - "Dave Binkley, Marcia Davis, Dawn Lawrie, Jonathan I. Maletic, Christopher Morrell, Bonita Sharif", 2013, - "The impact of identifier style on effort and comprehension", "#ESE", - "https://link.springer.com/article/10.1007/s10664-012-9201-4" - ], - "bird11": [ - "Christian Bird, Nachiappan Nagappan, Brendan Murphy, Harald Gall, and Premkumar Devanbu", 2011, - "Don't touch my code! Examining the effects of ownership on software quality", "#ESECFSE", - "http://dx.doi.org/10.1145/2025113.2025119" - ], - "boehm76": [ - "Barry W. Boehm", 1976, - "Software engineering", "IEEE Transactions on Computers", - "http://ieeexplore.ieee.org/document/1674590/" - ], - "boehm88": [ - "Barry W. Boehm", 1988, - "A spiral model of software development and enhancement", "#Computer", - "http://ieeexplore.ieee.org/abstract/document/59/" - ], - "boehm91": [ - "Boehm, B. W", 1991, - "Software risk management: principles and practices", "#Software", - "http://ieeexplore.ieee.org/abstract/document/62930" - ], - "borozdin17": [ - "Mike Borozdin", 2017, - "Engineering management with Mike Borozdin", "#SED", - "https://softwareengineeringdaily.com/2017/02/08/engineering-management-with-mike-borozdin/" - ], - "brindescu14": [ - "Caius Brindescu, Mihai Codoban, Sergii Shmarkatiuk, and Danny Dig", 2014, - "How do centralized and distributed version control systems impact software changes?", "#ICSE", - "http://dx.doi.org/10.1145/2568225.2568322" - ], - "brooks95": [ - "Fred P. Brooks", 1995, - "The mythical man month", "Pearson Education", - "https://books.google.com/books?id=Yq35BY5Fk3gC" - ], - "callaú13": [ - "Oscar Callaú, Romain Robbes, Éric Tanter, David Röthlisberger", 2013, - "How (and why) developers use the dynamic features of programming languages: the case of Smalltalk", "#ESE", - "https://doi.org/10.1145/1985441.1985448" - ], - "casalnuovo15": [ - "Casey Casalnuovo, Bogdan Vasilescu, Premkumar Devanbu, and Vladimir Filkov", 2015, - "Developer onboarding in GitHub: the role of prior social links and language experience", "#ESECFSE", - "https://doi.org/10.1145/2786805.2786854" - ], - "casalnuovo15b": [ - "Casey Casalnuovo, Prem Devanbu, Abilio Oliveira, Vladimir Filkov, and Baishakhi Ray", 2015, - "Assert use in GitHub projects", "#ICSE", - "https://doi.org/10.1145/2568225.2568285" - ], - "chedeua15": [ - "Sebastian Marbage, Christopher Chedeua", 2015, - "React JS with Sebastian Marbage and Christopher Chedeua", "#SED", - "https://softwareengineeringdaily.com/2015/07/27/react-js-with-sebastian-markbage-and-christopher-chedeau/" - ], - "chen09": [ - "Chien-Tsun Chen, Yu Chin Cheng, Chin-Yun Hsieh, and I-Lang Wu", 2008, - "Exception handling refactorings: Directed by goals and driven by bug fixing", "Journal of Systems and Software", - "https://doi.org/10.1016/j.jss.2008.06.035" - ], - "chen15": [ - "Lianping Chen", 2015, - "Continuous delivery: Huge benefits, but challenges too", "#Software", - "https://doi.org/10.1109/MS.2015.27" - ], - "chilana11": [ - "Parmit K. Chilana, Amy J. Ko, Jacob O. Wobbrock, Tovi Grossman, and George Fitzmaurice", 2011, - "Post-deployment usability: a survey of current practices", "#CHI", - "http://dx.doi.org/10.1145/1978942.1979270" - ], - "chilana13": [ - "Parmit K. Chilana, Amy J. Ko, Jacob O. Wobbrock, Tovi Grossman", 2013, - "A multi-site field study of crowdsourced contextual help: usage and perspectives of end users and software teams", "#CHI", - "http://dl.acm.org/citation.cfm?id=2470685" - ], - "chong07": [ - "Jan Chong and Tom Hurlbutt", 2007, - "The social dynamics of pair programming", "#ICSE", - "http://dx.doi.org/10.1109/ICSE.2007.87" - ], - "cito15": [ - "Jürgen Cito, Philipp Leitner, Thomas Fritz, and Harald C. Gall", 2015, - "The making of cloud applications: an empirical study on software development for the cloud", "#ESECFSE", - "https://doi.org/10.1145/2786805.2786826" - ], - "clarke06": [ - "Clarke, L. A., & Rosenblum, D. S", 2006, - "A historical perspective on runtime assertion checking in software development", "#SEN", - "https://doi.org/10.1145/1127878.1127900" - ], - "clegg08": [ - "Stewart Clegg, James R. Bailey", 2008, - "International encyclopedia of organization studies", "Sage Publications", - "https://books.google.com/books?id=Uac5DQAAQBAJ" - ], - "coelho17": [ - "Jailton Coelho and Marco Tulio Valente ", 2017, - "Why modern open source projects fail", "#ESECFSE", - "https://doi.org/10.1145/3106237.3106246" - ], - "conway68": [ - "Melvin E. Conway", 1968, - "How do committees invent", "Datamation", - "https://pdfs.semanticscholar.org/cbce/35eedcde3ef152bde75950fbc7ef4c6717b2.pdf" - ], - "dagenais10": [ - "Barthélémy Dagenais, Harold Ossher, Rachel K. E. Bellamy, Martin P. Robillard, and Jacqueline P. de Vries", 2010, - "Moving into a new software project landscape", "#ICSE", - "http://dx.doi.org/10.1145/1806799.1806842" - ], - "demarco85": [ - "Tom DeMarco and Tim Lister", 1985, - "Programmer performance and the effects of the workplace", "#ICSE", - "http://dl.acm.org/citation.cfm?id=319651" - ], - "demarco87": [ - "Tom DeMarco, Tim Lister", 1987, - "Peopleware: Productive projects and teams", " Addison-Wesley", - "https://books.google.com/books?id=TVQUAAAAQBAJ" - ], - "dibella13": [ - "di Bella, E., Fronza, I., Phaphoom, N., Sillitti, A., Succi, G., & Vlasenko, J", 2013, - "Pair programming and software defects—A large, industrial case study", "#TSE", - "https://doi.org/10.1109/TSE.2012.68" - ], - "dingsøyr03": [ - "Torgeir Dingsøyr, Emil Røyrvik", 2003, - "An empirical study of an informal knowledge repository in a medium-sized software consulting company", "#ICSE", - "http://dl.acm.org/citation.cfm?id=776827" - ], - "duala12": [ - "Ekwa Duala-Ekoko and Martin P. Robillard", 2012, - "Asking and answering questions about unfamiliar APIs: an exploratory study", "#ICSE", - "http://dl.acm.org/citation.cfm?id=2337255" - ], - "dybå02": [ - "Tore Dybå", 2002, - "Enabling software process improvement: an investigation of the importance of organizational issues", "#ESE", - "https://doi.org/10.1145/940071.940092" - ], - "dybå03": [ - "Tore Dybå ", 2003, - "Factors of software process improvement success in small and large organizations: an empirical study in the scandinavian context", "#ESECFSE", - "http://dx.doi.org/10.1145/940071.940092" - ], - "ebert15": [ - "Felipe Eberta, Fernando Castora, Alexander Serebrenik", 2015, - "An exploratory study on exception handling bugs in Java programs", "Journal of Systems and Software", - "https://doi.org/10.1016/j.jss.2015.04.066" - ], - "eisenstadt97": [ - "Marc Eisenstadt", 1997, - "My hairiest bug war stories", "#CACM", - "https://doi.org/10.1145/248448.248456" - ], - "endrikat14": [ - "Stefan Endrikat, Stefan Hanenberg, Romain Robbes, and Andreas Stefik", 2014, - "How do API documentation and static typing affect API usability?", "#ICSE", - "https://doi.org/10.1145/2568225.2568299" - ], - "ernst15": [ - "Neil A. Ernst, Stephany Bellomo, Ipek Ozkaya, Robert L. Nord, and Ian Gorton", 2015, - "Measure it? Manage it? Ignore it? Software practitioners and technical debt", "#ESECFSE", - "https://doi.org/10.1145/2786805.2786848" - ], - "fairbanks10": [ - "George Fairbanks", 2010, - "Just enough software architecture: a risk-driven approach", "Marshall & Brainerd", - "https://www.georgefairbanks.com/assets/jesa/Just_Enough_Software_Architecture__Fairbanks_2010-demo.pdf" - ], - "fleming13": [ - "Scott D. Fleming, Christopher Scaffidi, David Piorkowski, Margaret M. Burnett, Rachel K. E. Bellamy", 2013, - "An information foraging theory perspective on tools for debugging, refactoring, and reuse tasks", "#TOSEM", - "https://doi.org/10.1145/2430545.2430551" - ], - "foucault15": [ - "Matthieu Foucault, Marc Palyart, Xavier Blanc, Gail C. Murphy, and Jean-Rémy Falleri", 2015, - "Impact of developer turnover on quality in open-source software", "#ESECFSE", - "https://doi.org/10.1145/2786805.2786870" - ], - "fucci16": [ - "Davide Fucci, Hakan Erdogmus, Burak Turhan, Markku Oivo, Natalia Juristo", 2016, - "A dissection of test-driven development: Does it really matter to test-first or to test-last?", "#TSE", - "https://doi.org/10.1109/TSE.2016.2616877" - ], - "garlan95": [ - "Garlan, D., Allen, R., & Ockerbloom, J", 1995, - "Architectural mismatch or why it's hard to build systems out of existing parts", "#ICSE", - "https://doi.org/10.1145/225014.225031" - ], - "gilmore91": [ - "David Gilmore", 1991, - "Models of debugging", "Acta Psychologica", - "https://doi.org/10.1016/0001-6918(91)90009-O" - ], - "gleick11": [ - "James Gleick", 2011, - "The Information: A History, A Theory, A Flood", "Pantheon Books", - "https://books.google.com/books?id=617JSFW0D2kC" - ], - "glerum09": [ - "Kirk Glerum, Kinshuman Kinshumann, Steve Greenberg, Gabriel Aul, Vince Orgovan, Greg Nichols, David Grant, Gretchen Loihle, and Galen Hunt", 2009, - "Debugging in the (very) large: ten years of implementation and experience", "ACM SIGOPS Symposium on Operating Systems Principles (SOSP)", - "http://dx.doi.org/10.1145/1629575.1629586" - ], - "grabner16": [ - "Andi Grabner", 2016, - "Performance monitoring with Andi Grabner", "#SED", - "https://softwareengineeringdaily.com/2016/12/27/performance-monitoring-with-andi-grabner/" - ], - "green89": [ - "Thomas R. G. Green", 1989, - "Cognitive dimensions of notations", "People and computers", - "https://www.cl.cam.ac.uk/~afb21/CognitiveDimensions/papers/Green1989.pdf" - ], - "grossman09": [ - "Tovi Grossman, George Fitzmaurice, Ramtin Attar", 2009, - "A survey of software learnability: metrics, methodologies and guidelines", "#CHI", - "https://doi.org/10.1145/1518701.1518803" - ], - "grudin17": [ - "Grudin, Jonathan ", 2017, "From Tool to Partner: The Evolution of Human-Computer Interaction", "", "https://books.google.com/books?id=Wc3hDQAAQBAJ" - ], - "hanenberg13": [ - "Stefan Hanenberg, Sebastian Kleinschmager, Romain Robbes, Éric Tanter, Andreas Stefik", 2013, - "An empirical study on the impact of static typing on software maintainability", "#ESE", - "https://doi.org/10.1007/s10664-013-9289-1" - ], - "herbsleb03": [ - "James D. Herbsleb and Audris Mockus", 2003, - "Formulation and preliminary test of an empirical theory of coordination in software engineering", "#ESECFSE", - "http://dx.doi.org/10.1145/940071.940091" - ], - "herbsleb16": [ - "James Herbsleb", 2016, - "Building a socio-technical theory of coordination: why and how", "#FSE", - "https://doi.org/10.1145/2950290.2994160" - ], - "hilton16": [ - "Michael Hilton, Timothy Tunnell, Kai Huang, Darko Marinov, Danny Dig", 2016, - "Usage, costs, and benefits of continuous integration in open-source projects", "#ASE", - "https://doi.org/10.1145/2970276.2970358" - ], - "hoda10": [ - "Rashina Hoda, James Noble, and Stuart Marshall", 2010, - "Organizing self-organizing teams", "#ICSE", - "https://doi.org/10.1145/1806799.1806843" - ], - "hoda17": [ - "Rashina Hoda, James Noble", 2017, - "Becoming agile: a grounded theory of agile transitions in practice", "#ICSE", - "https://doi.org/10.1109/ICSE.2017.21" - ], - "ivory01": [ - "Melody Y. Ivory, Marti A. Hearst", 2001, - "The state of the art in automating usability evaluation of user interfaces", "#Surveys", - "http://doi.acm.org/10.1145/503112.503114" - ], - "jackson01": [ - "Michael Jackson", 2001, - "Problem frames", "Addison-Wesley", - "https://books.google.com/books?id=8fqIP83Q2IAC" - ], - "johnson13": [ - "Brittany Johnson, Yoonki Song, Emerson Murphy-Hill, and Robert Bowdidge", 2013, - "Why don't software developers use static analysis tools to find bugs?", "#ICSE", - "https://doi.org/10.1109/ICSE.2013.6606613" - ], - "johnson15": [ - "Brittany Johnson, Rahul Pandita, Emerson Murphy-Hill, and Sarah Heckman", 2015, - "Bespoke tools: adapted to the concepts developers know", "#ESECFSE", - "https://doi.org/10.1145/2786805.2803197" - ], - "kalliamvakou17": [ - "Eirini Kalliamvakou, Christian Bird, Thomas Zimmermann, Andrew Begel, Robert DeLine, Daniel M. German", 2017, - "What makes a great manager of software engineers?", "#TSE", - "https://doi.org/10.1109/TSE.2017.2768368" - ], - "kay96": [ - "Alan C. Kay", 1996, - "The early history of Smalltalk", "History of programming languages II", - "https://doi.org/10.1145/234286.1057828" - ], - "kenney00": [ - "Kenney, M", 2000, - "Understanding Silicon Valley: The anatomy of an entrepreneurial region", "Stanford University Press" - ], - "kernighan16": [ - "Brian Kernighan", 2016, - "Language Design with Brian Kernighan", "#SED", - "https://softwareengineeringdaily.com/2016/01/06/language-design-with-brian-kernighan/" - ], - "kersten06": [ - "Mik Kersten and Gail C. Murphy", 2006, - "Using task context to improve programmer productivity", "#FSE", - "http://dx.doi.org/10.1145/1181775.1181777" - ], - "khadka14": [ - "Ravi Khadka, Belfrit V. Batlajery, Amir M. Saeidi, Slinger Jansen, and Jurriaan Hage", 2014, - "How do professionals perceive legacy systems and software modernization?", "#ICSE", - "http://dx.doi.org/10.1145/2568225.2568318" - ], - "kim12": [ - "Miryung Kim, Thomas Zimmermann, and Nachiappan Nagappan", 2012, - "A field study of refactoring challenges and benefits", "#FSE", - "http://dx.doi.org/10.1145/2393596.2393655" - ], - "kim16": [ - "Miryung Kim, Thomas Zimmermann, Robert DeLine, and Andrew Begel", 2016, - "The emerging role of data scientists on software development teams", "#ICSE", - "https://doi.org/10.1145/2884781.2884783" - ], - "ko04": [ - "Amy J. Ko, Brad A. Myers, Htet Htet Aung", 2004, - "Six learning barriers in end-user programming systems", "#VL/HCC", - "https://doi.org/10.1109/VLHCC.2004.47" - ], - "ko05": [ - "Amy J. Ko, Htet Htet Aung, Brad A. Myers ", 2005, - "Eliciting design requirements for maintenance-oriented IDEs: a detailed ttudy of corrective and perfective maintenance tasks", "#ICSE", - "https://doi.org/10.1145/1062455.1062492" - ], - "ko05b": [ - "Amy J. Ko, Brad A. Myers", 2005, - "A framework and methodology for studying the causes of software errors in programming systems", "Journal of Visual Languages & Computing", - "https://doi.org/10.1016/j.jvlc.2004.08.003" - ], - "ko07": [ - "Amy J. Ko, Rob DeLine, and Gina Venolia ", 2007, - "Information needs in collocated software development teams", "#ICSE", - "https://doi.org/10.1109/ICSE.2007.45" - ], - "ko08": [ - "Amy J. Ko and Brad A. Myers", 2008, - "Debugging reinvented: asking and answering why and why not questions about program behavior", "#ICSE", - "http://dx.doi.org/10.1145/1368088.1368130" - ], - "ko09": [ - "Amy J. Ko and Brad A. Myers ", 2009, - "Finding causes of program output with the Java Whyline", "#CHI", - "https://doi.org/10.1145/1518701.1518942" - ], - "ko17": [ - "Amy J. Ko", 2017, - "A Three-Year Participant Observation of Software Startup Software Evolution", "#SEIP", - "https://faculty.washington.edu/ajko/papers/Ko2017AnswerDashReflection.pdf" - ], - "ko19": [ - "Amy J. Ko, Thomas D. LaToza, Stephen Hull, Ellen A. Ko, William Kwok, Jane Quichocho, Harshitha Akkaraju, and Rishin Pandit", 2019, - "Teaching explicit programming strategies to adolescents", "#SIGCSE", - "https://doi.org/10.1145/3287324.3287371" - ], - "kocaguneli13": [ - "Ekrem Kocaguneli, Thomas Zimmermann, Christian Bird, Nachiappan Nagappan, and Tim Menzies", 2013, - "Distributed development considered harmful?", "#ICSE", - "https://doi.org/10.1109/ICSE.2013.6606637" - ], - "kononenko16": [ - "Oleksii Kononenko, Olga Baysal, and Michael W. Godfrey", 2016, - "Code review quality: how developers see it", "#ICSE", - "https://doi.org/10.1145/2884781.2884840" - ], - "lamsweerde08": [ - "Axel van Lamsweerde", 2008, - "Requirements engineering: from craft to discipline", "#FSE", - "http://dx.doi.org/10.1145/1453101.1453133" - ], - "latoza06": [ - "Thomas D. LaToza, Gina Venolia, and Robert DeLine", 2006, - "Maintaining mental models: a study of developer work habits", "#ICSE", - "http://dx.doi.org/10.1145/1134285.1134355" - ], - "latoza07": [ - "Thomas D. LaToza, David Garlan, James D. Herbsleb, and Brad A. Myers", 2007, - "Program comprehension as fact finding", "#ESECFSE", - "http://dx.doi.org/10.1145/1287624.1287675" - ], - "latoza10": [ - "Thomas D. LaToza, Brad A. Myers", 2010, - "Developers ask reachability questions", "#ICSE", - "http://dx.doi.org/10.1145/1806799.1806829" - ], - "latoza20": [ - "Thomas D. LaToza, Maryam Arab, Dastyni Loksa, Amy J. Ko", 2020, - "Explicit programming strategies", "#ESE", - "https://doi.org/10.1007/s10664-020-09810-1" - ], - "lavallee15": [ - "Mathieu Lavallee and Pierre N. Robillard", 2015, - "Why good developers write bad code: an observational case study of the impacts of organizational factors on software quality", "#ICSE", - "http://dl.acm.org/citation.cfm?id=2818754.2818837" - ], - "lawrie06": [ - "Lawrie, D., Morrell, C., Feild, H., & Binkley, D", 2006, - "What's in a name? A study of identifiers", "#ICPC", - "https://doi.org/10.1109/ICPC.2006.51" - ], - "lee03": [ - "Gwendolyn K. Lee, Robert E. Cole", 2003, - "From a firm-based to a community-based model of knowledge creation: The case of the Linux kernel development", "Organization science", - "http://pubsonline.informs.org/doi/abs/10.1287/orsc.14.6.633.24866" - ], - "li15": [ - "Paul Luo Li, Amy J. Ko, and Jiamin Zhu", 2015, - "What makes a great software engineer?", "#ICSE", - "http://dl.acm.org/citation.cfm?id=2818839" - ], - "li17": [ - "Paul Luo Li, Amy J. Ko, and Andrew Begel", 2017, - "Cross-disciplinary perspectives on collaborations with software engineers", "#CHASE", - "https://doi.org/10.1109/CHASE.2017.3" - ], - "maalej14": [ - "Walid Maalej, Rebecca Tiarks, Tobias Roehm, and Rainer Koschke", 2014, - "On the comprehension of program comprehension", "#TOSEM", - "http://dx.doi.org/10.1145/2622669" - ], - "mader15": [ - "Patrick Mäder, Alexander Egyed ", 2015, - "Do developers benefit from requirements traceability when evolving and maintaining a software system?", "#ESE", - "https://doi.org/10.1007/s10664-014-9314-z" - ], - "mamykina11": [ - "Lena Mamykina, Bella Manoim, Manas Mittal, George Hripcsak, and Björn Hartmann", 2011, - "Design lessons from the fastest Q&A site in the west", "#CHI", - "https://doi.org/10.1145/1978942.1979366" - ], - "mark08": [ - "Gloria Mark, Daniela Gudith, and Ulrich Klocke", 2008, - "The cost of interrupted work: more speed and stress", "#CHI", - "https://doi.org/10.1145/1357054.1357072" - ], - "maxion00": [ - "Maxion, Roy A., and Robert T. Olszewski", 2000, - "Eliminating exception handling errors with dependability cases: a comparative, empirical study", "#TSE", - "https://doi.org/10.1109/32.877848" - ], - "may19": [ - "Anna May, Johannes Wachs, Anikó Hannák ", 2019, - "Gender differences in participation and reward on Stack Overflow", "#ESE", - "https://doi.org/10.1007/s10664-019-09685-x" - ], - "mccarthy78": [ - "John McCarthy", 1978, - "History of LISP", "History of Programming Languages I", - "http://dl.acm.org/citation.cfm?id=1198360" - ], - "mcilwain19": [ - "Charlton D. McIlwain", 2019, - "Black software: the internet and racial justice, from the AfroNet to Black Lives Matter", "Oxford University Press", - "https://global.oup.com/academic/product/black-software-9780190863845?cc=us&lang=en&" - ], - "meneely11": [ - "Andrew Meneely, Pete Rotella, and Laurie Williams", 2011, - "Does adding manpower also affect quality? An empirical, longitudinal analysis", "#ESECFSE", - "http://dx.doi.org/10.1145/2025113.2025128" - ], - "menzies13": [ - "Tim Menzies, Tom Zimmermann", 2013, - "Software analytics: so what?", "#Software", - "https://doi.ieeecomputersociety.org/10.1109/MS.2013.86" - ], - "metcalf02": [ - "Michael Metcalf", 2002, - "History of Fortran", "ACM SIGPLAN Fortran Forum", - "https://doi.org/10.1145/602376.602379" - ], - "meyer17": [ - "André N. Meyer, Laura E. Barton, Gail C. Murphy, Thomas Zimmermann, Thomas Fritz", 2017, - "The work life of developers: Activities, switches and perceived productivity", "#TSE", - "https://doi.org/10.1109/TSE.2017.2656886" - ], - "milewski07": [ - "Allen E. Milewski", 2007, - "Global and task effects in information-seeking among software engineers", "#ESE", - "https://doi.org/10.1007/s10664-007-9036-6" - ], - "mockus02": [ - "Audris Mockus and James D. Herbsleb", 2002, - "Expertise browser: a quantitative approach to identifying expertise", "#ICSE", - "http://dx.doi.org/10.1145/581339.581401" - ], - "mockus10": [ - "Audris Mockus", 2010, - "Organizational volatility and its effects on software defects", "#FSE", - "http://doi.acm.org/10.1145/1882291.1882311" - ], - "mohanani14": [ - "Rahul Mohanani, Paul Ralph, and Ben Shreeve", 2014, - "Requirements fixation", "#ICSE", - "http://dx.doi.org/10.1145/2568225.2568235" - ], - "murphy14": [ - "Emerson Murphy-Hill, Thomas Zimmermann, and Nachiappan Nagappan", 2014, - "Cowboys, ankle sprains, and keepers of quality: how is video game development different from software development?", "#ICSE", - "http://dx.doi.org/10.1145/2568225.2568226" - ], - "murphyhill09": [ - "Emerson Murphy-Hill, Chris Parnin, and Andrew P. Black", 2009, - "How we refactor, and how we know it", "#ICSE", - "http://dx.doi.org/10.1109/ICSE.2009.5070529" - ], - "murphyhill13": [ - "Emerson Murphy-Hill, Thomas Zimmermann, Christian Bird, and Nachiappan Nagappan", 2013, - "The design of bug fixes", "#ICSE", - "http://dl.acm.org/citation.cfm?id=2486833" - ], - "müller03": [ - "Matthias M. Müller and Frank Padberg", 2003, - "On the economic evaluation of XP projects", "#ESECFSE", - "http://dx.doi.org/10.1145/940071.940094" - ], - "nelson19": [ - "Nicholas Nelson, Caius Brindescu, Shane McKee, Anita Sarma & Danny Dig", 2019, - "The life-cycle of merge conflicts: processes, barriers, and strategies", "#ESE", - "https://doi.org/10.1007/s10664-018-9674-x" - ], - "ng06": [ - "T. H. Ng, S. C. Cheung, W. K. Chan, and Y. T. Yu", 2006, - "Work experience versus refactoring to design patterns: a controlled experiment", "#FSE", - "http://dx.doi.org/10.1145/1181775.1181778" - ], - "norris17": [ - "Jeff Norris", 2016, - "Tech leadership with Jeff Norris", "#SED", - "https://softwareengineeringdaily.com/2016/09/22/tech-leadership-with-jeff-norris/" - ], - "northrup16": [ - "Ben Northup", 2016, - "Reflections of an old programmer", "#SED", - "https://softwareengineeringdaily.com/2016/11/09/reflections-of-an-old-programmer-with-ben-northrup/" - ], - "osterwalder15": [ - "Alexander Osterwalder, Yves Pigneur, Gregory Bernarda, Alan Smith", 2015, - "Value proposition design: how to create products and services customers want", "John Wiley & Sons", - "https://books.google.com/books?id=jgu5BAAAQBAJ" - ], - "overney20": [ - "Cassandra Overney, Jens Meinicke, Christian Kästner, Bogdan Vasilescu", 2020, - "How to not get rich: an empirical study of donations in open source", "#ICSE", - "https://cmustrudel.github.io/papers/overney20donations.pdf" - ], - "parnas86": [ - "David L Parnas, Paul C. Clements", 1986, - "A rational design process: How and why to fake it", "#TSE", - "https://doi.org/10.1109/TSE.1986.6312940" - ], - "perlow99": [ - "Leslie A. Perlow", 1999, - "The time famine: Toward a sociology of work time", "Administrative science quarterly", - "http://journals.sagepub.com/doi/abs/10.2307/2667031" - ], - "petre13": [ - "Marian Petre", 2013, - "UML in practice", "#ICSE", - "https://doi.org/10.1145/2568225.2568285" - ], - "petre16": [ - "Marian Petre, André van der Hoek", 2016, - "Software design decoded: 66 ways experts think", "MIT Press", - "https://www.google.com/books/edition/_/EVE4DQAAQBAJ" - ], - "pettersen16": [ - "Tim Pettersen", 2016, - "Git Workflows with Tim Pettersen", "#SED", - "https://softwareengineeringdaily.com/2016/04/06/git-workflows-tim-pettersen/" - ], - "pham14": [ - "Raphael Pham, Stephan Kiesling, Olga Liskin, Leif Singer, and Kurt Schneider", 2014, - "Enablers, inhibitors, and perceptions of testing in novice software teams", "#FSE", - "http://dx.doi.org/10.1145/2635868.2635925" - ], - "phillips14": [ - "Shaun Phillips, Thomas Zimmermann, and Christian Bird", 2014, - "Understanding and improving software build teams", "#ICSE", - "http://dx.doi.org/10.1145/2568225.2568274" - ], - "pikkarainen98": [ - "M. Pikkarainen, J. Haikara, O. Salo, P. Abrahamsson, J. Still", 2008, - "The impact of agile practices on communication in software development", "#ESE", - "https://doi.org/10.1007/s10664-008-9065-9" - ], - "potvin16": [ - "Rachel Potvin, Josh Levenberg", 2016, - "Why Google stores billions of lines of code in a single repository", "#CACM", - "https://doi.org/10.1145/2854146" - ], - "prince17": [ - "Suzie Prince", 2017, - "Product management with Suzie Prince", "#SED", - "https://softwareengineeringdaily.com/2017/01/18/product-management-with-suzie-prince/" - ], - "procaccino05": [ - "J. Drew Procaccino, June M. Verner, Katherine M. Shelfer, David Gefen", 2005, - "What do software practitioners really think about project success: an exploratory study", "Journal of Systems and Software", - "https://doi.org/10.1016/j.jss.2004.12.011" - ], - "qiu13": [ - "Dong Qiu, Bixin Li, and Zhendong Su", 2013, - "An empirical analysis of the co-evolution of schema and code in database applications", "#ESECFSE", - "http://dx.doi.org/10.1145/2491411.2491431" - ], - "qureshi16": [ - "Haseeb Qureshi", 2016, - "Debugging stories with Haseeb Qureshi", "#SED", - "https://softwareengineeringdaily.com/2016/11/19/debugging-stories-with-haseeb-qureshi/" - ], - "ralph14": [ - "Paul Ralph and Paul Kelly", 2014, - "The dimensions of software engineering success", "#ICSE", - "http://dx.doi.org/10.1145/2568225.2568261" - ], - "ramasubbu11": [ - "Narayan Ramasubbu, Marcelo Cataldo, Rajesh Krishna Balan, and James D. Herbsleb", 2011, - "Configuring global software teams: a multi-company analysis of project productivity, quality, and profits", "#ICSE", - "https://doi.org/10.1145/1985793.1985830" - ], - "ray14": [ - "Baishakhi Ray, Daryl Posnett, Vladimir Filkov, and Premkumar Devanbu", 2014, - "A large scale study of programming languages and code quality in GitHub", "#FSE", - "http://dx.doi.org/10.1145/2635868.2635922" - ], - "rice16": [ - "David Rice", 2016, - "Continuous delivery with David Rice", "#SED", - "https://softwareengineeringdaily.com/2016/10/10/continuous-delivery-with-david-rice/" - ], - "rigby11": [ - "Peter C. Rigby and Margaret-Anne Storey", 2011, - "Understanding broadcast based peer review on open source software projects", "#ICSE", - "https://doi.org/10.1145/1985793.1985867" - ], - "rigby13": [ - "Peter C. Rigby and Christian Bird", 2013, - "Convergent contemporary software peer review practices", "#ESECFSE", - "http://dx.doi.org/10.1145/2491411.2491444" - ], - "rigby16": [ - "Peter C. Rigby, Yue Cai Zhu, Samuel M. Donadelli, and Audris Mockus", 2016, - "Quantifying and mitigating turnover-induced knowledge loss: case studies of chrome and a project at Avaya", - "#ICSE", - "https://doi.org/10.1145/2884781.2884851" - ], - "roehm12": [ - "Tobias Roehm, Rebecca Tiarks, Rainer Koschke, and Walid Maalej", 2012, - "How do professional developers comprehend software?", "#ICSE", - "https://doi.org/10.1109/ICSE.2012.6227188" - ], - "rothermel96": [ - "Gregg G. Rothermel, Mary Jean Harrold", 1996, - "Analyzing regression test selection techniques", "#TSE", - "https://doi.org/10.1109/32.536955" - ], - "rubin16": [ - "Julia Rubin and Martin Rinard", 2016, - "The challenges of staying together while moving fast: an exploratory study", "#ICSE", - "https://doi.org/10.1145/2884781.2884871" - ], - "runeson06": [ - "Per Runeson", 2006, - "A survey of unit testing practices", "#Software", - "https://doi.org/10.1109/MS.2006.91" - ], - "salvaneschi14": [ - "Guido Salvaneschi, Sven Amann, Sebastian Proksch, and Mira Mezini", 2014, - "An empirical study on program comprehension with reactive programming", "#FSE", - "https://doi.org/10.1145/2635868.2635895" - ], - "santos16": [ - "Ronnie E. S. Santos, Fabio Q. B. da Silva, Cleyton V. C. de Magalhães, and Cleviton V. F. Monteiro", 2016, - "Building a theory of job rotation in software engineering from an instrumental case study", "#ICSE", - "https://doi.org/10.1145/2884781.2884837" - ], - "schiller14": [ - "Todd W. Schiller, Kellen Donohue, Forrest Coward, and Michael D. Ernst", 2014, - "Case studies and tools for contract specifications", "#ICSE", - "https://doi.org/10.1145/2568225.2568285" - ], - "seaman97": [ - "Carolyn B. Seaman and Victor R. Basili", 1997, - "An empirical study of communication in code inspections", "#ICSE", - "http://dx.doi.org/10.1145/253228.253248" - ], - "sedano17": [ - "Todd Sedano, Paul Ralph, Cécile Péraire", 2017, - "Software development waste", "#ICSE", - "https://doi.org/10.1109/ICSE.2017.20" - ], - "sfetsos09": [ - "Panagiotis Sfetsos, Ioannis Stamelos, Lefteris Angelis, Ignatios Deligiannis ", 2009, - "An experimental investigation of personality types impact on pair effectiveness in pair programming", "#ESE", - "https://doi.org/10.1007/s10664-008-9093-5" - ], - "sharp04": [ - "Helen Sharp, Hugh Robinson", 2004, - "An ethnographic study of XP practice", "#ESE", - "https://doi.org/10.1023/B:EMSE.0000039884.79385.54" - ], - "shetterly17": [ - "Margot Lee Shetterly", 2017, - "Hidden figures: the American dream and the untold story of the Black women mathematicians who helped win the space race", "HarperCollins Nordic", - "https://www.harpercollins.com/products/hidden-figures-margot-lee-shetterly?variant=32132873093154" - ], - "shrestha20": [ - "Shrestha, N., Botta, C., Barik, T., & Parnin, C", 2020, - "Here we go again: why is it difficult for developers to learn another programming language?", "#ICSE", - "http://nischalshrestha.me/docs/cross_language_interference.pdf" - ], - "sillito06": [ - "Jonathan Sillito, Gail C. Murphy, and Kris De Volder", 2006, - "Questions programmers ask during software evolution tasks", "#FSE", - "http://dx.doi.org/10.1145/1181775.1181779" - ], - "silva16": [ - "Danilo Silva, Nikolaos Tsantalis, and Marco Tulio Valente", 2016, - "Why we refactor? Confessions of GitHub contributors", "#FSE", - "https://doi.org/10.1145/2950290.2950305" - ], - "singer14": [ - "Leif Singer, Fernando Figueira Filho, and Margaret-Anne Storey", 2014, - "Software engineering at the speed of light: how developers stay current using Twitter", "#ICSE", - "http://dx.doi.org/10.1145/2568225.2568305" - ], - "smite10": [ - "Darja Šmite, Claes Wohlin, Tony Gorschek, Robert Feldt ", 2010, - "Empirical evidence in global software engineering: a systematic review", "#ESE", - "https://doi.org/10.1007/s10664-009-9123-y" - ], - "somers17": [ - "James Somers", 2017, - "The coming software apocalypse", "The Atlantic Monthly", - "https://www.theatlantic.com/technology/archive/2017/09/saving-the-world-from-code/540393/" - ], - "sommerville97": [ - "Ian Sommerville, Pete Sawyer", 1997, - "Requirements engineering: a good practice guide", "John Wiley & Sons, Inc", - "https://books.google.com/books?id=5NnP-VODEc8C" - ], - "stefik13": [ - "Andreas Stefik and Susanna Siebert", 2013, - "An Empirical Investigation into Programming Language Syntax", "ACM Transactions on Computing Education", - "https://doi.org/10.1145/2534973" - ], - "stol14": [ - "Klaas-Jan Stol and Brian Fitzgerald", 2014, - "Two's company, three's a crowd: a case study of crowdsourcing software development", "#ICSE", - "http://dx.doi.org/10.1145/2568225.2568249" - ], - "stroustrup96": [ - "Bjarn Stroustrup, B", 1996, - "A history of C++: 1979--1991", "History of programming languages II", - "http://dl.acm.org/citation.cfm?id=1057836" - ], - "stylos08": [ - "Jeffrey Stylos and Brad A. Myers", 2008, - "The implications of method placement on API learnability", "#FSE", - "http://dx.doi.org/10.1145/1453101.1453117" - ], - "syedabdullah06": [ - "Sharifah Syed-Abdullah, Mike Holcombe & Marian Gheorge", 2006, - "The impact of an agile methodology on the well being of development teams", "#ESE", - "https://doi.org/10.1007/s10664-009-9123-y" - ], - "tao12": [ - "Yida Tao, Yingnong Dang, Tao Xie, Dongmei Zhang, and Sunghun Kim", 2012, - "How do software engineers understand code changes? An exploratory study in industry", "#FSE", - "http://dx.doi.org/10.1145/2393596.2393656" - ], - "thongtanunam16": [ - "Thongtanunam, P., McIntosh, S., Hassan, A. E., & Iida, H", 2016, - "Review participation in modern code review: An empirical study of the Android, Qt, and OpenStack projects", "#ESE", - "https://doi.org/10.1007/s10664-016-9452-6" - ], - "treude09": [ - "Christoph Treude and Margaret-Anne Storey", 2009, - "How tagging helps bridge the gap between social and technical aspects in software development", "#ICSE", - "http://dx.doi.org/10.1109/ICSE.2009.5070504" - ], - "treude10": [ - "Christoph Treude and Margaret-Anne Storey", 2010, - "Awareness 2.0: staying aware of projects, developers and tasks using dashboards and feeds", "#ICSE", - "http://dx.doi.org/10.1145/1806799.1806854" - ], - "treude11": [ - "Christoph Treude and Margaret-Anne Storey", 2011, - "Effective communication of software development knowledge through community portals", "#FSE", - "http://dx.doi.org/10.1145/2025113.2025129" - ], - "turnbull16": [ - "James Turnbull", 2016, - "The art of monitoring with James Turnbull", "#SED", - "https://softwareengineeringdaily.com/2016/07/28/2739/" - ], - "uemura84": [ - "Keiji Uemura and Miki Ohori", 1984, - "A cooperative approach to software development by application engineers and software engineers", "#ICSE", - "http://dl.acm.org/citation.cfm?id=801955" - ], - "vanderhoek97": [ - "André van der Hoek, Richard S. Hall, Dennis Heimbigner, and Alexander L. Wolf", 1997, - "Software release management", "#FSE", - "https://doi.org/10.1145/267896.267909" - ], - "vasilescu15": [ - "Bogdan Vasilescu, Yue Yu, Huaimin Wang, Premkumar Devanbu, and Vladimir Filkov", 2015, - "Quality and productivity outcomes relating to continuous integration in GitHub", "#ESECFSE", - "https://doi.org/10.1145/2786805.2786850" - ], - "vonmayrhauser94": [ - "Anneliese von Mayrhauser A. Marie Vans", 1994, - "Comprehension processes during large scale maintenance", "#ICSE", - "https://doi.org/10.1109/ICSE.1994.296764" - ], - "vosburgh84": [ - "J. Vosburgh, B. Curtis, R. Wolverton, B. Albert, H. Malec, S. Hoben, and Y. Liu", 1984, - "Productivity factors and programming environments", "#ICSE", - "http://dl.acm.org/citation.cfm?id=801963" - ], - "wagstrom14": [ - "Patrick Wagstrom and Subhajit Datta", 2014, - "Does latitude hurt while longitude kills? Geographical and temporal separation in a large scale software development project", "#ICSE", - "http://dx.doi.org/10.1145/2568225.2568279" - ], - "walker12": [ - "Robert J. Walker, Shreya Rawal, and Jonathan Sillito", 2012, - "Do crosscutting concerns cause modularity problems?", "#FSE", - "http://dx.doi.org/10.1145/2393596.2393654" - ], - "wang16": [ - "Jennifer Wang'", 2016, - "Female pursuit of Computer Science with Jennifer Wang", "#SED", - "https://softwareengineeringdaily.com/2016/06/13/female-pursuit-computer-science-jennifer-wang/" - ], - "washington20": [ - "Alicia Nicki Washington", 2020, - "When twice as good isn't enough: the case for cultural competence in computing", "#SIGCSE", - "https://doi.org/10.1145/3328778.3366792" - ], - "weinberg82": [ - "Gerald M. Weinberg", 1982, - "Over-structured management of software engineering", "#ICSE", - "https://dl.acm.org/doi/abs/10.5555/800254.807743" - ], - "weiser81": [ - "Mark Weiser", 1981, - "Program slicing", "#ICSE", - "http://dl.acm.org/citation.cfm?id=802557" - ], - "wobbrock11": [ - "Jacob O. Wobbrock, Shaun K. Kane, Krzysztof Z. Gajos, Susumu Harada, and Jon Froehlich", 2011, - "Ability-based design: Concept, principles and examples", "ACM Transactions on Accessible Computing (TACCESS)", - "https://doi.org/10.1145/1952383.1952384" - ], - "woodcock09": [ - "Jim Woodcock, Peter Gorm Larsen, Juan Bicarregui, and John Fitzgerald", 2009, - "Formal methods: Practice and experience", "#Surveys", - "http://dx.doi.org/10.1145/1592434.1592436" - ], - "woodfield81": [ - "Scott N. Woodfield, Hubert E. Dunsmore, and Vincent Y. Shen", 1981, - "The effect of modularization and comments on program comprehension", "#ICSE", - "http://dl.acm.org/citation.cfm?id=802534" - ], - "xia17": [ - "Xin Xia, Lingfeng Bao, David Lo, Pavneet Singh Kochhar, Ahmed E. Hassan, Zhenchang Xing ", 2017, - "What do developers search for on the web?", "#ESE", - "https://link.springer.com/article/10.1007/s10664-017-9514-4" - ], - "ye03": [ - "Yunwen Ye and Kouichi Kishida ", 2003, - "Toward an understanding of the motivation Open Source Software developers", "#ICSE", - "http://dl.acm.org/citation.cfm?id=776867" - ], - "yin11": [ - "Zuoning Yin, Ding Yuan, Yuanyuan Zhou, Shankar Pasupathy, and Lakshmi Bairavasundaram", 2011, - "How do fixes become bugs?", "#ESECFSE", - "http://dx.doi.org/10.1145/2025113.2025121" - ], - "zeller02": [ - "Andreas Zeller", 2002, - "Isolating cause-effect chains from computer programs", "FSE", - "http://dx.doi.org/10.1145/587051.587053" - ], - "zeller02b": [ - "Andreas Zeller, Ralf Hildebrandt", 2002, - "Simplifying and isolating failure-inducing input", "#TSE", - "https://doi.org/10.1109/32.988498" - ], - "zeller09": [ - "Andreas Zeller", 2009, - "Why programs fail: a guide to systematic debugging", "Elsevier", - "https://www.google.com/books/edition/_/_63Bm4LAdDIC" - ], - "zhou11": [ - "Minghui Zhou and Audris Mockus", 2011, - "Does the initial environment impact the future of developers?", "#ICSE", - "https://doi.org/10.1145/1985793.1985831" - ] - } -} \ No newline at end of file + "title": "Cooperative Software Development", + "number": 1, + "summary": "First draft", + "published": null, + "authors": ["[Amy J. Ko|https://faculty.washington.edu/ajko]"], + "license": "[Creative Commons Attribution-NoDeriviatives 4.0|https://creativecommons.org/licenses/by-nd/4.0/]", + "images": { + "cover": "|cover.jpg|A photograph of a racially and gender diverse team of six making decisions.|Software engineering is inherently social.|Shutterstock|", + "unknown": "|error.png|A screen shot of a Linux operating system kernel panic|Uh oh, something went wrong|William Pina|" + }, + "description": "This book is an introduction to the many human, social, and political aspects of software engineering. It's unique in two ways. First, unlike many software engineering books, it explictly avoids centering technical questions about software engineering, instead focusing on the many ways that software engineering work is cognitive, social, and organizational. Second, it does so by engaging extensively with academic research literature, summarizing key findings, but also questioning them, opening a dialog about the nature of software engineering work and the many factors that shape it. Anyone that reads it will be better prepared to critically engage in creating software in teams.\n\nThis book is a living document. Do you see ways to improve it? [Submit an issue|https://github.com/amyjko/cooperative-software-development/issues] or a [pull request|https://github.com/amyjko/cooperative-software-development/pulls] to its [GitHub repository|https://github.com/amyjko/cooperative-software-development].\n\n_This material is based upon work supported by the National Science Foundation under Grant No. 0952733. Any opinions, findings, and conclusions or recommendations expressed in this material are those of the author(s) and do not necessarily reflect the views of the National Science Foundation._", + "acknowledgements": "Thank you to the excellent software engineering research community for the continued feedback and of course for all of the insightful research upon which this book is based. And thank you the students who always have insightful things to add!", + "base": "/ajko/books/cooperative-software-development", + "chapters": [ + { + "id": "history", + "title": "History", + "image": "|Hamilton.jpg|Margaret Hamilton working on the Apollo flight software.|Margaret Hamilton working on the Apollo flight software|NASA|" + }, + { + "id": "organizations", + "title": "Organizations", + "image": "|team.jpg|A software team hard at work|Early days at the author's software startup in 2012.|Amy J. Ko|" + }, + { + "id": "communication", + "title": "Communication", + "image": "|communication.png|A man and a woman having a conversation|Clear and timely communication is at the heart of effective software engineering.|Creative Commons CC0|" + }, + { + "id": "productivity", + "title": "Productivity", + "image": "|productivity.jpg|A women working at a laptop|Productivity isn't just about working fast|Creative Commons CC0|" + }, + { + "id": "quality", + "title": "Quality", + "image": "|zoho.jpg|A screenshot of the Zoho issue tracker.|Software quality is multidimensional and often coursely measured through issue trackers like this one.|Zoho, Inc.|" + }, + { + "id": "requirements", + "title": "Requirements", + "image": "|scaffolding.jpg|An architectural structure showing the framework of a glass structure|Requirements specify what software must do, constraining, focusing, and defining it's successful functioning.|Public domain|" + }, + { + "id": "architecture", + "title": "Architecture", + "image": "|church.jpg|A photograph of a church hallway with arches.|Architecture is how code is organized|Creative Commons 0|" + }, + { + "id": "specifications", + "title": "Specifications", + "image": "|blueprint.jpg|A blueprint for an architectural plan|Specifications add a layer of detail onto architectural plans.|Public domain|" + }, + { + "id": "process", + "title": "Process", + "image": "|flow.jpg|A photograph of a river|Good process is like a river, seamlessly flowing around obstacles|Public domain|" + }, + { + "id": "comprehension", + "title": "Comprehension", + "image": "|network.png|A visualization of many interconnected node|Program comprehension is about understanding dependencies|Public domain|" + }, + { + "id": "verification", + "title": "Verification", + "image": "|check.png|A check mark|Have you met your requirements? How do you know?|Public domain|" + }, + { + "id": "monitoring", + "title": "Monitoring", + "image": "|monitoring.jpg|A photograph of a lifeguide monitoring a beach.|It's not always easy to see software fail.|Public domain|" + }, + { + "id": "evolution", + "title": "Evolution", + "image": "|atsign.png|Four variations on an at sign.|Software changes and that requires planning.|Public domain|" + }, + { + "id": "debugging", + "title": "Debugging", + "image": "|swatter.png|An illustration of a fly swatter.|Debugging is inevitable because defects are inevitable|Public domain|" + } + ], + "sources": { + "ASE": "IEEE/ACM International Conference on Automated Software Engineering", + "CACM": "Communications of the ACM", + "ESE": "Empirical Software Engineering", + "ICSE": "ACM/IEEE International Conference on Software Engineering", + "FSE": "ACM SIGSOFT Foundations of Software Engineering (FSE)", + "TSE": "IEEE Transactions on Software Engineering", + "CHI": "ACM SIGCHI Conference on Human Factors in Computing (CHI)", + "CHASE": "International Workshop on Cooperative and Human Aspects of Software Engineering", + "ICPC": "IEEE International Conference on Program Comprehension (ICPC)", + "SED": "Software Engineering Daily Podcast", + "ESECFSE": "ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering (ESEC/FSE)", + "CSCW": "ACM Conference on Computer Supported Cooperative Work (CSCW)", + "Software": "IEEE Software", + "Computer": "IEEE Computer", + "SEN": "ACM SIGSOFT Software Engineering Notes", + "TOSEM": "ACM Transactions on Software Engineering and Methodology (TOSEM)", + "VL/HCC": "IEEE Symposium on Visual Languages and Human-Centric Computing (VL/HCC)", + "SEIP": "ACM/IEEE International Conference on Software Engineering, Software Engineering in Practice", + "SIGCSE": "ACM Technical Symposium on Computer Science Education", + "Surveys": "ACM Computing Surveys" + }, + "references": { + "abbate12": [ + "Janet Abbate", + "2012", + "Recoding gender: women's changing participation in computing", + "MIT Press", + "https://mitpress.mit.edu/books/recoding-gender" + ], + "abdalkareem17": [ + "Rabe Abdalkareem, Olivier Nourry, Sultan Wehaibi, Suhaib Mujahid, and Emad Shihab", + "2017", + "Why do developers use trivial packages? An empirical case study on npm", + "#FSE", + "https://doi.org/10.1145/3106237.3106267" + ], + "aghajani20": [ + "Emad Aghajani, Csaba Nagy, Mario Linares-Vásquez, Laura Moreno, Gabriele Bavota, Michele Lanza, David C. Shepherd", + "2020", + "Software documentation: the practitioners' perspective", + "#ICSE", + "https://www.inf.usi.ch/phd/aghajani/resources/papers/agha2020a.pdf" + ], + "ahmed16": [ + "Iftekhar Ahmed, Rahul Gopinath, Caius Brindescu, Alex Groce, and Carlos Jensen", + "2016", + "Can testedness be effectively measured?", + "#FSE", + "https://doi.org/10.1145/2950290.2950324" + ], + "akers09": [ + "David Akers, Matthew Simpson, Robin Jeffries, and Terry Winograd", + "2009", + "Undo and erase events as indicators of usability problems", + "#CHI", + "http://dx.doi.org/10.1145/1518701.1518804" + ], + "albaik15": [ + "Osama Al-Baik & James Miller", + "2015", + "The kanban approach, between agility and leanness: a systematic review", + "#ESE", + "https://doi.org/10.1007/s10664-014-9340-x" + ], + "aranda09": [ + "Jorge Aranda and Gina Venolia", + "2009", + "The secret life of bugs: Going past the errors and omissions in software repositories", + "#ICSE", + "http://dx.doi.org/10.1109/ICSE.2009.5070530" + ], + "arnold96": [ + "Robert Arnold, Shawn Bohner", + "1996", + "Software change impact analysis", + "IEEE Computer Society Press", + null + ], + "atwood16": [ + "Jeff Atwood", + "2016", + "The state of programming with Stack Overflow co-founder Jeff Atwood", + "#SED", + "https://softwareengineeringdaily.com/2016/03/14/state-programming-jeff-atwood/" + ], + "bacchelli13": [ + "Alberto Bacchelli and Christian Bird", + "2013", + "Expectations, outcomes, and challenges of modern code review", + "#ICSE", + "https://doi.org/10.1109/ICSE.2013.6606617" + ], + "baecker88": [ + "Ron Baecker", + "1988", + "Enhancing program readability and comprehensibility with tools for program visualization", + "#ICSE", + "https://doi.org/10.1109/ICSE.1988.93716" + ], + "baltes18": [ + "Sebastian Baltes, Stephan Diehl", + "2018", + "Towards a theory of software development expertise", + "#ESECFSE", + "https://doi.org/10.1145/3236024.3236061" + ], + "bartram16": [ + "Ammon Bartram", + "2016", + "Hiring engineers with Ammon Bartram", + "#SED", + "https://softwareengineeringdaily.com/2015/12/23/hiring-engineers-with-ammon-bartram/" + ], + "barua14": [ + "Anton Barua, Stephen W. Thomas & Ahmed E. Hassan", + "2014", + "What are developers talking about? an analysis of topics and trends in Stack Overflow", + "#ESE", + "http://link.springer.com/article/10.1007/s10664-012-9231-y" + ], + "bass03": [ + "Len Bass, Bonnie E. John", + "2003", + "Linking usability to software architecture patterns through general scenarios", + "Journal of Systems and Software", + "http://www.sciencedirect.com/science/article/pii/S0164121202000766" + ], + "beck96": [ + "Kent Beck, Ron Crocker, Gerard Meszaros, John Vlissides, James O. Coplien, Lutz Dominick, and Frances Paulisch", + "1996", + "Industrial experience with design patterns", + "#ICSE", + "https://doi.org/10.1109/ICSE.1996.493406" + ], + "beck99": [ + "Kent Beck", + "1999", + "Embracing change with extreme programming", + "IEEE Computer", + "https://doi.org/10.1007/s10664-014-9340-x" + ], + "begel08": [ + "Andy Begel, Beth Simon", + "2008", + "Novice software developers, all over again", + "ICER", + "http://dl.acm.org/citation.cfm?id=1404522" + ], + "begel10": [ + "Andrew Begel, Yit Phang Khoo, and Thomas Zimmermann ", + "2010", + "Codebook: discovering and exploiting relationships in software repositories", + "#ICSE", + "http://dx.doi.org/10.1145/1806799.1806821" + ], + "begel14": [ + "Andy Begel, Thomas Zimmermann ", + "2014", + "Analyze this! 145 questions for data scientists in software engineering", + "#ICSE", + "https://doi.org/10.1145/2568225.2568233" + ], + "beller15": [ + "Moritz Beller, Georgios Gousios, Annibale Panichella, and Andy Zaidman", + "2015", + "When, how, and why developers (do not) test in their IDEs", + "#ESECFSE", + "https://doi.org/10.1145/2786805.2786843" + ], + "beller18": [ + "Beller, M., Spruit, N., Spinellis, D., & Zaidman, A", + "2018", + "On the dichotomy of debugging behavior among programmers", + "#ICSE", + "https://doi.org/10.1145/3180155.3180175" + ], + "bendifallah89": [ + "Salah Bendifallah and Walt Scacchi", + "1989", + "Work structures and shifts: an empirical analysis of software specification teamwork", + "#ICSE", + "http://dx.doi.org/10.1145/74587.74624" + ], + "benjamin19": [ + "Ruha Benjamin", + "2019", + "Race after technology: Abolitionist tools for the New Jim Code", + "Polity Books", + "https://www.ruhabenjamin.com/race-after-technology" + ], + "bertram10": [ + "Dane Bertram, Amy Voida, Saul Greenberg, and Robert Walker", + "2010", + "Communication, collaboration, and bugs: the social nature of issue tracking in small, collocated teams", + "#CSCW", + "http://dx.doi.org/10.1145/1718918.1718972" + ], + "bettenburg08": [ + "Nicolas Bettenburg, Sascha Just, Adrian Schröter, Cathrin Weiss, Rahul Premraj, and Thomas Zimmermann", + "2008", + "What makes a good bug report?", + "#FSE", + "http://dx.doi.org/10.1145/1453101.1453146" + ], + "bettenburg13": [ + "Nicolas Bettenburg, Ahmed E. Hassan", + "2013", + "Studying the impact of social interactions on software quality", + "#ESE", + "https://doi.org/10.1007/s10664-012-9205-0" + ], + "bhattacharya11": [ + "Pamela Bhattacharya and Iulian Neamtiu", + "2011", + "Assessing programming language impact on development and maintenance: a study on C and C++", + "#ICSE", + "https://doi.org/10.1145/1985793.1985817" + ], + "binkley13": [ + "Dave Binkley, Marcia Davis, Dawn Lawrie, Jonathan I. Maletic, Christopher Morrell, Bonita Sharif", + "2013", + "The impact of identifier style on effort and comprehension", + "#ESE", + "https://link.springer.com/article/10.1007/s10664-012-9201-4" + ], + "bird11": [ + "Christian Bird, Nachiappan Nagappan, Brendan Murphy, Harald Gall, and Premkumar Devanbu", + "2011", + "Don't touch my code! Examining the effects of ownership on software quality", + "#ESECFSE", + "http://dx.doi.org/10.1145/2025113.2025119" + ], + "boehm76": [ + "Barry W. Boehm", + "1976", + "Software engineering", + "IEEE Transactions on Computers", + "http://ieeexplore.ieee.org/document/1674590/" + ], + "boehm88": [ + "Barry W. Boehm", + "1988", + "A spiral model of software development and enhancement", + "#Computer", + "http://ieeexplore.ieee.org/abstract/document/59/" + ], + "boehm91": [ + "Boehm, B. W", + "1991", + "Software risk management: principles and practices", + "#Software", + "http://ieeexplore.ieee.org/abstract/document/62930" + ], + "borozdin17": [ + "Mike Borozdin", + "2017", + "Engineering management with Mike Borozdin", + "#SED", + "https://softwareengineeringdaily.com/2017/02/08/engineering-management-with-mike-borozdin/" + ], + "brindescu14": [ + "Caius Brindescu, Mihai Codoban, Sergii Shmarkatiuk, and Danny Dig", + "2014", + "How do centralized and distributed version control systems impact software changes?", + "#ICSE", + "http://dx.doi.org/10.1145/2568225.2568322" + ], + "brooks95": [ + "Fred P. Brooks", + "1995", + "The mythical man month", + "Pearson Education", + "https://books.google.com/books?id=Yq35BY5Fk3gC" + ], + "callaú13": [ + "Oscar Callaú, Romain Robbes, Éric Tanter, David Röthlisberger", + "2013", + "How (and why) developers use the dynamic features of programming languages: the case of Smalltalk", + "#ESE", + "https://doi.org/10.1145/1985441.1985448" + ], + "casalnuovo15": [ + "Casey Casalnuovo, Bogdan Vasilescu, Premkumar Devanbu, and Vladimir Filkov", + "2015", + "Developer onboarding in GitHub: the role of prior social links and language experience", + "#ESECFSE", + "https://doi.org/10.1145/2786805.2786854" + ], + "casalnuovo15b": [ + "Casey Casalnuovo, Prem Devanbu, Abilio Oliveira, Vladimir Filkov, and Baishakhi Ray", + "2015", + "Assert use in GitHub projects", + "#ICSE", + "https://doi.org/10.1145/2568225.2568285" + ], + "chedeua15": [ + "Sebastian Marbage, Christopher Chedeua", + "2015", + "React JS with Sebastian Marbage and Christopher Chedeua", + "#SED", + "https://softwareengineeringdaily.com/2015/07/27/react-js-with-sebastian-markbage-and-christopher-chedeau/" + ], + "chen09": [ + "Chien-Tsun Chen, Yu Chin Cheng, Chin-Yun Hsieh, and I-Lang Wu", + "2008", + "Exception handling refactorings: Directed by goals and driven by bug fixing", + "Journal of Systems and Software", + "https://doi.org/10.1016/j.jss.2008.06.035" + ], + "chen15": [ + "Lianping Chen", + "2015", + "Continuous delivery: Huge benefits, but challenges too", + "#Software", + "https://doi.org/10.1109/MS.2015.27" + ], + "chilana11": [ + "Parmit K. Chilana, Amy J. Ko, Jacob O. Wobbrock, Tovi Grossman, and George Fitzmaurice", + "2011", + "Post-deployment usability: a survey of current practices", + "#CHI", + "http://dx.doi.org/10.1145/1978942.1979270" + ], + "chilana13": [ + "Parmit K. Chilana, Amy J. Ko, Jacob O. Wobbrock, Tovi Grossman", + "2013", + "A multi-site field study of crowdsourced contextual help: usage and perspectives of end users and software teams", + "#CHI", + "http://dl.acm.org/citation.cfm?id=2470685" + ], + "chong07": [ + "Jan Chong and Tom Hurlbutt", + "2007", + "The social dynamics of pair programming", + "#ICSE", + "http://dx.doi.org/10.1109/ICSE.2007.87" + ], + "cito15": [ + "Jürgen Cito, Philipp Leitner, Thomas Fritz, and Harald C. Gall", + "2015", + "The making of cloud applications: an empirical study on software development for the cloud", + "#ESECFSE", + "https://doi.org/10.1145/2786805.2786826" + ], + "clarke06": [ + "Clarke, L. A., & Rosenblum, D. S", + "2006", + "A historical perspective on runtime assertion checking in software development", + "#SEN", + "https://doi.org/10.1145/1127878.1127900" + ], + "clegg08": [ + "Stewart Clegg, James R. Bailey", + "2008", + "International encyclopedia of organization studies", + "Sage Publications", + "https://books.google.com/books?id=Uac5DQAAQBAJ" + ], + "coelho17": [ + "Jailton Coelho and Marco Tulio Valente ", + "2017", + "Why modern open source projects fail", + "#ESECFSE", + "https://doi.org/10.1145/3106237.3106246" + ], + "conway68": [ + "Melvin E. Conway", + "1968", + "How do committees invent", + "Datamation", + "https://pdfs.semanticscholar.org/cbce/35eedcde3ef152bde75950fbc7ef4c6717b2.pdf" + ], + "dagenais10": [ + "Barthélémy Dagenais, Harold Ossher, Rachel K. E. Bellamy, Martin P. Robillard, and Jacqueline P. de Vries", + "2010", + "Moving into a new software project landscape", + "#ICSE", + "http://dx.doi.org/10.1145/1806799.1806842" + ], + "demarco85": [ + "Tom DeMarco and Tim Lister", + "1985", + "Programmer performance and the effects of the workplace", + "#ICSE", + "http://dl.acm.org/citation.cfm?id=319651" + ], + "demarco87": [ + "Tom DeMarco, Tim Lister", + "1987", + "Peopleware: Productive projects and teams", + " Addison-Wesley", + "https://books.google.com/books?id=TVQUAAAAQBAJ" + ], + "dibella13": [ + "di Bella, E., Fronza, I., Phaphoom, N., Sillitti, A., Succi, G., & Vlasenko, J", + "2013", + "Pair programming and software defects—A large, industrial case study", + "#TSE", + "https://doi.org/10.1109/TSE.2012.68" + ], + "dingsøyr03": [ + "Torgeir Dingsøyr, Emil Røyrvik", + "2003", + "An empirical study of an informal knowledge repository in a medium-sized software consulting company", + "#ICSE", + "http://dl.acm.org/citation.cfm?id=776827" + ], + "duala12": [ + "Ekwa Duala-Ekoko and Martin P. Robillard", + "2012", + "Asking and answering questions about unfamiliar APIs: an exploratory study", + "#ICSE", + "http://dl.acm.org/citation.cfm?id=2337255" + ], + "dybå02": [ + "Tore Dybå", + "2002", + "Enabling software process improvement: an investigation of the importance of organizational issues", + "#ESE", + "https://doi.org/10.1145/940071.940092" + ], + "dybå03": [ + "Tore Dybå ", + "2003", + "Factors of software process improvement success in small and large organizations: an empirical study in the scandinavian context", + "#ESECFSE", + "http://dx.doi.org/10.1145/940071.940092" + ], + "ebert15": [ + "Felipe Eberta, Fernando Castora, Alexander Serebrenik", + "2015", + "An exploratory study on exception handling bugs in Java programs", + "Journal of Systems and Software", + "https://doi.org/10.1016/j.jss.2015.04.066" + ], + "eisenstadt97": [ + "Marc Eisenstadt", + "1997", + "My hairiest bug war stories", + "#CACM", + "https://doi.org/10.1145/248448.248456" + ], + "endrikat14": [ + "Stefan Endrikat, Stefan Hanenberg, Romain Robbes, and Andreas Stefik", + "2014", + "How do API documentation and static typing affect API usability?", + "#ICSE", + "https://doi.org/10.1145/2568225.2568299" + ], + "ernst15": [ + "Neil A. Ernst, Stephany Bellomo, Ipek Ozkaya, Robert L. Nord, and Ian Gorton", + "2015", + "Measure it? Manage it? Ignore it? Software practitioners and technical debt", + "#ESECFSE", + "https://doi.org/10.1145/2786805.2786848" + ], + "fairbanks10": [ + "George Fairbanks", + "2010", + "Just enough software architecture: a risk-driven approach", + "Marshall & Brainerd", + "https://www.georgefairbanks.com/assets/jesa/Just_Enough_Software_Architecture__Fairbanks_2010-demo.pdf" + ], + "fleming13": [ + "Scott D. Fleming, Christopher Scaffidi, David Piorkowski, Margaret M. Burnett, Rachel K. E. Bellamy", + "2013", + "An information foraging theory perspective on tools for debugging, refactoring, and reuse tasks", + "#TOSEM", + "https://doi.org/10.1145/2430545.2430551" + ], + "foucault15": [ + "Matthieu Foucault, Marc Palyart, Xavier Blanc, Gail C. Murphy, and Jean-Rémy Falleri", + "2015", + "Impact of developer turnover on quality in open-source software", + "#ESECFSE", + "https://doi.org/10.1145/2786805.2786870" + ], + "fucci16": [ + "Davide Fucci, Hakan Erdogmus, Burak Turhan, Markku Oivo, Natalia Juristo", + "2016", + "A dissection of test-driven development: Does it really matter to test-first or to test-last?", + "#TSE", + "https://doi.org/10.1109/TSE.2016.2616877" + ], + "garlan95": [ + "Garlan, D., Allen, R., & Ockerbloom, J", + "1995", + "Architectural mismatch or why it's hard to build systems out of existing parts", + "#ICSE", + "https://doi.org/10.1145/225014.225031" + ], + "gilmore91": [ + "David Gilmore", + "1991", + "Models of debugging", + "Acta Psychologica", + "https://doi.org/10.1016/0001-6918(91)90009-O" + ], + "gleick11": [ + "James Gleick", + "2011", + "The Information: A History, A Theory, A Flood", + "Pantheon Books", + "https://books.google.com/books?id=617JSFW0D2kC" + ], + "glerum09": [ + "Kirk Glerum, Kinshuman Kinshumann, Steve Greenberg, Gabriel Aul, Vince Orgovan, Greg Nichols, David Grant, Gretchen Loihle, and Galen Hunt", + "2009", + "Debugging in the (very) large: ten years of implementation and experience", + "ACM SIGOPS Symposium on Operating Systems Principles (SOSP)", + "http://dx.doi.org/10.1145/1629575.1629586" + ], + "grabner16": [ + "Andi Grabner", + "2016", + "Performance monitoring with Andi Grabner", + "#SED", + "https://softwareengineeringdaily.com/2016/12/27/performance-monitoring-with-andi-grabner/" + ], + "green89": [ + "Thomas R. G. Green", + "1989", + "Cognitive dimensions of notations", + "People and computers", + "https://www.cl.cam.ac.uk/~afb21/CognitiveDimensions/papers/Green1989.pdf" + ], + "grossman09": [ + "Tovi Grossman, George Fitzmaurice, Ramtin Attar", + "2009", + "A survey of software learnability: metrics, methodologies and guidelines", + "#CHI", + "https://doi.org/10.1145/1518701.1518803" + ], + "grudin17": [ + "Grudin, Jonathan ", + "2017", + "From Tool to Partner: The Evolution of Human-Computer Interaction", + "", + "https://books.google.com/books?id=Wc3hDQAAQBAJ" + ], + "hanenberg13": [ + "Stefan Hanenberg, Sebastian Kleinschmager, Romain Robbes, Éric Tanter, Andreas Stefik", + "2013", + "An empirical study on the impact of static typing on software maintainability", + "#ESE", + "https://doi.org/10.1007/s10664-013-9289-1" + ], + "herbsleb03": [ + "James D. Herbsleb and Audris Mockus", + "2003", + "Formulation and preliminary test of an empirical theory of coordination in software engineering", + "#ESECFSE", + "http://dx.doi.org/10.1145/940071.940091" + ], + "herbsleb16": [ + "James Herbsleb", + "2016", + "Building a socio-technical theory of coordination: why and how", + "#FSE", + "https://doi.org/10.1145/2950290.2994160" + ], + "hilton16": [ + "Michael Hilton, Timothy Tunnell, Kai Huang, Darko Marinov, Danny Dig", + "2016", + "Usage, costs, and benefits of continuous integration in open-source projects", + "#ASE", + "https://doi.org/10.1145/2970276.2970358" + ], + "hoda10": [ + "Rashina Hoda, James Noble, and Stuart Marshall", + "2010", + "Organizing self-organizing teams", + "#ICSE", + "https://doi.org/10.1145/1806799.1806843" + ], + "hoda17": [ + "Rashina Hoda, James Noble", + "2017", + "Becoming agile: a grounded theory of agile transitions in practice", + "#ICSE", + "https://doi.org/10.1109/ICSE.2017.21" + ], + "ivory01": [ + "Melody Y. Ivory, Marti A. Hearst", + "2001", + "The state of the art in automating usability evaluation of user interfaces", + "#Surveys", + "http://doi.acm.org/10.1145/503112.503114" + ], + "jackson01": [ + "Michael Jackson", + "2001", + "Problem frames", + "Addison-Wesley", + "https://books.google.com/books?id=8fqIP83Q2IAC" + ], + "johnson13": [ + "Brittany Johnson, Yoonki Song, Emerson Murphy-Hill, and Robert Bowdidge", + "2013", + "Why don't software developers use static analysis tools to find bugs?", + "#ICSE", + "https://doi.org/10.1109/ICSE.2013.6606613" + ], + "johnson15": [ + "Brittany Johnson, Rahul Pandita, Emerson Murphy-Hill, and Sarah Heckman", + "2015", + "Bespoke tools: adapted to the concepts developers know", + "#ESECFSE", + "https://doi.org/10.1145/2786805.2803197" + ], + "kalliamvakou17": [ + "Eirini Kalliamvakou, Christian Bird, Thomas Zimmermann, Andrew Begel, Robert DeLine, Daniel M. German", + "2017", + "What makes a great manager of software engineers?", + "#TSE", + "https://doi.org/10.1109/TSE.2017.2768368" + ], + "kay96": [ + "Alan C. Kay", + "1996", + "The early history of Smalltalk", + "History of programming languages II", + "https://doi.org/10.1145/234286.1057828" + ], + "kenney00": [ + "Kenney, M", + "2000", + "Understanding Silicon Valley: The anatomy of an entrepreneurial region", + "Stanford University Press", + null + ], + "kernighan16": [ + "Brian Kernighan", + "2016", + "Language Design with Brian Kernighan", + "#SED", + "https://softwareengineeringdaily.com/2016/01/06/language-design-with-brian-kernighan/" + ], + "kersten06": [ + "Mik Kersten and Gail C. Murphy", + "2006", + "Using task context to improve programmer productivity", + "#FSE", + "http://dx.doi.org/10.1145/1181775.1181777" + ], + "khadka14": [ + "Ravi Khadka, Belfrit V. Batlajery, Amir M. Saeidi, Slinger Jansen, and Jurriaan Hage", + "2014", + "How do professionals perceive legacy systems and software modernization?", + "#ICSE", + "http://dx.doi.org/10.1145/2568225.2568318" + ], + "kim12": [ + "Miryung Kim, Thomas Zimmermann, and Nachiappan Nagappan", + "2012", + "A field study of refactoring challenges and benefits", + "#FSE", + "http://dx.doi.org/10.1145/2393596.2393655" + ], + "kim16": [ + "Miryung Kim, Thomas Zimmermann, Robert DeLine, and Andrew Begel", + "2016", + "The emerging role of data scientists on software development teams", + "#ICSE", + "https://doi.org/10.1145/2884781.2884783" + ], + "ko04": [ + "Amy J. Ko, Brad A. Myers, Htet Htet Aung", + "2004", + "Six learning barriers in end-user programming systems", + "#VL/HCC", + "https://doi.org/10.1109/VLHCC.2004.47" + ], + "ko05": [ + "Amy J. Ko, Htet Htet Aung, Brad A. Myers ", + "2005", + "Eliciting design requirements for maintenance-oriented IDEs: a detailed ttudy of corrective and perfective maintenance tasks", + "#ICSE", + "https://doi.org/10.1145/1062455.1062492" + ], + "ko05b": [ + "Amy J. Ko, Brad A. Myers", + "2005", + "A framework and methodology for studying the causes of software errors in programming systems", + "Journal of Visual Languages & Computing", + "https://doi.org/10.1016/j.jvlc.2004.08.003" + ], + "ko07": [ + "Amy J. Ko, Rob DeLine, and Gina Venolia ", + "2007", + "Information needs in collocated software development teams", + "#ICSE", + "https://doi.org/10.1109/ICSE.2007.45" + ], + "ko08": [ + "Amy J. Ko and Brad A. Myers", + "2008", + "Debugging reinvented: asking and answering why and why not questions about program behavior", + "#ICSE", + "http://dx.doi.org/10.1145/1368088.1368130" + ], + "ko09": [ + "Amy J. Ko and Brad A. Myers ", + "2009", + "Finding causes of program output with the Java Whyline", + "#CHI", + "https://doi.org/10.1145/1518701.1518942" + ], + "ko17": [ + "Amy J. Ko", + "2017", + "A Three-Year Participant Observation of Software Startup Software Evolution", + "#SEIP", + "https://faculty.washington.edu/ajko/papers/Ko2017AnswerDashReflection.pdf" + ], + "ko19": [ + "Amy J. Ko, Thomas D. LaToza, Stephen Hull, Ellen A. Ko, William Kwok, Jane Quichocho, Harshitha Akkaraju, and Rishin Pandit", + "2019", + "Teaching explicit programming strategies to adolescents", + "#SIGCSE", + "https://doi.org/10.1145/3287324.3287371" + ], + "kocaguneli13": [ + "Ekrem Kocaguneli, Thomas Zimmermann, Christian Bird, Nachiappan Nagappan, and Tim Menzies", + "2013", + "Distributed development considered harmful?", + "#ICSE", + "https://doi.org/10.1109/ICSE.2013.6606637" + ], + "kononenko16": [ + "Oleksii Kononenko, Olga Baysal, and Michael W. Godfrey", + "2016", + "Code review quality: how developers see it", + "#ICSE", + "https://doi.org/10.1145/2884781.2884840" + ], + "lamsweerde08": [ + "Axel van Lamsweerde", + "2008", + "Requirements engineering: from craft to discipline", + "#FSE", + "http://dx.doi.org/10.1145/1453101.1453133" + ], + "latoza06": [ + "Thomas D. LaToza, Gina Venolia, and Robert DeLine", + "2006", + "Maintaining mental models: a study of developer work habits", + "#ICSE", + "http://dx.doi.org/10.1145/1134285.1134355" + ], + "latoza07": [ + "Thomas D. LaToza, David Garlan, James D. Herbsleb, and Brad A. Myers", + "2007", + "Program comprehension as fact finding", + "#ESECFSE", + "http://dx.doi.org/10.1145/1287624.1287675" + ], + "latoza10": [ + "Thomas D. LaToza, Brad A. Myers", + "2010", + "Developers ask reachability questions", + "#ICSE", + "http://dx.doi.org/10.1145/1806799.1806829" + ], + "latoza20": [ + "Thomas D. LaToza, Maryam Arab, Dastyni Loksa, Amy J. Ko", + "2020", + "Explicit programming strategies", + "#ESE", + "https://doi.org/10.1007/s10664-020-09810-1" + ], + "lavallee15": [ + "Mathieu Lavallee and Pierre N. Robillard", + "2015", + "Why good developers write bad code: an observational case study of the impacts of organizational factors on software quality", + "#ICSE", + "http://dl.acm.org/citation.cfm?id=2818754.2818837" + ], + "lawrie06": [ + "Lawrie, D., Morrell, C., Feild, H., & Binkley, D", + "2006", + "What's in a name? A study of identifiers", + "#ICPC", + "https://doi.org/10.1109/ICPC.2006.51" + ], + "lee03": [ + "Gwendolyn K. Lee, Robert E. Cole", + "2003", + "From a firm-based to a community-based model of knowledge creation: The case of the Linux kernel development", + "Organization science", + "http://pubsonline.informs.org/doi/abs/10.1287/orsc.14.6.633.24866" + ], + "li15": [ + "Paul Luo Li, Amy J. Ko, and Jiamin Zhu", + "2015", + "What makes a great software engineer?", + "#ICSE", + "http://dl.acm.org/citation.cfm?id=2818839" + ], + "li17": [ + "Paul Luo Li, Amy J. Ko, and Andrew Begel", + "2017", + "Cross-disciplinary perspectives on collaborations with software engineers", + "#CHASE", + "https://doi.org/10.1109/CHASE.2017.3" + ], + "maalej14": [ + "Walid Maalej, Rebecca Tiarks, Tobias Roehm, and Rainer Koschke", + "2014", + "On the comprehension of program comprehension", + "#TOSEM", + "http://dx.doi.org/10.1145/2622669" + ], + "mader15": [ + "Patrick Mäder, Alexander Egyed ", + "2015", + "Do developers benefit from requirements traceability when evolving and maintaining a software system?", + "#ESE", + "https://doi.org/10.1007/s10664-014-9314-z" + ], + "mamykina11": [ + "Lena Mamykina, Bella Manoim, Manas Mittal, George Hripcsak, and Björn Hartmann", + "2011", + "Design lessons from the fastest Q&A site in the west", + "#CHI", + "https://doi.org/10.1145/1978942.1979366" + ], + "mark08": [ + "Gloria Mark, Daniela Gudith, and Ulrich Klocke", + "2008", + "The cost of interrupted work: more speed and stress", + "#CHI", + "https://doi.org/10.1145/1357054.1357072" + ], + "maxion00": [ + "Maxion, Roy A., and Robert T. Olszewski", + "2000", + "Eliminating exception handling errors with dependability cases: a comparative, empirical study", + "#TSE", + "https://doi.org/10.1109/32.877848" + ], + "may19": [ + "Anna May, Johannes Wachs, Anikó Hannák ", + "2019", + "Gender differences in participation and reward on Stack Overflow", + "#ESE", + "https://doi.org/10.1007/s10664-019-09685-x" + ], + "mccarthy78": [ + "John McCarthy", + "1978", + "History of LISP", + "History of Programming Languages I", + "http://dl.acm.org/citation.cfm?id=1198360" + ], + "mcilwain19": [ + "Charlton D. McIlwain", + "2019", + "Black software: the internet and racial justice, from the AfroNet to Black Lives Matter", + "Oxford University Press", + "https://global.oup.com/academic/product/black-software-9780190863845?cc=us&lang=en&" + ], + "meneely11": [ + "Andrew Meneely, Pete Rotella, and Laurie Williams", + "2011", + "Does adding manpower also affect quality? An empirical, longitudinal analysis", + "#ESECFSE", + "http://dx.doi.org/10.1145/2025113.2025128" + ], + "menzies13": [ + "Tim Menzies, Tom Zimmermann", + "2013", + "Software analytics: so what?", + "#Software", + "https://doi.ieeecomputersociety.org/10.1109/MS.2013.86" + ], + "metcalf02": [ + "Michael Metcalf", + "2002", + "History of Fortran", + "ACM SIGPLAN Fortran Forum", + "https://doi.org/10.1145/602376.602379" + ], + "meyer17": [ + "André N. Meyer, Laura E. Barton, Gail C. Murphy, Thomas Zimmermann, Thomas Fritz", + "2017", + "The work life of developers: Activities, switches and perceived productivity", + "#TSE", + "https://doi.org/10.1109/TSE.2017.2656886" + ], + "milewski07": [ + "Allen E. Milewski", + "2007", + "Global and task effects in information-seeking among software engineers", + "#ESE", + "https://doi.org/10.1007/s10664-007-9036-6" + ], + "mockus02": [ + "Audris Mockus and James D. Herbsleb", + "2002", + "Expertise browser: a quantitative approach to identifying expertise", + "#ICSE", + "http://dx.doi.org/10.1145/581339.581401" + ], + "mockus10": [ + "Audris Mockus", + "2010", + "Organizational volatility and its effects on software defects", + "#FSE", + "http://doi.acm.org/10.1145/1882291.1882311" + ], + "mohanani14": [ + "Rahul Mohanani, Paul Ralph, and Ben Shreeve", + "2014", + "Requirements fixation", + "#ICSE", + "http://dx.doi.org/10.1145/2568225.2568235" + ], + "murphy14": [ + "Emerson Murphy-Hill, Thomas Zimmermann, and Nachiappan Nagappan", + "2014", + "Cowboys, ankle sprains, and keepers of quality: how is video game development different from software development?", + "#ICSE", + "http://dx.doi.org/10.1145/2568225.2568226" + ], + "murphyhill09": [ + "Emerson Murphy-Hill, Chris Parnin, and Andrew P. Black", + "2009", + "How we refactor, and how we know it", + "#ICSE", + "http://dx.doi.org/10.1109/ICSE.2009.5070529" + ], + "murphyhill13": [ + "Emerson Murphy-Hill, Thomas Zimmermann, Christian Bird, and Nachiappan Nagappan", + "2013", + "The design of bug fixes", + "#ICSE", + "http://dl.acm.org/citation.cfm?id=2486833" + ], + "müller03": [ + "Matthias M. Müller and Frank Padberg", + "2003", + "On the economic evaluation of XP projects", + "#ESECFSE", + "http://dx.doi.org/10.1145/940071.940094" + ], + "nelson19": [ + "Nicholas Nelson, Caius Brindescu, Shane McKee, Anita Sarma & Danny Dig", + "2019", + "The life-cycle of merge conflicts: processes, barriers, and strategies", + "#ESE", + "https://doi.org/10.1007/s10664-018-9674-x" + ], + "ng06": [ + "T. H. Ng, S. C. Cheung, W. K. Chan, and Y. T. Yu", + "2006", + "Work experience versus refactoring to design patterns: a controlled experiment", + "#FSE", + "http://dx.doi.org/10.1145/1181775.1181778" + ], + "norris17": [ + "Jeff Norris", + "2016", + "Tech leadership with Jeff Norris", + "#SED", + "https://softwareengineeringdaily.com/2016/09/22/tech-leadership-with-jeff-norris/" + ], + "northrup16": [ + "Ben Northup", + "2016", + "Reflections of an old programmer", + "#SED", + "https://softwareengineeringdaily.com/2016/11/09/reflections-of-an-old-programmer-with-ben-northrup/" + ], + "osterwalder15": [ + "Alexander Osterwalder, Yves Pigneur, Gregory Bernarda, Alan Smith", + "2015", + "Value proposition design: how to create products and services customers want", + "John Wiley & Sons", + "https://books.google.com/books?id=jgu5BAAAQBAJ" + ], + "overney20": [ + "Cassandra Overney, Jens Meinicke, Christian Kästner, Bogdan Vasilescu", + "2020", + "How to not get rich: an empirical study of donations in open source", + "#ICSE", + "https://cmustrudel.github.io/papers/overney20donations.pdf" + ], + "parnas86": [ + "David L Parnas, Paul C. Clements", + "1986", + "A rational design process: How and why to fake it", + "#TSE", + "https://doi.org/10.1109/TSE.1986.6312940" + ], + "perlow99": [ + "Leslie A. Perlow", + "1999", + "The time famine: Toward a sociology of work time", + "Administrative science quarterly", + "http://journals.sagepub.com/doi/abs/10.2307/2667031" + ], + "petre13": [ + "Marian Petre", + "2013", + "UML in practice", + "#ICSE", + "https://doi.org/10.1145/2568225.2568285" + ], + "petre16": [ + "Marian Petre, André van der Hoek", + "2016", + "Software design decoded: 66 ways experts think", + "MIT Press", + "https://www.google.com/books/edition/_/EVE4DQAAQBAJ" + ], + "pettersen16": [ + "Tim Pettersen", + "2016", + "Git Workflows with Tim Pettersen", + "#SED", + "https://softwareengineeringdaily.com/2016/04/06/git-workflows-tim-pettersen/" + ], + "pham14": [ + "Raphael Pham, Stephan Kiesling, Olga Liskin, Leif Singer, and Kurt Schneider", + "2014", + "Enablers, inhibitors, and perceptions of testing in novice software teams", + "#FSE", + "http://dx.doi.org/10.1145/2635868.2635925" + ], + "phillips14": [ + "Shaun Phillips, Thomas Zimmermann, and Christian Bird", + "2014", + "Understanding and improving software build teams", + "#ICSE", + "http://dx.doi.org/10.1145/2568225.2568274" + ], + "pikkarainen98": [ + "M. Pikkarainen, J. Haikara, O. Salo, P. Abrahamsson, J. Still", + "2008", + "The impact of agile practices on communication in software development", + "#ESE", + "https://doi.org/10.1007/s10664-008-9065-9" + ], + "potvin16": [ + "Rachel Potvin, Josh Levenberg", + "2016", + "Why Google stores billions of lines of code in a single repository", + "#CACM", + "https://doi.org/10.1145/2854146" + ], + "prince17": [ + "Suzie Prince", + "2017", + "Product management with Suzie Prince", + "#SED", + "https://softwareengineeringdaily.com/2017/01/18/product-management-with-suzie-prince/" + ], + "procaccino05": [ + "J. Drew Procaccino, June M. Verner, Katherine M. Shelfer, David Gefen", + "2005", + "What do software practitioners really think about project success: an exploratory study", + "Journal of Systems and Software", + "https://doi.org/10.1016/j.jss.2004.12.011" + ], + "qiu13": [ + "Dong Qiu, Bixin Li, and Zhendong Su", + "2013", + "An empirical analysis of the co-evolution of schema and code in database applications", + "#ESECFSE", + "http://dx.doi.org/10.1145/2491411.2491431" + ], + "qureshi16": [ + "Haseeb Qureshi", + "2016", + "Debugging stories with Haseeb Qureshi", + "#SED", + "https://softwareengineeringdaily.com/2016/11/19/debugging-stories-with-haseeb-qureshi/" + ], + "ralph14": [ + "Paul Ralph and Paul Kelly", + "2014", + "The dimensions of software engineering success", + "#ICSE", + "http://dx.doi.org/10.1145/2568225.2568261" + ], + "ramasubbu11": [ + "Narayan Ramasubbu, Marcelo Cataldo, Rajesh Krishna Balan, and James D. Herbsleb", + "2011", + "Configuring global software teams: a multi-company analysis of project productivity, quality, and profits", + "#ICSE", + "https://doi.org/10.1145/1985793.1985830" + ], + "ray14": [ + "Baishakhi Ray, Daryl Posnett, Vladimir Filkov, and Premkumar Devanbu", + "2014", + "A large scale study of programming languages and code quality in GitHub", + "#FSE", + "http://dx.doi.org/10.1145/2635868.2635922" + ], + "rice16": [ + "David Rice", + "2016", + "Continuous delivery with David Rice", + "#SED", + "https://softwareengineeringdaily.com/2016/10/10/continuous-delivery-with-david-rice/" + ], + "rigby11": [ + "Peter C. Rigby and Margaret-Anne Storey", + "2011", + "Understanding broadcast based peer review on open source software projects", + "#ICSE", + "https://doi.org/10.1145/1985793.1985867" + ], + "rigby13": [ + "Peter C. Rigby and Christian Bird", + "2013", + "Convergent contemporary software peer review practices", + "#ESECFSE", + "http://dx.doi.org/10.1145/2491411.2491444" + ], + "rigby16": [ + "Peter C. Rigby, Yue Cai Zhu, Samuel M. Donadelli, and Audris Mockus", + "2016", + "Quantifying and mitigating turnover-induced knowledge loss: case studies of chrome and a project at Avaya", + "#ICSE", + "https://doi.org/10.1145/2884781.2884851" + ], + "roehm12": [ + "Tobias Roehm, Rebecca Tiarks, Rainer Koschke, and Walid Maalej", + "2012", + "How do professional developers comprehend software?", + "#ICSE", + "https://doi.org/10.1109/ICSE.2012.6227188" + ], + "rothermel96": [ + "Gregg G. Rothermel, Mary Jean Harrold", + "1996", + "Analyzing regression test selection techniques", + "#TSE", + "https://doi.org/10.1109/32.536955" + ], + "rubin16": [ + "Julia Rubin and Martin Rinard", + "2016", + "The challenges of staying together while moving fast: an exploratory study", + "#ICSE", + "https://doi.org/10.1145/2884781.2884871" + ], + "runeson06": [ + "Per Runeson", + "2006", + "A survey of unit testing practices", + "#Software", + "https://doi.org/10.1109/MS.2006.91" + ], + "salvaneschi14": [ + "Guido Salvaneschi, Sven Amann, Sebastian Proksch, and Mira Mezini", + "2014", + "An empirical study on program comprehension with reactive programming", + "#FSE", + "https://doi.org/10.1145/2635868.2635895" + ], + "santos16": [ + "Ronnie E. S. Santos, Fabio Q. B. da Silva, Cleyton V. C. de Magalhães, and Cleviton V. F. Monteiro", + "2016", + "Building a theory of job rotation in software engineering from an instrumental case study", + "#ICSE", + "https://doi.org/10.1145/2884781.2884837" + ], + "schiller14": [ + "Todd W. Schiller, Kellen Donohue, Forrest Coward, and Michael D. Ernst", + "2014", + "Case studies and tools for contract specifications", + "#ICSE", + "https://doi.org/10.1145/2568225.2568285" + ], + "seaman97": [ + "Carolyn B. Seaman and Victor R. Basili", + "1997", + "An empirical study of communication in code inspections", + "#ICSE", + "http://dx.doi.org/10.1145/253228.253248" + ], + "sedano17": [ + "Todd Sedano, Paul Ralph, Cécile Péraire", + "2017", + "Software development waste", + "#ICSE", + "https://doi.org/10.1109/ICSE.2017.20" + ], + "sfetsos09": [ + "Panagiotis Sfetsos, Ioannis Stamelos, Lefteris Angelis, Ignatios Deligiannis ", + "2009", + "An experimental investigation of personality types impact on pair effectiveness in pair programming", + "#ESE", + "https://doi.org/10.1007/s10664-008-9093-5" + ], + "sharp04": [ + "Helen Sharp, Hugh Robinson", + "2004", + "An ethnographic study of XP practice", + "#ESE", + "https://doi.org/10.1023/B:EMSE.0000039884.79385.54" + ], + "shetterly17": [ + "Margot Lee Shetterly", + "2017", + "Hidden figures: the American dream and the untold story of the Black women mathematicians who helped win the space race", + "HarperCollins Nordic", + "https://www.harpercollins.com/products/hidden-figures-margot-lee-shetterly?variant=32132873093154" + ], + "shrestha20": [ + "Shrestha, N., Botta, C., Barik, T., & Parnin, C", + "2020", + "Here we go again: why is it difficult for developers to learn another programming language?", + "#ICSE", + "http://nischalshrestha.me/docs/cross_language_interference.pdf" + ], + "sillito06": [ + "Jonathan Sillito, Gail C. Murphy, and Kris De Volder", + "2006", + "Questions programmers ask during software evolution tasks", + "#FSE", + "http://dx.doi.org/10.1145/1181775.1181779" + ], + "silva16": [ + "Danilo Silva, Nikolaos Tsantalis, and Marco Tulio Valente", + "2016", + "Why we refactor? Confessions of GitHub contributors", + "#FSE", + "https://doi.org/10.1145/2950290.2950305" + ], + "singer14": [ + "Leif Singer, Fernando Figueira Filho, and Margaret-Anne Storey", + "2014", + "Software engineering at the speed of light: how developers stay current using Twitter", + "#ICSE", + "http://dx.doi.org/10.1145/2568225.2568305" + ], + "smite10": [ + "Darja Šmite, Claes Wohlin, Tony Gorschek, Robert Feldt ", + "2010", + "Empirical evidence in global software engineering: a systematic review", + "#ESE", + "https://doi.org/10.1007/s10664-009-9123-y" + ], + "somers17": [ + "James Somers", + "2017", + "The coming software apocalypse", + "The Atlantic Monthly", + "https://www.theatlantic.com/technology/archive/2017/09/saving-the-world-from-code/540393/" + ], + "sommerville97": [ + "Ian Sommerville, Pete Sawyer", + "1997", + "Requirements engineering: a good practice guide", + "John Wiley & Sons, Inc", + "https://books.google.com/books?id=5NnP-VODEc8C" + ], + "stefik13": [ + "Andreas Stefik and Susanna Siebert", + "2013", + "An Empirical Investigation into Programming Language Syntax", + "ACM Transactions on Computing Education", + "https://doi.org/10.1145/2534973" + ], + "stol14": [ + "Klaas-Jan Stol and Brian Fitzgerald", + "2014", + "Two's company, three's a crowd: a case study of crowdsourcing software development", + "#ICSE", + "http://dx.doi.org/10.1145/2568225.2568249" + ], + "stroustrup96": [ + "Bjarn Stroustrup, B", + "1996", + "A history of C++: 1979--1991", + "History of programming languages II", + "http://dl.acm.org/citation.cfm?id=1057836" + ], + "stylos08": [ + "Jeffrey Stylos and Brad A. Myers", + "2008", + "The implications of method placement on API learnability", + "#FSE", + "http://dx.doi.org/10.1145/1453101.1453117" + ], + "syedabdullah06": [ + "Sharifah Syed-Abdullah, Mike Holcombe & Marian Gheorge", + "2006", + "The impact of an agile methodology on the well being of development teams", + "#ESE", + "https://doi.org/10.1007/s10664-009-9123-y" + ], + "tao12": [ + "Yida Tao, Yingnong Dang, Tao Xie, Dongmei Zhang, and Sunghun Kim", + "2012", + "How do software engineers understand code changes? An exploratory study in industry", + "#FSE", + "http://dx.doi.org/10.1145/2393596.2393656" + ], + "thongtanunam16": [ + "Thongtanunam, P., McIntosh, S., Hassan, A. E., & Iida, H", + "2016", + "Review participation in modern code review: An empirical study of the Android, Qt, and OpenStack projects", + "#ESE", + "https://doi.org/10.1007/s10664-016-9452-6" + ], + "treude09": [ + "Christoph Treude and Margaret-Anne Storey", + "2009", + "How tagging helps bridge the gap between social and technical aspects in software development", + "#ICSE", + "http://dx.doi.org/10.1109/ICSE.2009.5070504" + ], + "treude10": [ + "Christoph Treude and Margaret-Anne Storey", + "2010", + "Awareness 2.0: staying aware of projects, developers and tasks using dashboards and feeds", + "#ICSE", + "http://dx.doi.org/10.1145/1806799.1806854" + ], + "treude11": [ + "Christoph Treude and Margaret-Anne Storey", + "2011", + "Effective communication of software development knowledge through community portals", + "#FSE", + "http://dx.doi.org/10.1145/2025113.2025129" + ], + "turnbull16": [ + "James Turnbull", + "2016", + "The art of monitoring with James Turnbull", + "#SED", + "https://softwareengineeringdaily.com/2016/07/28/2739/" + ], + "uemura84": [ + "Keiji Uemura and Miki Ohori", + "1984", + "A cooperative approach to software development by application engineers and software engineers", + "#ICSE", + "http://dl.acm.org/citation.cfm?id=801955" + ], + "vanderhoek97": [ + "André van der Hoek, Richard S. Hall, Dennis Heimbigner, and Alexander L. Wolf", + "1997", + "Software release management", + "#FSE", + "https://doi.org/10.1145/267896.267909" + ], + "vasilescu15": [ + "Bogdan Vasilescu, Yue Yu, Huaimin Wang, Premkumar Devanbu, and Vladimir Filkov", + "2015", + "Quality and productivity outcomes relating to continuous integration in GitHub", + "#ESECFSE", + "https://doi.org/10.1145/2786805.2786850" + ], + "vonmayrhauser94": [ + "Anneliese von Mayrhauser A. Marie Vans", + "1994", + "Comprehension processes during large scale maintenance", + "#ICSE", + "https://doi.org/10.1109/ICSE.1994.296764" + ], + "vosburgh84": [ + "J. Vosburgh, B. Curtis, R. Wolverton, B. Albert, H. Malec, S. Hoben, and Y. Liu", + "1984", + "Productivity factors and programming environments", + "#ICSE", + "http://dl.acm.org/citation.cfm?id=801963" + ], + "wagstrom14": [ + "Patrick Wagstrom and Subhajit Datta", + "2014", + "Does latitude hurt while longitude kills? Geographical and temporal separation in a large scale software development project", + "#ICSE", + "http://dx.doi.org/10.1145/2568225.2568279" + ], + "walker12": [ + "Robert J. Walker, Shreya Rawal, and Jonathan Sillito", + "2012", + "Do crosscutting concerns cause modularity problems?", + "#FSE", + "http://dx.doi.org/10.1145/2393596.2393654" + ], + "wang16": [ + "Jennifer Wang'", + "2016", + "Female pursuit of Computer Science with Jennifer Wang", + "#SED", + "https://softwareengineeringdaily.com/2016/06/13/female-pursuit-computer-science-jennifer-wang/" + ], + "washington20": [ + "Alicia Nicki Washington", + "2020", + "When twice as good isn't enough: the case for cultural competence in computing", + "#SIGCSE", + "https://doi.org/10.1145/3328778.3366792" + ], + "weinberg82": [ + "Gerald M. Weinberg", + "1982", + "Over-structured management of software engineering", + "#ICSE", + "https://dl.acm.org/doi/abs/10.5555/800254.807743" + ], + "weiser81": [ + "Mark Weiser", + "1981", + "Program slicing", + "#ICSE", + "http://dl.acm.org/citation.cfm?id=802557" + ], + "wobbrock11": [ + "Jacob O. Wobbrock, Shaun K. Kane, Krzysztof Z. Gajos, Susumu Harada, and Jon Froehlich", + "2011", + "Ability-based design: Concept, principles and examples", + "ACM Transactions on Accessible Computing (TACCESS)", + "https://doi.org/10.1145/1952383.1952384" + ], + "woodcock09": [ + "Jim Woodcock, Peter Gorm Larsen, Juan Bicarregui, and John Fitzgerald", + "2009", + "Formal methods: Practice and experience", + "#Surveys", + "http://dx.doi.org/10.1145/1592434.1592436" + ], + "woodfield81": [ + "Scott N. Woodfield, Hubert E. Dunsmore, and Vincent Y. Shen", + "1981", + "The effect of modularization and comments on program comprehension", + "#ICSE", + "http://dl.acm.org/citation.cfm?id=802534" + ], + "xia17": [ + "Xin Xia, Lingfeng Bao, David Lo, Pavneet Singh Kochhar, Ahmed E. Hassan, Zhenchang Xing ", + "2017", + "What do developers search for on the web?", + "#ESE", + "https://link.springer.com/article/10.1007/s10664-017-9514-4" + ], + "ye03": [ + "Yunwen Ye and Kouichi Kishida ", + "2003", + "Toward an understanding of the motivation Open Source Software developers", + "#ICSE", + "http://dl.acm.org/citation.cfm?id=776867" + ], + "yin11": [ + "Zuoning Yin, Ding Yuan, Yuanyuan Zhou, Shankar Pasupathy, and Lakshmi Bairavasundaram", + "2011", + "How do fixes become bugs?", + "#ESECFSE", + "http://dx.doi.org/10.1145/2025113.2025121" + ], + "zeller02": [ + "Andreas Zeller", + "2002", + "Isolating cause-effect chains from computer programs", + "FSE", + "http://dx.doi.org/10.1145/587051.587053" + ], + "zeller02b": [ + "Andreas Zeller, Ralf Hildebrandt", + "2002", + "Simplifying and isolating failure-inducing input", + "#TSE", + "https://doi.org/10.1109/32.988498" + ], + "zeller09": [ + "Andreas Zeller", + "2009", + "Why programs fail: a guide to systematic debugging", + "Elsevier", + "https://www.google.com/books/edition/_/_63Bm4LAdDIC" + ], + "zhou11": [ + "Minghui Zhou and Audris Mockus", + "2011", + "Does the initial environment impact the future of developers?", + "#ICSE", + "https://doi.org/10.1145/1985793.1985831" + ] + }, + "theme": { + "imports": [ + "https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Roboto:ital,wght@0,300;0,500;1,300&display=swap" + ], + "light": { + "backgroundColor": "#FFFFFF", + "blockBackgroundColor": "#FCFAFA", + "errorBackgroundColor": "#F8D7DA", + "borderColorLight": "#E0E0E0", + "borderColorBold": "#000000", + "paragraphColor": "#000000", + "mutedColor": "#9AA1A7", + "highlightColor": "#bb4242", + "commentColor": "#257F31", + "errorColor": "#721C24", + "linkColor": "#bb4242", + "bulletColor": "#bb4242" + }, + "dark": { + "backgroundColor": "#010101", + "blockBackgroundColor": "#333333", + "errorBackgroundColor": "#721C24", + "borderColorLight": "#444444", + "borderColorBold": "#DADADA", + "paragraphColor": "#DADADA", + "mutedColor": "#666666", + "highlightColor": "#b36363", + "commentColor": "#1c4722", + "errorColor": "#F8D7DA", + "linkColor": "#b36363", + "bulletColor": "#b36363" + }, + "fonts": { + "paragraphFontFamily": "\"Roboto\", serif", + "headerFontFamily": "\"Bebas Neue\", serif", + "codeFontFamily": "\"Courier New\", monospace", + "bulletFontFamily": "\"Roboto\"" + }, + "sizes": { + "paragraphFontSize": "14pt", + "blockFontSize": "11pt", + "smallFontSize": "9pt", + "titleFontSize": "30pt", + "header1FontSize": "24pt", + "header2FontSize": "20pt", + "header3FontSize": "14pt", + "codeFontSize": "12pt" + }, + "weights": { + "headerFontWeight": "700", + "paragraphFontWeight": "300", + "boldFontWeight": "500", + "linkFontWeight": "300", + "codeFontWeight": "400", + "bulletFontWeight": "500" + }, + "spacing": { + "paragraphLineHeight": "2rem", + "paragraphLineHeightTight": "1.6em", + "headerLineHeight": "1.3em", + "paragraphSpacing": "1.8rem", + "headerSpacing": "2rem", + "indent": "10%", + "inlinePadding": "0.25rem", + "blockPadding": "1rem", + "roundedness": "5px" + } + } +} diff --git a/bookish.css b/bookish.css deleted file mode 100644 index 57f806b..0000000 --- a/bookish.css +++ /dev/null @@ -1 +0,0 @@ -:root{--bookish-background-color: #FFFFFF;--bookish-block-background-color: #FCFAFA;--bookish-error-background-color: #F8D7DA;--bookish-border-color-light: #E0E0E0;--bookish-border-color-bold: #000000;--bookish-paragraph-color: #000000;--bookish-muted-color: #9AA1A7;--bookish-highlight-color: #E8AF22;--bookish-comment-color: #257F31;--bookish-error-color: #721C24;--bookish-link-color: #1B499C;--bookish-bullet-color: #EB2C27;--bookish-paragraph-font-family: "Georgia", serif;--bookish-header-font-family: "Verdana", serif;--bookish-code-font-family: "Courier New", monospace;--bookish-bullet-font-family: "Verdana";--bookish-paragraph-font-size: 14pt;--bookish-block-font-size: 11pt;--bookish-small-font-size: 9pt;--bookish-title-font-size: 2.4rem;--bookish-header-1-font-size: 2rem;--bookish-header-2-font-size: 1.5rem;--bookish-header-3-font-size: 1rem;--bookish-code-font-size: 11pt;--bookish-paragraph-font-weight: 400;--bookish-bold-font-weight: 700;--bookish-link-font-weight: 400;--bookish-header-font-weight: 700;--bookish-code-font-weight: 400;--bookish-bullet-font-weight: 500;--bookish-paragraph-line-height: 1.8em;--bookish-paragraph-line-height-tight: 1.4em;--bookish-header-line-height: 1.4em;--bookish-paragraph-spacing: 1.8rem;--bookish-header-spacing: 2rem;--bookish-roundedness: 5px;--bookish-indent: 10%;--bookish-inline-padding: .25rem;--bookish-block-padding: 1rem;--bookish-outline-width: 12em;--bookish-outline-padding: 1em;--bookish-outline-offset: calc(-1 * (var(--bookish-outline-width) + 2 * var(--bookish-outline-padding)))}.bookish-dark{--bookish-background-color: #1C1C1C;--bookish-block-background-color: #333333;--bookish-error-background-color: #721C24;--bookish-border-color-light: #444444;--bookish-border-color-bold: #DADADA;--bookish-paragraph-color: #DADADA;--bookish-muted-color: #666666;--bookish-highlight-color: #c5a248;--bookish-comment-color: #1c4722;--bookish-error-color: #F8D7DA;--bookish-link-color: #73a3fa;--bookish-bullet-color: #721C24}*{box-sizing:border-box}body{margin:0;padding:0;background-color:var(--bookish-background-color)}.bookish{font-weight:var(--bookish-paragraph-font-weight);font-family:var(--bookish-paragraph-font-family);font-size:var(--bookish-paragraph-font-size);line-height:var(--bookish-paragraph-line-height);background-color:var(--bookish-background-color);color:var(--bookish-paragraph-color);width:100%;z-index:0;text-align:left}.bookish-page{max-width:720px;position:relative;padding-left:var(--bookish-block-padding);padding-right:var(--bookish-block-padding);padding-bottom:5em;margin-top:0;margin-left:auto;margin-right:auto;opacity:0;transition:opacity .25s ease-in;z-index:1}.bookish-page-loaded{opacity:1}.bookish-loading{width:100vw;height:100vh}.bookish-loading-animation{position:fixed;width:80px;height:80px;left:50%;top:50%;margin-left:-40px;margin-top:-40px;z-index:2}.bookish-loading-animation div{position:absolute;width:16px;height:16px;border-radius:50%;background:var(--bookish-muted-color);animation:bookish-loading 1.2s linear infinite}.bookish-loading-animation div:nth-child(1){top:8px;left:8px;animation-delay:0s}.bookish-loading-animation div:nth-child(2){top:8px;left:32px;animation-delay:-.4s}.bookish-loading-animation div:nth-child(3){top:8px;left:56px;animation-delay:-.8s}.bookish-loading-animation div:nth-child(4){top:32px;left:8px;animation-delay:-.4s}.bookish-loading-animation div:nth-child(5){top:32px;left:32px;animation-delay:-.8s}.bookish-loading-animation div:nth-child(6){top:32px;left:56px;animation-delay:-1.2s}.bookish-loading-animation div:nth-child(7){top:56px;left:8px;animation-delay:-.8s}.bookish-loading-animation div:nth-child(8){top:56px;left:32px;animation-delay:-1.2s}.bookish-loading-animation div:nth-child(9){top:56px;left:56px;animation-delay:-1.6s}@keyframes bookish-loading{0%,to{opacity:1}50%{opacity:.5}}.bookish-muted{color:var(--bookish-muted-color);font-weight:400}.bookish-chapter-body{min-height:2em;min-width:100%}p{font-family:var(--bookish-paragraph-font-family);font-size:var(--bookish-paragraph-font-size);color:var(--bookish-paragraph-color);margin-top:var(--bookish-paragraph-spacing);margin-bottom:var(--bookish-paragraph-spacing);word-break:break-word;min-height:var(--bookish-paragraph-line-height)}strong,b{font-weight:var(--bookish-bold-font-weight)}h1,h2,h3,h4,h5,h6{font-family:var(--bookish-header-font-family);font-weight:var(--bookish-header-font-weight);margin-top:var(--bookish-header-spacing);margin-bottom:var(--bookish-header-spacing);line-height:var(--bookish-header-line-height)}h1{font-size:var(--bookish-title-font-size)}h2{font-size:var(--bookish-header-1-font-size)}h3{font-size:var(--bookish-header-2-font-size)}h4{font-size:var(--bookish-header-3-font-size);font-style:italic}.bookish-chapter-number{font-family:var(--bookish-header-font-family);font-weight:400;font-style:italic}.bookish-title{margin-top:0;margin-bottom:0}.bookish-subtitle{font-size:var(--bookish-header-1-font-size);font-weight:400;font-style:italic;margin-top:0;margin-bottom:calc(var(--bookish-title-font-size) * .5);line-height:var(--bookish-header-line-height)}.bookish-figure{margin-bottom:var(--bookish-paragraph-spacing)}.bookish-section-name{display:inline-block;font-family:var(--bookish-paragraph-font-family);font-size:var(--bookish-small-font-size);font-weight:400;font-style:normal;color:var(--bookish-muted-color);line-height:1em}.bookish-tag{font-size:var(--bookish-small-font-size);display:inline-block;padding:var(--bookish-inline-padding) calc(2 * var(--bookish-inline-padding));border-radius:var(--bookish-roundedness);background-color:var(--bookish-border-color-light);font-weight:700;text-transform:uppercase}.bookish-authors{font-family:var(--bookish-paragraph-font-family);font-style:italic;margin-top:0;margin-bottom:var(--bookish-paragraph-spacing)}input[type=text]{font-family:var(--bookish-paragraph-font-family);font-size:var(--bookish-paragraph-font-size);padding:var(--bookish-inline-padding) calc(2 * var(--bookish-inline-padding));width:100%}.bookish-chapter>p:first-of-type:first-letter{padding:0 .25rem;margin:0 .25rem 0 0;font-size:4rem;font-weight:700;float:left;line-height:1;color:var(--bookish-paragraph-color)}ol{list-style:none;counter-reset:item}ol>li{counter-increment:item}ol>li{list-style-type:none}ol>ol>li{list-style-type:none}ol>ol>ol>li{list-style-type:none}ol>li:before,ul>ol>li:before,ul>ul>ol>li:before{content:counter(item) ". ";color:var(--bookish-bullet-color);display:inline-block;width:1em;margin-left:-1.5rem;margin-right:.5rem;text-align:right}ol>ol>li:before,ul>ol>ol>li:before{content:counter(item,lower-alpha) ". "}ol>ol>ol>li:before{content:counter(item,upper-alpha) ". "}li{margin-bottom:calc(.5 * var(--bookish-paragraph-spacing))}ul li{list-style:none}ul li:before{content:"*";color:var(--bookish-bullet-color);display:inline-block;width:1rem;margin-left:-1rem;font-family:var(--bookish-bullet-font-family);font-weight:var(--bookish-bullet-font-weight)}hr{border:none;border-bottom:1px solid var(--bookish-border-color-light);margin-top:calc(var(--bookish-paragraph-spacing) * 3);margin-bottom:calc(var(--bookish-paragraph-spacing) * 3)}.bookish-figure{margin-top:var(--bookish-paragraph-spacing);margin-bottom:var(--bookish-paragraph-spacing);width:100%}.bookish-figure-image{border-radius:var(--bookish-roundedness);max-width:100%;width:100%;height:auto;margin-bottom:0}.bookish-dark .bookish-figure-image{filter:brightness(50%)}.bookish-figure-caption{text-align:center;color:var(--bookish-muted-color);line-height:var(--bookish-paragraph-line-height-tight);font-size:var(--bookish-block-font-size);margin-top:0;margin-bottom:var(--bookish-paragraph-spacing);margin-left:var(--bookish-paragraph-spacing);margin-right:var(--bookish-paragraph-spacing)}.bookish-figure-credit{display:block;text-align:right;font-style:italic;font-size:var(--bookish-small-font-size)}.bookish-figure-preview{display:inline-block;width:10rem;margin:1em;vertical-align:bottom}.bookish-figure-preview img{width:100%;height:auto}.bookish-figure-embed{position:relative;display:block;width:100%;padding:0;overflow:hidden;border-radius:var(--bookish-roundedness)}.bookish-figure-embed:before{padding-top:56.25%;display:block;content:""}.bookish-figure-frame{position:absolute;top:0;bottom:0;left:0;width:100%;height:100%;border:0}.bookish-figure-full{left:50%;margin-left:-50vw;margin-right:-50vw;margin-bottom:3em;max-width:100vw;position:relative;right:50%;width:100vw}.bookish-figure-full .bookish-figure{margin-top:0}.bookish-figure-unspecified{width:100%;height:8em;background-color:var(--bookish-error-background-color);color:var(--bookish-error-color);display:flex;flex-direction:column;justify-content:center;align-items:center}.bookish-figure-dragging{background-color:var(--bookish-highlight-color)}.bookish-scroll-reminder{position:fixed;bottom:4em;left:50%;animation:bookish-bounce 3s infinite;animation-timing-function:ease;width:0;height:0;margin-left:-1rem;border-left:1rem solid transparent;border-right:1rem solid transparent;border-top:1rem solid white;mix-blend-mode:difference}.bookish-scroll-reminder.bookish-past-title{display:none}@keyframes bookish-bounce{0%{bottom:4em}50%{bottom:5em}to{bottom:4em}}a{color:var(--bookish-link-color);font-weight:var(--bookish-link-font-weight);text-decoration:none}a:hover{text-decoration:underline}.bookish-forthcoming{opacity:.5}.bookish-blockquote{clear:both;border:none;font-family:var(--bookish-header-font-family);font-weight:400;font-style:italic;padding:0;margin-top:var(--bookish-paragraph-spacing);margin-bottom:var(--bookish-paragraph-spacing);margin-left:var(--bookish-indent);margin-right:var(--bookish-indent);position:relative}.bookish-blockquote>p{margin:0;padding:0}.bookish-blockquote .bookish-blockquote-caption{margin-top:.5em;text-align:right;font-family:var(--bookish-header-font-family);font-style:italic;color:var(--bookish-muted-color)}.bookish-blockquote:before{content:"\201c";position:relative;top:80pt;left:-40pt;font-family:Modum Extra;font-size:120pt;font-weight:700;color:var(--bookish-highlight-color);z-index:-1}.bookish-blockquote-caption:before{content:"--";margin-right:.25em}.bookish-callout{border:none;border-top:2px solid var(--bookish-border-color-bold);border-bottom:2px solid var(--bookish-border-color-bold);margin:var(--bookish-paragraph-spacing);padding-left:0;padding-right:0;padding-top:var(--bookish-paragraph-spacing);padding-bottom:var(--bookish-paragraph-spacing);line-height:var(--bookish-paragraph-line-height-tight);clear:both;position:relative}.bookish-callout h2,.bookish-callout h3,.bookish-callout h4{margin-top:0}.bookish-callout ol,.bookish-callout ul{padding-left:1rem}.bookish-table{display:block;width:100%;overflow-x:auto}.bookish-table table{width:100%;line-height:var(--bookish-paragraph-line-height-tight);margin-bottom:var(--bookish-paragraph-spacing);border-collapse:collapse;clear:both}.bookish-table td{padding:var(--bookish-block-padding);vertical-align:top;border-top:1px solid var(--bookish-border-color-light)}.bookish-chapter .bookish-table{border-collapse:separate;border-radius:var(--bookish-roundedness);border-spacing:0}.bookish-chapter .bookish-table tbody tr:first-child{border:0;background-color:var(--bookish-border-color-light)}.bookish-chapter .bookish-table tbody tr:first-child td{font-weight:700;border:0;border-bottom:1px solid var(--bookish-border-color-light)}.bookish-chapter .bookish-table tbody tr:nth-child(even){background-color:var(--bookish-block-background-color)}.bookish-chapter table tr:last-child td:first-child{border-bottom-left-radius:var(--bookish-roundedness)}.bookish-chapter table tr:last-child td:last-child{border-bottom-right-radius:var(--bookish-roundedness)}.bookish-chapter table tr:first-child td:first-child{border-top-left-radius:var(--bookish-roundedness)}.bookish-chapter table tr:first-child td:last-child{border-top-right-radius:var(--bookish-roundedness)}.bookish-chapter .bookish-table td{font-size:var(--bookish-block-font-size);border:0}.bookish-error{background-color:var(--bookish-error-background-color);color:var(--bookish-error-color);border-radius:var(--bookish-roundedness);font-weight:400;padding:var(--bookish-inline-padding) calc(2 * var(--bookish-inline-padding))}.bookish-content-highlight{position:relative}.bookish-label.bookish-content-highlight{display:inline-block;width:3em;height:3em;border-radius:3em;position:absolute;z-index:-1;margin-left:-1em}.bookish-marginal-interactor .bookish-citation-symbol:before,.bookish-marginal-interactor .bookish-footnote-symbol:before,.bookish-marginal-interactor .bookish-comment-symbol:before{content:"";width:3em;height:3em;top:-1em;left:calc(-1.5em + 50%);border-radius:3em;position:absolute;z-index:-1;opacity:0;background-color:var(--bookish-highlight-color);transition:opacity .2s}@media (hover: hover){.bookish-marginal-interactor.bookish-marginal-hovered .bookish-citation-symbol:before,.bookish-marginal-interactor.bookish-marginal-hovered .bookish-footnote-symbol:before,.bookish-marginal-interactor.bookish-marginal-hovered .bookish-comment-symbol:before{opacity:.3}}.bookish-marginal-interactor.bookish-marginal-selected .bookish-citation-symbol:before,.bookish-marginal-interactor.bookish-marginal-selected .bookish-footnote-symbol:before,.bookish-marginal-interactor.bookish-marginal-selected .bookish-comment-symbol:before{opacity:.7}.bookish-content-highlight:before{content:"";z-index:-1;left:-.5em;top:-.5em;position:absolute;width:100%;height:2em;opacity:.7;padding:.1em .25em;background-color:var(--bookish-highlight-color);filter:url(#marker)}.bookish-reference{font-family:var(--bookish-paragraph-font-family);list-style-position:outside}.bookish-footnote{font-family:Epilogue;font-weight:300;font-size:var(--bookish-small-font-size);line-height:1.5em}ol li.bookish-reference:before{color:var(--bookish-paragraph-color)}.bookish-reference-text .bookish-reference-summary{font-size:var(--bookish-small-font-size);padding-left:var(--bookish-indent);display:inline-block;border-left:1px solid var(--bookish-border-color-light);margin-top:1em;font-style:italic}.bookish-footnote,.bookish-marginal .bookish-reference{font-size:var(--bookish-small-font-size);font-style:normal;color:var(--bookish-paragraph-color)}.bookish-footnote-symbol,.bookish-citation-symbol{font-family:var(--bookish-paragraph-font-family);font-weight:400;color:var(--bookish-link-color);position:relative}.bookish-comment-symbol,.bookish-reference,.bookish-footnote{position:relative}.bookish-references .bookish-reference,.bookish-footnote{display:block;line-height:var(--bookish-paragraph-line-height-tight);margin-left:1rem;margin-bottom:1rem;text-align:left}.bookish-reference .bookish-citation-symbol,.bookish-footnote .bookish-footnote-symbol{display:block;float:left;margin-top:-.5em;position:absolute;left:-1.75em;text-align:right;width:1.5em}.bookish-definition .bookish-marginal-interactor{border-bottom:2px solid var(--bookish-link-color)}.bookish-definition-entry{display:block;padding-left:.75rem;font-size:var(--bookish-small-font-size);line-height:var(--bookish-paragraph-line-height-tight);text-align:left;margin-left:.25rem;margin-bottom:1rem;background:linear-gradient(to right,var(--bookish-link-color) 0px,var(--bookish-link-color) 2px,transparent 2px) no-repeat right}.bookish-definition-entry .bookish-definition-entry-synonyms{color:var(--bookish-muted-color);font-style:italic}.bookish-outline{font-family:var(--bookish-header-font-family);font-weight:400;font-size:var(--bookish-paragraph-font-size);color:var(--bookish-muted-color)}.bookish-outline-header-nav{display:inline-block;width:100%;padding-bottom:var(--bookish-outline-padding)}.bookish-outline-header{display:block;line-height:var(--bookish-paragraph-line-height-tight);text-indent:0;padding-left:1rem;padding-right:1rem;margin-bottom:.75rem}.bookish-outline-header-level-0{font-size:1rem}.bookish-outline-header-level-1{font-size:.9rem}.bookish-outline-header-level-2{font-size:.8rem;font-style:italic;margin-left:1em}a .bookish-outline-header,.bookish-outline-header-nav a{color:var(--bookish-muted-color)}a .bookish-outline-header-active,a:hover .bookish-outline-header{color:var(--bookish-paragraph-color)}.bookish-outline-header-nav-disabled{opacity:.3}.bookish-outline a:hover{text-decoration:none}@media (hover: hover){.bookish-outline a:hover{color:var(--bookish-paragraph-color)}}a .bookish-outline-header-active{color:var(--bookish-paragraph-color)}.bookish-outline-reading-mode{transition:transform .2s ease-in}.bookish-outline-reading-mode:hover{cursor:pointer;transform:scale(1.25);color:var(--bookish-paragraph-color)}@media screen and (max-width: 1200px){.bookish-marginal{background-color:var(--bookish-background-color);padding:.75em;position:fixed;width:auto;height:auto;left:0;right:0;bottom:0;z-index:2;cursor:pointer;transform:translateY(0);transition:transform .2s ease-in}.bookish-marginal .bookish-marginal{display:none}.bookish-marginal-interactor{cursor:pointer}.bookish-marginal-interactor:hover{font-weight:700}.bookish-definition .bookish-marginal-interactor:hover{font-weight:400}.bookish-definition:hover{border-bottom-color:var(--bookish-border-color-bold)!important}.bookish-marginal-hidden{transform:translateY(100%);transition:transform .2s ease-out;height:0;bottom:0}.bookish-outline{position:fixed;top:100%;left:0;right:0;width:100%;z-index:2;border-top:1px solid var(--bookish-border-color-light);text-align:left;transition:transform .2s ease-in;background-color:var(--bookish-background-color);box-shadow:0 -1px 2px #00000040;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);max-height:100%;overflow-y:scroll}.bookish-outline-headers{width:20em;margin:auto}.bookish-outline-header-nav{text-align:center;padding-top:.5em;padding-bottom:.5em;text-indent:0!important;font-size:1.25rem!important}.bookish-outline-reading-mode{position:absolute;top:.5em;left:0;font-size:1em;display:inline-block;padding-left:1em;padding-right:1em}.bookish-outline-collapse-cue{position:absolute;top:.5em;right:0;font-size:1em;display:inline-block;padding-left:1em;padding-right:1em;transition:transform .2s ease-in}.bookish-outline-collapse-cue:hover{cursor:pointer;transform:scale(1.25);color:var(--bookish-paragraph-color)}.bookish-outline-collapse-cue-disabled{display:none}.bookish-outline-expanded .bookish-outline-collapse-cue{transform:rotate(90deg)}.bookish-outline.bookish-outline-expanded{transform:translateY(-100%)}.bookish-outline.bookish-outline-collapsed{transform:translateY(-3em)}}@media screen and (min-width: 1200px){.bookish-marginal-left-inset{float:left;clear:both;width:75%;margin-left:-30%!important;margin-right:2em}.bookish-marginal-right-inset{float:right;clear:both;width:75%;margin-right:-30%!important;margin-left:2em}.bookish-marginal{float:right;width:12rem;display:block;padding-bottom:.5rem;position:absolute}.bookish-definition .bookish-marginal-interactor.bookish-marginal-hovered{border-bottom-color:var(--bookish-link-color)!important;border-bottom-width:3px}.bookish-definition .bookish-marginal.bookish-marginal-hovered .bookish-definition-entry{background:linear-gradient(to right,var(--bookish-link-color) 0px,var(--bookish-link-color) 3px,transparent 3px) no-repeat right}.bookish-outline{width:var(--bookish-outline-width);z-index:0;border-right:1px solid var(--bookish-border-color-light);padding:var(--bookish-outline-padding);background-color:var(--bookish-background-color)}.bookish-outline.bookish-outline-fixed-left{position:fixed;display:inline-block;top:50px;transform:translate(var(--bookish-outline-offset))}.bookish-outline.bookish-outline-title-left{position:absolute;margin-left:var(--bookish-outline-offset)}.bookish-outline-collapse-cue{display:none}.bookish-outline-reading-mode{position:absolute;top:calc(var(--bookish-outline-padding));right:calc(var(--bookish-outline-padding))}}.bookish-code{font-family:var(--bookish-code-font-family);font-weight:var(--bookish-code-font-weight);font-size:var(--bookish-code-font-size);white-space:pre-wrap;border:1px solid var(--bookish-border-color-light);color:var(--bookish-muted-color);background-color:var(--bookish-block-background-color);clear:both}code{font-family:var(--bookish-code-font-family);font-weight:var(--bookish-code-font-weight);font-size:var(--bookish-code-font-size)}.bookish-code-block{display:block;padding:var(--bookish-block-padding);line-height:var(--bookish-paragraph-line-height-tight);border-radius:var(--bookish-roundedness)}.bookish-code-inline{display:inline;padding:calc(1.5 * var(--bookish-inline-padding)) var(--bookish-inline-padding)}.bookish-code-inline code{display:inline;padding:0}.bookish-code-language{float:right;margin-top:-3em;font-size:small;color:gray;margin-right:.5em}.hljs,.hljs-title,.hljs-params,.hljs-section{color:var(--bookish-paragraph-color)}.hljs-comment,.hljs-quote{color:var(--bookish-comment-color)}.hljs-variable,.hljs-template-variable,.hljs-tag,.hljs-name,.hljs-selector-id,.hljs-selector-class,.hljs-regexp,.hljs-deletion{color:var(--bookish-error-color)}.hljs-number,.hljs-built_in,.hljs-builtin-name,.hljs-literal,.hljs-string,.hljs-symbol,.hljs-meta,.hljs-link .hljs-bullet,.hljs-addition{color:var(--bookish-link-color)}.hljs-type,.hljs-attribute,.hljs-keyword,.hljs-selector-tag{color:var(--bookish-highlight-color)}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.bookish-python-controls{display:flex;flex-direction:row;align-items:stretch;width:100%}.bookish-python button{background:var(--bookish-block-background-color);border:1px solid var(--bookish-border-color-light);width:3em;height:3rem;padding:0;display:inline-block;vertical-align:top}.bookish-python .bookish-python-output{flex:1;border:1px solid lightGray;padding:.5rem;height:3rem;overflow-y:scroll;display:inline-block;vertical-align:top;color:var(--bookish-paragraph-color);font-family:var(--bookish-code-font-family);font-weight:var(--bookish-code-font-weight);font-size:var(--bookish-block-font-size)}@media print{.bookish-chapter-header{break-before:page}body{font-size:16pt}@page{margin:1in}h1,h2,h3,h4,h5,h6{break-after:avoid!important}} diff --git a/bookish.js b/bookish.js deleted file mode 100644 index ea5bb45..0000000 --- a/bookish.js +++ /dev/null @@ -1,3040 +0,0 @@ -var EJ=Object.defineProperty;var SJ=(Ht,Yt,en)=>Yt in Ht?EJ(Ht,Yt,{enumerable:!0,configurable:!0,writable:!0,value:en}):Ht[Yt]=en;var et=(Ht,Yt,en)=>(SJ(Ht,typeof Yt!="symbol"?Yt+"":Yt,en),en),JU=(Ht,Yt,en)=>{if(!Yt.has(Ht))throw TypeError("Cannot "+en)};var y=(Ht,Yt,en)=>(JU(Ht,Yt,"read from private field"),en?en.call(Ht):Yt.get(Ht)),it=(Ht,Yt,en)=>{if(Yt.has(Ht))throw TypeError("Cannot add the same private member more than once");Yt instanceof WeakSet?Yt.add(Ht):Yt.set(Ht,en)},st=(Ht,Yt,en,Eo)=>(JU(Ht,Yt,"write to private field"),Eo?Eo.call(Ht,en):Yt.set(Ht,en),en);(function(){var gt,Es,id,vn,Et,_o,yn,me,Ft,Qn,bn,Cn,kr,Sr,sd,At,Gi,mo,Yl,pn,lr,Vt,Zt,Ur,Ts,mn,mi,Be,on,cr;"use strict";function Ht(t,e){for(var n=0;n