[go: up one dir, main page]

Jump to content

User:Policy1257/sandbox

From Wikipedia, the free encyclopedia

Open Source Software

[edit]

The term open source software (OSS) refers to software projects that are redistributable, with all source code being made available. Similarly, modifications and derived works are allowed and distributable.[1]

Though open-source software has many similarities to free software, open-source software focuses on the logic of publicly available software creating as much innovation as possible, while the free software movement sees publicly available software as a moral right, creating philosophical differences, though both movements support publicly available software.[1] Because of their similarities, some refer to their projects with both terms; free and open source (FOSS) or free/libre open source (F/LOSS, FLOSS).[1] Whichever the case, because of their respective philosophical focuses, it is generally expected to refer to projects as the creator has labeled them.[1]

The strength of open source software is its community, involving a range of roles from contributors to users. Because open source software is generally made up of voluntary contributions, open source projects differ from proprietary software in their organization, membership, leadership, contribution policies, and quality control.[2] This allows for lower barriers to participation, but also removes the monetary incentive to finish projects.[2] However, there are also some disadvantages.[1] For example, due to being made up of voluntary contributions there may be members who are unhelpful or have agendas that influence their contributions.[1] These issues may be true of any voluntary community and the majority greatly outnumbers the minority of unpleasant participants.[1] Some other issues may be licensing difficulties, disordered projects, language barriers, poor communication, or abandoned projects.[1]

For the consumer, open source software offers and opportunity to share, modify, improve software within the licensing limitations or to enjoy the software others have altered.[1] For society, open source software offers software that can be tailored to the needs of many industries and institutions around the world, including governments, allowing for greater economic development.[3][4][5]

Open Source Model

[edit]

Development Model

[edit]

In his 1997 essay The Cathedral and the Bazaar, open source software influential contributor Eric S. Raymond suggests a model for developing OSS known as the bazaar model.[6] Raymond likens the development of software by traditional methodologies to building a cathedral, with careful isolated work by individuals or small groups.[6] He suggests that all software should be developed using the bazaar style, with differing agendas and approaches.[6]

In the traditional model of development, which he called the cathedral model, development takes place in a centralized way.[6] Roles are clearly defined.[6] Roles include people dedicated to designing (the architects), people responsible for managing the project, and people responsible for implementation.[6] Traditional software engineering follows the cathedral model.[6]

The bazaar model, however, is different.[6] In this model, roles are not clearly defined.[6] Some proposed characteristics of software developed using the bazaar model should exhibit the following patterns:[7]

Users should be treated as co-developers: The users are treated like co-developers and so they should have access to the source code of the software.[7] Furthermore, users are encouraged to submit additions to the software, code fixes for the software, bug reports, documentation, etc. Having more co-developers increases the rate at which the software evolves.[7] Linus's law states that given enough eyeballs all bugs are shallow.[7] This means that if many users view the source code, they will eventually find all bugs and suggest how to fix them.[7] Some users have advanced programming skills, and furthermore, each user's machine provides an additional testing environment.[7] This new testing environment offers the ability to find and fix a new bug.[7]

Early releases: The first version of the software should be released as early as possible so as to increase one's chances of finding co-developers early.[7]

Frequent integration: Code changes should be integrated (merged into a shared code base) as often as possible so as to avoid the overhead of fixing a large number of bugs at the end of the project life cycle.[7][8] Some open-source projects have nightly builds where integration is done automatically.[7]

Several versions: There should be at least two versions of the software.[7] There should be a buggier version with more features and a more stable version with fewer features.[7] The buggy version (also called the development version) is for users who want the immediate use of the latest features and are willing to accept the risk of using code that is not yet thoroughly tested.[7] The users can then act as co-developers, reporting bugs and providing bug fixes.[7][8]

High modularization: The general structure of the software should be modular allowing for parallel development on independent components.[7]

Dynamic decision-making structure: There is a need for a decision-making structure, whether formal or informal, that makes strategic decisions depending on changing user requirements and other factors.[7] Compare with extreme programming.[7]

The process of open source software development begins with a requirements elicitation where developers consider if they should add new features or if a bug needs to be fixed in their project.[8] This is established by communicating with the OSS community through avenues such as bug reporting and tracking or mailing lists and project pages.[8] Next, OSS developers select or are assigned to a task and identify a solution. Because there are often many different possible routes for solutions in OSS, the best solution must be chosen with careful consideration and sometimes even peer feedback.[8] The developer then begins to develop and commit the code.[8] The code is then tested and reviewed by peers.[8] Developers can edit and evolve their code through feedback from continuous integration.[8] Once the leadership and community are satisfied with the whole project, it can be partially released and user instruction can be documented.[8] If the project is ready to be released, it is frozen, with only serious bug fixes or security repairs occurring.[8] Finally, the project is fully released and only changed through minor bug fixes.[8]

Technologies Used

[edit]

In open source software development, tools are used to support the development of the product and the development process itself.[8]

Version control systems such as Centralized Version control system (CVCS) and the distributed version control system (DVCS) are examples of tools, often open source, that help manage the source code files and the changes to those files for a software project in order to foster collaboration.[9] CVCS are centralized with a central repository while DVCS are decentralized and have a local repository for every user.[9] concurrent versions system (CVS) and later Subversion (SVN) and Git are examples of CVCS.[9] The repositories are hosted and published on source-code-hosting facilities such as GitHub.[9]

Open-source projects use utilities such as issue trackers to organize open-source software development. Commonly used bugtrackers include Bugzilla and Redmine.[8]

Tools such as mailing lists and IRC provide means of coordination and discussion of bugs among developers.[8] Project web pages, wiki pages, roadmap lists and newsgroups allow for the distribution of project information that focuses on end users.[8]

Key Projects

[edit]

Open source software projects are built and maintained by a network of programmers, who may often be volunteers, and are widely used in free as well as commercial products.[10]

Unix: Unix is an operating system created by AT&T that began as a precursor to open source software in that the free and open source software revolution began when developers began trying to create operating systems without Unix code.[11] Unix was created in the 1960s, before the commercialization of software and before the concept of open source software was necessary, therefore it was not considered a true open source software project.[11] It started as a research project before being commercialized in the mid 1980s.[11] Before its commercialization, it represented many of the ideals held by the Free and Open source software revolution, including the decentralized collaboration of global users, rolling releases and a community culture of distaste towards proprietary software.[11]

