Tech Articles
- Details
- Written by Bruce Armstrong
- Category: PowerBuilder
- Hits: 6495
Support for using Git as a source control system without going through a bridge product was added in 2017 R2 and covered in a previous blog post. In this blog post we're going to look at the enhancements that were added to that feature in 2017 R3.
- Details
- Written by David Lacey
- Category: PowerBuilder
- Hits: 3420
In SQL Server it is generally a good idea to use temporary tables, rather than table variables within your stored procedures. Temporary tables perform much better, particularly with large volumes of data, as SQL Server is able to compile statistics on the data in temporary tables. However, if you are calling your stored procedures from a Powerbuilder application, you may find that the switch to temporary tables has an unwanted side effect. Here is how the unwanted side effect comes around and what to do about it.
- Details
- Written by Alfredo Aldama
- Category: PowerBuilder
- Hits: 8155
Con los nuevos sistemas una de las cosas que hoy en día escuchamos es: tenemos un web services donde puedes consultar…
Por lo que ante esta necesidad y teniendo un sistema desarrollado originalmente en powerbuilder 6.5 ( les traigo esta solución.
Un “consumer” de WS REST
Para hacer este ejemplo utilizaremos objetos no visuales, principalmente el objeto internetresult.
- Details
- Written by Bruce Armstrong
- Category: PowerBuilder
- Hits: 2542
Up through Windows XP, if you wanted to get the physical location of certain defined folders (e.g. the users Documents folder), you would use the SHGetFolderPath function in the Windows API. Roland Smith has examples of using that on his Topwiz Software site. That function continues to work in later versions of Windows, although it's basically a wrapper for the SHGetKnownFolderPath function.
SHGetFolderPath uses CSIDL values, whereas SHGetKnownFolderPath uses KnownFolderID GUIDs. One difference is that there are a lot more KnownFolderIDs than there are CSIDLs. That means some of the defined folder locations you may want to get the physical location for can't be accessed through the older SHGetFolderPath method. And that's exactly the situation I ran into.
I needed to find the user's Downloads folder, and there isn't a CSIDL value for that. So, I needed to see how to call the SHGetKnownFolderPath function from PowerBuilder. As with many OLE and Windows API calls, it can save you a lot of time if you can find some Visual Basic code that does what you need to do, and you can convert the syntax. And fortunately, I found some that did this.
- Details
- Written by Michael Kramer
- Category: PowerBuilder
- Hits: 2632
This article describes how you can emulate C# style enumeration types in PowerScript since PowerScript currently does not support creation of custom enumerations. Personally, I found myself in need of such enumerations when interfacing to Microsoft Word/Excel using OLE Automation.
Calls to Word or Excel functions without enumerated values (or named constants) are incredibly hard to read and understand. An example:
oleDocument.Selection.Move( 10, 2)
oleDocument.Selection.Move( 12, 4)
Using C# style enumerations, the same code could read like this:
oleDocument.Selection.Move( wdUnits.Row, 2)
oleDocument.Selection.Move( wdUnits.Cell, 4)
- Details
- Written by Alfredo Aldama
- Category: PowerBuilder
- Hits: 2540
- Insertar un breakpoint.- Ejecute la opción de menú principal: Edit/ Insert BreakPoint
- Requisito: Debes estar en el editor de código (script) .
- Inicializar el depurador. Ejecute la opción de menú principal: Run / Debug nombre de su aplicación
- Ejecute la opción Debug / Start nombre de su aplicación
- Ejecutar línea por línea.- F8
- Detener el depurador.- Debug/Stop
- Ver el contenido de una variable.—Seleccione la variable, dar click derecho y escoger la opción quickwatch
- Requisito: Debe estar ejecutándose la aplicación en modo de depuración
Truco: Algunas veces tenemos un error en tiempo de ejecución que nos hace que Powerbuilder se cierre, para localizar en donde ocurre esto la opción Depurar en tiempo de ejecución ayuda mucho.