TweetFollow Us on Twitter

Dec 96 Factory Floor
Volume Number:12
Issue Number:12
Column Tag:From The Factory Floor

Marcel Achim, Pascal Reanimator

By Dave Mark, ©1996 by Metrowerks, Inc., all rights reserved.

This month’s Factory Floor interview is with Marcel Achim, the heart and soul of Metrowerks Pascal efforts. As Neil never tires of reminding me, Pascal is alive and well and, in one publisher’s opinion, still a wonderful language.

Dave: How did you hook up with Metrowerks?

Marcel: I was recruited on the university campus by the then VP of Research who was teaching there. I became involved in an underway project, the development of a Modula-2 compiler running on various UNIX boxes built on MIPS chips. That was my introduction to the fascinating world of compilation. I started by writing library code and translating interfaces from C to Modula-2, then I moved on to porting the compiler to the different vendor boxes, figuring out their idiosyncrasies.

Dave: Were you doing this work in Pascal? If not, when did you bring Pascal and Metrowerks together?

Marcel: The MIPS compilers used a frontend/backend architecture with the backend being proprietary which caused some problems. That led to our need to develop a compiler technology where we could hold rights both on the frontend and backend. At the same time we started another project on the Macintosh to provide a Pascal compiler along with tutorial and teaching material for Macmillan. That compiler was built around the Modula-2 package available then. So the new technology was meant to provide a solution for multiple frontends and multiple backends, and was supposed to be the replacement for these versions of Pascal and Modula-2. The chosen architecture was a derivative from the Oberon architecture developed in Zurich by Nicklaus Wirth’s team and was first targeted to the SPARC platform. I then implemented Pascal and Modula-2 on SPARC using that architecture. We then stopped the development of UNIX compilers and I inherited the Macintosh compilers where I unified the Pascal and Modula-2 code generators. Around this time it was decided that we needed a C compiler, the PowerPC was in the air and we received in the mail a terrific demo from Andreas. [To hear more about Andreas’s story, check back a few issues for the interview with Andreas Hommel.]

Dave: How did the Pascal compiler make the leap to CodeWarrior?

Marcel: At this point, we had a 68K C compiler with optimizations, a split frontend/backend design. Pascal is very strong in the developer community (still today FileMaker Pro is mostly written in Pascal and is built with CodeWarrior). CodeWarrior alone would only be Metrowerks C and wouldn’t provide the broader industrial completeness and strength that we wanted to provide. So we dropped the architecture used on the SPARC, which still didn’t support optimizations, and I got the Pascal frontend development plus backend/linker modifications, interfaces, libraries and utilities. DR/1 was to ship in January with the scheduled launch of the first Power Macintoshes. In the mean time, I dropped my Masters and stopped teaching. I was giving lectures at the university for the past few months along with working on my Masters and working part-time on Metrowerks compilers.

MPW Pascal was the chosen dialect because it’s the de facto standard Pascal dialect on Macintosh. THINK Pascal wasn’t supported and relates heavily to MPW Pascal except for a few minor differences. The biggest problem involved in developing CodeWarrior Pascal was the universal interfaces. Since Apple decided not to support Pascal anymore, the new interfaces developed for the introduction of the PowerPC were made, keeping the PowerPC calling conventions in mind and making use of C’s syntactic capabilities (for example, the CONST keyword is meant to specify an invariant pointer parameter and doesn’t have a Pascal equivalent).

The change from 68K to PPC calling conventions was dramatic for Pascal as the passing of value records and arrays are not the same. There were two possibilities: either support the 68K calling conventions on the PowerPC (thus breaking the calling conventions adopted for all languages, which were inherited from IBM’s AIX machines and provide a seamless common way of doing cross-language, cross-vendor routine calls) or modify the interfaces to render the expected parameter passing. The 68K conventions pass every record and array bigger than 4 bytes by passing a pointer. The PowerPC passes value records into registers and on the stack, and all arrays by pointer regardless of the size. To be able to match both PowerPC and 68K conventions with the same set of interfaces could have been achieved by using a new parameter passing method using the CONST keyword that would have the semantics of a value parameter and an efficient passing implementation. This solution wasn’t taken because it would have broken some compilers. The retained solution was to use VAR parameters because they force the use of pointers, but it has the drawback of breaking some user code, especially in the case of packed arrays and records.