BSD: Berkely Software Distribution (BSD) is an operating system that began as a variant of Unix in 1978 that mixed Unix code with code from Berkely labs to increase functionality.[11] As BSD was focused on increasing functionality, it would publicly share its greatest innovations with the main Unix operating system.[11] This is an example of the free public code sharing that is a central characteristic of FOSS today.[11] As Unix became commercialized in the 1980s, developers or members of the community who did not support proprietary software began to focus on BSD and turning it into an operating system that did not include any of Unix's code.[11]The final version of BSD was released in 1995.[11]

GNU: GNU is a free operating system created by Richard Stallman in 1984 with its name meaning Gnu's Not Unix.[11] The idea was to create a Unix alternative operating system that was would be available for anyone to use and allow programmers to share code freely between them.[11] However, the goal of GNU was not to only replace Unix, but to make a superior version that had more technological capabilities.[11] It was released before the philosophical beliefs of the Free and Open source software revolution were truly defined.[11] Because of its creation by prominent FOSS programmer Richard Stallman, GNU was heavily involved in FOSS activism, with one of the greatest achievements of GNU being the creation of the GNU General Public License or GPL, which allowed developers to release software that could be legally shared and modified.[11]

Linux: Linux is an operating system kernel that was introduced in 1991 by Linus Torvalds.[11] Linux was inspired by making a better version of the for profit operating service Minux.[11] It was radically different than what other hackers were producing at the time due to it being totally free of cost and being decentralized.[11] Later, Linux was put under the GPL license, allowing people to make money with Linux and bringing Linux into the FOSS community.[11]

Apache: Apache began in 1995 as a collaboration between a group of developers releasing their own web server due to their frustration with NCSA HTTPd code base.[11] The name Apache was used because of the several patches they applied to this code base.[11] Within a year of its release, it became the worldwide leading web server.[11] Soon, Apache came out with its own license, creating discord in the greater FOSS community, though ultimately proving successful.[11] The Apache license allowed permitted members to directly access source code, a marked difference from GNU and Linux's approaches.[11]

Representative Examples of Open Source Software Projects

[edit]
The figure shows a collection of examples of open source software applications. These examples demonstrate the variety and use of noteworthy open source projects as mentioned in academic papers.[2][12][1][11]
Project name Category License Logo Brief description
MySQL Systems Applications - Databases GPL 2.0[13]
MySQL is a relational database management system. While it was originally distributed as open source software, it now has a dual licensing scheme that allows either free gpl-like licensing for oss applications, or a non-free proprietary license[2]
WildFly Systems Applications - Web and Application Servers Apache License 2.0[14]
WildFly, formerly JBoss, is a open-source Java EE-based application.[2]
SpamAssassin Systems Applications - Email Apache License 2.0[15]
SpamAssassin is an e-mail spam filtering program that uses local and network tests to identify spam signatures.[2]
WinSCP Systems Applications - Security GPL[16]
WinSCP is an ftp/sftp client program for Windows that is used to secure file transfers.[2]
Firefox Desktop MPL 2.0[17]
Firefox is a free and open source web browser descended from the Mozilla Application Suite and managed by the Mozilla Corporation.[2]
VLC Entertainment GPL 2.0/LGPL 2.1[18]
VLC is a media player for DVDs, (S)VCDs, Audio CDs, web streams, TV cards, etc.[2]
GIMP Graphics GPL 3.0[19]
GIMP (gnu Image Manipulation Program) is a program for photo retouching, image composition and image authoring.[2]
Moodle Education GPL 3.0[20]
Moodle is a Course Management System that educators can use to create online learning sites.[2]
R-Project Scientific and Engineering GPL 2.0/GPL 3[21]
R is an extensible language and environment for statistical computing and graphics. It supports many statistical and graphical techniques.[2]
TCPDF Publishing GNU lesser general public license 3.0 TCPDF is a php class for generating pdf documents.[2]
JAVA Software Development - Language GPL 2.0 + CPE[22]
Java is a programming language released as a core component of Sun Microsystems’ Java platform.[2]
CVS Software Development - Version Control Systems GNU[23]
CVS keeps track of all work and changes in a set of files, and to allows several developers to collaborate.[2]
Qt Software Development - Frameworks LGPL 3.0/GPL 3.0[24]
Qt is a cross-platform application development framework used for the development of GUI programs and developing non GUI programs.[2]
WordPress Content Management Systems GPL 2.0 (or later)[25]
WordPress is an open source CMS, often used as a blog publishing application.[2]
Compiere Business Applications GPL 2.0[26]
Compiere is an open source ERP and CRM business solution for Enterprises in distribution, retail, service and manufacturing.[2]

Opportunities for Participation

[edit]

Contributing

[edit]

The basic roles OSS participants can fall into multiple categories, beginning with leadership at the center of the project who have control over its execution.[1] Next are the core contributors with a great deal of experience and authority in the project who may guide the other contributors.[1] Non-core contributors have less experience and authority, but regularly contribute and are vital to the project’s development.[1] New contributors are the least experienced but with mentorship and guidance can become regular contributors.[1]

Some possible ways of contributing to open source software include such roles as programming, user interface design and testing, web design, Bug triage, accessibility design and testing, UX design, code testing, and security review and testing.[1] However, there are several ways of contributing to OSS projects even without coding skills.[1] For example, some less technical ways of participating are documentation writing and editing, translation, project management, event organization and coordination, marketing, release management, community management, and public relations and outreach.[1]

Industry Participation

[edit]

The adoption of open source software by industry is increasing over time.[27] OSS is popular in several industries such as telecommunications, aerospace, healthcare, and media & entertainment due to the benefits it provides.[28] Adoption of OSS is more likely in larger organizations and is dependent on the company’s IT usage, operating efficiencies, and the productivity of employees.[27]

Industries are likely to use OSS due to back-office functionality, sales support, research and development, software features, quick deployment, portability across platforms and avoidance of commercial license management.[27] Additionally, lower cost for hardware and ownership are also important benefits.[27]

Prominent Organizations

[edit]

