Unity Version Control

Unity Version Control
Developer(s)Codice Software
Initial release31 October 2006; 18 years ago (2006-10-31)
Stable release
9.0 / August 21, 2020; 4 years ago (2020-08-21)
Operating systemMicrosoft Windows, Linux, Mac OS
Platform.NET / Mono
Size93 MB (Windows installer)
TypeRevision control
LicenseProprietary
Websitewww.plasticscm.com

Unity Version Control (previously known as Plastic SCM)[1] is a cross-platform commercial distributed version control tool developed by Códice Software for Microsoft Windows, Mac OS X, Linux, and other operating systems. It includes a command-line tool, native GUIs, diff and merge tool and integration with a number of IDEs. It is a full version control stack not based on Git (although it can communicate with it).

Features

Unity Version Control is a full version control stack platform. It includes these components:

  • Server
  • Command line client
  • GUIs
  • Diff and merge tools[2]
  • Web GUI[3]
  • Web-based admin interface[4]

Some of its features include:

  • Support for heavy branching and merging: According to its creators, Unity Version Control can handle unlimited branching and complex merge scenarios[5]
  • Visual Branch Explorer: A timeline to represent branches, merges and changes in repositories, implemented in all of its GUIs[6]
  • ACL-based security: Every object in the system can be secured with access control lists[7]
  • Built-in three-way merge and side-by-side diff including language-aware support and history of a specific method or function[8]
  • Directory versioning and support for versioning renames
  • Revision history for branched, renamed, moved, copied and deleted files
  • Blame/Annotate
  • Centralized operation (SVN/Perforce style)
  • Distributed operation (Git/Mercurial style)
  • Atomic commits—the server assures that changesets are committed in the repository entirely
  • Shelving—users can save and restore work in progress for task switching
  • Support for ASCII, Unicode, binary, symbolic link (on Unix), Mac-specific, and UTF-16 files
  • Support for Mac OS X, Windows and Linux platforms
  • Server-side and client-side event triggers[9]
  • High-latency network support: The network protocol used by Unity Version Control is optimized for high-speed/high-latency networks[10]
  • Gluon: GUI and workflow for non-developers (specially focused on game development)[11]
  • Locking: Binary files and assets that can't be merged can use locking instead of branching/merging[12]

Design

Unity Version Control is a client/server system although in current terms of version control it can also be defined as a distributed revision control system, due to its ability to have very lightweight servers on the developer computer and push and pull branches between servers (similar to what Git and Mercurial do). Developers work on files in their client workspaces, and check in changed files together in changesets.

Storage

Unity Version Control has 2 different families of storage for all its data and metadata:

  • Jet: An ad-hoc storage designed for high-performance, released with version 6.0. It is now the default storage.
  • Relational databases: Traditionally Unity Version Control supported storing all data and metadata in relational databases: MySQL, SQL Server, SQLite, SQL Server Compact Edition, Firebird, Firebird Embedded, Postgresql and Oracle. Relational databases are still supported although Jet is now the default option.[13]

Modes of operation

Unity Version Control can work in 2 modes:

  • Centralized: With workspaces (working copies) connected directly to a server. Users perform checkin operations without the need for an additional push step.
  • Distributed: Users host their own repositories on their computers and push/pull to a central server.[14]

Differences from Git

Unity Version Control SCM is not based on Git although it can act as a Git server and a Git client. Differences can be summarized as: improvements in merge, native support for large files and projects, optional file-locking, can work distributed and centralized. There are differences in the branching structure too: while in Git branches are just pointers, in Unity Version Control branches are containers. Unity Version Control versions directories and files identifying them with "item ids" which is good for move/rename tracking, while Git relies on diffs to rebuild the renames/moves and doesn't version directories.[15]

Interoperability with other version control systems

Git

Unity Version Control can interoperate with Git in the following ways:

  • GitSync: Every Unity Version Control client can push and pull from a Git repository.[16]
  • GitServer: A Unity Version Control server can act as a Git server, so any git client can push/pull to a Unity Version Control server.
  • Fast-import/export support: Fast-export and fast-import commands are available to export Unity Version Control repositories to Git intermediate format and import from Git intermediate format.[17]

Perforce

Unity Version Control can do bi-directional sync with Perforce depots to ease migration[18]

Other version controls

