MacTech Network:   MacForge.net  |  Computer Memory  |  Register Domains  |  Printer Supplies  |  Cables  |  iPod Deals  |  Mac Deals  |  Mac Book Shelf


  MacTech Magazine

The journal of Macintosh technology

 
 
MacTech Magazine: Now for all geeks at heart.

Magazine In Print
  About MacTech  
  Home Page  
  Subscribe  
  Archives DVD  
  Submit News  
  Submit a Tip!  
  Get a copy of MacTech RISK FREE  
Google
Entire Web
mactech.com
Mac Community
More...
MacTech Central
  by Category  
  by Company  
  by Product  
MacTech News
  MacTech News  
  Previous News  
  MacTech RSS  
Article Archives
  Show Indices  
  by Volume  
  by Author  
  Source Code FTP  
Inside MacTech
  Writer's Kit  
  Editorial Staff  
  Editorial Calendar  
  Back Issues  
  Advertising  
Contact Us
  Customer Service  
  MacTech Store  
  Legal/Disclaimers  
  Webmaster Feedback  
ADVERTISEMENT
Click Here
Volume Number:11
Issue Number:9
Column Tag:Symantec Top 10

Symantec Top 10

This monthly column, written by Symantec’s Technical Support Engineers, aims to provide you with technical information based on the use of Symantec products.

By Steve Howard

Note: Source code files accompanying article are located on MacTech CD-ROM or source code disks.

Q: What is MacApp?

A: MacApp is an object-oriented application framework from Apple Computer. Although MacApp has many similarities with the THINK Class Library, it is larger, more complex, and more modular in design. This flexibility has made it a popular tool in the Macintosh Programming community and has been used for programs like Adobe Photoshop, and RayDream Designer.

Q: What versions of MacApp are supported by the Symantec Project Manager?

A: The earliest supported MacApp version is 3.1.1. We recommend version 3.1.3 (distributed on ETO 17) because the examples and code will work without modification. MacApp 3.3a1, also on ETO 17, is a prerelease of the next major version and is basically the same as MacApp 3.1.3 except it adds support for AOCE, scriptability, and the Drag Manager.

Q: Where can I get MacApp?

A: Symantec has licensed MacApp from Apple and has included it on SDA #3. All non SDA customers must get MacApp from Apple Computer by purchasing it through APDA, as part of MPWPro or an ETO subscription. To order MacApp call APDA at 1-800-282-2732.

Q: What are the system requirements to install and run MacApp?

A: The Symantec C/C++ for MPW folder with the associated electronic documentation will require approximately 22MB of hard disk space. The latest MPW (3.3.1) will require 3.6MB and the prebuilt MacApp 3.1.3 system on the ETO CD-ROM takes up another 20MB. You’re looking at about 56MB of disk space that you’ll need free.

Both MacApp versions come with a project model for Symantec C++ for Power Macintosh which, by using the Symantec Project Manager frees developers from having to utilize the MPW shell. The Symantec C++ for Power Macintosh full installation folder requires 44.8MB of disk space which, added to the requirements of the prebuilt MacApp 3.1.3 system makes the free disk space needed 63MB. This requirement can be reduced by using the alternate installation of the Symantec C++ for Power Mac 8.0.

Apple recommends that you use a Macintosh system with at least 24MB of RAM for developing MacApp applications. Symantec recommends that the minimum partition for the Symantec Project Manager be 8000K with the preferred size being 12000K. You may want to increase the preferred sizes of the partitions depending on the size of the application you are developing.

Q: Are there any installation subtleties I need to be aware of?

A: To run MacApp 3.3a1 under the Symantec Project Manager there are a few changes you will need to make. You will have to install Drag.h and the AOCE headers and AOCE library. The process to install these are outlined in the Release notes provided on both SDA #3 and ETO #17.

There are also two errors in MacApp 3.3a1 that you will need to correct to compile with the Symantec Project Manager. In the file UDebugView.cp you will need to move the #if qDebug that is before the TDebugFlagsView class definition (around line number 92) to the top of the file, so it is before the first Include. Also in the file UGridView.cp, following the DoFulfillPromise member function (around line 2460), you will need to change #endif qDrag to #endif //qDrag. Both these files can be found in the libraries folder within the MacApp3.3a1 - HD Ready folder.

Be sure to read the Release notes and readmes provided with either SDA #3 or ETO #17. They provide information that is essential to you being able to successfully develop with MacApp and the Symantec Project Manager.

