Tech Articles


Git for a single developer


Let's say you're an independent contractor or a one person shop.  You want to take advantage of the source control features of Git, but you don't want to have to set up a server just for one developer.  Fortunately, you don't have to.  We're going to walk through the steps of connecting PowerBuilder to a local directory based repository.

Step 1.  Create a new folder

Nothing tricky here, just create a new folder to hold the repository.  For this example, I'm going to name it "local_repository"

Step 2.  Create a "bare" Git repository using the new directory.

I'm going to use TortoiseGit here because it's what I'm familiar with, but you can perform the same operation using the Git client command line.

Make sure that you check the option to create a "bare" repository.  If you don't, you won't be able to push to it.  Non-bare repositories are typically working repositories (cloned).  You need a bare repository so that you can push to it.

Step 3.  Create a share for the repository folder

We're going to need to be able to access the repository using a network reference, so we need to create a network share.

Step 4.  Connect the PowerBuilder workspace to Git

Remember that the repository won't come into play until we attempt to push.  For now, the connection to Git is just to a local working repository that PowerBuilder creates for it's own use

Select "Add to Source Control" from the RMB menu on the workspace

Select Git as the source control system to connect to

Provide a name and email address that Git will associated to your code changes

Do the initial commit of your PowerBuilder code to the local working repository

Step 5:  Push and configure the connection to the bare repository

From the workspace RMB, select Git Push

Here's the step where the bare repository comes in.  You'll be prompted for a Git login.  Instead of a http or https url reference, provide a network share reference (e.g., \\server_name\share_name).  In this example I'm connecting to a folder on the same machine, so I'm using localhost for the server name.  Provide at least a User ID, and then hit "Test Connection" to ensure you've configured it correctly.  Then press OK.

 

You should see the locally committed source code pushed to the bare repository.

At this point you can do all the same operations with the bare repository that you would with a Git server.   However, TortoiseGit (which is a client application) isn't set up to perform operations such as creating branches.   For that, you'll need to use the git command line.  For an example of how to do that, and for a good overall introduction to the git command line, see https://githowto.com/creating_a_branch

 

 

 

 

Comments (1)
Friday, Mar 26 2021

Nice article, thanks Bruce !

0

Find Articles by Tag

SVN Source Control Windows OS SqlExecutor TLS/SSL API Elevate Conference Export JSON Messagging CoderObject UI Themes UI Modernization ActiveX WebBrowser PBVM Mobile Transaction Debug JSON PDFlib Debugger Charts .NET Assembly Sort Model Jenkins JSONGenerator DragDrop Automated Testing Android CI/CD PDF REST COM OrcaScript Open Source NativePDF Source Code HTTPClient InfoMaker Design DataType PowerServer Web Repository OLE TreeView .NET Std Framework Interface JSONParser GhostScript PowerBuilder Compiler Variable Import JSON Database Table Data IDE PowerBuilder Graph TFS Database Profile OAuth 2.0 SOAP Syntax Database Table Schema Error WinAPI PowerBuilder (Appeon) Excel PowerServer Mobile Web API Configuration DevOps TortoiseGit Window Bug SQL Data Validation Encoding RibbonBar Debugging Resize Installation C# PBNI RibbonBar Builder SDK Stored Procedure MessageBox Expression DataWindow JSON File .NET DataStore License SnapObjects Git Database Table SQL Server Application DataWindow Class Platform UI CrypterObject Event Handler Migration Database BLOB Visual Studio Menu PostgreSQL ODBC driver Windows 10 Icons Database Object Database Connection Event Handling PFC Outlook Trial Array Testing Oracle Authentication SnapDevelop PBDOM OAuth Import External Functions RichTextEdit Control PostgreSQL Performance Export Icon Service Text XML Event Web Service Proxy Azure Script ODBC Authorization Deployment DLL Filter Encryption Branch & Merge RESTClient SqlModelMapper Database Painter PowerScript (PS) 64-bit Linux OS 32-bit iOS