Download presentation
Presentation is loading. Please wait.
Published byAubrey Brooks Modified over 9 years ago
1
CodeBreaker Decentralized, cooperative and flexible support for extreme programming software development Nelson Baloian Roberto Konow Francisco Claude Mitsuji Matsumoto
2
The Problem Juanita Pedro
3
* Extreme Programming *
4
Program as fast as you can Simple Designs Pair Programming Small Releases Beta testing Team Communication
5
Available Technologies Version Control Systems CVS Subversion Etc... Collaborative Environments IBM Rational ClearCase TUKAN File Level permissions Central Repository Synchronous/Asynchronous Central/Distributed Repository Expensive Many Developers
6
“Breaking” The code A.java String sint d Method zMethod y
7
“Breaking” The code A.java String sint d B.java Method zMethod y Method HMethod v
8
Logical Locking Every File, Class, Method or Logical Object must have an owner. Every Logical Object is locked to everyone except the owner. The locking is done over a name of a class or interface, a method inside a class or a class variable. (Fine Grained Locking) Automatically locking the inherited classes of a locked class. (Extended classes, Implementation of Interfaces, etc) It is possible to lock code which still not exists
9
“Breaking” The code
10
Coordination Rules The Coordination Rules are necessary to maintain the development in order. Code ownership can be transferred with or without permit to transfer to a third New members can be created with or without right or limited number to invite others, This can implement a kind of “administrator role” Two kind of Files: Accepted Java Files The “final” and revised java files. Temporary Java Files Files being changed by another users.
11
Exceptions to the rules What happens when the hard disk of a code- owner crushes forever ? Change ownership by voting Define creator of the project as administrator What if a user start not cooperating ? Does not confirm code change ownership Starts distributing code which does not owns Introduce public and private keys
12
Coordination Rules Participant “Pedro” is not available. Participant “Juanita” Needs to modify something in the definition file of Object E.
13
Coordination Rules “Juanita” Changes part of the code in object E. A Temporary Java File is created.
14
Coordination Rules “Pedro” goes online and receives the changes made by “juanita”. “Pedro” can Accept or Reject the changes made.
15
Coordination Rules “Pedro” accepts the changes and the modified java file is now an “accepted java file”.
16
Requirements Work on a peer-to-peer architecture without having a central repository. Allow synchronous and asynchronous collaborative working (including synchronization of the code). Allow the inclusion of new unforeseen participants. Allow fine grained and logical oriented locking of code.
17
* File System Architecture * Accepted Java Files : This layer contains the Java files with that where accepted by their owner. It is used to create distributions of the software, giving an alternative to build a patched version also, including code that has not been accepted yet. The files are stored as normal java files of a NetBeans project. Temporary Files : Those are the copy made for every java file containing modifications which are still not approved by the owner of the code XML Files : There is an XML for every Java file containing the information about the owner, permissions and information needed for the merging phase. The Simulated File System: Is the logical layer that manages the logical access to the physical files and presents the information about which part of the code is owned by which user and whether the local code has been approved or released by the owner. For this, it uses the information stored in the XML files. It also implements a transparent file system for the user merging the temporary files with the accepted ones when corresponds.
18
* The XML File * name : The name of the entity. owner : user that owns this object. rev : the version of this object, incrementing in one for every modification made or accepted by the owner. modified : a boolean variable that allows to know if a certain object has been modified by a user that has not the rights. umod : user that modified the file without permission. uver : the version created by the user that is making the modifications without owning the object itself. srcid : a description of the object that allows to distinguish for example two methods with the same name but different arguments. type : if the object is a variable, method, class, etc.
19
class Test { // fields... // methods... }....... Java File XML File Transform... The Variables owner, srcid, user modification and user version are assigned in the xml file, including all the java source file information.
20
Synchronization JXTA/email/pen drive XML FILE
21
....... XML File 2....... XML File 1 Compare......... XML Transfer File PRODUCEPRODUCE
22
Types of Differences: Modification: Changes in the source code or the owner. DeleteClass: Deletes a Class DeleteMethod: Deletes a Method Delete Field: Deletes a Field NewMethod: Creates a new Method NewField: Creates a new Field NewClass Creates a new Class XML Transfer File
23
Scenarios of usage Development of Extreme Programming Projects with small teams. Development of small Spontaneous Ideas outside the working area. (i.e: Coffee Break) Development of medium-sized projects without having a fixed development team and a fixed physical work area. (small student-owned software developing enterprises) Support for development teams where members are constantly changing roles. Collaborative learning tool for Java courses.
24
Conclusions CodeBreaker is: Synchronized/Asynchronized development tool Fine-grained and logical blocking of the code Support for Extreme Programming teams Support for Pair-Programming. Controlled permissions of the code for the developers with flexibility for special cases. Peer-to-peer Network Easy to install and use (Netbeans plugin)
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.