Q: What is SMrC/Cpp ?

A: It is the PowerPC compiler for MPW. It is compatible with MrC/Cpp. You can build MacApp with SMrCpp, instead of using MrCpp. As of ETO #17, you may have to rename the SMrCpp to MrCpp to trick MABuild to use SMrCpp for build. Then you would just use MABuild -cp MrC ......

Q: I want to weak link a shared library (e.g. QuickDrawGXLib.xcoff) to a project because I want my application to run even if the shared library is not present. How do I do this?

A: Bring your project up to date and double click on the shared library in your project window. (If you did not update the project before you double click on the shared library you will get an error “Could not complete the last command because the AppleEvent was not handled. Error = -1708”). Turn on the “Soft Import Binding” radio button. In this case your program should take care not to call any non-existent routine in the shared library.

Q: I am precompiling my header files and am getting the following build error:

File “TextUtils.h”; Line 311; While compiling “Mac #includes.c” Error: ‘stringtonum’ previously declared as something else

It was declared as: void C func(char const *, long *)

It is now declared as: void C func(char *, long *)

A: Go into the header file BDC.h in the 2.0a4 Universal Headers folder that you copied from the Symantec C++ for Power Macintosh CD-ROM and change the following code:

 #ifdef CGLUESUPPORTED // defined in 2.0a4 or later
 void stringtonum(const char *theString, long *theNum);
 #else
 void stringtonum(const char *theString, long *theNum ); 
    #endif
         to:
 #ifdef CGLUESUPPORTED // defined in 2.0a4 or later
 void stringtonum(const char *theString, long *theNum);
 #else
 void stringtonum(char *theString, long *theNum );
 #endif

This is only a problem with the newer version of BDC.h that comes with universal headers 2.0a4

Q: Why are the structs in my PowerPC project a different size from those in my 68K project?

A: By default, the PowerPC compilers align fields within structs to 4-byte boundaries. The 68K C++ compiler, by default, will align the fields within structs to 2-byte boundaries. THINK C will always align fields within structs to 2-byte boundaries. 68000 chips must reference word or long values from even addresses. Therefore, the 68000 chip requires, at least, 2-byte alignment. More recent 680x0 chips do not have this limitation, but perform faster when referencing word or long values from even addresses. The 68040 and PowerPC chips perform even faster with structures aligned to 4-byte boundaries.

If you need to share data structures in memory between 68K and PowerPC code, or need to read or write a data structure from/to disk with both 68K and PowerPC code, you will need to enable the same type of alignment in both your 68K and PowerPC projects.

Q: I’ve heard that Symantec is going to make the THINK Reference compiler available to developers so they can create their own databases. When is that going to be available?

A: The THINK Reference compiler is not ready to be released to the developer population as of yet. If you are interested in becoming a beta tester for the THINK Reference compiler you can contact us here at technical support by email at: support@devtools.symantec.com or by calling: (503)465-8470 and we will be able to start the necessary processes to get you in our beta testing program.

Special thanks to Michael Hopkins, Yuen Li, and Kevin Quah.



Click here to find out more about our best subscription bundle deal ever!
2 years of the magazine, and the all new MacTech DVD ... at 70% off!



Click on the cover to
see this month's issue!

TRIAL SUBSCRIPTION
Get a RISK-FREE subscription to the only technical Mac magazine!
 
 


MacTech Magazine. www.mactech.com
Toll Free 877-MACTECH, Outside US/Canada: 805-494-9797

Register Low Cost (ok dirt cheap!) Domain Names in the MacTech Domain Store. As low as $1.99!
Save on brand compatible and name brank ink jet and laser supplies.
Save on long distance * Upgrade your Computer
Movies with No Late Fees!

See local info about Westlake Village
SJ * BRJ * BJ * OJ * NITS
Staff Site Links



All contents are Copyright 1984-2007 by Xplain Corporation. All rights reserved.

MacTech is a registered trademark of Xplain Corporation. Xplain, Video Depot, Movie Depot, Palm OS Depot, Explain It, MacDev, MacDev-1, THINK Reference, NetProfessional, NetProLive, JavaTech, WebTech, BeTech, LinuxTech, Apple Expo, MacTech Central and the MacTutorMan are trademarks or service marks of Xplain Corporation. Sprocket is a registered trademark of eSprocket Corporation. Other trademarks and copyrights appearing in this printing or software remain the property of their respective holders.