From 9b3367922d6040557c31aa7b2df7fdc2adbdc0e7 Mon Sep 17 00:00:00 2001 From: Tim Mackinnon Date: Tue, 20 Jun 2017 17:22:34 +0100 Subject: [PATCH 1/4] Update README.md The api for loading a package seems to have changed --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 1e0b983ebd..e59c2e9133 100644 --- a/README.md +++ b/README.md @@ -190,7 +190,7 @@ myRepository createBranch: 'newBranchName' ### Load a package from a repository ```Smalltalk -myRepository loadPackage: 'Package-Name' +(myRepository packageNamed: 'Package-Name') loadLatest. ``` ### Update packages From a03609232ce523f077ca2121714ef474cdfac41c Mon Sep 17 00:00:00 2001 From: Serge Stinckwich Date: Mon, 3 Jul 2017 17:19:41 +0100 Subject: [PATCH 2/4] Restore README.md from 0.4 version --- README.md | 88 ++++++++++++++++++++++++++++++++----------------------- 1 file changed, 51 insertions(+), 37 deletions(-) diff --git a/README.md b/README.md index e71e46f6aa..e57f297896 100644 --- a/README.md +++ b/README.md @@ -9,6 +9,7 @@ To better understand Iceberg (or even this documentation), I recommend to read t ### Prerequisites - Latest Pharo 6.0 image. - Latest Pharo VM. + - **IMPORTANT FOR LINUX USERS:** For Pharo6, you need a special VM (it will be default for Pharo7), the "threaded hearbeat VM". You can download it by executing `curl get.pharo.org/vmT60 | bash`. - NO LONGER NEEDED (Just for testing iceberg itself): Git v1.9.1 or later. ### Install Iceberg @@ -17,7 +18,7 @@ We are in active development and too many things have changed, until we release ```Smalltalk Metacello new baseline: 'Iceberg'; - repository: 'github://pharo-vcs/iceberg:dev-0.4'; + repository: 'github://pharo-vcs/iceberg'; load. ``` @@ -39,33 +40,30 @@ Iceberg update - Open the *Repositories Browser*, you can find on Pharo menu under 'Tools' or just type 'Iceberg' in Spotter. Normally you will see something like this: - ![image](https://cloud.githubusercontent.com/assets/4633913/20836463/b9398eac-b89f-11e6-92c7-d0f6ed785c83.png) + ![image](https://cloud.githubusercontent.com/assets/513630/25996638/9316c4fe-3718-11e7-91a6-dd2e1e5168bd.png) - But if it is the first time you use Iceberg you might be looking at this: - - ![image](https://cloud.githubusercontent.com/assets/4633913/20835889/3a2c2914-b89d-11e6-96fa-c0ba1f16041b.png) + But if it is the first time you use Iceberg you might be looking at an empty list. So let's add a repository. -- The easiest way to create a new repository is by clicking on 'Clone new Repository'. You will see this dialog: +- The easiest way to create a new repository is by clicking on 'Clone repository'. You will see this dialog: - ![image](https://cloud.githubusercontent.com/assets/4633913/20840028/27e57712-b8af-11e6-8b20-76c674afe21d.png) + ![image](https://cloud.githubusercontent.com/assets/513630/25996645/9a441b3c-3718-11e7-95ea-8e7c71b91ece.png) - - Remote URL: This is the url we should use to clone your github project, it should be something like `git@github.com:pharo-vcs/iceberg.git` or `https://github.com/pharo-vcs/iceberg.git`. + - Remote URL: This is the url we should use to clone your github project, it should be something like `git@github.com:pharo-vcs/iceberg.git` or `https://github.com/pharo-vcs/iceberg.git` (**IMPORTANT:** HTTPS is not recommended for the moment, since it has problems with getting credentials. See [FAQ](#FAQ) section). > **Tip:** If you do not know it, you can get it from github, look for the green "Clone or Download" button. - Local directory: You can just leave the default location for a start. - - Code subdirectory: You should provide the name of a subdirectory inside of your repository inside which your code lies. Usual options are `mc` or `repository`. Leaving it empty means that the code is in the root of your repository, this is a valid choice too. + - Code subdirectory: You should provide the name of a subdirectory inside of your repository inside which your code lies. Usual options are `src`, `mc` or `repository`. Leaving it empty means that the code is in the root of your repository, this is a valid choice too. - Click on 'Create repository', then you should see a new entry in the repositories browser. ### Add packages to your repository - If your repository is new, you should add some packages to it. - First create a Pharo package in the usual way, it should have at least one class, and the class should have at least one method. - - Then open the repositories browser and select your repository. - - In the bottom right panel you will see the current packages in your repository. + - Then open the repositories browser, select your repository and click on the "Packages" tab. - Click on 'Add package' and select a package. ### Your first commit @@ -74,30 +72,41 @@ Iceberg update - You should see that your repository name is highlighted in green, and its status changed to 'Uncommited changes'. - From the contextual menu of your repository, select the 'Synchronize Repository' option. (Or you can also double-click on your repository). You should see something like this: - ![image](https://cloud.githubusercontent.com/assets/4633913/20836730/eaf72804-b8a0-11e6-8f01-10a6ca25d41e.png) + ![image](https://cloud.githubusercontent.com/assets/513630/25996648/9cf5d442-3718-11e7-9f4d-fdb598c51f1e.png) On the top-left panel, you will see all changes to the packages stored in the repository, by selecting a method on the changes tree you will see the differences in the bottom panel. - > **Please be aware that current Iceberg version has a bug and shows your version in red, while the original version is shown in green.**. - - From the contextual menu of the tree, you can also *revert* a change, or *browse* the changed method/class. - If you make more changes after opening the synchronize view, you have to click on *Refresh tree* to see the new changes. - After you are comfortable with your you can commit. - First enter a suitable message in the top right panel, under 'Commit changes'. - Then click on the 'Commit' button. - - By default Iceberg will try to immediately *push* your commits to your remote repository. If you do not want that you can uncheck the 'Upload changes on commit' option. If you do so, your changes will be saved only in the local repository, and you can push them later. + - You can choose to just *commit* your changes or *commit and push*. There will be buttons available for both options. + +## FAQ + +Q. Image seems freeze when doing a clone of a repository. +A. This is because operation is taking time and Iceberg still does not shows feedback properly. You just need to be patient :) + +Q. Image freezes when cloning/commiting and there is nothing I can do to fix it. I used HTTPS protocol to do the clone. +A. There is a known bug around HTTPS and the get of credentials. We will fix this, but while waiting for the fix, you can workaround the problem by: +- Adding your credentials **before** doing any operation (go to `System Settings/Tools/Software Configuration Management/Iceberg/Plain credentials`) +- Just using SSH protocol (but that option is not so easy on Windows). - - Whenever you decide to push your commits, Iceberg will require your github credentials. Currently Iceberg (in its default configuration) can not use SSH keys to connect to github, so you will have to provide your github user and password. +Q. I installed iceberg and try to clone a project, but I'm getting "LGit_GIT_ERROR no ssh-agent suitable credentials found" error message. +A. For the moment, iceberg SSH support for iceberg just handles SSH/ssh-agent. You can fix this problem two ways: +- In command line, run this: `ssh-add ~/.ssh/id_rsa` (macOS users may prefer to execute this: `ssh-add -K ~/.ssh/id_rsa`) +- Go to iceberg settings `System Settings/Tools/Software Configuration Management/Iceberg/Use custom SSH keys` and add there the path to your `id_rsa.pub` and `id_rsa` files. - > By default, these credentials will be saved to avoid requiring them each time, but **be aware that this is is not a really safe option**. +Q. I'm on linux and when I want to commit I have this message: "LGit_GIT_ERROR: no error message set by libgit2." +A. Iceberg for Pharo6 on Linux requires a different version of the VM than the one that is provided by +default (this **will** be the default on Pharo7). To get this VM, the easiest way is to execute `curl get.pharo.org/vmT60 | bash`. ## Usage ### Repositories Browser The main entry point to Iceberg is the *Repositories Browser*. After installing Iceberg you will see a new entry on Pharo menu, below 'Tools' submenu, called Iceberg, which will open the browser. -![image](https://cloud.githubusercontent.com/assets/4633913/16365789/ac446d00-3c0a-11e6-83e0-976b00cbc0fb.png) - This tool shows you all known Iceberg repositories, allowing you to clone new repositories, import existing local repositories or forget repositories. It it is the main entrance point to every action to a repository, such as - *Synchronize* a repository (see 'Synchronize Repository' section). @@ -130,8 +139,10 @@ Right now this is ths simplest of the three views, you can only push all of your ## Iceberg API ### Creating and retreiving repositories. Example: -``` - myRepo := IceRepository origin: 'git@github.com:pharo-vcs/pharo-git-test.git'. +```Smalltalk +myRepository := IceRepositoryCreator new + url: 'git@github.com:pharo-vcs/pharo-git-test.git'; + createRepository. ``` ### Local storage of a repository @@ -140,44 +151,47 @@ When the repository gets first used, it will create a local clone in your disk. > In the future we would like to avoid having local working copies on disk. If you prefere to do clones at specific locations, you can provide a directory: -``` - myRepo := IceRepository new - origin: 'git@github.com:pharo-vcs/iceberg.git'; - localDirectory: ... absolute or relative path +```Smalltalk +myRepository := IceRepositoryCreator new + url: 'git@github.com:pharo-vcs/iceberg.git'; + location: aFileReference; "... absolute or relative path" + createRepository. ``` Or, if you already have a local repository, you can avoid setting the origin, it will be inferred for you. -``` - myRepo := IceRepository new localDirectory: ... absolute or relative path +```Smalltalk +myRepository := IceRepositoryCreator new + location: aFileReference; "... absolute or relative path" + createRepository. ``` If a local repository already exists at the same location we will get all necessary information from it (for example: remote origin and current checked out branch). ### Manage branches By default repositories will checkout the 'master' branch. If you need to work with another branch you can do: -``` - myRepo checkoutBranch: 'anotherBranch' +```Smalltalk +myRepository checkoutBranch: 'anotherBranch' ``` If you want to create a new branch it is slight different: -``` - myRepo createBranch: 'newBranchName' +```Smalltalk +myRepository createBranch: 'newBranchName' ``` ### Load a package from a repository -``` - myRepo loadPackage: 'Package-Name' +```Smalltalk +myRepository loadPackage: 'Package-Name' ``` ### Update packages -- `myRepo pull` will update all the packages in the repo (that have already been loaded). -- To update an individual package you can write: `myRepo updatePackage: 'Some-Package-Name'` +- `myRepository pull` will update all the packages in the repo (that have already been loaded). +- To update an individual package you can write: `myRepository updatePackage: 'Some-Package-Name'` ### Commit your changes After making some changes, you can use the IceSynchronizer to commit them: -``` +```Smalltalk IceSynchronizer new - changeSet: (IceWorkingCopyDiff forRepository: myRepo); + changeSet: (IceWorkingCopyDiff forRepository: myRepository); openWithSpec. ``` From 035fda65144099d9635696db489d1962e92a95b5 Mon Sep 17 00:00:00 2001 From: Serge Stinckwich Date: Mon, 3 Jul 2017 17:21:54 +0100 Subject: [PATCH 3/4] Move FAQ before 5 min tutorial --- README.md | 38 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/README.md b/README.md index e57f297896..76ecdf5827 100644 --- a/README.md +++ b/README.md @@ -32,6 +32,25 @@ Iceberg update - You don't need this step if you have just downloaded Iceberg. - Update is comfortable, but please note that it is just an **experimental feature**. Building a software that is able to update itself in a 100% safe way is far beyond the scope of the Iceberg project. The safest way is always start with a clean image. +## FAQ + +Q. Image seems freeze when doing a clone of a repository. +A. This is because operation is taking time and Iceberg still does not shows feedback properly. You just need to be patient :) + +Q. Image freezes when cloning/commiting and there is nothing I can do to fix it. I used HTTPS protocol to do the clone. +A. There is a known bug around HTTPS and the get of credentials. We will fix this, but while waiting for the fix, you can workaround the problem by: +- Adding your credentials **before** doing any operation (go to `System Settings/Tools/Software Configuration Management/Iceberg/Plain credentials`) +- Just using SSH protocol (but that option is not so easy on Windows). + +Q. I installed iceberg and try to clone a project, but I'm getting "LGit_GIT_ERROR no ssh-agent suitable credentials found" error message. +A. For the moment, iceberg SSH support for iceberg just handles SSH/ssh-agent. You can fix this problem two ways: +- In command line, run this: `ssh-add ~/.ssh/id_rsa` (macOS users may prefer to execute this: `ssh-add -K ~/.ssh/id_rsa`) +- Go to iceberg settings `System Settings/Tools/Software Configuration Management/Iceberg/Use custom SSH keys` and add there the path to your `id_rsa.pub` and `id_rsa` files. + +Q. I'm on linux and when I want to commit I have this message: "LGit_GIT_ERROR: no error message set by libgit2." +A. Iceberg for Pharo6 on Linux requires a different version of the VM than the one that is provided by +default (this **will** be the default on Pharo7). To get this VM, the easiest way is to execute `curl get.pharo.org/vmT60 | bash`. + ## 5 minutes tutorial ### Clone a repository - Before using Iceberg you should have a git repository. If you do not have one, you can *create* or *fork* one on Github. @@ -84,25 +103,6 @@ Iceberg update - You can choose to just *commit* your changes or *commit and push*. There will be buttons available for both options. -## FAQ - -Q. Image seems freeze when doing a clone of a repository. -A. This is because operation is taking time and Iceberg still does not shows feedback properly. You just need to be patient :) - -Q. Image freezes when cloning/commiting and there is nothing I can do to fix it. I used HTTPS protocol to do the clone. -A. There is a known bug around HTTPS and the get of credentials. We will fix this, but while waiting for the fix, you can workaround the problem by: -- Adding your credentials **before** doing any operation (go to `System Settings/Tools/Software Configuration Management/Iceberg/Plain credentials`) -- Just using SSH protocol (but that option is not so easy on Windows). - -Q. I installed iceberg and try to clone a project, but I'm getting "LGit_GIT_ERROR no ssh-agent suitable credentials found" error message. -A. For the moment, iceberg SSH support for iceberg just handles SSH/ssh-agent. You can fix this problem two ways: -- In command line, run this: `ssh-add ~/.ssh/id_rsa` (macOS users may prefer to execute this: `ssh-add -K ~/.ssh/id_rsa`) -- Go to iceberg settings `System Settings/Tools/Software Configuration Management/Iceberg/Use custom SSH keys` and add there the path to your `id_rsa.pub` and `id_rsa` files. - -Q. I'm on linux and when I want to commit I have this message: "LGit_GIT_ERROR: no error message set by libgit2." -A. Iceberg for Pharo6 on Linux requires a different version of the VM than the one that is provided by -default (this **will** be the default on Pharo7). To get this VM, the easiest way is to execute `curl get.pharo.org/vmT60 | bash`. - ## Usage ### Repositories Browser The main entry point to Iceberg is the *Repositories Browser*. After installing Iceberg you will see a new entry on Pharo menu, below 'Tools' submenu, called Iceberg, which will open the browser. From 883b0f7f904fe5456791d009fd34d74a91715142 Mon Sep 17 00:00:00 2001 From: Cyril Ferlicot Date: Wed, 12 Jul 2017 22:43:40 +0200 Subject: [PATCH 4/4] Add shortcut to open Iceberg. (meta o + meta i). Issue related: https://github.com/pharo-vcs/iceberg/issues/390 --- .../BaselineOfIceberg.class/instance/baseline..st | 6 +++++- .../BaselineOfIceberg.class/instance/resetKMRepository.st | 3 +++ .../IceRepositoriesBrowser.class/class/menuCommandOn..st | 1 + .../instance/openIcebergShortcut.st | 3 +++ Iceberg-UI.package/PharoShortcuts.extension/properties.json | 3 +++ .../ToolShortcutsCategory.extension/instance/openIceberg.st | 4 ++++ .../ToolShortcutsCategory.extension/properties.json | 3 +++ 7 files changed, 22 insertions(+), 1 deletion(-) create mode 100644 BaselineOfIceberg.package/BaselineOfIceberg.class/instance/resetKMRepository.st create mode 100644 Iceberg-UI.package/PharoShortcuts.extension/instance/openIcebergShortcut.st create mode 100644 Iceberg-UI.package/PharoShortcuts.extension/properties.json create mode 100644 Iceberg-UI.package/ToolShortcutsCategory.extension/instance/openIceberg.st create mode 100644 Iceberg-UI.package/ToolShortcutsCategory.extension/properties.json diff --git a/BaselineOfIceberg.package/BaselineOfIceberg.class/instance/baseline..st b/BaselineOfIceberg.package/BaselineOfIceberg.class/instance/baseline..st index 329059f698..e8d7e4ff8d 100644 --- a/BaselineOfIceberg.package/BaselineOfIceberg.class/instance/baseline..st +++ b/BaselineOfIceberg.package/BaselineOfIceberg.class/instance/baseline..st @@ -1,7 +1,11 @@ baseline baseline: spec - spec for: #common do: [ spec + spec for: #common do: [ + + spec postLoadDoIt: #resetKMRepository. + + spec configuration: 'OSSubprocess' with: [ spec versionString: #stable; repository: 'github://marianopeck/OSSubprocess/repository' ]; diff --git a/BaselineOfIceberg.package/BaselineOfIceberg.class/instance/resetKMRepository.st b/BaselineOfIceberg.package/BaselineOfIceberg.class/instance/resetKMRepository.st new file mode 100644 index 0000000000..9137d1335f --- /dev/null +++ b/BaselineOfIceberg.package/BaselineOfIceberg.class/instance/resetKMRepository.st @@ -0,0 +1,3 @@ +script +resetKMRepository + KMRepository reset \ No newline at end of file diff --git a/Iceberg-UI.package/IceRepositoriesBrowser.class/class/menuCommandOn..st b/Iceberg-UI.package/IceRepositoriesBrowser.class/class/menuCommandOn..st index 3ece354a16..34c36ee026 100644 --- a/Iceberg-UI.package/IceRepositoriesBrowser.class/class/menuCommandOn..st +++ b/Iceberg-UI.package/IceRepositoriesBrowser.class/class/menuCommandOn..st @@ -7,4 +7,5 @@ menuCommandOn: aBuilder order: 0.18; icon: self icon; parent: #'Tools'; + keyText: 'o, i'; action: [ self open ]. diff --git a/Iceberg-UI.package/PharoShortcuts.extension/instance/openIcebergShortcut.st b/Iceberg-UI.package/PharoShortcuts.extension/instance/openIcebergShortcut.st new file mode 100644 index 0000000000..b112ca39df --- /dev/null +++ b/Iceberg-UI.package/PharoShortcuts.extension/instance/openIcebergShortcut.st @@ -0,0 +1,3 @@ +*Iceberg-UI +openIcebergShortcut + ^ $o meta, $i meta \ No newline at end of file diff --git a/Iceberg-UI.package/PharoShortcuts.extension/properties.json b/Iceberg-UI.package/PharoShortcuts.extension/properties.json new file mode 100644 index 0000000000..1949e006ad --- /dev/null +++ b/Iceberg-UI.package/PharoShortcuts.extension/properties.json @@ -0,0 +1,3 @@ +{ + "name" : "PharoShortcuts" +} \ No newline at end of file diff --git a/Iceberg-UI.package/ToolShortcutsCategory.extension/instance/openIceberg.st b/Iceberg-UI.package/ToolShortcutsCategory.extension/instance/openIceberg.st new file mode 100644 index 0000000000..ed870a6061 --- /dev/null +++ b/Iceberg-UI.package/ToolShortcutsCategory.extension/instance/openIceberg.st @@ -0,0 +1,4 @@ +*Iceberg-UI +openIceberg + + ^ KMKeymap shortcut: PharoShortcuts current openIcebergShortcut action: [ IceRepositoriesBrowser open ] \ No newline at end of file diff --git a/Iceberg-UI.package/ToolShortcutsCategory.extension/properties.json b/Iceberg-UI.package/ToolShortcutsCategory.extension/properties.json new file mode 100644 index 0000000000..fe55832294 --- /dev/null +++ b/Iceberg-UI.package/ToolShortcutsCategory.extension/properties.json @@ -0,0 +1,3 @@ +{ + "name" : "ToolShortcutsCategory" +} \ No newline at end of file