The other problem encountered on the PowerPC is the signatures. They are packed arrays of 4 chars, so they’d have to be passed by pointer. But their C equivalent is an unsigned long, thus value not pointers. To get this to work I had to introduce on PowerPC an UNSIGNEDLONG data type that’s compatible with packed arrays of 4 chars so OSTYPE can be used without problems. After 2 years of use, this solution to the Universal Interfaces problem has proven to be the right one. Another conclusion that comes up is the need to add a procedural data type to Pascal. The new data type enables the compiler to do type checking on the callback routines that get passed either to user code or the toolbox. This type checking capability has proven to be very effective in the porting of code from 68K to PowerPC.

Dave: So at this point, we have the first CodeWarrior IDE with Pascal and C/C++. Since plugins weren’t introduced till CW6/7, how did the Pascal compiler work?

Marcel: The first releases of CodeWarrior didn’t used the plugins architecture but a common IDE was always in the air as the cornerstone of CodeWarrior. The new PowerPC machines had more resources and made such a design more interesting for an entire IDE. So along with the C/C++ compiler, the Pascal compiler was compiled and linked along with the IDE sources. It wasn’t that the Macintoshes were too slow or the resources poor, it was just that it wasn’t the way to do things. People knew about their machine constraints and didn’t go for blue sky, so the applications were kind of in scale with the hardware capabilities. Now that we have faster and bigger machines it is possible to add on facilities to the programs and these added facilities eat up not only disk space but also memory. So having the ability to load on demand various parts of a program has been around almost as long as computers. It’s the way of doing it that changes over time and across platforms.

Dave: Can You talk about the difference between the C++ “value model” and Object Pascal’s “reference” model?

Marcel: The object model is the underlying runtime model that affects the aspect and behavior of objects. In Object Pascal the object model used is known as the reference model because you have to explicitly invoke the creation and deletion of objects. On the other hand, C++ and Turbo Pascal use the value model which involves far more complex semantics for manipulating objects. People often mix method binding with the object model. This accounts for some misconceptions. In Object Pascal, the language only allows compile time binding determination for ‘inherited’ method calls. All the other methods can be overridden, thus forcing late binding which can be changed by a clever linker for monomorphic methods (methods that are never overridden within the program).

In C++, member functions need the ‘virtual’ keyword to specify polymorphism, thus helping the compiler decide how to perform the method call. (It gets more complicated when multiple inheritance is involved.) This binding facility is partially lifted by the introduction of procedural types in CodeWarrior Pascal, but still has to be hand constructed along with the data fields when the object gets created. The difference between object models comes to light when you look at the copy semantics. In Object Pascal, assigning one object to another, passing it as a value parameter or returning one as a function result doesn’t create a new instance as in C++ (and associated copy constructors) or as in Turbo Pascal (bug prone object casting), but only copies a reference. In Object Pascal cloning an object requires a method call and is explicit. This greatly simplifies the complexity of the program without limiting the functionality.

Dave: What are some of the differences between CodeWarrior Object Pascal and other dialects of Object Pascal?

Marcel: There are as many Pascal dialects as there are vendors. One of the biggest contenders is Turbo Pascal. The differences can be categorized into three fields; runtime support (mostly IO and platform specific stuff), the enhanced syntax, and finally the class and object models. We’ve already discussed the object model. The most apparent IO difference between Object Pascal and Turbo Pascal is TP’s assign routine, which binds a logical file to a physical file. Under Object Pascal this is performed directly by the opening routines.

The other IO differences lie in file access semantics, mostly for the handling of binary files. The original Pascal’s (and also the ANS standard) way of dealing with them is using get/put and direct file access thru the caret operator ‘file^’. The object support is very different. OP implements a very simple syntax that hasn’t evolved in about 10 years, whereas TP went through a constant evolution of their implementation. This is clearly an area where we have to expand OP’s capabilities because it really represents an advantage to programmers to have a more flexible implementation.

Dave: What are you working on now?

Marcel: My group is currently working on a Windows version of CodeWarrior Pascal. We are also developing a tool that will automate the use of C precompiled headers within Pascal as Pascal support is more and more lacking within Apple and nonexistent on Windows.

Dave: What do see in the future for yourself and for Pascal?

Marcel: I think in the near future we’re going to see some kind of reevaluation of project development using C/C++ as metrics, and studies are going to circulate. I think that there could be some kind of backlash toward Pascal and Ada if the figures show that C/C++ didn’t deliver the expected results. As far as Pascal goes, from the market share perspectives, Pascal is a player in the academic market as most attempts to move to C and C++ didn’t work very well.