Organizations that contribute to the development and expansions of free and open source software movements exist all over the world.[1] These organizations are dedicated to goals such as teaching and spreading technology.[1] As listed by a former vice president of the open source initiative, some American organizations include the free software foundation, software freedom conservancy, the open source initiative and software in the public interest.[1] Within Europe some notable organizations are Free Software Foundation Europe, open source projects EU (OSP) and openforum europe (OFE).[1] One Australian organization is linux australia while Asia has open source asia and fossasia.[1] free and open source software for africa (FOSSFA) and openafrica are African organizations and Central and South Asia has such organizations as FLISOL and GRUP de usuarios de software libre peru.[1] Outside of these, many more organizations dedicated to the advancement of open source software exist.[1]

[edit]

Licensing

[edit]

Main article: Open-source license

Further information: Free software license

See also: Free and open-source software § Licensing, and Software license  

FOSS products are generally licensed under two types of licenses: permissive licensing and copyleft licensing.[12] Both of these types of licenses are different than proprietary licensing in that they can allow more users access to the software and allow for the creation of derivative works as specified by the terms of the specific license, as each license has its own rules.[12] Permissive licenses allow recipients of the software to implement the author's copyright rights without having to use the same license for distribution.[12] Examples of this type of license include the BSD, MIT, and Apache licenses.[12] Copyleft licenses are different in that they require recipients to use the same license for at least some parts of the distribution of their works.[12] Strong copyleft licenses require all derivative works to use the same license while weak copyleft licenses require the use of the same license only under certain conditions.[12] Examples of this type of license include the GNU family of licenses, and the MPL and EPL licenses.[12] The similarities between these two categories of licensing include that they provide a broad grant of copyright rights, require that recipients preserve copyright notices, and that a copy of the license is provided to recipients with the code.[12]

One important legal precedent for open source software was created in 2008, when the Jacobson v Katzer case enforced terms of the Artistic license, including attribution and identification of modifications.[12] The ruling of this case cemented enforcement under copyright law when the conditions of the license were not followed.[12] Because of the similarity of the Artistic license to other open source software licenses, the ruling created a precedent that applied widely.[12]

Examples of free software license / open source licenses include Apache License, BSD license, GNU General Public License, GNU Lesser General Public License, MIT License, Eclipse Public License and Mozilla Public License.[12]

[edit]

Several gray areas exist within software regulation that have great impact on open source software, such as if software is a good or service, what can be considered a modification, governance through contract vs license, ownership and right of use.[12] While there have been developments on these issues, they often lead to even more questions.[12] The existence of these uncertainties in regulation has a negative impact on industries involved in technologies as a whole.[12]

Within the legal history of software as a whole, there was much debate on whether to protect it as intellectual property under patent law, copyright law or establishing a unique regulation.[12] Ultimately, copyright law became the standard with computer programs being considered a form of literary work, with some tweaks of unique regulation.[12]

Software is generally considered source code and object code, with both being protectable, though there is legal variety in this definition.[12] Some jurisdictions attempt to expand or reduce this conceptualization for their own purposes.[12] For example, The European Court of Justice defines a computer program as not including the functionality of a program, the programing language, or the format of data files.[12] By limiting protections of the different aspects of software, the law favors an open source approach to software use.[12] The US especially has an open approach to software, with most open-source licenses originating there.[12] However, this has increased the focus on patent rights within these licenses, which has seen backlash from the OSS community, who prefer other forms of IP protection.[12]

Another issue includes technological protection measures (TPM) and digital rights management (DRM) techniques which were internationally legally recognized and protected in the 1996 World Intellectual Property Organization (WIPO) Treaty.[12] Open source software proponents disliked these technologies as they constrained end-users potentially beyond copyright law.[12] Europe responded to such complaints by putting TPM under legal controls, representing a victory for OSS supporters.[12]

Economic/Business Implications

[edit]

In open source communities, instead of owning the software produced, the producer owns the development of the evolving software.[4] In this way, the future of the software is open, making ownership or intellectual property difficult within OSS.[4] Licensing and branding can prevent others from stealing it, preserving its status as a public good.[4] Open source software can be considered a public good as it available to everyone and does not decrease in value for others when downloaded by one person.[4] Open source software is unique in that it becomes more valuable as it used and contributed to instead of diminishing the resource which is explained by concepts such as investment in reputation and network effects.[4]

The economic model of open source software can be explained as developers contribute work to projects, creating public benefits.[4] Developers choose projects based on the perceived benefits or costs, such as improved reputation or value of the project.[4] The motivations of developers can come from many different places and reasons, but the important takeaway is that money is not the only or even most important incentivization.[4]

Because economic theory mainly focuses on the consumption of scarce resources, the OSS dynamic can be hard to understand. In OSS, producers become consumers by reaping the rewards of contributing to a project.[4] For example, a developer becomes well regarded by their peers for a successful contribution to an OSS project.[4] The social benefits and interactions of OSS are difficult to account for in economic models as well.[4] Furthermore, the innovation of technology creates constantly changing value discussions and outlooks, making economic model unable to predict social behavior.[4]

Although OSS is theoretically challenging in economic models, it is explainable as a sustainable social activity that requires resources.[4] These resources include time, money, technology and contributions.[4] Many developers have used technology funded by organizations such as universities and governments, though these same organizations benefit from the work done by OSS.[4] As OSS grows, hybrid systems containing OSS and proprietary systems are becoming more common.[4]

Throughout the mid 2000s, more and more tech companies have begun to use OSS.[11] For example, Dell's move of selling computers with GNU/Linux already installed.[11] Microsoft itself has launched a Linux-based operating system despite previous animosity with the OSS movement.[11] Despite these developments, these companies tend to only use OSS for certain purposes, leading to worries that OSS is being taken advantage of by corporations and not given anything in return.[11]

Government Uses

[edit]

While many governments are interested in implementing and promoting open-source software due to the many benefits provided, a huge issue to be considered is cybersecurity.[5] While accidental vulnerabilities are possible, so are attacks by outside agents.[5] Because of these fears, governmental interest in contributing to the governance of software has become more prominent.[5] However, these are the broad strokes of the issue, with each country having their own specific politicized interactions with open source software and their goals for its implementation.[5] For example, the United States has focused on national security in regard to open source software implementation due to the perceived threat of the increase of open source software activity in countries like China and Russia, with the Department of Defense considering multiple criteria for using OSS.[5] These criteria include: if it comes from and is maintained by trusted sources, whether it will continue to be maintained, if there are dependencies on sub-components in the software, component security and integrity, and foreign governmental influence.[5]

