Open Source Cloud Authors: Elizabeth White, Yeshim Deniz, Pat Romanski, Liz McMillan, Zakia Bouachraoui

Related Topics: Open Source Cloud, Linux Containers

Open Source Cloud: Article

The Best of Both Worlds

Debugging Linux/Unix code using Windows XP software development tools

For your convenience comments on how to use this technology under other conditions are included in this section. The Web page that will be used is named RemoteDebugging.html. It's given in Listing 1. Note that only standard HTML tags constitute a page that's usable with most Web servers these days. If you use a remote server you'll need a special page (or special fields on the page) with a logon ID and password and/or other means of authentication that will be automatically filled out with the required credentials in a way similar to other fields that are used in a form. Please see the details below on how the form will be filled out. Security issues related to authentication are a huge topic that's far beyond the scope of this article. If you are new to security, a good place to start is to google the Internet and read the book on secure coding listed in the resources. You'll get many other security references from it.

The Web page with its needed permissions will be put in the appropriate directory of the Web server. If you use the Apache server that comes with Fedora Core 5 with the standard configuration, the directory will be /var/www/html. You may want to read your Web server documentation on where HTML pages should be put if you use other Web servers in Fedora Core 5 or if you use a remote Web server. In the case of a remote Web server you'll need server administration assistance if you're not allowed to ftp (or otherwise submit) the Web page in question to the server and give it appropriate permissions.

The Perl script that will do the job described above is called RemoteCompilation.pl. It's given in Listing 2. With the standard Apache in Fedora Core 5 it should be put under /var/www/cgi-bin. Note that in this case files that are produced by scripts from /var/www/cgi-bin have an owner named apache that belongs to a group with the same name. You may want to issue the command: chown [your user name goes here]:apache RemoteCompilation.pl after you create the script to be able to edit the script and run it. You must replace [your user name goes here] with your Fedora Core 5 user name. Then you'll have to issue the command: chmod 775 RemoteCompilation.pl (or set up permissions with another appropriate tool like Konqueror). Of course you should have enough authority to run these commands. In case of a remote server (or a server other than the Apache under Fedora Core 5) you'll have to read the documentation to figure out what the name of needed group is. If a remote server is used, you'll likely have to contact server administration to figure out what the appropriate permissions for the script are and how to set it up since security is involved here.

Note that with a remote server, the appropriate code for authentication checking must be used just after print start_html in the script (or implement separate software for this purpose). Only standard Perl constructions are used in the script so it's possible to use the script with almost any current Web server. First, the script checks if a standard output of your compiler exists (in the example it's a file called a.out) and deletes it. The script also deletes an auxiliary file named err.txt that will be described below.

After that it reads the code for debugging from the appropriate parameter and the file name for the code from another parameter and writes the code to the file with this name to the server. Chunks of 512 bytes are used for writing. If host operating system and/or compilers require it, you should then insert a statement for changing the file permissions. The needed compiler will be called by the script using the file in question as well as another special auxiliary file with possible errors called err.txt to which any errors produced by the compiler should be redirected.

In our example Intel Fortran for Linux is used. But the same technology can be applied to any other needed compiler. If you use other compilers you'll have to read the documentation and adjust the script accordingly (particularly the statement that calls the compiler). In our case, redirection is provided by 2>err.txt in the corresponding statement. In case of other compilers figure out from the documentation how to provide the redirection. Note that the script files are written in the directory in which the script is located. In the case of a remote server you have to contact server administration to figure out the appropriate directory. Then the script checks if a.out (the default name for the executable file with this compiler) is produced, which means that the compilation is OK. The check is done using a pipeline of ls and grep. If the compilation is OK, the user will see a corresponding message in the browser. If compilation failed (i.e., a.out isn't produced) the script will read each line from err.txt and display it in the browser. Note that in this case the HTML
tag will be added to the end of the line. With other compilers you may want to use another condition to determine whether or not compilation is OK. The condition can be found by reading the documentation.