On the other hand, in software engineering things are different. Pascal would have to evolve much faster to meet today’s software engineering needs and standardize on a wide variety of platforms. Even then I’m not too sure about the prospects. As for me, I’m linked to Pascal as I want to evolve CodeWarrior’s implementation of Object Pascal to be a player in both the Macintosh and Windows Pascal market.

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

BetterTouchTool 1.84 - Customize Multi-T...
BetterTouchTool adds many new, fully customizable gestures to the Magic Mouse, Multi-Touch MacBook trackpad, and Magic Trackpad. These gestures are customizable: Magic Mouse: Pinch in / out (zoom... Read more
Dropbox 8.4.21 - Cloud backup and synchr...
Dropbox is an application that creates a special Finder folder that automatically syncs online and between your computers. It allows you to both backup files and keep them up-to-date between systems... Read more
OmniGraffle Pro 6.6.1 - Create diagrams,...
OmniGraffle Pro helps you draw beautiful diagrams, family trees, flow charts, org charts, layouts, and (mathematically speaking) any other directed or non-directed graphs. We've had people use... Read more
OmniGraffle 6.6.1 - Create diagrams, flo...
OmniGraffle helps you draw beautiful diagrams, family trees, flow charts, org charts, layouts, and (mathematically speaking) any other directed or non-directed graphs. We've had people use Graffle to... Read more
f.lux 37.7 - Adjusts the color of your d...
f.lux makes the color of your computer's display adapt to the time of day, warm at night and like sunlight during the day. Ever notice how people texting at night have that eerie blue glow? Or wake... Read more
BBEdit 11.6.1 - Powerful text and HTML e...
BBEdit is the leading professional HTML and text editor for the Mac. Specifically crafted in response to the needs of Web authors and software developers, this award-winning product provides a... Read more
ScreenFlow 6.1 - Create screen recording...
ScreenFlow is powerful, easy-to-use screencasting software for the Mac. With ScreenFlow you can record the contents of your entire monitor while also capturing your video camera, microphone and your... Read more
Microsoft Office 2016 15.25 - Popular pr...
Microsoft Office 2016 - Unmistakably Office, designed for Mac. The new versions of Word, Excel, PowerPoint, Outlook and OneNote provide the best of both worlds for Mac users - the familiar Office... Read more
FileZilla 3.21.0 - Fast and reliable FTP...
FileZilla (ported from Windows) is a fast and reliable FTP client and server with lots of useful features and an intuitive interface. Version 3.21.0: Fixed Vulnerabilities Fixed a string format... Read more
Fantastical 2.2.5 - Create calendar even...
Fantastical 2 is the Mac calendar you'll actually enjoy using. Creating an event with Fantastical is quick, easy, and fun: Open Fantastical with a single click or keystroke Type in your event... Read more

Pokemon GO update: Take me to your leade...
The Team Leaders in Pokemon GO have had it pretty easy up until now. They show up when players reach level 5, make their cases for joining their respective teams, and that's pretty much it. Light work, as Floyd Mayweather might say. [Read more] | Read more »
Ruismaker FM (Music)
Ruismaker FM 1.0 Device: iOS Universal Category: Music Price: $4.99, Version: 1.0 (iTunes) Description: Following up on the success of Ruismaker, here's her crazy twin-sister, designed for people who want to design their own... | Read more »
Space Marshals 2 (Games)
Space Marshals 2 1.0.15 Device: iOS iPhone Category: Games Price: $5.99, Version: 1.0.15 (iTunes) Description: The sci-fi wild west adventure in outer space continues with Space Marshals 2. This tactical top-down shooter puts you in... | Read more »
Dungeon Warfare (Games)
Dungeon Warfare 1.0 Device: iOS Universal Category: Games Price: $3.99, Version: 1.0 (iTunes) Description: Dungeon Warfare is a challenging tower defense game where you become a dungeon lord to defend your dungeon against greedy... | Read more »
Solitairica (Games)
Solitairica 1.0.7 Device: iOS Universal Category: Games Price: $3.99, Version: 1.0.7 (iTunes) Description: Solitairica takes RPG combat and challenging rogue-like progression to a fresh new place—the world of solitaire! | Read more »
Bowmasters tips, tricks and hints
At least for this writer, archery was one of the more pleasant surprises of the 2016 Rio Olympics. As opposed to target shooting with guns, which was dreadfully boring, watching people shoot arrows at targets was pretty darn cool. [Read more] | Read more »
Best apps for watching live TV
The Olympics have come and gone, leaving nearly everyone in a temporary state of "What the heck am I going to watch on TV right now?" Besides old reruns of Golden Girls, but that goes without saying. [Read more] | Read more »
What is Flip Diving, and why has it take...
Move over Pokemon GO. There's a new king in town, and it's "the world's #1 cliff diving game." [Read more] | Read more »
5 places where Pokemon GO is still numbe...
In the U.S., the bloom is off the Pokemon Go rose ever so slightly. It's still doing great, sitting atop the top grossing chart as it has for some time, but it's no longer among the top 10 free apps in downloads, possibly because darn near... | Read more »
Madden NFL Mobile: How defense has chang...
Saying that defense is not a priority in Madden NFL Mobile is a bit of an understatement. In asynchronous head-to-head play, you don't take control of your defenders at all, as the AI manages them while your opponent plays offense. When it's your... | Read more »

Price Scanner via MacPrices.net

Apple refurbished 13-inch MacBook Airs availa...
Apple has Certified Refurbished 2016 and 2015 13″ MacBook Airs now available starting at $849. An Apple one-year warranty is included with each MacBook, and shipping is free: - 2016 13″ 1.6GHz/8GB/... Read more
Apple refurbished iPad mini 2s available for...
Apple is offering Certified Refurbished iPad mini 2s for up to $80 off the cost of new minis. An Apple one-year warranty is included with each model, and shipping is free: - 16GB iPad mini 2 WiFi: $... Read more
Save up to $600 with Apple refurbished Mac Pr...
Apple has Certified Refurbished Mac Pros available for up to $600 off the cost of new models. An Apple one-year warranty is included with each Mac Pro, and shipping is free. The following... Read more
Mac Pros on sale for $200 off MSRP
B&H Photo has Mac Pros on sale for $200 off MSRP. Shipping is free, and B&H charges sales tax in NY only: - 3.7GHz 4-core Mac Pro: $2799, $200 off MSRP - 3.5GHz 6-core Mac Pro: $3799, $200... Read more
Will We See A 10.5″ iPad Pro in 2017? – The ‘...
A MacRumors report, cites a research note from KGI Securities analyst Ming-Chi Kuo, saying a new size iPad model is in the works. According to the highly respected Cho, who has a strong track record... Read more
IOGEAR USB-C Docking Station Transforms Lapto...
IOGEAR has announced the launch of its innovative USB-C Docking Station with Power Delivery which turns USB-C enabled laptops into desktop workstations. The new IOGEAR USB-C Docking Station features... Read more
12-inch Retina MacBooks on sale for up to $10...
Amazon has 2016 12″ Apple Retina MacBooks on sale for $100 off MSRP. Shipping is free: - 12″ 1.1GHz Space Gray Retina MacBook: $1199 $100 off MSRP - 12″ 1.1GHz Silver Retina MacBook: $1224.99 $75 off... Read more
13-inch 2.5GHz MacBook Pro (Apple refurbished...
Apple has Certified Refurbished 13″ 2.5GHz MacBook Pros available for $829, or $270 off the cost of new models. Apple’s one-year warranty is standard, and shipping is free: - 13″ 2.5GHz MacBook Pros... Read more
21-inch iMacs on sale for up to $120 off MSRP
B&H Photo has 21″ iMacs on sale for up to $120 off MSRP including free shipping plus NY sales tax only: - 21″ 3.1GHz iMac 4K: $1379 $120 off MSRP - 21″ 2.8GHz iMac: $1199.99 $100 off MSRP - 21″ 1... Read more
Typinator 6.10 comes with 50 improvements – G...
Ergonis Software today announced release of Typinator 6.10, a new version of their text expander utility for macOS. Typinator 6.10 comes with 50 improvements, including new features, compatibility... Read more

Jobs Board

*Apple* Mobile Master - Best Buy (United Sta...
What does a Best Buy Apple Mobile Master do? At Best Buy, our mission is to leverage the unique talents and passions of our employees to inspire, delight, and enrich Read more
*Apple* Retail - Multiple Positions Akron, O...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
Simply Mac *Apple* Specialist- Repair Techn...
…The Technician is a master at working with our customers to diagnose and repair Apple devices in a manner that exceeds the expectations set forth by Apple Read more
*Apple* Retail - Multiple Positions Germanto...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
*Apple* Professional Learning Specialist - A...
# Apple Professional Learning Specialist Job Number: 51234379 Portland, Maine, Maine, United States Posted: Aug. 18, 2016 Weekly Hours: 40.00 **Job Summary** The Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.