Another issue for governments in regard to open source is their investments in technologies such as operating systems, semiconductors, cloud, and artificial intelligence.[5] These technologies all have implications for global cooperation, again opening up security issues and political consequences.[5] Many countries have to balance technological innovation with technological dependence in these partnerships.[5] For example, after China’s open-source dependent company Huawei was prevented from using Google's android system in 2019, they began to create their own alternative operating system: Harmony OS.[5]

Open Software Movement

[edit]

History

[edit]

Further information: History of free and open-source software

In the early days of computing, such as the 1950s and into the 1960s, programmers and developers shared software to learn from each other and evolve the field of computing.[29] For example, Unix included the operating system source code for users.[29] Eventually, the commercialization of software in the years 1970–1980 began to prevent this practice.[29] However, academics still often developed software collaboratively.[29]

In response, the open source movement was born out of the work of skilled programmer enthusiasts, widely referred to as hackers or hacker culture.[3] One of these enthusiasts, Richard Stallman, was a driving force behind the free software movement, which would later allow for the open source movement.[3] In 1984, he resigned from MIT to create a free operating system, GNU, after the programmer culture in his lab was stifled by proprietary software preventing source code from being shared and improved upon.[3] GNU was UNIX compatible, meaning that the programmer enthusiasts would still be familiar with how it worked.[3] However, it quickly became apparent that there was some confusion with the label Stallman had chosen of free software, which he described as free as in free speech, not free beer, referring to the meaning of free as freedom rather than price.[3] He later expanded this concept of freedom to the four essential freedoms.[3] Through GNU, open source norms of incorporating others' source code, community bug fixes and suggestions of code for new features appeared.[3] In 1985, Stallman founded the Free Software Foundation (FSF) to promote changes in software and to help write GNU.[3] In order to prevent his work from being used in proprietary software, Stallman created the concept of copyleft, which allowed the use of his work by anyone, but under specific terms.[3] To do this, he created the GNU General Public License (GNU GPL) in 1989, which was updated in 1991.[3] In 1991, GNU was combined with the Linux kernel written by Linus Torvalds, as a kernel was missing in GNU.[30] The operating system is now usually referred to as Linux.[3] Throughout this whole period, there were many other free software projects and licenses around at the time, all with different ideas of what the concept of free software was and should be, as well as the morality of proprietary software, such as Berkely Software Distribution, TeX, and the X Windows System.[31]

As free software developed, the Free Software Foundation began to look how to bring free software ideas and perceived benefits to the commercial software industry.[31] It was concluded that FSF's social activism was not appealing to companies and they needed a way to rebrand the free software movement to emphasize the business potential of sharing and collaborating on software source code.[31] The term open source was suggested by Christine Peterson in 1998 at a meeting of supporters of free software.[3] Many in the group felt the name free software was confusing to newcomers and holding back industry interest and they readily accepted the new designation of open source, creating the Open Source Initiative (OSI) and the OSI definition of what open source software is.[3] The Open Source Initiative's (OSI) definition is now recognized by several governments internationally as the standard or de facto definition.[30] The definition was based on the Debian Free Software Guidelines, written and adapted primarily by Bruce Perens.[32] The OSI definition differed from the free software definition in that it allows the inclusion of proprietary software and allows more liberties in its licensing.[3] Some, such as Stallman, agree more with the original concept of free software as a result because it takes a strong moral stance against proprietary software, through there is much overlap between the two movements in terms of the operation of the software.[3]

While the Open Source Initiative sought to encourage the use of the new term and evangelize the principles it adhered to, commercial software vendors found themselves increasingly threatened by the concept of freely distributed software and universal access to an application's source code, with an executive of Microsoft calling open source an intellectual property destroyer in 2001.[33] However, while free and open-source software (FOSS) has historically played a role outside of mainstream private software development, companies as large as Microsoft have begun to develop official open source presences on the Internet.[33] IBM, Oracle, and State Farm are just a few of the companies with a serious public stake in today's competitive open source market, marking a significant shift in the corporate philosophy concerning the development of FOSS.[33]

Future

[edit]

The future of the open source software community, and the free software community by extension, has become successful if not confused about what it stands for.[11] For example, Android and Ubuntu are examples milestones of success in the open source software rise to prominence from the sidelines of technological innovation as it existed in the early 2000s.[11] However, some in the community consider them failures in their representation of OSS due to issues such as the downplaying of the OSS center of Android by Google and its partners, the use of an Apache license that allowed forking and resulted in a loss of opportunities for collaboration within Android, the prioritization of convivence over freedom in Ubuntu, and features within Ubuntu that track users for marketing purposes.[11]

The use of OSS has become more common in business with 78% of companies reporting that they run all or part of their operations on FOSS.[11] The popularity of OSS has risen to the point that Microsoft, a once detractor of OSS, has included its use in their systems.[11] However, this success has raised concerns that will determine the future of OSS as the community must answer questions such as what OSS is, what should it be, and what should be done to protect it, if it even needs protecting.[11] All in all, while the free and open source revolution has slowed to a perceived equilibrium in the market place, that does not mean it is over as many theoretical discussions must take place to determine its future.[11]

Comparisons with other software licensing/development models

[edit]

Closed source / proprietary software

[edit]

Main article: Comparison of open-source and closed-source software

Open source software differs from proprietary software in that it is publicly available, the license requires no fees, modifications and distributions are allowed under license specifications.[34] All of this works to prevent a monopoly on any OSS product, which is a goal of proprietary software.[34] Proprietary software limits their customers' choices to either committing to using that software, upgrading it or switching to other software, forcing customers to have their software preferences impacted by their monetary cost.[34] The ideal case scenario for the proprietary software vendor would be a lock-in, where the customer does not or cannot switch software due to these costs and continues to buy products from that vendor.[34]

Within proprietary software, bug fixes can only be provided by the vendor, moving platforms requires another purchase and the existence of the product relies on the vendor, who can discontinue it at any point.[3] Additionally, proprietary software does not provide its source code and cannot be altered by users.[3] For businesses, this can pose a security risk and source of frustration, as they cannot specialize the product to their needs, and there may be hidden threats or information leaks within the software that they cannot access or change.[3]

Free Software

