TweetFollow Us on Twitter

May 95 Top 10
Volume Number:11
Issue Number:5
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 Colen Garoutte-Carson, Quality Assurance & Technical Support, Symantec Corp.

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

Q: How do I build a fat application with Symantec C++ v8.0?

A: We’ve touched on this before, and here’s a more detailed look. When an application is launched on a 68K Macintosh, the operating system (OS) loads and executes a 68K ‘CODE’ resource ID 1. When an application is launched on a PowerMac, the OS first looks for a ‘cfrg’ resource describing a PowerPC code fragment stored in the application’s data fork, and if found, prepares and executes the PowerPC code fragment. If the OS is unable to launch the application this way, it tries to loads and execute a 68K ‘CODE’ resource ID 1.

A fat (fat-binary) application has both a PowerPC code fragment and 68K ‘CODE’ resources, and can be launched on either platform.

To create a fat binary app, enable the option to merge an existing 680x0 application into your final application, in the project Options dialog, in the Project Type settings for an application. This copies all resources from the 68K application that do not already exist in your PowerPC application. Most importantly, this copies all 68K ‘CODE’ resources to your PowerPC application.

Resources in your 68K application with the same type and ID as those in your PowerPC application will not be copied.

You can also build a fat application by including a 68K application’s ‘CODE’ resources in a resource (.rsrc) file, and adding that resource file to your PowerPC project.

Q: How do I create an accelerated code resource?

A: Although the linker in Symantec C++ v8.0 does not yet support the creation of code resources, there is a way to create a code resource from a PowerPC application using Symantec Rez. Symantec C++ v8.0 includes a Code Resource project model which does this.

The Code Resource project model consists of two projects. The first, Code Resource.Π, is similar to a Mac Application project, but doesn’t include InitToolbox() (it’s unnecessary in a code resource). It uses the rsrcMPWPPCRuntime.o runtime library instead of PPCRuntime.o, and PPCLink & MakePEF instead of the internal linker.

In PowerMac applications, constructors and destructors for global and static objects are called automatically by __cplusstart(), which the linker assigns as the main entry point to your application (not main()). This routine calls your constructors, initializes your QuickDraw globals, calls your main() function, and then calls your destructors.

In a shared library, constructors for global and static objects are called by __cplusinit, which the linker assigns as an initialization routine. The Code Fragment Manager will automatically call this initialization routine when your shared library is loaded. The __cplusinit() routine will also hook your shared library’s QuickDraw globals into the QuickDraw globals of the calling application. Destructors for global and static objects are called by __cplusterm(), which the linker assigns as a termination routine. The Code Fragment Manager will automatically call this termination routine when your shared library is unloaded.

In code resources, there is no way to automatically call constructors or destructors for global and static objects, or hook QuickDraw globals, and still preserve the arguments passed to main(). Instead, you must call routines to do this for you. In C, you use __rsrcinit() and __rsrcterm(), declared in stdlib.h. In C++, you use __cplusrsrcinit() and __cplusrsrcterm(), declared in new.h. The C++ initialization and termination routines call the C initialization and termination routines. Use only the C++ or C initialization routines. Do not use both. These routines are defined in the rsrcMPWPPCRuntime.o library.

If your code resource is called only once to perform its function, call __rsrcinit() or __cplusrsrcinit() at the start of your program, and __rsrcterm() or __cplusrsrcterm() at the end.

If your code resource is reentrant, call __rsrcinit() or __cplusrsrcinit() only the first time your code resource is called, and __rsrcterm() or __cplusrsrcterm() the last time your code resource is called.

Do not use any QuickDraw globals, or any global or static objects that rely on their constructor, before calling __rsrcinit() or __cplusrsrcinit().

The second project in the Code Resource project model will copy the data fork of the target built by Code Resource.Π into a resource and prepend a routine descriptor to it. Code Resource.Π is included as a sub-project to the second project. Debugging is disabled for the sub-project to ensure that the sub-project’s target is built instead of a temporary instant-run PEF when the parent project is brought up to date.

Code Resource.Π includes two resource (.r) files, _CopyToResource.r and __AppendRoutineDescriptor.r.

_CopyToResource.r reads the data fork of the sub-project’s target and stores it into a temporary resource.

__AppendRoutineDescriptor.r prepends a routine descriptor to the temporary resource and stores it in your final resource. Before you build your code resource, you will need to modify a number of #define’s in this file. The file contains comments that describe the necessary changes.

The Always check file dates option is enabled in the second project to ensure that the resource description files’ dependency on the sub-project’s target is properly tracked.

__AppendRoutineDescriptor.r is dependant on _CopyToResource.r. These files have been named to compile in the right order.

Once the parent project has been brought up to date, your accelerated code resource will be stored in the project’s resource file (<projectname>.rsrc).

Q: How do I create a fat or safe fat code resource?

A: You can build a fat or safe fat code resource in much the same way that you would create an accelerated code resource, discussed above. The Code Resource project model includes support for these fat code resource types, as well as a few others. See the comments within the project model for details.