The application that calls the browser with the page in question from your XP software development tool is given in Listing 3. The name of the .exe file obtained with the source code in Listing 3 is DebuggingUnderLinux.exe. If you use VS.NET 2005 to compile the source, a System.Windows.Forms reference should be added to the "Console application" type of the project. The DebuggingUnderLinux.exe in our example is placed under C:\G77Start, but you can use any directory. Note that in the example the application calls FireFox from a specific location, but you can easily adjust it to any browser with any needed location. If you use FireFox, it should be closed before the application runs again.

The application is called from the tool by the menu, hot keys, etc. and obtains from the caller 2 parameters: the name of the file that contains the code and the path to the directory where the file is located. Most modern software development tools allow these two parameters to be passed via a customizable configuration (please see the examples below). Consider the following popular software development tools under Windows XP: VS.NET 2005 and Crimson from www.crimsoneditor.com. The example of the configuration to be used with the application from VS.NET 2005 is given in Figure 1 and the one from Crimson is given in Figure 2. As soon as configuration is made you can debug the needed code with these tools simply by clicking the hot keys of your choice (CTRL+3). If you use Crimson select Tools | Debugging under Linux. If you use VS.NET 2005 you can use any name for this command and assign hot keys to it. Note that with a remote server, the URL of the Web page used in the application will be given to you by server administration.

If you use VMware workstation 5 or 5.5 for virtualization and Fedora Core 5 as the guest operating system, the URL can be obtained by the following means. Within the Fedora Core 5 terminal window, issue an ifconfig command. Locate "inet addr" in eth0. It will be part of the url. In this example the part in question is and this value is used in the application. You need to obtain the value in question using ifconfig and adjust the application accordingly.

Please refer to Listing 3 on how to get the URL using the part.