[edit]

Main article: Alternative terms for free software

See also: Comparison of free and open-source software licenses

Under OSI's definition, open source is a broad software license that makes source code available to the general public with relaxed or non-existent restrictions on the use and modification of the code.[35] It is an explicit feature of open source that it puts very few restrictions on the use or distribution by any organization or user, in order to enable the rapid evolution of the software.[35]

Richard Stallman, leader of the Free software movement and member of the free software foundation opposes the term open source being applied to what they refer to as free software.[36] Although he agrees that the two terms describe almost the same category of software, Stallman considers equating the terms incorrect and misleading.[36] He believes that the main difference is that by choosing one term over the other lets others know about what one's goals are: development (open source) or a social stance (free software).[37] Nevertheless, there is significant overlap between open source software and free software.[36] Stallman also opposes the professed pragmatism of the Open Source Initiative, as he fears that the free software ideals of freedom and community are threatened by compromising on the FSF's idealistic standards for software freedom.[37] The FSF considers free software to be a subset of open-source software, and Richard Stallman explained that DRM software, for example, can be developed as open source, despite how it restricts its users, and thus does not qualify as free software.[36]

The FSF said that the term open source fosters an ambiguity of a different kind such that it confuses the mere availability of the source with the freedom to use, modify, and redistribute it.[36] On the other hand, the term free software was criticized for the ambiguity of the word free, which was seen as discouraging for business adoption, and for the historical ambiguous usage of the term.[37]

Developers have used the alternative terms Free and Open Source Software (FOSS), or Free/Libre and Open Source Software (FLOSS), consequently, to describe open-source software that is also free software.[1]

Source-available software

[edit]

Main article: Source-available software

Software can be distributed with source code, which is a code that is readable.[38] Software is source available when this source code is available to be seen.[38] However to be source available or FOSS, the source code does not need to be accessible to all, just the users of that software.[38] While all FOSS software is source available because this is a requirement made by the Open Source Definition, not all source available software is FOSS.[38] For example, if the software doesn't meet other aspects of the Open Source Definition such as permitted modification or redistribution, even if the source code is available, the software is not FOSS.[38]

Open-sourcing

[edit]

A recent trend within software companies is open sourcing, or transitioning their previous proprietary software into open source software through releasing it under a open source license.[39][40] Examples of companies who have done this are Google, Microsoft and Apple.[39] Additionally, open sourcing can refer to programming open source software or installing open source software.[40] Open sourcing can be beneficial in multiple ways, such as attracting more external contributors who bring new perspectives and problem solving capabilities. [39] The downsides of open sourcing include the work that has to be done to maintaining the new community, such as making the base code easily understandable, setting up communication channels for new developers and creating documentation to allow new developers to easily join.[39] However, a review of several open sourced projects found that although a newly open sourced project attracts many newcomers, a great amount are likely to soon leave the project and their forks are also likely to not be impactful.[39]

Other

[edit]

Other concepts that may share some similarities to open source are shareware, public domain software, freeware, and software viewers/readers that are freely available but do not provide source code.[3] However, these differ from open source software in access to source code, licensing, copyright and fees.[3]

Society and Culture

[edit]

Demographics

[edit]

Despite being able to collaborate internationally, open source software contributors were found to mostly be located in large clusters such as Silicon Valley that largely collaborate within themselves.[41] Possible reasons for this phenomenon may be that the OSS contributor demographic largely works in software, meaning that the OSS geographic location is closely related to that dispersion and collaborations could be encouraged through work and social networks.[41] Code acceptance can be impacted by status within these social network clusters, creating unfair predispositions in code acceptance based on location.[42] Barriers to international collaboration also include linguistic or cultural differences.[43] Furthermore, each country has been shown to have a higher acceptance rate for code from contributors within their country except India, indicating a bias for culturally similar collaborators.[43]

In 2021, the countries with the highest open source software contributions included the United States, China, Germany, India, and the UK, in that order.[41] The counties with the highest OSS developers per capita from a study in 2021 include, in order, Iceland, Switzerland, Norway, Sweden, and Finland, while in 2008 the countries with top amount of estimated contributors in SourceForge were the United States, Germany, United Kingdom, Canada and France.[41] [43] Though there have been several studies done on the distribution and contributions of OSS developers, this is still an open field that can be measured in several different ways.[43] For instance, Information and communication technology participation, population, wealth and proportion of access to the internet have been shown to be correlated with OSS contributions.[43]

Although gender diversity has been found to enhance team productivity, women still face biases while contributing to open source software projects when their gender is identifiable.[44] In 2002, only 1.5% of international open-source software developers were women, while women made up 28% of tech industry roles, demonstrating their low representation in the software field.[45] Despite OSS contributions having no prerequisites, this gender bias may continue to exist due to the common belief of contributors that gender shouldn't matter, and the quality of code should be the only consideration for code acceptance, preventing the community from addressing the systemic disparities in female representation.[45] However, a more recent figure of female OSS participation internationally calculated across 2005 to 2021 is 9.8%, with most being recent contributors, indicating that female participation may be growing.[46]

Motivations

[edit]

There are many motivations for contributing to the OSS community.[1] For one, it is an opportunity to learn and practice multiple skills such as coding and other technology related abilities, but also fundamental skills such as communication and collaboration and practical skills needed to excel in technology related fields such as issue tracking or version control.[1] Instead of learning through a classroom or a job, learning through contributing to OSS allows participants to learn at their own pace and follow what interests them.[1] When contributing to OSS, you can learn the current industry best practices, technology and trends and even have the opportunity to contribute to the next big innovation as OSS grows increasingly popular within the tech field.[1] Contributing to OSS without payment means there is no threat of being fired, though reputations can take a hit.[1] On the other hand, a huge motivation to contribute to OSS is the reputation gained as you grow your public portfolio.[1]

Disparities

[edit]

