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

 
 
MacRentals

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:10
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 Noah Lieberman and Andy McFarland, Symantec Technical Support

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

Q: I want to use QuickDraw 3D in my application. Is there anything special that I need to do to use it with Symantec C++ for the Power Macintosh?

A: Yes. There are some slight changes that must made to the interfaces and sample projects. We have a patch kit available that will allow you to use our compiler and has sample projects for all of the demos. You must also make sure that you have the QuickDraw GX headers. QuickDraw 3D interfaces and libraries are avilable from Apple as part of their MacOS SDK subscription.

Q: I have some binary data that was written with a MSDOS program that I want to read into my Macintosh program, but the numbers are all messed up. Why?

A: The two systems save numbers differently. The Motorola processors use big-endian numbers, and the Intel processor machines use little-endian numbers. There is a difference in how numbers are stored in memory and on the disk. For example, the long hexadecimal value $12345678 would be stored by an Intel processor as $34127856.

To convert a number as you read it into a Macintosh, you can use the following C code:

        long    longVal = ReadALong(srcFile); // read a long from the       // file
        char    *cp = (char*) &longVal;
        char    temp;

        temp = cp[0];
        cp[0] = cp[1];
        cp[1] = temp;

        temp = cp[2];
        cp[2] = cp[3];
        cp[3] = temp;

Of course, if you are real ambitious, the assembly code is MUCH simpler and faster:

        MOVE.L  longVal,D0
        ROR.W   #8,D0
        SWAP    D0
        ROR.W   #8,D0
        SWAP    D0
        MOVE.L  D0,longVal

So you could define the code like this for 68K:

 #pragma parameter __D0 Little2BigEndian(__D0)
 pascal long Little2BigEndian(long val) = {
        0xE058,         // ROR.W    #8,D0
        0x4840,         // SWAP     D0
        0xE058,         // ROR.W    #8,D0
        0x4840          // SWAP     D0
        };

        long  longVal =   Little2BigEndian(ReadALong(srcFile));

Q: I am using SPM 8.0.x and have created an array of 50 elements. However, when I look at the array in the debugger only the first 25 elements are displayed (0-24) in the data window. Is there now a limit to the number of array elements that can be displayed in the data window and if so, how do I view the values in the latter elements of my array?

A: There is an option in the SPM debugger, under the data menu, to set the array bounds. The default setting is 25 elements, starting from element 0 and ending with element 24. The upper limit of the array bounds is 32767 elements (0-32766) that can be displayed and you can display any subset of your array by setting the starting element (lower bounds) and the number of elements you want to display (display range).

Q: I am getting Undefined MyClassName::_VTBL what does it mean?

A: This is caused by declaring a function in the header file but not defining it in the source file.

Q: Is there any way to change the order in which code is compiled in the Symantec Project Manager?

A: You can set the “Save Project as Script” script to save the project as a script, physically change the lines in the script to reflect the desired build order, and then rebuild the project using the script.

Q: I have a 7.0.x VA application that I want to port to PowerPC, but if I open it with 8.0 and click the convert button in the conversion dialog, I am getting compiler and linker errors. Are there any alternate methods for updating to PPC?

A: Yes. Usually most of these errors are due to the lack of neccessary libraries. Create a new VA app with 8.0, and add your source files and VA Resource. This way the 8.0 VA project model will add the basic libraries for you.

Q: My code works fine on 68k but its crashing on PowerPC.

A: The PPC forces 4 byte struct alignment, which can often cause problem when converting from 68k. There is a pragma you can use to get around this problem:

 #if defined(powerc) || defined (__powerc)
 #pragma options align = mac68k
 #endif
 struct myRecord
 {
 OSType theOSType;
 unsigned short  theSize;
 };
 #if defined(powerc) || defined(__powerc)
 #pragma options align = reset
 #endif

Q: When I call x80told it sets the 8 bytes following the long double to 0.

example:

 void main()
 {
 long double   ld1, ld2;
 extended80 x80;

 ld2 = 131.416726;
 ldtox80(&ld2, &x80);
 x80told(&x80, &ld1);//when this is called, ld2 is set to 0
 } 

A: Apple’s MathLib expects true long doubles which are 16 bytes. You can get around this by passing an array of long double (i.e. long double ld1[2]).

Here is an example:

 void main()
 {
 long double   ld1[2], ld2;
 extended80 x80;

 ld2 = 131.416726;
 ldtox80(&ld2, &x80);
 x80told(&x80, ld1); // by passing the array, ld2 maintains it            // value
 }

Q: I rebuilt my PPCAnsi.o file with gla_alloc.c, but when I try and compile my project with this new file I get the error: “PPCANSI: specified file not recognized as a valid object”.

A: The Toolserver may not be installed on your Hard Disk. If this is the case you need to copy the toolserver folder from the Symantec C++ CD, and place an alias of Toolserver in your (Tools) folder.

Another possibility is that the modifications were made to the Shared Library PPCAnsi project instead of the Static Library project. gla_alloc.c needs to be added to the PPCAnsi_xcoff.Π project found in the Headers and Source folder in your Standard Libraries folder.

Q: I want to put a CStyleText into my view in VA, but there isn’t a tool for it in the tool palette.

A: Choose Classes from the edit menu. Enter the name of your new class (i.e. CMyStyleText) that will be derived from CStyleText. Choose CEditText from the Base Class: popup menu. Enter CStyleText into the Library Class: box; CMyStyleText will now be derived from CStyleText. Now use the Panorama tool from the tool palette to place a pane into your view. Select the pane, go to the Class submenu under the pane menu and select CMyStyleText.

Note: Normally the Library Class: box is for a class you have already derived from the Base Class, but this also works with other TCL classes as long as they are derived from the Base Class. For more info see p. 30-8 in the 8.0 User’s Guide, or p. 241 in the 7.0 Visual Architect and THINK Class Library Guide.

Special Thanks to Michael Hopkins, Craig Conner, Mark Baldwin, Scott Morison, Levi Brown, Steve Howard, Kevin Quah, Glenn Austin.



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.