To test of the example of this technology you can use dwhet.f (an application for performance measurement from my Web site at www.myjavaserver.com/~akrivitsky/G77.html. (You may want to read my article in JDJ at http://jdj.sys-con.com/read/83099.htm on the subject.) First use it "as is." You will see a "Complilation OK" message in your browser. Then introduce an error by typing "error" anywhere in the code. You'll see a corresponding error message in the browser.

What We Just Did
This example shows you how by simple and therefore effective means (a Web page, a Perl script, and an application) you can debug Linux or Unix code with Windows XP software development tools. In other words, we can run the compiler under another operating system and get the results back to Windows XP with the proposed technology.

Homework for Manufactures
This example offers a solution that fits the needs of many developers. However, it can be polished further by IDE manufactures and included in their products. Here's how. After obtaining results in the browser one sends the following commands to the browser window: CTRL+A to select all the text in the window, CTRL+C to copy the selection to the clipboard, and ALT+F4 to close the window. See Listing 3 on how to send commands to the browser window. Then you can grab the text from the clipboard to your IDE and deal with it in exactly the same way as output from your native IDE compiler for the convenience of your user. The user will be able to get additional help on errors, and get to the line with the error by clicking the corresponding error message. So by using this approach you can give your IDE additional multi-operating system capabilities.


  • M.G. Graff and K.R. van Wyk. Secure coding: Principles and Practices. O'Reilly and Associates. 2003. ISBN 0-596-00242-4.
  • My Web site has useful information on the subject www.myjavaserver.com/~akrivitsky.
  • More Stories By Anatoly Krivitsky

    Anatoly Krivitsky has a PhD in computer science and has more than 24 years of working experience in the IT field. He's the author of 20 published papers and books and five patents. For more information, please visit http://www.myjavaserver.com/~akrivitsky/index.html.

    Comments (1) View Comments

    Share your thoughts on this story.

    Add your comment
    You must be signed in to add a comment. Sign-in | Register

    In accordance with our Comment Policy, we encourage comments that are on topic, relevant and to-the-point. We will remove comments that include profanity, personal attacks, racial slurs, threats of violence, or other inappropriate material that violates our Terms and Conditions, and will block users who make repeated violations. We ask all readers to expect diversity of opinion and to treat one another with dignity and respect.

    Most Recent Comments
    Linux News Desk 10/23/06 05:27:56 PM EDT

    These days the size of almost all the resources available to a programmer (memory volume, CPU speed, etc.) are on the rise except for one: the time required to complete a project, which is shrinking. So it's important to work with tools that are convenient and make you productive. It's also important to keep the cost of software development in check by keeping as much as possible of the investments that were already made.

    IoT & Smart Cities Stories
    Digital Transformation and Disruption, Amazon Style - What You Can Learn. Chris Kocher is a co-founder of Grey Heron, a management and strategic marketing consulting firm. He has 25+ years in both strategic and hands-on operating experience helping executives and investors build revenues and shareholder value. He has consulted with over 130 companies on innovating with new business models, product strategies and monetization. Chris has held management positions at HP and Symantec in addition to ...
    Dynatrace is an application performance management software company with products for the information technology departments and digital business owners of medium and large businesses. Building the Future of Monitoring with Artificial Intelligence. Today we can collect lots and lots of performance data. We build beautiful dashboards and even have fancy query languages to access and transform the data. Still performance data is a secret language only a couple of people understand. The more busine...
    The challenges of aggregating data from consumer-oriented devices, such as wearable technologies and smart thermostats, are fairly well-understood. However, there are a new set of challenges for IoT devices that generate megabytes or gigabytes of data per second. Certainly, the infrastructure will have to change, as those volumes of data will likely overwhelm the available bandwidth for aggregating the data into a central repository. Ochandarena discusses a whole new way to think about your next...
    CloudEXPO | DevOpsSUMMIT | DXWorldEXPO are the world's most influential, independent events where Cloud Computing was coined and where technology buyers and vendors meet to experience and discuss the big picture of Digital Transformation and all of the strategies, tactics, and tools they need to realize their goals. Sponsors of DXWorldEXPO | CloudEXPO benefit from unmatched branding, profile building and lead generation opportunities.
    All in Mobile is a place where we continually maximize their impact by fostering understanding, empathy, insights, creativity and joy. They believe that a truly useful and desirable mobile app doesn't need the brightest idea or the most advanced technology. A great product begins with understanding people. It's easy to think that customers will love your app, but can you justify it? They make sure your final app is something that users truly want and need. The only way to do this is by ...
    DXWorldEXPO LLC announced today that Big Data Federation to Exhibit at the 22nd International CloudEXPO, colocated with DevOpsSUMMIT and DXWorldEXPO, November 12-13, 2018 in New York City. Big Data Federation, Inc. develops and applies artificial intelligence to predict financial and economic events that matter. The company uncovers patterns and precise drivers of performance and outcomes with the aid of machine-learning algorithms, big data, and fundamental analysis. Their products are deployed...
    Cell networks have the advantage of long-range communications, reaching an estimated 90% of the world. But cell networks such as 2G, 3G and LTE consume lots of power and were designed for connecting people. They are not optimized for low- or battery-powered devices or for IoT applications with infrequently transmitted data. Cell IoT modules that support narrow-band IoT and 4G cell networks will enable cell connectivity, device management, and app enablement for low-power wide-area network IoT. B...
    The hierarchical architecture that distributes "compute" within the network specially at the edge can enable new services by harnessing emerging technologies. But Edge-Compute comes at increased cost that needs to be managed and potentially augmented by creative architecture solutions as there will always a catching-up with the capacity demands. Processing power in smartphones has enhanced YoY and there is increasingly spare compute capacity that can be potentially pooled. Uber has successfully ...
    SYS-CON Events announced today that CrowdReviews.com has been named “Media Sponsor” of SYS-CON's 22nd International Cloud Expo, which will take place on June 5–7, 2018, at the Javits Center in New York City, NY. CrowdReviews.com is a transparent online platform for determining which products and services are the best based on the opinion of the crowd. The crowd consists of Internet users that have experienced products and services first-hand and have an interest in letting other potential buye...
    When talking IoT we often focus on the devices, the sensors, the hardware itself. The new smart appliances, the new smart or self-driving cars (which are amalgamations of many ‘things'). When we are looking at the world of IoT, we should take a step back, look at the big picture. What value are these devices providing. IoT is not about the devices, its about the data consumed and generated. The devices are tools, mechanisms, conduits. This paper discusses the considerations when dealing with the...