Even though programming was originally seen as a female profession, there remains a large gap in computing.[47] Social identity tends to be a large concern as women in the tech industry face insecurity about attracting unwanted male attention and harassment or being unfeminine in their technology knowledge, having a large impact on confidence.[45] Some male tech participants make clear that they believe women fitting in within the culture is impossible, furthering the insecurity for women and their place in the tech industry.[44] Additionally, even in a voluntary contribution environment like open source software, women tend to end up doing the less technical aspects of projects, such as manual testing or documentation despite women and men showing the same productivity in OSS contributions.[44] Explicit biases include longer feedback time, more scrutinization of code and lower acceptance rate of code.[44] Specifically in the open-source software community, women report that sexually offensive language is common and the women’s identity as female is given more attention that as an OSS contributor[45] Bias is hard to address due to the belief that gender shouldn’t matter, with most contributors feeling that women getting special treatment is unfair and success should be dependent on skill, preventing any changes to be more inclusive.[45]

Wikipedia page

[edit]

Notes for Wikipedia article outline

Definitions

- get rid of open source software licensing, addressed in legal issues

Open source software development

- replace development tools with technologies used

- delete funding section, not sourced

opportunities for participation

legal and economic issues

society and culture

- move to bottom, above current applications

open software movement

comparisons

current applications and adoption

- delete practical uses section

extensions for non-software use

- combine with current applications and adoption, replace with Adoption and Application

- fix advantages section

Delete:

- open source software licensing

- funding section

Adoption and Application

[edit]

Key Projects

[edit]

Open source software projects are built and maintained by a network of programmers, who may often be volunteers, and are widely used in free as well as commercial products.[10]

Unix: Unix is an operating system created by AT&T that began as a precursor to open source software in that the free and open source software revolution began when developers began trying to create operating systems without Unix code.[11] Unix was created in the 1960s, before the commercialization of software and before the concept of open source software was necessary, therefore it was not considered a true open source software project.[11] It started as a research project before being commercialized in the mid 1980s.[11] Before its commercialization, it represented many of the ideals held by the Free and Open source software revolution, including the decentralized collaboration of global users, rolling releases and a community culture of distaste towards proprietary software.[11]

BSD: Berkely Software Distribution (BSD) is an operating system that began as a variant of Unix in 1978 that mixed Unix code with code from Berkely labs to increase functionality.[11] As BSD was focused on increasing functionality, it would publicly share its greatest innovations with the main Unix operating system.[11] This is an example of the free public code sharing that is a central characteristic of FOSS today.[11] As Unix became commercialized in the 1980s, developers or members of the community who did not support proprietary software began to focus on BSD and turning it into an operating system that did not include any of Unix's code.[11]The final version of BSD was released in 1995.[11]

GNU: GNU is a free operating system created by Richard Stallman in 1984 with its name meaning Gnu's Not Unix.[11] The idea was to create a Unix alternative operating system that was would be available for anyone to use and allow programmers to share code freely between them.[11] However, the goal of GNU was not to only replace Unix, but to make a superior version that had more technological capabilities.[11] It was released before the philosophical beliefs of the Free and Open source software revolution were truly defined.[11] Because of its creation by prominent FOSS programmer Richard Stallman, GNU was heavily involved in FOSS activism, with one of the greatest achievements of GNU being the creation of the GNU General Public License or GPL, which allowed developers to release software that could be legally shared and modified.[11]

Linux: Linux is an operating system kernel that was introduced in 1991 by Linus Torvalds.[11] Linux was inspired by making a better version of the for profit operating service Minux.[11] It was radically different than what other hackers were producing at the time due to it being totally free of cost and being decentralized.[11] Later, Linux was put under the GPL license, allowing people to make money with Linux and bringing Linux into the FOSS community.[11]

Apache: Apache began in 1995 as a collaboration between a group of developers releasing their own web server due to their frustration with NCSA HTTPd code base.[11] The name Apache was used because of the several patches they applied to this code base.[11] Within a year of its release, it became the worldwide leading web server.[11] Soon, Apache came out with its own license, creating discord in the greater FOSS community, though ultimately proving successful.[11] The Apache license allowed permitted members to directly access source code, a marked difference from GNU and Linux's approaches.[11]

Extensions for non-software use

[edit]

While the term open source applied originally only to the source code of software, it is now being applied to many other areas such as open source ecology, a movement to decentralize technologies so that any human can use them.[36][48] However, it is often misapplied to other areas that have different and competing principles, which overlap only partially.[3]

The same principles that underlie open-source software can be found in many other ventures, such as open source, open content, and open collaboration. [49][50]

This "culture" or ideology takes the view that the principles apply more generally to facilitate concurrent input of different agendas, approaches, and priorities, in contrast with more centralized models of development such as those typically used in commercial companies.[6]

Advantages

[edit]

Open source implementation of a standard can increase adoption of that standard.[51] This creates developer loyalty as developers feel empowered and have a sense of ownership of the end product.[52]

Moreover, lower costs of marketing and logistical services are needed for OSS.[53] OSS can be a tool to promote a company's image, including its commercial products.[54] The OSS development approach has helped produce reliable, high quality software quickly and inexpensively.[53]

Open source development offers the potential to quicken innovation and create of social value.[55] In France for instance, a policy that incentivized government to favor free open-source software increased to nearly 600,000 OSS contributions per year, generating social value by increasing the quantity and quality of open-source software.[55] This policy also led to an estimated increase of up to 18% of tech startups and a 14% increase in the number of people employed in the IT sector.[55]

OSS can be highly reliable when it has thousands of independent programmers testing and fixing bugs of the software.[7] Open source is not dependent on the company or author that originally created it.[11] Even if the company fails, the code continues to exist and be developed by its users.[11]

OSS is flexible because modular systems allow programmers to build custom interfaces, or add new abilities to it and it is innovative since open-source programs are the product of collaboration among a large number of different programmers.[7] The mix of divergent perspectives, corporate objectives, and personal goals speeds up innovation.[56]

Moreover, free software can be developed in accordance with purely technical requirements.[57] It does not require thinking about commercial pressure that often degrades the quality of the software.[57] Commercial pressures make traditional software developers pay more attention to customers' requirements than to security requirements, since such features are somewhat invisible to the customer.[57]

References