Q: Why are my structs a different size in my PowerPC project than they are in my 68K project?

A: The MC68000 chip must reference word or long values from even addresses. More recent chips in the 680x0 family 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 on 4-byte boundaries.

If you need to share data structures in memory between 68K and PowerPC code (e.g. when passing data to the Macintosh Toolbox’s pre-existing 68K-based interfaces), or need to read or write data structures from/to disk with both 68K and PowerPC code, you will need to ensure that your alignment settings match in both your 68K and PowerPC projects.

By default, the PowerPC compilers align fields within structs on 4-byte boundaries. By default, the 68K C++ compiler aligns fields within structs on 2-byte boundaries. Think C always aligns fields within structs on 2-byte boundaries.

The PowerPC compiler supports the following #pragma directive to enable 68K (2-byte) structure alignment in a given structure declaration :

#pragma options align=mac68K
/* Your struct declaration */
#pragma options align=reset

Q: My 68K application, created with the Visual Architect in v7.0(.x), works fine. Why does a fat version of the same application not run on a 68K Mac?

A: Because of changes in the TCL, you will need to re-compile the 68K application with the 68K environment and TCL included in version 8, and re-merge it into your fat application.

Q: When I run my program with the debugger, it launches “Power Mac DebugServices”. This program remains running invisibly. How can I quit this application when I am done debugging?

A: You can write an AppleScript that contains the following :

 tell application "Power Mac DebugServices" to quit

Never run this script while debugging. To ensure that DebugServices has quit when no longer needed, name the script ShutDown, and put it in your (Scripts) folder. The script will be run when you quit the Symantec Project Manager.

Q: Can I use Apple’s new Toolbox Assistant with the Symantec Project Manager?

A: Yes. The Symantec Project Manager supports both The THINK Reference and QuickViewer. It is capable of using both simultaneously.

As with the Think Project Manager, the Symantec Project Manager will allow you to reference the Think Reference or QuickViewer directly if an alias to it, named exactly “THINK Reference” or “Primary Doc Server”, is located in your “(Tools)” folder. The Symantec Project Manager considers these names synonymous. The Symantec Project Manager will search a second documentation server if it’s unsuccessful in finding a match in the first. The second documentation server’s alias must also be located in the “(Tools)” folder and must be named “Secondary Doc Server”.

Q: When I convert my Think Project Manager project, the Symantec Project Manager preserves the segmentation in groups. Is there a way around this?

A: Yes, hold down the shift key when opening the Think Project Manager project.

Q: How do I Check In files to my SourceServer database for the first time? And how do I Check Out files from a SourceServer database that I’ve never checked out before?

A: To do these actions, you must send the command to SourceServer manually. The Symantec Project Manager includes a Worksheet window, available under the Windows menu, that you can use to send commands to SourceServer or ToolServer.

Example of a CheckIn command :

CheckIn -new "filename.cp"

Q: Can I use Check In on the Revision menu to check in header files to a SourceServer database?

A: Yes. In the project Options dialog, on the “Extension” settings page, add .h to the list of supported filename extensions, but do not specify a translator. You will be able to add files with names ending in .h to your project, but they will not be compiled. You can then check these files into your SourceServer database by selecting them in the project window, and then selecting Check In from the Revision menu.

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

Latest Forum Discussions

See All

Aether Gazer unveils Chapter 16 of its m...
After a bit of maintenance, Aether Gazer has released Chapter 16 of its main storyline, titled Night Parade of the Beasts. This big update brings a new character, a special outfit, some special limited-time events, and, of course, an engaging... | Read more »
Challenge those pesky wyverns to a dance...
After recently having you do battle against your foes by wildly flailing Hello Kitty and friends at them, GungHo Online has whipped out another surprising collaboration for Puzzle & Dragons. It is now time to beat your opponents by cha-cha... | Read more »
Pack a magnifying glass and practice you...
Somehow it has already been a year since Torchlight: Infinite launched, and XD Games is celebrating by blending in what sounds like a truly fantastic new update. Fans of Cthulhu rejoice, as Whispering Mist brings some horror elements, and tests... | Read more »
Summon your guild and prepare for war in...
Netmarble is making some pretty big moves with their latest update for Seven Knights Idle Adventure, with a bunch of interesting additions. Two new heroes enter the battle, there are events and bosses abound, and perhaps most interesting, a huge... | Read more »
Make the passage of time your plaything...
While some of us are still waiting for a chance to get our hands on Ash Prime - yes, don’t remind me I could currently buy him this month I’m barely hanging on - Digital Extremes has announced its next anticipated Prime Form for Warframe. Starting... | Read more »
If you can find it and fit through the d...
The holy trinity of amazing company names have come together, to release their equally amazing and adorable mobile game, Hamster Inn. Published by HyperBeard Games, and co-developed by Mum Not Proud and Little Sasquatch Studios, it's time to... | Read more »
Amikin Survival opens for pre-orders on...
Join me on the wonderful trip down the inspiration rabbit hole; much as Palworld seemingly “borrowed” many aspects from the hit Pokemon franchise, it is time for the heavily armed animal survival to also spawn some illegitimate children as Helio... | Read more »
PUBG Mobile teams up with global phenome...
Since launching in 2019, SpyxFamily has exploded to damn near catastrophic popularity, so it was only a matter of time before a mobile game snapped up a collaboration. Enter PUBG Mobile. Until May 12th, players will be able to collect a host of... | Read more »
Embark into the frozen tundra of certain...
Chucklefish, developers of hit action-adventure sandbox game Starbound and owner of one of the cutest logos in gaming, has released their roguelike deck-builder Wildfrost. Created alongside developers Gaziter and Deadpan Games, Wildfrost will... | Read more »
MoreFun Studios has announced Season 4,...
Tension has escalated in the ever-volatile world of Arena Breakout, as your old pal Randall Fisher and bosses Fred and Perrero continue to lob insults and explosives at each other, bringing us to a new phase of warfare. Season 4, Into The Fog of... | Read more »