Import/export from other systems is achieved through Git's fast-import/export format.

Availability, release cycle and supported platforms

Unity Version Control is available to download from the Unity Cloud Dashboard[19] or plasticscm.com.[20] Major releases are published yearly as pre-built executables for Microsoft Windows, Mac OS X, and Linux.[21]

Minor releases are available on a weekly basis.

Licensing and terms of use

Unity Version Control is free for individuals (Personal Edition), non-profit organizations and open-source projects (Community Edition).[citation needed]

Cloud Edition is a commercial version for teams that do not need an on-premise server. Customers pay per active monthly user and cloud storage. The subscription includes all the Unity Version Control software.

Enterprise Edition is a commercial version for teams over 15 users, typically used by corporations. It can be purchased in perpetual edition mode or with a monthly or annual subscription.[22]

History

Codice Software started in August 2005 backed by an angel investor and the founders.[23] The goal was to create a version control stronger than SVN in branching and merging and more affordable for SME than the commercial alternatives available at the time. In October 2006, they released the first version of Plastic SCM and was officially presented in Tech Ed 2006 in Barcelona.[24][25]

In 2007, Codice was the first Spanish SME to achieve CMMI L2 using SCRUM.[26]

Plastic SCM was featured by Novell as one of the companies using Mono commercially.[27]

Plastic SCM 2.0 was launched in March 2008.[28]

In 2009, Codice secures its first round of VC backed by Bullnet Capital, a Spanish firm specializing in tech companies.[29]

Plastic SCM was a Jolt Award finalist in the Change and Configuration Management category, announced in December 2008.[30]

Plastic SCM 3.0 was launched in July 2010[31] and it featured Xdiff/Xmerge: their first approach to track moved code in diffs and merges.

In December 2010, Plastic SCM announces "method history", a feature that allows the user to calculate the history of a given method/function instead of the history of a full file.[32]

In 2011, Francisco Monteverde joined the company as CEO while Pablo Santos, founder, was appointed as CTO and President of the board.[33]

Plastic SCM 4.0 was launched on November 23, 2011[34][35] and introduced a major change in the internal design: versioning and merge tracked was moved from a per-file approach to a per-changeset approach, which helped improving later Git-interop.[36]

Since 4.0, Plastic started to be more oriented toward game development, specially considering the weaknesses of Git in terms of big repositories and files.[37]

Version 4.1 was launched in April 2012.[38]

In 2013, Codice launches SemanticMerge, a tool that diffs and merges based on code structure and not text.[39] The technology was later integrated inside Plastic. Semantic builds on top of the previous work done on the Xdiff/Xmerge tool. Later that year Semantic added Java support to complement the initial .NET offering.[40] Pablo Santos introduced cross-file diff and merge detection in QCon 2013 in San Francisco.[41]

In 2013, Plastic SCM started natively supporting the Git network protocol, which virtually converts any Plastic installation into a Git client.[42]

Plastic SCM 5.0 is launched in September 2013.[43] It features built-in semantic diff, refactor detection[44] and method history.[45] Other features are path based security, client changelists and improved cloaked rules.

Version 5.4 later expands some of these features and add a few more: encrypted servers, JavaCLI (a Java client to support HP-UX and Solaris scripting), multi-core file upload and download, Plastic Gluon (developed in collaboration with Telltale [46]), a GUI for artists in game development, WAN optimized data transfer, submodules, transformable workspaces. Plastic 5.4 evolves as Plastic's primary version and in December 2014 a new native GUI for Linux is launched replacing the previous cross-platform one.[47] 5.4 includes a new native MacOS GUI too.

In January 2016, Plastic Cloud was launched as a cloud repo hosting system.[48]

In March 2016, Plastic Cloud Edition was launched, a new version designed for teams who do not need an on-premise server.[49]

Version 6.0 was finally released in January 2017.[50] It features a new data storage system called Jet, full backward compatibility up to 5.0 and floating licenses support. 6.0 continues evolving during 2017.

Plastic SCM 7.0 was launched in March 2018[51] including a new Branch Explorer design, new web-based administration interface, and improvements in MacOS and Linux GUIs.

The mergebots feature was launched in September 2018. Mergebots are a way to implement DevOps with server-side agents that detect when branches have to be merged after testing them on a CI system.[52] Plastic SCM 8.0 was released in January 2019.