[edit]
  1. ^ a b c d e f g h i j k l m n o p q r s t u v w x y z aa ab ac ad ae Brasseur, V. M. (2018). Forge your future with open source: build your skills, build your network, build the future of technology. The pragmatic programmers. Raleigh, North Carolina: The Pragmatic Bookshelf. ISBN 978-1-68050-301-2.
  2. ^ a b c d e f g h i j k l m n o p q r Androutsellis-Theotokis, Stephanos (2010). "Open Source Software: A Survey from 10,000 Feet". Foundations and Trends® in Technology, Information and Operations Management. 4 (3–4): 187–347. doi:10.1561/0200000026. ISSN 1571-9545.
  3. ^ a b c d e f g h i j k l m n o p q r s t u v Bretthauer, David (2001). "Open Source Software: A History". Information Technology and Libraries. 21 (1).
  4. ^ a b c d e f g h i j k l m n o p q Wynants, M., & Cornelis, J. (Eds.). (2005). How open is the future? : Economic, social and cultural scenarios inspired by free and open-source software. ASP.
  5. ^ a b c d e f g h i j k Pannier, Alice (2022). Software Power: The Economic and Geopolitical Implications of Open Source Software. Études de l’Ifri. ISBN 9791037306418.
  6. ^ a b c d e f g h i j Raymond, Eric (2005). "The Cathedral and the Bazaar (originally published in Volume 3, Number 3, March 1998)". First Monday. doi:10.5210/fm.v0i0.1472. ISSN 1396-0466.{{cite journal}}: CS1 maint: unflagged free DOI (link)
  7. ^ a b c d e f g h i j k l m n o p q r s "Empirical Software Engineering Research on Free/Libre/Open Source Software | IEEE Conference Publication | IEEE Xplore". ieeexplore.ieee.org. doi:10.1109/icsm.2006.25. Retrieved 2023-11-21.
  8. ^ a b c d e f g h i j k l m n o Napoleao, Bianca M.; Petrillo, Fabio; Halle, Sylvain (2020). "Open Source Software Development Process: A Systematic Review". IEEE 24th International Enterprise Distributed Object Computing Conference (EDOC). IEEE: 135–144. doi:10.1109/EDOC49727.2020.00025. ISBN 978-1-7281-6473-1.
  9. ^ a b c d Zolkifli, Nazatul Nurlisa; Ngah, Amir; Deraman, Aziz (2018). "Version Control System: A Review". Procedia Computer Science. 135: 408–415. doi:10.1016/j.procs.2018.08.191.
  10. ^ a b Popp, Karl Michael, ed. (2020). Best practices for commercial use of open source software: business models, processes and tools for managing open source software. Synomic Academy. Norderstedt: BoD – Books on Demand. ISBN 978-3-7386-1909-6.
  11. ^ a b c d e f g h i j k l m n o p q r s t u v w x y z aa ab ac ad ae af ag ah ai aj ak al am an ao ap aq ar as at au av aw ax ay az ba bb bc bd be bf bg bh Tozzi, Christopher (2017). For Fun and Profit: A History of the Free and Open Source Software Revolution. United States: MIT Press. ISBN 9780262341189.
  12. ^ a b c d e f g h i j k l m n o p q r s t u v w x y z aa Brock, Amanda (2023). Open Source Law, Policy and Practice (2nd ed.). UK: Oxford University Press. ISBN 9780198862345.
  13. ^ "MySQL". www.mysql.com. Retrieved 2024-01-24.
  14. ^ "WildFly". www.wildfly.org. Retrieved 2024-01-24.
  15. ^ "Apache SpamAssassin: Welcome". spamassassin.apache.org. Retrieved 2024-01-24.
  16. ^ "WinSCP". WinSCP - Free SFTP and FTP client. Retrieved 2024-01-24.
  17. ^ "Download the fastest Firefox ever". Mozilla. Retrieved 2024-01-24.
  18. ^ "Official download of VLC media player, the best Open Source player - VideoLAN". www.videolan.org. Retrieved 2024-01-24.
  19. ^ "GIMP". GIMP. Retrieved 2024-01-24.
  20. ^ "Moodle". Moodle. Retrieved 2024-01-24.
  21. ^ "R: The R Project for Statistical Computing". www.r-project.org. Retrieved 2024-01-24.
  22. ^ "Oracle". Oracle. Retrieved 2024-01-25.
  23. ^ "[cvs] Contents of /ccvs/README". cvs.savannah.nongnu.org. Retrieved 2024-01-25.
  24. ^ "Open Source Development | Open Source License | Qt". www.qt.io. Retrieved 2024-01-25.
  25. ^ "License". WordPress.org. Retrieved 2024-01-25.
  26. ^ "Compiere Public License". www.compiere.com. Retrieved 2024-01-25.
  27. ^ a b c d Spinellis, Diomidis; Giannikas, Vaggelis (2012). "Organizational adoption of open source software". Journal of Systems and Software. 85 (3): 666–682. doi:10.1016/j.jss.2011.09.037.
  28. ^ Zhang, Yiming; Malhotra, Baljeet; Chen, Cheng (2018). "Industry-Wide Analysis of Open Source Security". 2018 16th Annual Conference on Privacy, Security and Trust (PST). IEEE: 1–10. doi:10.1109/PST.2018.8514185. ISBN 978-1-5386-7493-2.
  29. ^ a b c d Maracke, Catharina (2019). "Free and Open Source Software and FRAND‐based patent licenses: How to mediate between Standard Essential Patent and Free and Open Source Software". The Journal of World Intellectual Property. 22 (3–4): 78–102. doi:10.1111/jwip.12114. ISSN 1422-2213.
  30. ^ a b "International Authority & Recognition". Open Source Initiative. 2015-04-21. Retrieved 2023-12-18.
  31. ^ a b c Fogel, Karl (2006). Producing open source software: how to run a successful free software project (1. Aufl., [Nachdr.] ed.). Beijing Köln: O'Reilly. ISBN 978-0-596-00759-1.
  32. ^ Kelty, Christopher (2008). Two Bits: The Cultural Significance of Free Software. Duke University Press. ISBN 978-0-8223-8900-2.
  33. ^ a b c Miller, Keith W.; Voas, Jeffrey; Costello, Tom (2010). "Free and Open Source Software". IT Professional. 12 (6): 14–16. doi:10.1109/mitp.2010.147. ISSN 1520-9202.
  34. ^ a b c d Zhu, Kevin Xiaoguo; Zhou, Zach Zhizhong (2012). "Research Note —Lock-In Strategy in Software Competition: Open-Source Software vs. Proprietary Software". Information Systems Research. 23 (2): 536–545. doi:10.1287/isre.1110.0358. ISSN 1047-7047.
  35. ^ a b "The Open Source Definition (Annotated)". Open Source Initiative. 2006-07-24. Retrieved 2023-12-18.
  36. ^ a b c d e f Stallman, Richard (2007). "Why Open Source Misses the Point of Free Software".{{cite web}}: CS1 maint: url-status (link)
  37. ^ a b c Stallman, Richard M.; Gay, Joshua (2002). Free software, free society. Boston (Mass.): Free software foundation. ISBN 978-1-882114-98-6.
  38. ^ a b c d e Fortunato, Laura; Galassi, Mark (2021-05-17). "The case for free and open source software in research and scholarship". Philosophical Transactions of the Royal Society A: Mathematical, Physical and Engineering Sciences. 379 (2197). doi:10.1098/rsta.2020.0079. ISSN 1364-503X.
  39. ^ a b c d e Pinto, Gustavo; Steinmacher, Igor; Dias, Luiz Felipe; Gerosa, Marco (2018). "On the challenges of open-sourcing proprietary software projects". Empirical Software Engineering. 23 (6): 3221–3247. doi:10.1007/s10664-018-9609-6. ISSN 1382-3256.
  40. ^ a b Ågerfalk; Fitzgerald (2008). "Outsourcing to an Unknown Workforce: Exploring Opensurcing as a Global Sourcing Strategy". MIS Quarterly. 32 (2): 385. doi:10.2307/25148845. ISSN 0276-7783.
  41. ^ a b c d Wachs, Johannes; Nitecki, Mariusz; Schueller, William; Polleres, Axel (March 2002). "The Geography of Open Source Software: Evidence from GitHub". Technological Forecasting and Social Change. 176: 121478. doi:10.1016/j.techfore.2022.121478.
  42. ^ Rastogi, Ayushi; Nagappan, Nachiappan; Gousios, Georgios; van der Hoek, André (2018-10-11). "Relationship between geographical location and evaluation of developer contributions in github". ESEM '18: Proceedings of the 12th ACM/IEEE International Symposium on Empirical Software Engineering and Measurement. ACM: 1–8. doi:10.1145/3239235.3240504. ISBN 978-1-4503-5823-1.
  43. ^ a b c d e Gonzalez-Barahona, Jesus M.; Robles, Gregorio; Andradas-Izquierdo, Roberto; Ghosh, Rishab Aiyer (August 2008). "Geographic origin of libre software developers". Information Economics and Policy. 20 (4): 356–363. doi:10.1016/j.infoecopol.2008.07.001.
  44. ^ a b c d Bosu, Amiangshu; Sultana, Kazi Zakia (2019). "Diversity and Inclusion in Open Source Software (OSS) Projects: Where Do We Stand?". 2019 ACM/IEEE International Symposium on Empirical Software Engineering and Measurement (ESEM). IEEE: 1–11. doi:10.1109/ESEM.2019.8870179. ISBN 978-1-7281-2968-6.
  45. ^ a b c d e Nafus, Dawn (June 2012). "'Patches don't have gender': What is not open in open source software". New Media & Society. 14 (4): 669–683. doi:10.1177/1461444811422887. ISSN 1461-4448.
  46. ^ Trinkenreich, Bianca; Wiese, Igor; Sarma, Anita; Gerosa, Marco; Steinmacher, Igor (2022-10-31). "Women's Participation in Open Source Software: A Survey of the Literature". ACM Transactions on Software Engineering and Methodology. 31 (4): 1–37. doi:10.1145/3510460. ISSN 1049-331X.
  47. ^ Albusays, Khaled; Bjorn, Pernille; Dabbish, Laura; Ford, Denae; Murphy-Hill, Emerson; Serebrenik, Alexander; Storey, Margaret-Anne (April 2021). "The Diversity Crisis in Software Development". IEEE Software. 38 (2): 19–25. doi:10.1109/MS.2020.3045817. ISSN 0740-7459.
  48. ^ Powers, Stephen M.; Hampton, Stephanie E. (2019). "Open science, reproducibility, and transparency in ecology". Ecological Applications. 29 (1). doi:10.1002/eap.1822. ISSN 1051-0761.
  49. ^ Cheliotis, Giorgos (2009). "From open source to open content: Organization, licensing and decision processes in open cultural production". Decision Support Systems. 47 (3): 229–244. doi:10.1016/j.dss.2009.02.006. ISSN 0167-9236.
  50. ^ Levine, Sheen S.; Prietula, Michael J. (2013-12-30). "Open Collaboration for Innovation: Principles and Performance". Organization Science. 25 (5): 1414–1433. arXiv:1406.7541. doi:10.1287/orsc.2013.0872. ISSN 1047-7039. S2CID 6583883.
  51. ^ US Department of Defense. "Open Source Software FAQ". Chief Information Officer. Archived from the original on 28 August 2016. Retrieved 22 July 2016.
  52. ^ Sharma, Srinarayan; Vijayan Sugumaran; Balaji Rajagopalan (2002). "A framework for creating hybrid-open source software communities" (PDF). Information Systems Journal. 12: 7–25. doi:10.1046/j.1365-2575.2002.00116.x. S2CID 5815589. Archived (PDF) from the original on 30 October 2008. Retrieved 8 September 2008.
  53. ^ a b Reynolds, Carl; Jeremy Wyatt (February 2011). "Open Source, Open Standards, and Health Care Information Systems". Journal of Medical Internet Research. 13 (1): e24. doi:10.2196/jmir.1521. PMC 3221346. PMID 21447469.
  54. ^ Landry, John; Rajiv Gupta (September 2000). "Profiting from Open Source". Harvard Business Review. doi:10.1225/F00503 (inactive 31 January 2024).{{cite journal}}: CS1 maint: DOI inactive as of January 2024 (link)
  55. ^ a b c Nagle, Frank (3 March 2019). "Government Technology Policy, Social Value, and National Competitiveness" (PDF). Information Systems Journal. 12. doi:10.2139/ssrn.3355486. S2CID 85509685. SSRN 3355486.
  56. ^ Plotkin, Hal (December 1998). "What (and Why) you should know about open-source software". Harvard Management Update: 8–9.
  57. ^ a b c Payne, Christian (February 2002). "On the Security of Open Source Software". Information Systems Journal. 12 (1): 61–78. doi:10.1046/j.1365-2575.2002.00118.x. S2CID 8123076.