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

 
 
Surround SCM 5

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:9
Issue Number:8
Column Tag:Think Top 10

Think Top 10

By Scott Shurr, THINK Technical Support, Symantec Corp.

This is the first installment of a monthly column written by Symantec's Technical Support Engineers intended to provide you with ingormation on Symantec products. This month we answer some of the most frequently asked questions about THINK C 6.0 and Symantec C++ for Macintosh.

Q. How closely does Symantec C++ conform to the language described in The Annotated C++ Reference Manual (ARM) by Margaret A. Ellis and Bjarne Stroustrup?

A. Symantec C++ is AT&T CFront 3.0 compliant, and conforms to the ARM in all respects except for exception handling, which has not yet been implemented.

Q. Will libraries built with THINK C 5.0 work under Symantec C++?

A. The libraries themselves will, for the most part, work as expected. There are a couple of points to keep in mind though. The C++ compiler uses 4-byte integers and native floating point format, so if your library uses variables declared int (which are 2-bytes in THINK C but 4-bytes in Symantec C++) or floating point (float, double, long double, extended) then you should rebuild it with THINK C 6.0 using these settings or port it to C++. The other thing to keep in mind is that C and C++ use different calling conventions, so you will need to modify your header files to contain a C linkage specification for the prototypes. A typical sequence is:

 #if __cplusplus
 extern "C" {
 #endif
 //  
 // Your prototypes go here
 //  
 #if __cplusplus
 }
 #endif

Take a look at one of the standard library header files if you want to see this mechanism in action.

Q. How do you convert THINK Class Library projects from 5.x to 6.0? To C++?

A. The safest way to do the conversion is to start with the 6.0 Starter application: the TCL 1.1.3 sources all have the file extension .cp (with the exception of a handfull with .asm), so you can’t just bring your existing 5.0 TCL project over and expect it to build. By using the Starter app you get the right extension mappings and options at no cost (other than adding and segmenting your sources). For a THINK C based TCL project, you should have .c, .asm, and .cp all mapped to the THINK C translator. If you want to build your existing TCL application using C++, then you can add the files to the C++ based Starter app, and change the extension mapping for .c from THINK C to Symantec C++. This is very imporatant: the object model used in the THINK C object extensions are not compatible with C++, and you will get many link errors if you forget to change the mapping.

Q. The THINK C User’s Guide says that if I option double-click on the name of a Toolbox or standard library function, then THINK reference will open up and show me the documentation for that function. But it isn’t working all the time, why?

A. If THINK Reference isn’t running on your machine, then option double-clicking will not launch it: you need to chose "Find in THINK Reference" from the Search menu, or press -minus ('-'). Once you have launched it then you will be able to use option double-click to perform lookups.

Q. What is "Internal Error ZREF," and what can I do about it?

A. It means that your project file is corrupted. Removing objects from the project and rebuilding may fix it, providing the corruption was in the object portion of the project. If it wasn’t, you need to create a new project and add the sources into it. If your project file grows towards 16 megabytes, you may also see this error. Try storing your debug info separately: this will cut down on the project size. Unfortunately this still means you will need to rebuild the project from scratch. If you have AppleScript then you can use the "Save project as text" and "Create project as text" AppleScripts (in the ':Scripting:Sample AppleScripts' folder) to automate this task.

Q. When compiling a C++ source file, a syntax error in my .h file is reported in the errors window. When I double-click to open the .h file, I don’t see anything that looks wrong, so I do Check Syntax. Now I don’t get any errors. But when I go back to the original file and try compiling again, I get the same error.

A. You can’t do Check Syntax on files that do not have a translator mapping, and .h files are not part of the default set of mappings. If you set the THINK Project Manager’s extension mapping to map .h to THINK C or Symantec C++, you will be able to directly check such a file, and see the errors. (Note that compiling this a .h file will add it to the project!) Another solution, which doesn’t require changing the extension mappings, is to preprocess the file, saving the resulting file with a .c or .cp extension (which is appropriate) and compiling it.

Q. Can I include my "projectname.rsrc" file in my project?

A. You can, but you may cause a “duplicate resource” error. The default extension mapping for .rsrc files specifies that the Resource Copier as the translator. Since the Resource Copier copies its input into the “projectname.rsrc” file (creating it if necessary), you will get that error. You can prevent this from happening by naming the file something other than “projectname.rsrc”. If you have multiple .rsrc files in the project, the contents of each will be copied into “projectname.rsrc”. You could also set the .rsrc translator to «none», but that would defeat the advantages of having the project automatically keep track of the resources.

Q. I’m building a TCL project in THINK C 6.0 that I know will need far code and far data, so I take the starter project, replace oopsDebug with oopsDebugFar, set Far Data and Far Code, and select Bring Up To Date. I get the following compile error:

File <LongQD.cp>; Line 28
Error:     second argument to function ‘__member’ does not match prototype

A. The member() function is declared in oops.h, which gets included in the precompiled header, TCLHeaders. Its second argument gets declared as a void * if either far code or far data are on, but as a short if not. Hence the prototype mismatch. The manual, by mentioning that you must include oops.h in all far TCL projects, is subtly whispering that perhaps you should recompile TCLHeaders with far options on.

Q. I’m trying to use the lowercase, C style newcdialog() function, which is declared in Dialogs.h - but the linker tells me it’s undefined. I have MacTraps and MacTraps2 in my project. What’s the problem?

A. The declarations for these functions are in there because we use the headers supplied by Apple. However, these functions are implemented via glue that only works in MPW. We have never, and probably will never, support them.

Q. I have a strange problem with THINK C. It beeps at the end of compilation, without displaying any message or alert. The beep occurs only when I compile all files of the project together, not when I compile a single file. This is very disturbing. What can I do to recover normal behavior?

A. It’s a feature! If you’re compiling a lot of files, the beep occurs so you will know to end your coffee break and get back to work.



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.