Price Scanner via MacPrices.net

Boost Mobile will sell you an iPhone 11 for $...
Boost Mobile, an MVNO using AT&T and T-Mobile’s networks, is offering an iPhone 11 for $149.99 when purchased with their $40 Unlimited service plan (12GB of premium data). No trade-in is required... Read more
Free iPhone 15 plus Unlimited service for $60...
Boost Infinite, part of MVNO Boost Mobile using AT&T and T-Mobile’s networks, is offering a free 128GB iPhone 15 for $60 per month including their Unlimited service plan (30GB of premium data).... Read more
$300 off any new iPhone with service at Red P...
Red Pocket Mobile has new Apple iPhones on sale for $300 off MSRP when you switch and open up a new line of service. Red Pocket Mobile is a nationwide MVNO using all the major wireless carrier... Read more
Clearance 13-inch M1 MacBook Airs available a...
Apple has clearance 13″ M1 MacBook Airs, Certified Refurbished, available for $759 for 8-Core CPU/7-Core GPU/256GB models and $929 for 8-Core CPU/8-Core GPU/512GB models. Apple’s one-year warranty is... Read more
Updated Apple MacBook Price Trackers
Our Apple award-winning MacBook Price Trackers are continually updated with the latest information on prices, bundles, and availability for 16″ and 14″ MacBook Pros along with 13″ and 15″ MacBook... Read more
Every model of Apple’s 13-inch M3 MacBook Air...
Best Buy has Apple 13″ MacBook Airs with M3 CPUs in stock and on sale today for $100 off MSRP. Prices start at $999. Their prices are the lowest currently available for new 13″ M3 MacBook Airs among... Read more
Sunday Sale: Apple iPad Magic Keyboards for 1...
Walmart has Apple Magic Keyboards for 12.9″ iPad Pros, in Black, on sale for $150 off MSRP on their online store. Sale price for online orders only, in-store price may vary. Order online and choose... Read more
Apple Watch Ultra 2 now available at Apple fo...
Apple has, for the first time, begun offering Certified Refurbished Apple Watch Ultra 2 models in their online store for $679, or $120 off MSRP. Each Watch includes Apple’s standard one-year warranty... Read more
AT&T has the iPhone 14 on sale for only $...
AT&T has the 128GB Apple iPhone 14 available for only $5.99 per month for new and existing customers when you activate unlimited service and use AT&T’s 36 month installment plan. The fine... Read more
Amazon is offering a $100 discount on every M...
Amazon is offering a $100 instant discount on each configuration of Apple’s new 13″ M3 MacBook Air, in Midnight, this weekend. These are the lowest prices currently available for new 13″ M3 MacBook... Read more

Jobs Board

Omnichannel Associate - *Apple* Blossom Mal...
Omnichannel Associate - Apple Blossom Mall Location:Winchester, VA, United States (https://jobs.jcp.com/jobs/location/191170/winchester-va-united-states) - Apple Read more
Operations Associate - *Apple* Blossom Mall...
Operations Associate - Apple Blossom Mall Location:Winchester, VA, United States (https://jobs.jcp.com/jobs/location/191170/winchester-va-united-states) - Apple Read more
Cashier - *Apple* Blossom Mall - JCPenney (...
Cashier - Apple Blossom Mall Location:Winchester, VA, United States (https://jobs.jcp.com/jobs/location/191170/winchester-va-united-states) - Apple Blossom Mall Read more
IT Systems Engineer ( *Apple* Platforms) - S...
IT Systems Engineer ( Apple Platforms) at SpaceX Hawthorne, CA SpaceX was founded under the belief that a future where humanity is out exploring the stars is Read more
*Apple* Systems Administrator - JAMF - Activ...
…**Public Trust/Other Required:** None **Job Family:** Systems Administration **Skills:** Apple Platforms,Computer Servers,Jamf Pro **Experience:** 3 + years of Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.