Join GitHub today
GitHub is home to over 20 million developers working together to host and review code, manage projects, and build software together.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Smallsource is a smalltalk project about managing source code. Since Smalltalk is manages source in an image, it often is a problem to interact with source code management systems. To use it, take a Pharo-1.3 image and just load MonticelloFileTree. Open a monticello browser and select a package. +Repository has a new menu item called "file tree"; select any directory on your PC. Save the package there. You should see a directory <package name>.tree in the directory after you saved. The GemStone-Extensions package contains the gemstone hacks to make it work in GLASS. What this code currently does, is to add a new kind of Monticello repository, called a file tree. If you add such repository, you will be able to save a monticello package there. The package will be saved as files. You can also load code from this kind of repository. Browse differences works. I'll list the things that do not work as issues :-). The mapping is as follows: <Package Name>.tree is a directory in which the package is saved <Package Name>.tree/version is the version file <Package Name>.tree/package is the original package file, (can be "constructed on the fly" I suppose) <Package Name>.tree/initializers contains all the class initializers code <Package Name>.tree/<Class Name> a directory for the class definition and the instance methods <Package Name>.tree/<Class Name>/<Class Name> definition for the class name <Package Name>.tree/<Class Name>/<selector> instance side method definition <Package Name>.tree/<Class Name>/encoded slash / is the only method that does not work out of the box. stupid name to use, I know <Package Name>.tree/<Class Name>_class directory with class side methods <Package Name>.tree/<Class Name>_class/<selector> a class method Here are some ideas: 1. If we have a file mapping to Smalltalk source, we can manage the source in external source code management systems, such as git or mercurial. 2. We must somehow interoperate with Monticello and Metacello to be able to interchangeably work with the loads of Smalltalk code out there. 3. In order to properly interact with source code management systems, we need to write proper, but specific tools for these systems in order to use them from a Smalltalk environment. This stuff has been done on a Pharo-1.3 image More to follow... What would you like to see here?