On August 17 2020, it was revealed that Unity Technologies, the creators of the game engine Unity, had acquired Codice Software.[53][54]

See also

Notes

  1. ^ "Unity Version Control". Archived from the original on July 16, 2024. Retrieved August 2, 2024.
  2. ^ XDIFF AND XMERGE
  3. ^ WebUI: redesigned web interface for Plastic
  4. ^ webadmin – introducing the new server admin tool
  5. ^ mergeMachine
  6. ^ Branch Explorer
  7. ^ SECURITY
  8. ^ Semantic Version Control
  9. ^ TRIGGERS GUIDE
  10. ^ Optimized network channel for high latency
  11. ^ Gluon: Version Control for Artists
  12. ^ PLASTIC SCM ADMINISTRATOR'S GUIDE: Chapter 7: Configuring exclusive checkout (Lock)
  13. ^ The story of Jet: Plastic's super-fast repo storage
  14. ^ Plastic SCM – DVCS at Enterprise Level
  15. ^ Plastic SCM vs Git — 2018 edition
  16. ^ GitSync for Plastic SCM with Native Git Protocols and Visual Studio 2012 Support
  17. ^ PLASTIC SCM HIGHLIGHTS FOR GIT USERS
  18. ^ [reference: https://www.plasticscm.com/perforce Plastic SCM for Perforce teams]
  19. ^ "Get started with Unity Version Control via the Desktop Client". docs.unity.com. Archived from the original on April 15, 2024. Retrieved 2024-08-02.
  20. ^ "Plastic SCM - Download Plastic SCM". www.plasticscm.com. Archived from the original on July 10, 2024. Retrieved 2024-08-02.
  21. ^ Miguel de Icaza on Plastic SCM UI on Linux and Mac OS X
  22. ^ Major PlasticSCM Updates
  23. ^ LinkedIn: Pablo Santos
  24. ^ SIMO 2006
  25. ^ Plastic SCM – DVCS at Enterprise Level Plastic SCM – DVCS at Enterprise Level
  26. ^ Codice Software shows off new SCM tool
  27. ^ Companies using Mono
  28. ^ Plastic SCM 2.0 set for parallel development projects
  29. ^ Innova.- La entidad de capital riesgo Bullnet Capital entra en el accionariado de la vallisoletana Códice Software
  30. ^ Embarcadero products are Jolt Award finalists in several categories
  31. ^ Codice includes XMerge/XDiff 2.0 in Plastic SCM release
  32. ^ Announcing the method history
  33. ^ Francisco Monteverde se convierte en el nuevo CEO de Códice Software
  34. ^ Plastic SCM 4.0 Launch: new features in Plastic SCM 4.0 by Pablo Santos
  35. ^ Codice Software Launches Plastic SCM 4.0; Challenges Git and Perforce in DVCS
  36. ^ Plastic internals: de 3.0 a 4.0
  37. ^ Codice Software Unveils Plastic SCM 4.0 for Game Development, Successful Collaboration With Digital Legends Entertainment
  38. ^ Plastic SCM Pays Attention to Detail in Source Code Management
  39. ^ A Merge Tool that Understands Functions
  40. ^ Codice Add Java Support to their Code-Aware Merging Tool
  41. ^ InfoQ - QCon San Francisco 2013 - Refactoring in the DVCS Age - Enter Semantic Merge
  42. ^ GitSync for Plastic SCM with Native Git Protocols and Visual Studio 2012 Support
  43. ^ Two new Plastic SCM versions are out today
  44. ^ Semantic Version Control
  45. ^ Plastic SCM features
  46. ^ How Telltale Games handles version control
  47. ^ Native Linux GUI – gtkplastic
  48. ^ Plastic Cloud is now out!
  49. ^ Plastic SCM Cloud Edition
  50. ^ Release 6.0.16.804
  51. ^ Release 7.0.16.2047
  52. ^ Add a mergebot to your repo!
  53. ^ "Unity acquires Codice Software to manage 3D workflows". VentureBeat. 2020-08-17. Retrieved 2020-08-17.
  54. ^ Barton, Seth (2020-08-17). "Unity acquires Plastic SCM developer Codice Software | Development News". MCV/DEVELOP. Retrieved 2020-08-17.

References