From: pottier@clipper.ens.fr (Francois Pottier) Subject: csmp-digest-v3-053 Date: Mon, 5 Sep 1994 15:28:25 +0200 (MET DST) C.S.M.P. Digest Mon, 05 Sep 94 Volume 3 : Issue 53 Today's Topics: A real funny story AppleScript: event times out C++ Virtual Destructor Q Enum size -- what's the LCD? Followup on 'Safe Save' problem - still ticking! MW DebugNew Tip Scrollbars in Dialogs? Should new programs still be System 6 compatible? The System 7.5 Think Debugger Bug - and fix! Think Debugger & INIT source code [Q] How to do non-bypassable INIT? malloc problem in CW-4 The Comp.Sys.Mac.Programmer Digest is moderated by Francois Pottier (pottier@clipper.ens.fr). The digest is a collection of article threads from the internet newsgroup comp.sys.mac.programmer. It is designed for people who read c.s.m.p. semi- regularly and want an archive of the discussions. If you don't know what a newsgroup is, you probably don't have access to it. Ask your systems administrator(s) for details. If you don't have access to news, you may still be able to post messages to the group by using a mail server like anon.penet.fi (mail help@anon.penet.fi for more information). Each issue of the digest contains one or more sets of articles (called threads), with each set corresponding to a 'discussion' of a particular subject. The articles are not edited; all articles included in this digest are in their original posted form (as received by our news server at nef.ens.fr). Article threads are not added to the digest until the last article added to the thread is at least two weeks old (this is to ensure that the thread is dead before adding it to the digest). Article threads that consist of only one message are generally not included in the digest. The digest is officially distributed by two means, by email and ftp. If you want to receive the digest by mail, send email to listserv@ens.fr with no subject and one of the following commands as body: help Sends you a summary of commands subscribe csmp-digest Your Name Adds you to the mailing list signoff csmp-digest Removes you from the list Once you have subscribed, you will automatically receive each new issue as it is created. The official ftp info is //ftp.dartmouth.edu/pub/csmp-digest. Questions related to the ftp site should be directed to scott.silver@dartmouth.edu. Currently no previous volumes of the CSMP digest are available there. Also, the digests are available to WAIS users. To search back issues with WAIS, use comp.sys.mac.programmer.src. With Mosaic, use http://www.wais.com/wais-dbs/comp.sys.mac.programmer.html. ------------------------------------------------------- >From nick+@pitt.edu ( nick.c ) Subject: A real funny story Date: Fri, 19 Aug 94 21:40:04 GMT Organization: The Pitt, Chemistry Folks: A friend of mine just sent me this, personally I think it's hilarious (so long as you don't work for MS :-). Enjoy, - -- "Star Trek Lost Episodes" transcript. <Picard> "Mr. LaForge, have you had any success with your attempts at finding a weakness with the Borg? And Mr. Data, have you been able to access their command pathways?" <Geordi> "Yes, Captain. In fact, we found the answer by searching through our archives on late twentieth-century computing technology." <Geordi presses a key, and a logo appears on the computer screen.> <Riker looks puzzled.> "What the hell is 'Microsoft'?" <Data turns to answer.> "Allow me to explain. We will send this program, for some reason called 'Windows,' through the Borg command pathways. Once inside their root com- mand unit, it will begin consuming system resources at an unstoppable rate." <Picard> "But the Borg have the ability to adapt. Won't they alter their processing systems to increase their storage capacity?" <Data> "Yes, Captain. But when 'Windows' detects this, it will create a new version of itself called an 'upgrade.' The use of resources increases exponentially with each iteration. The Borg will not be able to adapt quickly enough. Eventually all of their processing ability will be taken over and none will be available for their normal operational functions." <Picard> "Excellent work. This is even better than that 'unsolvable geometric shape' idea." <. . . 15 minutes later . . .> <Data> "Captain, we have successfully installed the 'Windows' in the command unit and, as expected, it immediately consumed 85% of all resources. We, however, have not received any confirmation of the expected 'upgrade.'" <Geordi> "Our scanners have picked up an increase in Borg storage and CPU capacity to compensate, but we still have no indication of an 'upgrade' to compensate for their increase." <Picard> "Data, scan the history books again and determine if there is something we have missed." <Data> "Sir, I believe there is a reason for the failure in the 'upgrade.' Apparently the Borg have circumvented that part of the plan by not sending in their 'registration cards.'" <Riker> "Captain, we have no choice. Requesting permission to begin emergency escape sequence 3F . . ." <Geordi, excited> "Wait, Captain, I just detected that their CPU capacity has suddenly dropped to 0%!" <Picard> "Data, what do your scanners show?" <Data> "Apparently the Borg have found the internal 'Windows' module named 'solitaire' and it has used up all the CPU capacity." <Picard> "Let's wait and see how long this 'solitaire' can reduce their functionality." <. . . Two hours pass . . .> <Riker> "Geordi, what's the status of the Borg?" <Geordi> "As expected the Borg are attempting to re- engineer to compensate for increased CPU and storage demands, but each time they successfully increase resources I have set up our closest deep space monitor beacon to transmit more 'Windows' modules from something called the 'Microsoft fun-pack.'" <Picard> "How much time will that buy us?" <Data> "Current Borg solution rates allow me to predict an interest time span of 6 more hours." <Geordi> "Captain, another vessel has entered our sector." <Picard> "Identify." <Data> "It appears to have markings similar to the 'Microsoft' logo." <Over the speakers> "THIS IS ADMIRAL BILL GATES OF THE MICROSOFT FLAGSHIP MONOPOLY. WE HAVE POSITIVE CONFIRMATION OF UN- REGISTERED SOFTWARE IN THIS SECTOR. SURRENDER ALL ASSETS AND WE CAN AVOID ANY TROUBLE. YOU HAVE TEN SECONDS." <Data> "The alien ship has just opened its forward hatches and released thousands of humanoid shaped objects." <Picard> "Magnify forward viewer on the alien craft." <Riker> "Good God Captain! Those are humans floating straight toward the Borg ship with no life support suits! How can they survive the tortures of deep space?!" <Data> "I do not believe that those are humans sir; if you will look closer, I believe you will see that they are carrying something recognized in the twenty-first century as doe-skin leather briefcases, and wearing Armani suits." <Riker and Picard together horrified> "Lawyers!!" <Geordi> "It can't be. All the lawyers were rounded up and sent hurtling into the sun in 2017 during the great awaken- ing." <Data> "True, but apparently some must have survived." <Riker> "They have surrounded the Borg ship and are covering it with all types of papers." <Data> "I believe that is known in ancient vernacular as 'red tape.' It often proves fatal. <Riker> "They're tearing the Borg to pieces!" <Picard> "Turn off the monitors. I can't stand to watch. Not even the Borg deserve that." Disclaimer: Just my opinion. _/ _/ _/ _/_/_/ _/ _/ Interet: nick@pitt.edu _/_/ _/ _/ _/ _/ _/_/_/ eWorld: nick _/ _/_/ _/ _/ _/ _/ CIS: 71232,766 _/ _/ _/ _/_/_/ _/ _/ "Science is nothing but perception" - Plato --------------------------- >From kocher@lts.sel.alcatel.de (Hartmut Kocher US/ESA 60/1L/2? #5629) Subject: AppleScript: event times out Date: Mon, 22 Aug 94 08:33:35 GMT Organization: SEL-Alcatel LTS Dept. US/ES I've written a small AppleScript, that copies a few folders around using the scriptable Finder. My problem is that if one of these folders holds many files, the reply from the Finder takes too long and the reply times out (aborting the script :-( ). How can I set the timeout value, so my script is willing to wait longer fro a reply? Thanks for your suggestions. -- +==============================|==============================+ | Hartmut Kocher | | | Technical Consultant | All opinions expressed here | | Rational GmbH | are my own. | | Rosenstrasse 7 | | | 82049 Pullach im Isartal | I know you guessed it, | | Germany | but it keeps my lawyer happy.| | Email: hwk@rational.com | | +==============================|==============================+ +++++++++++++++++++++++++++ >From dmcleod@hpb.hwc.ca (D.A. McLeod) Date: 22 Aug 1994 13:32:42 GMT Organization: Health Canada Hartmut Kocher US/ESA 60/1L/2? #5629 (kocher@lts.sel.alcatel.de) wrote: : How can I set the timeout value, so my script is willing to wait : longer fro a reply? with timeout of #### seconds . . . end timeout +++++++++++++++++++++++++++ >From engelhar@bga.com (Michael Engelhart) Date: 22 Aug 1994 15:38:09 GMT Organization: Apple Travel In article <1994Aug22.083335.25853@lts.sel.alcatel.de>, kocher@lts.sel.alcatel.de (Hartmut Kocher US/ESA 60/1L/2? #5629) wrote: > I've written a small AppleScript, that copies a few folders around > using the scriptable Finder. My problem is that if one of these folders > holds many files, the reply from the Finder takes too long and the > reply times out (aborting the script :-( ). > > How can I set the timeout value, so my script is willing to wait > longer fro a reply? > > Thanks for your suggestions. > > -- > +==============================|==============================+ > | Hartmut Kocher | | > | Technical Consultant | All opinions expressed here | > | Rational GmbH | are my own. | > | Rosenstrasse 7 | | > | 82049 Pullach im Isartal | I know you guessed it, | > | Germany | but it keeps my lawyer happy.| > | Email: hwk@rational.com | | > +==============================|==============================+ Hartmut, simply enclose your routine with the following: with timeout of 400 seconds --use any value you want, the default is 120 seconds your routine end timeout Mike --------------------------- >From jpek@umich.edu (Jeff Pek) Subject: C++ Virtual Destructor Q Date: 19 Aug 1994 22:05:08 GMT Organization: U of Mich (MBA) I wonder if someone could clear the air around our office about why virtual destructors should or should not be used. Specifically, I'm interested in Metrowerks' compiler's implementation. 1) Why would I want to/need to declare a destructor virtual? 2) What happens if I don't? Thanks very much! Jeff - ------------------------------------------- Jeff Pek jpek@umich.edu Emerald Intelligence / University of Michigan +++++++++++++++++++++++++++ >From mwron@aol.com (MW Ron) Date: 19 Aug 1994 19:44:06 -0400 Organization: America Online, Inc. (1-800-827-6364) In article <333aak$fj8@lastactionhero.rs.itd.umich.edu>, jpek@umich.edu (Jeff Pek) writes: >>1) Why would I want to/need to declare a destructor virtual? >>2) What happens if I don't? 1) You need to declare a virtual destructor when you have a base class, its destructor is different than the derived classes destructor, and objects are deleted via pointer or refernce to base class. ( a good habit, declare it for all base classes ) 2) if you don't, you will not guarantee all objects will be deleted when an object is deleted, if it is accessed as a base class poiter. Scott Meyers in Effective C++ explains this quite well. Ron Liechty RonL@metrowerks.com Metrowerks Inc. +++++++++++++++++++++++++++ >From neeri@iis.ee.ethz.ch (Matthias Neeracher) Date: 19 Aug 1994 23:19:32 GMT Organization: Swiss Federal Institute of Technology (ETHZ) jpek@umich.edu (Jeff Pek) writes: >I wonder if someone could clear the air around our office about why >virtual destructors should or should not be used. Specifically, I'm >interested in Metrowerks' compiler's implementation. >1) Why would I want to/need to declare a destructor virtual? As a rule of thumb, as soon as you have a virtual function for a class, you should also have a virtual destruction. >2) What happens if I don't? As an example, take: class A ... class B : public A ... A * pa = new B; delete pa; Unless A has a virtual destructor, no destructor for B will be executed on the object pointed to by pa, which is would often be desirable. Matthias - --- Matthias Neeracher <neeri@iis.ee.ethz.ch> http://err.ethz.ch/members/neeri.html "There once was an Age of Reason, but we've progressed beyond it." -- Ayn Rand, _Atlas Shrugged_ +++++++++++++++++++++++++++ >From gurgle@dnai.com (Pete Gontier) Date: Fri, 19 Aug 1994 20:17:34 -0800 Organization: Integer Poet Software In article <333aak$fj8@lastactionhero.rs.itd.umich.edu>, jpek@umich.edu (Jeff Pek) wrote: > 1) Why would I want to/need to declare a (C++) destructor virtual? > 2) What happens if I don't? The Annotated C++ Reference Manual (commonly known as "the ARM"), Ellis and Stroustup, ISBN, 0-201-51459-1, chapter 12.4 (page 276 in my printing). And a note to aid in your reading: non-virtual destructors are the exception (no pun intended), not the rule. -- Pete Gontier // CTO, Integer Poet Software // gurgle@dnai.com "Even during a particularly harsh (Colorado) winter... many of the 300 families in the VCTV (movies-on-demand) trial continued to go to video stores." -- eis@murrow.tufts.edu, in Wired 2.09 p62 +++++++++++++++++++++++++++ >From mwron@aol.com (MW Ron) Date: 20 Aug 1994 12:20:01 -0400 Organization: America Online, Inc. (1-800-827-6364) In article <gurgle-1908942017340001@gurgle.dnai.com>, gurgle@dnai.com (Pete Gontier) writes: Here is a short example of a virtual destructor in use. remove the virtual keyword and you will see that only the base class's destructor is called. Ron Liechty RonL@metrowerks.com Metrowerks Inc. #include <iostream> class base { public: int *a; protected: base() { a = new int(1);} public: virtual ~base() { cout << "deleteting base "; delete a;}; }; class base2 : public base { public: int *b; protected: base2() { b = new int(1);} public: virtual ~base2() { cout << "deleteting base2 "; delete b;}; }; class d : public base2 { public : int *c; public: d() { c = new int(3);} ~d() { cout << "deleteting d "; delete c;}; }; main() { base *bPtr = new d; delete bPtr; cout << "enter a char " ; cin.get(); return 0; } +++++++++++++++++++++++++++ >From ekstrom@aggroup.com (Harold Ekstrom) Date: Sat, 20 Aug 1994 20:45:15 -0800 Organization: Ag Group In article <333g46$hu5@search01.news.aol.com>, mwron@aol.com (MW Ron) wrote: > In article <333aak$fj8@lastactionhero.rs.itd.umich.edu>, jpek@umich.edu > (Jeff Pek) writes: > > >>1) Why would I want to/need to declare a destructor virtual? > >>2) What happens if I don't? > > 1) You need to declare a virtual destructor when you have a base class, > its destructor is different than the derived classes destructor, and > objects are deleted via pointer or refernce to base class. ( a good habit, > declare it for all base classes ) > > 2) if you don't, you will not guarantee all objects will be deleted when > an object is deleted, if it is accessed as a base class poiter. > > Scott Meyers in Effective C++ explains this quite well. > > Ron Liechty > RonL@metrowerks.com > Metrowerks Inc. Another good source of answers for this and other common C++ questions is the C++FAQ (rtfm.mit.edu). It was one of the first things I read when learning C++. harold - ------------------------------------------------------------ Harold Ekstrom ekstrom@aggroup.com ag group, inc. 2540 camino diablo, suite 200 walnut creek, ca 94596 510-937-7900 voice 510-937-2479 fax 510-937-6704 ara ftp.aggroup.com anonymous ftp --------------------------- >From afrancke@netcom.com (Andrew Francke) Subject: Enum size -- what's the LCD? Date: Wed, 17 Aug 1994 02:54:56 GMT Organization: Netcom Online Communications Services (408-241-9760 login: guest) If I'm not mistaken, the lowest common denominator for enum size is that presented by MPW 68k C -- variable 1, 2, or 4 bytes. Other Mac C and C++ compilers support the ANSI definition, sizeof(enum) == sizeof(int), but not MPW C. All Mac compilers support variable enum size just like MPW C. Is this strictly correct? Now, examine the following code: typedef enum { a=255 } one_byte_enum_t; typedef enum { b=65000 } two_byte_enum_t; typedef enum { c=1000000 } three_byte_enum_t; #if defined (powerc) || defined (__power) #pragma align=mac68k #endif struct test1 { one_byte_enum_t mem1; two_byte_enum_t mem2; three_byte_enum_t mem3; }; #if defined (powerc) || defined (__powerc) #pragma align reset // or whatever it is #endif The $10,000,000 question -- do these structures lay out on every Mac C compiler in this way: Offset Byte from Contents &test 1: - --------- -------- 0x00000000: mem1 0x00000001: <pad> 0x00000002: mem2 0x00000003: mem2 0x00000004: mem3 0x00000005: mem3 0x00000006: mem3 0x00000007: mem3 How about stack alignment? If I declare a function: void foo ( one_byte_enum a, two_byte_enum b, three_byte_enum c ); ...what will the stack look like? Will it be the same for all Mac C/C++ compilers? Example stack: 1 2 3 4 5 6 7 8 SP-0x8: c c c c b b <pad> a SP: (Sorry if this last example isn't that clear -- the stack is being displayed in hi-lo, left to right order, assuming that all parameters have been pushed and we're about to JSR to foo) Thanks in advance for your insight. Andy Francke +++++++++++++++++++++++++++ >From mclow@san_marcos.csusm.edu (Marshall Clow) Date: Wed, 17 Aug 1994 00:53:32 -0800 Organization: Aladdin Systems In article <afranckeCuns3L.MuC@netcom.com>, afrancke@netcom.com (Andrew Francke) wrote: > If I'm not mistaken, the lowest common denominator for enum size is > that presented by MPW 68k C -- variable 1, 2, or 4 bytes. Other Mac C > and C++ compilers support the ANSI definition, sizeof(enum) == > sizeof(int), but not MPW C. All Mac compilers support variable enum > size just like MPW C. > > Is this strictly correct? > No. It's wrong in several areas. > [ code deleted ] > > The $10,000,000 question -- do these structures lay out on every Mac > C compiler in this way: > [ more code deleted ] No. Different compilers allocated sizes for enums differently. I believe that the following is true: 1) MPW C (68K) -- enums are 4 bytes 2) Think C (68K) -- enums are 1, 2, or 4 bytes (based on values) except if the "Enums are always ints" preference is checked, in which case they are 2 or 4 bytes depending on how big your ints are. 3) Metrowerks C (68K) -- same as Think C (68K). 4) Metrowerks C (PPC) -- enums are 1, 2, or 4 bytes (based on values) except if the "Enums are always ints" preference is checked, in which case they are 4 bytes. 5) PPCC (Apple's MPW based PPC compiler) -- I don't know. 6) Apple's new PPC C compiler (Beta on ETO #15) -- I don't know 7) Motorola C (PPC) -- I don't know 8) Absoft C (PPC) -- I don't know [ I'm sure I forgot someone. ] The ANSI spec (from memory, so don't flame me for wordage) says that enums must be "compatible with integer type". The rest is up to the compiler writer. This is one of the non-portable aspects of C. -- Marshall -- Marshall Clow Aladdin Systems mclow@san_marcos.csusm.edu +++++++++++++++++++++++++++ >From becker@Xenon.Stanford.EDU (Denizen of the Deep) Date: 17 Aug 1994 16:22:16 GMT Organization: Computer Science Department, Stanford University. In article <mclow-1708940053320001@lpm8.csusm.edu>, Marshall Clow <mclow@san_marcos.csusm.edu> wrote: > >The ANSI spec (from memory, so don't flame me for wordage) says that enums >must be "compatible with integer type". The rest is up to the compiler >writer. > >This is one of the non-portable aspects of C. > >-- Marshall > >From K&R II, A8.4: The identifiers in an enumerator list are declared as constants of type int... So there you have it. In strict ANSI C, enums should take up the same space as an int on the machine (i.e. 2 or 4 bytes, depending on your settings and/or compiler). It's only non-portable in the sense that different compilers may have different sizes for int; however once the choice of int size is made, there is no latitude for choosing how to deal with enums. -Jon +++++++++++++++++++++++++++ >From Lars.Farm@nts.mh.se (Lars Farm) Date: Fri, 19 Aug 1994 10:08:12 +0100 Organization: Mid Sweden University In article <32tdfo$gn2@Times.Stanford.EDU>, becker@Xenon.Stanford.EDU (Denizen of the Deep) wrote: > From K&R II, A8.4: > The identifiers in an enumerator list are declared as constants > of type int... > > So there you have it. In strict ANSI C, enums should take up the same > space as an int on the machine (i.e. 2 or 4 bytes, depending on your In C perhaps, but not so in C++. enum is not int. An enum can be initialized by a constant expression of integral type. An enum will silently be converted to an int where an int is expected (|, &, + ...) but an int will not silently be converted to an enum, because nothing says it will fit in the space allocated for the enum. Cast needed. An enum is required to have room for "...the nearest larger binary power minus 1 and down to 0...". So enum { false,true } is only required to allocate one bit for the value. [ARM - ANSI/ISO resolutions r.7.2]. Realistically this means that an enum will be allocated 1, 2 or 4 bytes depending on enumerated constants and whatever the compilers author sees reasonable. In any event the space allocated to an enum may be smaller than what is needed for an int provided it has room for any of the enum constants. Lars -- Lars.Farm@nts.mh.se +++++++++++++++++++++++++++ >From phils@bedford.symantec.com (Phil Shapiro) Date: Fri, 19 Aug 1994 12:36:51 -0400 Organization: Symantec Corp. | No. Different compilers allocated sizes for enums differently. I believe | that the following is true: Only slightly off, with respect to "enums are always ints", see below*. | 1) MPW C (68K) -- enums are 4 bytes | | 2) Think C (68K) -- enums are 1, 2, or 4 bytes (based on values) except if | the "Enums are always ints" preference is checked, in which case they are | 2 or 4 bytes depending on how big your ints are. | | 3) Metrowerks C (68K) -- same as Think C (68K). | | 4) Metrowerks C (PPC) -- enums are 1, 2, or 4 bytes (based on values) | except if the "Enums are always ints" preference is checked, in which case | they are 4 bytes. | | 5) PPCC (Apple's MPW based PPC compiler) -- I don't know. | 6) Apple's new PPC C compiler (Beta on ETO #15) -- I don't know | 7) Motorola C (PPC) -- I don't know | 8) Absoft C (PPC) -- I don't know 9) Symantec C/C++ -- enums are 1, 2, or 4 bytes based on values. If enums are always ints is checked, then they are 4 bytes. The rules are the same for both the 68k and PowerPC compilers. Apple's new PPC C++ compiler (aka MrC) should be the same as Symantec C++, since they share compiler front ends. (*) In ANSI C, enums are the same size as int, provided that the value that they contain can be represented in an int. So when you use the "enums are always ints" option, you're really saying that they're at least as big as an int. They can be bigger, or unsigned (or both), depending on the value that they contain. The main thing is that you shouldn't depend on the size of an enum. If you plan to do I/O with an enum, cast it to a known (portable) type first. -phil +++++++++++++++++++++++++++ >From afrancke@netcom.com (Andrew Francke) Date: Fri, 19 Aug 1994 21:16:29 GMT Organization: Netcom Online Communications Services (408-241-9760 login: guest) > The main thing is that you shouldn't depend on the size of an enum. If > you plan to do I/O with an enum, cast it to a known (portable) type first. > -phil I'm afraid this is a moot point in my case. I've already got a sizable amount of ASN.1-compiler-generated C source with enums a'plenty in struture declarations. I'll state my question again: GIVEN THE RIGHT SET OF COMPILER OPTIONS, is not the LCD of enum sizes the 1-2-4 packing scheme? I yet labor under the impression that MPW C doesn't even support "enums are ints" as an option. --------------------------- >From redial <redial@netcom.com> Subject: Followup on 'Safe Save' problem - still ticking! Date: Sat, 20 Aug 1994 21:46:44 GMT Organization: NETCOM On-line Communication Services (408 261-4700 guest) Netters - Thanks to all who attempted to help with my 'Safe save' problem. It did indeed look as tho closing the temporary file after the FSpExchangeFiles swap would solve the problem of the 'File Busy' error message when I attempted to delete the temporary file. Unfortunately :-( it didn't. Here's a summary of my Safe Save procedure, which follows the example in Think C Reference 2.0. I call StandardPutFile to get the user's input re the new file. If the reply is good and we're not replacing an existing file, I call FSpCreate. (According to IM:Files this creates a file with both forks, only they're both empty.) I then call FSpCreateResFile to open the resource fork, and proceed to copy a string resource for the 'Application missing' error message ('STR ' ID -16396) from my application's resources into the new file. I then close the resouce fork with an FSClose. Next, I open the data fork using FSpOpenDF. If no errors occur, I proceed to create a temporary file, open its data fork, write the data into it, close it, exchange its data with the real file, and then delete the temporary file. It's at this point I get my first sign of trouble: OSErr -47, aka 'File busy.' My snooping has revealed the following points of information. 1) When I attempt to open the newly created document file with ResEdit, I'm told it doesn't have a resource fork. 2) It does contain the appropriate data in its data fork. And 3) if I reboot the computer, the temporary file shows up in the trashcan in a folder labled 'Rescued items.' >From this, is it obvious to anyone as to what I'm doing wrong? Any suggestions on what debugging steps I should take would be greatly appreciated. TIA. Ron Goebel | Internet: redial@netcom.com +++++++++++++++++++++++++++ >From tgaul@halcyon.com (Troy Gaul) Date: Sat, 20 Aug 1994 23:05:30 -0700 Organization: Infinity Systems In article <netnewsCuusHx.25A@netcom.com>, redial <redial@netcom.com> wrote: > Here's a summary of my Safe Save procedure, which follows the example in > Think C Reference 2.0. I call StandardPutFile to get the user's input re > the new file. If the reply is good and we're not replacing an existing > file, I call FSpCreate. (According to IM:Files this creates a file with > both forks, only they're both empty.) I then call FSpCreateResFile to > open > the resource fork, and proceed to copy a string resource for the > 'Application missing' error message ('STR ' ID -16396) from my > application's resources into the new file. I then close the resouce fork > with an FSClose. Next, I open the data fork using FSpOpenDF. If no > errors > occur, I proceed to create a temporary file, open its data fork, write the > data into it, close it, exchange its data with the real file, and then > delete the temporary file. It's at this point I get my first sign of > trouble: OSErr -47, aka 'File busy.' First, it sounds like you're putting the resources into the 'real' file, and then putting the data into the 'temp' file's data fork, and then doing a swap on them. This isn't what you want to do. The call FSpExchangeFiles doesn't swap the data fork from one file to another, it swaps the directory information for the two files. This means that both the data and resource forks are swapped. Note, though, that this call does not swap the Finder information (like Modification Dates) for the files (or the locations in the file system, i.e. the file named 'Temp File' is still in the Temporary Items Folder). Next, once you have exchanged the files, I _think_ that the refnums you have for the files are also considered 'swapped' (it's been a while since I've done this, and I don't have the source code I produced anymore, but a quick glance into the Think Reference seemed to indicate that). This means if you have the variables 'realFileRefnum' and 'tempFileRefnum', which point where their names imply before the swap, after the swap, they point to the opposite files in the files system. So, by closing tempFileRefnum, you're really closing the 'real' file, and when you try to delete the file with tempFileFSSpec, the 'temp' file hasn't been closed, and you'd get that error. (Note that although the refnums are backward, the FSSpecs still point to the files that their names would imply, because these files are still in the same locations in the file system, just their contents have been swapped.) > My snooping has revealed the following points of information. > 1) When I > attempt to open the newly created document file with ResEdit, I'm told it > doesn't have a resource fork. That's because you never added a resource fork to the temp file (where you should have), you added it to the intended destination file (where it was then swapped into the temp file, the one you find in the Rescued Items folder). > 2) It does contain the appropriate data in > its data fork. And That's because the swap did in fact occur. > 3) if I reboot the computer, the temporary file shows > up in the trashcan in a folder labled 'Rescued items.' Anything in the temporary folder upon restart will be put into a folder by that name in the Trash automatically. This is indicative of the fact that the temp file was never deleted (as your error message indicated). Hope this helps. _troy //////// //////___Troy Gaul____________________tgaul@halcyon.com___// // // Infinity Systems // // // // Redmond, Washington // // //////____________________________________________________// +++++++++++++++++++++++++++ >From h+@nada.kth.se (Jon W{tte) Date: Sun, 21 Aug 1994 13:28:06 +0200 Organization: Royal Institute of Something or other In article <netnewsCuusHx.25A@netcom.com>, redial <redial@netcom.com> wrote: >Thanks to all who attempted to help with my 'Safe save' problem. It did >indeed look as tho closing the temporary file after the FSpExchangeFiles >swap would solve the problem of the 'File Busy' error message when I >attempted to delete the temporary file. Unfortunately :-( it didn't. That's because when you call FSpExchangeFiles, the open file reference still points into the data you're writing; i e the fRefNum now points into the "real" file and not the "temp" file which now contains the old data. You have to close the _old_ file! /* * Add error checking to taste * This assumes you're passing the address of your currently- * open file's fRefNum, and the FSSpec for it, and that there * is indeed a currently-open file. */ void SafeSave ( short * oldRefNum , const FSSpec * fileLocation ) { FSSpec tempSpec ; short tempRef = 0 ; FInfo fi ; FSpGetFInfo ( fileLocation , & fi ) ; MakeTempSpec ( & tempSpec ) ; FSpCreate ( & tempSpec , 'trsh' , 'trsh' , smSystemScript ) ; FSpOpenDF ( & tempSpec , fsRdWrPerm , & tempRef ) ; WriteDataToFile ( tempRef ) ; FSpExchangeFiles ( fileLocation , & tempSpec ) ; FSpSetFInfo ( fileLocation , & fi ) ; FSClose ( * oldRefNum ) ; * oldRefNum = tempRef ; FSpDelete ( & tempSpec ) ; } -- Jon Wätte (h+@nada.kth.se), Hagagatan 1, 113 48 Stockholm, Sweden Not speaking for IBM. --------------------------- >From Felix Ungman <felix@hu.se> Subject: MW DebugNew Tip Date: 22 Aug 94 14:06:13 +0000 Organization: (none) I want to thank MW for the DebugNew module! Even though my code was pretty well tested, I tracked down 5 memory leaks after only 15 minutes of testing! The only unneccecary flaw is that it violates the first rule of tools: Never, ever, increase the work of the user. Instead of making your code look like a mess of NEW macros (NEW is defined as "#define NEW new(__FILE__, __LINE__)") you can simply overide operator new with "#define new new(__FILE__, __LIN= E__)" Or if you don't want to edit the DebugNew.h file: #include <DebugNew.h> #define new NEW Works great in most cases. +++++++++++++++++++++++++++ >From dpodwall@world.std.com (Dan Podwall) Date: Mon, 22 Aug 1994 15:26:57 GMT Organization: Metrowerks, Inc. Felix Ungman (felix@hu.se) wrote: : Instead of making your code look like a mess of NEW macros : (NEW is defined as "#define NEW new(__FILE__, __LINE__)") : you can simply overide operator new with "#define new new(__FILE__, __LIN= : E__)" There reason it isn't done that way is because it would break the array form of operator new, e.g. char* p = new char[10]; You can't currently override the array operator new. I agree that if you don't need the array version then your modification is handy. Dan Podwall Metrowerks, Inc. --------------------------- >From peter.lewis@info.curtin.edu.au (Peter N Lewis) Subject: Scrollbars in Dialogs? Date: Sun, 21 Aug 1994 18:51:33 +0800 Organization: NCRPDA, Curtin University Hi All, Simple question, how do you do scroll bars as dialog items? I can set up the CNTL resource and then make a control item in the dialog, and the scontrol appears, and the dialog manager does all the tracking for it (tracks the clicks on the arrows and highlights them, and drags the thumb around). But the clicks on the arrows don't seem to change the value of the control. Do I have to install some sort of proc to track them? It can't be that hard, but I checked another program and it used a user item and created it's own control, so maybe it is? Peter. -- Peter N Lewis <peter.lewis@info.curtin.edu.au> - Macintosh TCP fingerpainter +++++++++++++++++++++++++++ >From rmah@panix.com (Robert Mah) Date: Sun, 21 Aug 1994 15:00:50 -0500 Organization: One Step Beyond peter.lewis@info.curtin.edu.au (Peter N Lewis) wrote: ) Simple question, how do you do scroll bars as dialog items? I can set up ) the CNTL resource and then make a control item in the dialog, and the ) scontrol appears, and the dialog manager does all the tracking for it I put a user item over (under?) the scroll bar item to catch clicks before they get to the scroll bar itself. This way, you can still use ResEdit (or whatever) to edit your dialog. And, yeah, you have to manually track the the arrows using a callback. Cheers, Rob _____________________________________________________________________ Robert S. Mah Software Development +1.212.947.6507 One Step Beyond and Network Consulting rmah@panix.com +++++++++++++++++++++++++++ >From tclement@hmc.edu (Todd Clements) Date: 22 Aug 1994 02:22:22 GMT Organization: Harvey Mudd College, Claremont CA USA Check out DialogBits on ftp.apple.com (I think in the snippets directory)... it's in C, but I'm sure you can figure it out. =) Todd -- tclement@hmc.edu Todd Clements - Chem nerd at Harvey Mudd College "In the beginning, there was nothing. And God said, 'Let there be LIGHT!' And there was still nothing; but now you could see it." --------------------------- >From Ola.Montan@malmo.trab.se (Ola Montan) Subject: Should new programs still be System 6 compatible? Date: Wed, 3 Aug 1994 11:32:14 GMT Organization: Telia Research AB I'm writing new programs for the Macintosh and I wonder: - Is it OK today to assume that the user have System 7.0 or later, or do I have to make it possible to run the program on System 6 or even System 5? - If I have to be able to run on System 6, what do I have to think about? All "compatiblity guidelines" tells about what to think about to run in System 7. / Ola Montán +++++++++++++++++++++++++++ >From decartwr@newstand.syr.edu (Dana Cartwright 3rd) Date: 3 Aug 1994 12:23:13 GMT Organization: Syracuse University, Syracuse NY, USA Ola Montan (Ola.Montan@malmo.trab.se) wrote: : I'm writing new programs for the Macintosh and I wonder: : - Is it OK today to assume that the user have System 7.0 or later, or do : I have to make it possible to run the program on System 6 or even System : 5? I'll add two more questions to your list: 68000 compatibility, and older versions of QuickDraw. I keep an "old" SE around and run my software on it, but I'm darned if I know why. Preserving compability with these older systems is less and less attractive (to the developer, at any rate!). Development goes forward (in my case) on a 68040. If you use floating windows (like Dean Yu's), you'll find they work differently on older ROM's (at least, I suspect it's code in the ROM's that's the difference, but that's just a guess on my part). +++++++++++++++++++++++++++ >From nagle@netcom.com (John Nagle) Date: Wed, 3 Aug 1994 16:38:21 GMT Organization: NETCOM On-line Communication Services (408 261-4700 guest) Ola.Montan@malmo.trab.se (Ola Montan) writes: >I'm writing new programs for the Macintosh and I wonder: >- Is it OK today to assume that the user have System 7.0 or later, or do >I have to make it possible to run the program on System 6 or even System >5? Unless your application is for the educational or game market, forget System 6. John Nagle +++++++++++++++++++++++++++ >From h+@nada.kth.se (Jon W{tte) Date: Wed, 03 Aug 1994 19:35:33 +0200 Organization: Royal Institute of Something or other In article <31o27h$8q8@newstand.syr.edu>, decartwr@newstand.syr.edu (Dana Cartwright 3rd) wrote: >: - Is it OK today to assume that the user have System 7.0 or later, or do >: I have to make it possible to run the program on System 6 or even System >: 5? >I'll add two more questions to your list: 68000 compatibility, and >older versions of QuickDraw. I keep an "old" SE around and run my This is covered in the FAQ (the Total Authority Document :-) Anyway, there seems to be two ways you can go: 1) Does your app require color, or AppleEvents, or QuickTime, or more than 1 MB of memory (for itself)? Or does it require more than one process running at once? Go for System 7 only. 2) Is your application in the "typical application" cathegory; word processing, telecommunications, ... People who bought their computers four years ago probably bought what they need already. Go with System 7. 3) So you're writing a novelty application which will work well on small screens, in black/white, in a small memory footprint. Here, you might still sell into a bigger market if you work with System 6 as well. However, for the majority of applications, it's just not worth it. As an example, here is what I _demand_ to run in my newer apps: - New File Manager (soon to be renamed the Old New File Manager :-) - 32-bit QuickDraw - 68020 or better - AppleEvents Of course I test for these individually, but on failure, I tell users to upgrade to System 7 (or their computer, if the CPU test fails) However, some things should NOT be demanded. That Virtual Memory be off is an _evil_ thing, especially on PowerPCs where system performance is BETTER with VM on, as long as your swap file just covers your RAM and another meg or two. Cheers, / h+ -- Jon Wätte Hagagatan 1 113 48 Stockholm Sweden +++++++++++++++++++++++++++ >From blm@chinook.halcyon.com (Brian L. Matthews) Date: 3 Aug 1994 17:28:09 GMT Organization: Northwest Nexus Inc. In article <1994Aug3.113214.15566@malmo.trab.se>, Ola Montan <Ola.Montan@malmo.trab.se> wrote: |- Is it OK today to assume that the user have System 7.0 or later, or do |I have to make it possible to run the program on System 6 or even System |5? In my opinion, don't worry about anything earlier than System 6. If your target market is higher end users (who probably have newer machines which don't even run System 6), don't worry about System 6. If your target is lower end users (who can't necessarily afford to upgrade to the new machines or have the hardware to run System 7), you need to worry about System 6. However, whatever you assume about the target machine, make sure your software tests your assumptions at run time and reacts gracefully if they're wrong. So if your software requires System 7, test for that, and if you're not running on System 7 or later, present an alert stating you need System 7, then exit (and of course the code that does this needs to run on System 6, and is simple enough it can probably run on earlier systems as well). Similarly for things like processor (68000 vs. 68020 vs. PowerPC), Color Quickdraw, DSP, etc. Brian +++++++++++++++++++++++++++ >From woody@alumni.caltech.edu (William Edward Woody) Date: 3 Aug 1994 20:32:35 GMT Organization: California Institute of Technology, Alumni Association In article <1994Aug3.113214.15566@malmo.trab.se>, Ola Montan <Ola.Montan@malmo.trab.se> wrote: >I'm writing new programs for the Macintosh and I wonder: > >- Is it OK today to assume that the user have System 7.0 or later, or do >I have to make it possible to run the program on System 6 or even System >5? According to some information I got from Apple in one of their developer's mailings, most users are running under System 7. But 'most' means > 50%; not everyone has upgraded yet. It's reasonable to support System 6.0.7 as well as System 7. >- If I have to be able to run on System 6, what do I have to think about? >All "compatiblity guidelines" tells about what to think about to run in >System 7. What I check for in my standard initialization loop in the library I tend to use for all applications are: o Is AppleEvents available? (If they are, I install my Apple Events handler. If they are not, I use CountAppFiles() and GetAppFiles() to get the files which my application was run with.) o Is Color Quickdraw available? (For applications which use color. For applications which use 32 bit color, I also check the features which are available through the gestaltQuickdrawFeatures selector. o Are FSSpec-selectors available? (This sets a global flag. Anytime I want to open a file, I use the FSpOpenDF() call if the flag is set, and HOpen() call if it's clear. One of the cheats I use is to use the fields of the FSSpec data structure to store the Volume RefNum, Directory ID, and file name of the file I'm working with if that flag is clear. Though Apple says not to initialize the fields of a FSSpec by hand, I interpret that as meaning that if FSSpecs are supported by the OS, then you should use FSMakeFSSpec(). Otherwise, an FSSpec is simply 70 bytes of storage that's up for grabs.) All of the System 7 compatability guidelines (be 32 bit clean, work well with MultiFinder, etc., etc., etc.) are just generally good hygene. And getting into the habit of checking with Gestalt for a particular feature is algo just good hygene. I hope this helps. - Bill -- - William Edward Woody | Disclamer: woody@alumni.cco.caltech.edu | "He who knows does not speak; - In Phase Consulting | He who speaks does not know." 337 West California #4; Glendale, CA 91203 | - Lao Tzu +++++++++++++++++++++++++++ >From lbotez@picard.cs.wisc.edu (Lynda Botez) Date: 3 Aug 1994 21:04:49 GMT Organization: U of Wisconsin CS Dept Excuse me, but do you really tell your users to "upgrade their computer?" haha... "Your computer sucks; get a "real" computer..." Sorry, that just cracks me up... <grin> +++++++++++++++++++++++++++ >From marshall@cais.com (Preston Marshall) Date: 3 Aug 1994 18:09:24 GMT Organization: Vanguard Research, Inc. > Ola Montan (Ola.Montan@malmo.trab.se) wrote: > : I'm writing new programs for the Macintosh and I wonder: > > : - Is it OK today to assume that the user have System 7.0 or later, or do > : I have to make it possible to run the program on System 6 or even System > : 5? > I sent E-mail to Apple developer services once suggesting that they periodically publish their estimates as to "what was out there" in terms of systems and OS's. They must have a guess as to how many plusses, SE's or even IIfx's are stil active and being used. I would like to know what I loose when I decide to make a feature mandatory. The problem is going to come up again when 7.5 gets established. -- ___________________________________________________________________ | Preston Marshall - marshall@cais.com | | Vanguard Research, Inc. - | | 10306 Eaton Pl. - The opinions are mine, | | Farifax, Va 22111 - my employer doesn't care | ___________________________________________________________________ +++++++++++++++++++++++++++ >From h+@nada.kth.se (Jon W{tte) Date: Thu, 04 Aug 1994 11:00:59 +0200 Organization: Royal Institute of Something or other In article <31out3$lme@gap.cco.caltech.edu>, woody@alumni.caltech.edu (William Edward Woody) wrote: >According to some information I got from Apple in one of their >developer's mailings, most users are running under System 7. >But 'most' means > 50%; not everyone has upgraded yet. It's >reasonable to support System 6.0.7 as well as System 7. A year ago, the 50% limit was already passed. Since then, Apple has sold several million more computers, all of them with 68030s, color quickdraw enabled, and running System 7. People seem to be still living in the pre-1991 world of "lots" of 68000 macs. Face it: the way Apples sales have been taking off the last few years, 68000 and System 6 is a CLEAR minority, and since those computers are at least three years old, they probably don't buy much software anymore. The exception is of course the lower educational market; nobody ever spends enough money on educating the coming generation. Cheers, / h+ -- Jon Wätte Hagagatan 1 113 48 Stockholm Sweden +++++++++++++++++++++++++++ >From zobkiw@datawatch.com (joe zobkiw) Date: Thu, 4 Aug 1994 15:13:35 GMT Organization: Datawatch Corporation Even if your app doesn't REQUIRE AppleEvents, PPCToolbox, QuickTime, etc. I would say don't waste your time supporting System 6. I am currently working on a commercial project that must support System 6 and it stinks. You can't use the cool icon utilities, can't use the new standard file routines, can't tail patch safely, can't depend on color QuickDraw, can't use the the nice auto-positioning features of the Window Manager. Supporting System 6 consists of carrying a lot of extra baggage - in the form of code. Ever date someone who has a lot of extra emotional baggage? It's a _very_ similar experience! ___________________________________________________________ _/_/_/_/ Joe Zobkiw ,,, _/ Senior Software Engineer - - _/ Datawatch Corporation L _/_/_/_/ zobkiw@datawatch.com - How can one expect to program without buying a single IM? +++++++++++++++++++++++++++ >From Jeff Abrahamson <Jeff@purple.com> Date: Thu, 04 Aug 94 10:20:40 -0500 Organization: Purple In article <31ok39$sth@nwfocus.wa.com>, Brian L. Matthews writes: > However, whatever you assume about the target machine, make sure your > software tests your assumptions at run time and reacts gracefully if they're > wrong. I agree. However, some problems arise: - I compile for a 68020, but the user has but a 68000. Unless I'm using MPW, I don't know how to compile just a single segment for 68000 and the rest for 68020. - I compile for 68881, but the user doesn't have a 68881. Same problem as above. Note that PPC's crash when you make 68881 calls, so it's not just a low-end-only problem. Standard Disclaimer: Of course, these may be easily solved problems to which I simply don't know the answers. -Jeff Abrahamson PDI +++++++++++++++++++++++++++ >From Kevin.R.Boyce@gsfc.nasa.gov (Kevin R. Boyce) Date: Thu, 04 Aug 1994 13:24:23 -0400 Organization: NASA/GSFC In article <94080410204000115@purple.com>, clio!jeff@vu-vlsi.ee.vill.edu wrote: >In article <31ok39$sth@nwfocus.wa.com>, Brian L. Matthews writes: > >> However, whatever you assume about the target machine, make sure your >> software tests your assumptions at run time and reacts gracefully if they're >> wrong. > >I agree. However, some problems arise: > >- I compile for a 68020, but the user has but a 68000. Unless I'm using >MPW, I don't know how to compile just a single segment for 68000 and the >rest for 68020. Metrowerks I don't know from (yet), but for Think C: #pragma options( mc68020, mc68881 ) to turn them on, #pragma options( !mc68020, !mc68881 ) to turn them off. See pp. 322ff in the TC6 manual. BTW, it would be nice if you used shorter lines in your posts. Newswatcher couldn't clean it up; I had to shlep all the way over to BBEdit. :-) -- Kevin Kevin.R.Boyce@gsfc.nasa.gov Goodbye Clipper chip, hello asteroid Zappa. Is this a great country or what? +++++++++++++++++++++++++++ >From pcastine@jake.prz.tu-berlin.de (Peter Castine) Date: Thu, 4 Aug 1994 19:08:29 GMT Organization: PRZ TU-Berlin marshall@cais.com (Preston Marshall) writes: > >I sent E-mail to Apple developer services once suggesting that they >periodically publish their estimates as to "what was out there" in terms >of systems and OS's. They must have a guess as to how many plusses, SE's >or even IIfx's are stil active and being used. > If you're a registered developer, you get Apple Direct. They have published figures from time to time Re: numbers of various Machines and OS Versions out there in userland. Sorry, don't have one here to quote off hand. -- Peter Castine | Oh, wenn jene alten, musikkundigen Gelehrten die pcastine@prz.tu-berlin.de | Modernen hoerten, was wuerden sie tun, was Process Control Center | wuerden sie sagen! Technical University Berlin | -- Jacobus von Luettich (ca. 1330) +++++++++++++++++++++++++++ >From Jens Alfke <jens_alfke@powertalk.apple.com> Date: Wed, 3 Aug 1994 20:34:58 GMT Organization: Apple Computer Jon W{tte, h+@nada.kth.se writes: > However, some things should NOT be demanded. That Virtual Memory be > off is an _evil_ thing, especially on PowerPCs where system > performance is BETTER with VM on, as long as your swap file just > covers your RAM and another meg or two. Is that true for you? I turned VM on on my 7100 and gave it 1 more MB than I have physical RAM, and still it made my CodeWarrior compiles a lot slower. (During compilation, after every few files I could hear my disk doing a lot of VM thrashing...) It was something like a 20% performance penalty, although I didn't time it. I believe the problem is that since part of the physical RAM is being used to store code, it's not available for heaps, so there's really much greater than 1MB difference between the virtual and physical memory available for heap zones. It's a shame ... guess I'll have to wait until Copland for good VM. --Jens Alfke jens_alfke@powertalk.apple.com "A man, a plan, a yam, a can of Spam ... Bananama!" +++++++++++++++++++++++++++ >From Jens Alfke <jens_alfke@powertalk.apple.com> Date: Thu, 4 Aug 1994 20:34:16 GMT Organization: Apple Computer Jeff Abrahamson, Jeff@purple.com writes: > - I compile for a 68020, but the user has but a 68000. Unless I'm using MPW, I > don't know how to > compile just a single segment for 68000 and the rest for 68020. In C/C++, you do this with #pragma statements. Check your development system's manual; THINK and CodeWarrior do this differently but both of them let you change most of the compile settings via pragmas. I believe Pascal has similar stuff. > - I compile for 68881, but the user doesn't have a 68881. Same problem as > above. Note that PPC's > crash when you make 68881 calls, so it's not just a low-end-only problem. Again, there are pragmas to turn 881 codegen on and off. If you want to run with or without an 881 but take advantage of it if it exists, the best thing is probably to include two versions of your core math-intensive routines, one compiled for 881 and one not. (You can put the two versions in different segments, so only one will ever get loaded.) Then call Gestalt at startup to check whether you have an 881, and call one routine or the other depending. Or if you're megaconcerned about efficiency, at startup set up some procptrs to point to one or the other set of routines, and then call the routines through the procptrs. --Jens Alfke jens_alfke@powertalk.apple.com "A man, a plan, a yam, a can of Spam ... Bananama!" +++++++++++++++++++++++++++ >From ari@world.std.com (Ari I Halberstadt) Date: Fri, 5 Aug 1994 09:25:45 GMT Organization: The World Public Access UNIX, Brookline, MA In article <zobkiw-0408941013350001@zobkiw.datawatch.com>, joe zobkiw <zobkiw@datawatch.com> wrote: >Even if your app doesn't REQUIRE AppleEvents, PPCToolbox, QuickTime, etc. >I would say don't waste your time supporting System 6. I am currently >working on a commercial project that must support System 6 and it stinks. >You can't use the cool icon utilities, can't use the new standard file >routines, can't tail patch safely, can't depend on color QuickDraw, can't >use the the nice auto-positioning features of the Window Manager. I don't think tail patching was fully authorized with sys-7.0. I think the PowerPC sys software was the first to allow tail-patching for all patchable traps, and that was due to the way the MMM (mixed-mode mangler) calls patches. Color QuickDraw is only supported on CPUs 68K and greater, and was supported in systems prior to 7.0 on appropriate hardware. >How can one expect to program without buying a single IM? Buy all of them on the forthcoming CD :-) Regular $100, but if you preorder, then it's only $80. You're not charged till it ships, and they'll call to confirm that you still want it. MacWorld show special, but Addison-Wesley might extend this beyond the show. I think having all of NIM on a CD is essential. -- Ari Halberstadt ari@world.std.com One generation passes away, and another generation comes: but the earth abides for ever. -- Ecclesiastes, 1:4. +++++++++++++++++++++++++++ >From ari@world.std.com (Ari I Halberstadt) Date: Fri, 5 Aug 1994 09:40:14 GMT Organization: The World Public Access UNIX, Brookline, MA In article <Cu226y.MLn@world.std.com>, Ari I Halberstadt <ari@world.std.com> wrote: >Color QuickDraw is only supported on CPUs 68K and greater, and was >supported in systems prior to 7.0 on appropriate hardware. Ack, I didn't mean 68K or greater, I meant 68020 and later CPUs. -- Ari Halberstadt ari@world.std.com One generation passes away, and another generation comes: but the earth abides for ever. -- Ecclesiastes, 1:4. +++++++++++++++++++++++++++ >From giles@med.cornell.edu (Aaron Giles) Date: Fri, 05 Aug 1994 13:36:13 -0400 Organization: Cornell University Medical College In article <1994Aug3.203458.22623@gallant.apple.com>, Jens Alfke <jens_alfke@powertalk.apple.com> wrote: > Jon W{tte, h+@nada.kth.se writes: > > However, some things should NOT be demanded. That Virtual Memory be > > off is an _evil_ thing, especially on PowerPCs where system > > performance is BETTER with VM on, as long as your swap file just > > covers your RAM and another meg or two. > > Is that true for you? I turned VM on on my 7100 and gave it 1 more MB than I > have physical RAM, and still it made my CodeWarrior compiles a lot slower. > (During compilation, after every few files I could hear my disk doing a lot > of VM thrashing...) It was something like a 20% performance penalty, although > I didn't time it. I think CW uses temporary memory during compiles, which will cause thrashing in the system heap, where your extra 1MB is probably hanging out. I really really wish Apple would let you set your VM to exactly your system memory, so that you can get file mapping without fear of trashing in the extra 1MB. I tried hacking the system file to set VM down to exactly equal to my physical memory, but it wasn't too happy after that. :-) Aaron -- Aaron Giles (giles@med.cornell.edu) Power Macintosh Developer, Cornell University Medical College JPEGView home page: http://www.med.cornell.edu/jpegview.html JPEGView FTP site: ftp://ftp.med.cornell.edu/pub/aarong/jpegview/ +++++++++++++++++++++++++++ >From gurgle@dnai.com (Pete Gontier) Date: Fri, 05 Aug 1994 11:02:43 -0800 Organization: Integer Poet Software In article <zobkiw-0408941013350001@zobkiw.datawatch.com>, zobkiw@datawatch.com (joe zobkiw) wrote: > I am currently working on a commercial project that must support System 6 > and it stinks... You can't ... depend on color QuickDraw... You can't depend on Color QuickDraw even under System 7. -- Pete Gontier // CTO, Integer Poet Software // gurgle@dnai.com "Clear-cutting removes all trees... to create new habitats for wildlife. P&G uses this economically and environmentally sound method because it most closely mimics nature's own processes. Clear-cutting also opens the floor to sunshine, thus stimulating growth and providing food for animals." -- Procter & Gamble's "Decision Earth" free school curriculum +++++++++++++++++++++++++++ >From wdh@netcom.com (Bill Hofmann) Date: Fri, 5 Aug 1994 18:04:16 GMT Organization: Fresh Software In article <Cu226y.MLn@world.std.com>, ari@world.std.com (Ari I Halberstadt) wrote: > I don't think tail patching was fully authorized with sys-7.0. I think > the PowerPC sys software was the first to allow tail-patching for all > patchable traps, and that was due to the way the MMM (mixed-mode > mangler) calls patches. Recent threads have discussed that tail patching has been legit with a few exceptions (FrontWindow(), apparently, who knows why?) since system 7, because of the revised way come-from patches are done by system software. -Bill -- Bill Hofmann wdh@netcom.com Fresh Software and Instructional Design voice: +1 510 524 0852 1640 San Pablo Ave #C, Berkeley CA 94702 USA fax: +1 510 524 0853 +++++++++++++++++++++++++++ >From wdh@netcom.com (Bill Hofmann) Date: Fri, 5 Aug 1994 18:16:35 GMT Organization: Fresh Software In article <nagleCtywvx.Bys@netcom.com>, nagle@netcom.com (John Nagle) wrote: > Ola.Montan@malmo.trab.se (Ola Montan) writes: > >I'm writing new programs for the Macintosh and I wonder: > >- Is it OK today to assume that the user have System 7.0 or later, or do > >I have to make it possible to run the program on System 6 or even System > >5? > Unless your application is for the educational or game market, > forget System 6. I agree: this is the "proper" approach--evaluate your target market, and decide based on this. So for instance, if you're targeting PowerBooks, you can ignore sys 6 (unless you're worried about the transitional Kanji sys 6 that lots of people in Japan were running prior to system 7.1). Probably at this point, you could ignore system 6 (maybe even 7.0) for mass market if you're targeting the Performa market. Don't forget to factor in development time: 50% may be running 7.5 by the time you finish :-(. Also, where you *don't* have to assume system 7, don't. You can and should use FSSpec's, and the MakeFSSpec call has glue for pre-7 systems. You can wrap portions that are different in 6 vs 7 (HOpen vs FSpOpenDF: who names these things?) in a common routine that has consistent calling conventions to maintain maximum compatibility. Other areas like the script manager are so different from release to release of system software that one could be forgiven for requiring not just 7.0 but 7.1 (the basis of NIM, after all). Obviously if you're writing a program to do collaboration, you can require 7.1 Pro, or if you're writing a GX Print Utility, you can require GX, so that gives you license to require all kindsa things. I would still test on 68000 Macs, but more as an afterthought. I've still got a Classic at home and an SE with a jet engine fan in the office collecting dust, and occasionally give things a try on there. -Bill -- Bill Hofmann wdh@netcom.com Fresh Software and Instructional Design voice: +1 510 524 0852 1640 San Pablo Ave #C, Berkeley CA 94702 USA fax: +1 510 524 0853 +++++++++++++++++++++++++++ >From qsi@cnh.wlink.nl (Peter Kocourek) Date: 07 Aug 94 16:54:24 +0200 Organization: Care Net Holland Bill Hofmann wrote in a message on 05 Aug 94: BH> Probably at this point, you could ignore system 6 (maybe even BH> 7.0) for mass market if you're targeting the Performa market. BH> Don't forget to factor in development time: 50% may be running BH> 7.5 by the time you finish :-(. Considering Apple's idiotic pricing of 7.5, I don't think you should be too worried about many users running it. :-/ YHS:QSI! +++++++++++++++++++++++++++ >From mason@cis.umassd.edu (Mason Bliss) Date: Wed, 10 Aug 1994 02:41:11 GMT Organization: University of Massachusetts Dartmouth In <80b_9408080302@cnh.wlink.nl> qsi@cnh.wlink.nl (Peter Kocourek) writes: >Considering Apple's idiotic pricing of 7.5, I don't think you should be too >worried about many users running it. :-/ Heh. Oh, come on! I *want* to go out and spend big bucks so that my system disks will install all the stuff I've FTPed *for* me. I may be missing something, but it doesn't look like 7.5 has anything terribly significant in it. It looks more akin to the jump from 7.0 to 7.5, where we could spend all kinds of money to have a fonts folder. My preference is this: Write for 7.0. Don't go out of your way to make things incompatible with System 6. If you can be compatible with System 6, great, but if not, don't worry about it. -- Mason L. Bliss - mason@acheron.middleboro.ma.us - mason@cis.umassd.edu "What diabolical chicken stepped on your forehead and sat on your chin?" +++++++++++++++++++++++++++ >From gurgle@dnai.com (Pete Gontier) Date: Tue, 09 Aug 1994 20:19:53 -0800 Organization: Integer Poet Software In article <Cu226y.MLn@world.std.com>, ari@world.std.com (Ari I Halberstadt) wrote: > I don't think tail patching was fully authorized with sys-7.0. Yes, it was, other than FrontWindow or FindWindow or some other call that starts with 'F' and ends with 'Window'. :-) I'd be surprised if there were an official Apple document with a specific announcement, but Apple employees, indeed, Blue Meanies, have posted repeatedly here that this is the case. -- Pete Gontier // CTO, Integer Poet Software // gurgle@dnai.com "I am Homer of Borg! Prepare to be... Ooooooo! Donuts!" +++++++++++++++++++++++++++ >From alexr@apple.com (Alexander M. Rosenberg) Date: Wed, 10 Aug 1994 19:06:51 GMT Organization: Hackers Anonymous In article <gurgle-0908942019530001@gurgle.dnai.com>, gurgle@dnai.com (Pete Gontier) wrote: > In article <Cu226y.MLn@world.std.com>, ari@world.std.com (Ari I > Halberstadt) wrote: > > > I don't think tail patching was fully authorized with sys-7.0. > > Yes, it was, other than FrontWindow or FindWindow or some other call that > starts with 'F' and ends with 'Window'. :-) I'd be surprised if there were > an official Apple document with a specific announcement, but Apple > employees, indeed, Blue Meanies, have posted repeatedly here that this is > the case. And I believe that Inside Mac: Operating System Utilities even states this. - ------------------------------------------------------------------------- - Alexander M. Rosenberg - INTERNET: alexr@apple.com - Yoyodyne - - 330 Waverley St., Apt B - UUCP:ucbvax!apple!alexr - Propulsion - - Palo Alto, CA 94301 - - Systems - - (415) 329-8463 - Nobody is my employer so - :-) - - (408) 974-3110 - nobody cares what I say. - - +++++++++++++++++++++++++++ >From qsi@cnh.wlink.nl (Peter Kocourek) Date: 11 Aug 94 15:37:07 +0200 Organization: Care Net Holland Mason Bliss wrote in a message on 10 Aug 94: MB> In <80b_9408080302@cnh.wlink.nl> qsi@cnh.wlink.nl (Peter Kocourek) MB> writes: >Considering Apple's idiotic pricing of 7.5, I don't think you should be too >worried about many users running it. :-/ MB> Heh. Oh, come on! I *want* to go out and spend big bucks so MB> that my system disks will install all the stuff I've FTPed MB> *for* me. MB> I may be missing something, but it doesn't look like 7.5 has MB> anything terribly significant in it. It looks more akin to MB> the jump from 7.0 to 7.5, where we could spend all kinds of MB> money to have a fonts folder. This is not entirely fair: System 7.5 does come with QuickDraw GX and PowerTalk. Some people will find these enhancements valuable, although personally, I probably won't be using either of them. The question is, whether the $140 Apple wants to charge for the update is reasonable. I don't happen to think so, even if I had a use for GX. It is clear that GX is a substantial achievement, and its development cost Apple a lot of money. I also understand that Apple wants to offset the developments costs. However, I don't this is the best way of going about it. The ultimate success of new technologies will be determined by how widely they are adopted by users and developers. Developers are less likely to support Apple's cool new technologies, if the installed user base is small. I think the $140 (or $99 street) would be more reasonable for a more substantial upgrade, like Copland. MB> My preference is this: Write for 7.0. Don't go out of your MB> way to make things incompatible with System 6. If you can be MB> compatible with System 6, great, but if not, don't worry about MB> it. I don't support System 6 any longer in new programs I write. Maintaining older programs, I keep the System 6 stuff in. As for supporting post-7.0 features, I implement them based on how much work it is, and how much demand there is for them. YHS:QSI! +++++++++++++++++++++++++++ >From ingemar@lysator.liu.se (Ingemar Ragnemalm) Date: 19 Aug 1994 21:27:13 GMT Organization: (none) Ola.Montan@malmo.trab.se (Ola Montan) writes: >I'm writing new programs for the Macintosh and I wonder: >- Is it OK today to assume that the user have System 7.0 or later, or do >I have to make it possible to run the program on System 6 or even System 5? Forget System 5. If you can make your program run on it, well, good, but that is like paiting the back of the drawers - you know you did a great job, but few will care. System 6.0.7 is the lowest system that is interesting to support. If you should, depends on the users. Many low-end users use System 6, especially those on slow Macs like MacPlus, or Macs with little memory. Extreme case of needing System 6: Networked games! If you make a networked game, try to support both System 6 and non-color-QuickDraw. Many long-time Mac users have two Macs, and one of them might be an old Plus or SE. If your program is color only, there is a smaller population who will want System 6. Not none at all, but making it work in b/w (esp non-color QD) is more important. And, as someone noted, if you make high-end applications, where most of your users use new, high-end Macs, well, who will notice? >- If I have to be able to run on System 6, what do I have to think about? >All "compatiblity guidelines" tells about what to think about to run in >System 7. Only use stuff described in IM 1-5. GWorlds can be demanded, at least from color users, since they can install it under sys 6. If you can't run System 6 yourself, you better find someone who do, or you'll never know. -- - - Ingemar Ragnemalm, PhD Image processing, Mac shareware games E-mail address: ingemar@isy.liu.se or ingemar@lysator.liu.se +++++++++++++++++++++++++++ >From quinn@cs.uwa.edu.au (Quinn "The Eskimo!") Date: Sun, 21 Aug 1994 15:26:10 +0800 Organization: Department of Computer Science, The University of Western Australia In article <33383h$cm0@newsy.ifm.liu.se>, ingemar@lysator.liu.se (Ingemar Ragnemalm) wrote: >System 6.0.7 is the lowest system that is interesting to support. I disagree. 6.0.5 has most of the features of 6.0.7 (specifically _Gestalt) but is a lot more reliable on machines that don't need 6.0.7 (ie LC, IIsi). If you're going to support System 6 you should support back to 6.0.5! -- Quinn "The Eskimo!" <quinn@cs.uwa.edu.au> "Support HAVOC!" Department of Computer Science, The University of Western Australia +++++++++++++++++++++++++++ >From kaufman@Xenon.Stanford.EDU (Marc T. Kaufman) Date: 22 Aug 1994 03:08:30 GMT Organization: Computer Science Department, Stanford University. In article <quinn-2108941526100001@edu-dynamic5.educ.ecel.uwa.edu.au>, Quinn "The Eskimo!" <quinn@cs.uwa.edu.au> wrote: >In article <33383h$cm0@newsy.ifm.liu.se>, ingemar@lysator.liu.se (Ingemar >Ragnemalm) wrote: ->System 6.0.7 is the lowest system that is interesting to support. >I disagree. 6.0.5 has most of the features of 6.0.7 (specifically >_Gestalt) but is a lot more reliable on machines that don't need 6.0.7 (ie >LC, IIsi). If you're going to support System 6 you should support back to >6.0.5! I have one customer who is running 6.0.3, because he likes the Quickdraw bug that caused hairlines not to fatten when copied to a larger bitmap. He needed that feature to create hairline targets on 35mm slides. I think we can agree not to go back to 4.x, though, can't we? Marc --------------------------- >From h+@nada.kth.se (Jon W{tte) Subject: The System 7.5 Think Debugger Bug - and fix! Date: Fri, 19 Aug 1994 22:27:29 +0200 Organization: Royal Institute of Something or other As you may now be aware of, there is a bug in Think Debugger and/or System 7.5 that makes the debugger freeze on startup for several kinds of projects. It worked in 7.5b5, but not now. Everyone at apple says that nothing changed in the Process Manager between them. The bug, however, DOES depend on Think Debugger calling GetNextEvent in a tight loop, waiting for an app4Evt that doesn't get there. This INIT, when installed, patches GetNextEvent to call WaitNextEvent and give 6 in background time, which makes the debugger work once again. Since WaitNextEvent calls GetNextEvent internally, AND process switched happen during WaitNextEvent calls, I have a nice re-entrancy problem which I solve with a linked list of A5 values in the system heap. This list is NOT cleaned up, and consists of nonrelocatable blocks, so use with care! (it doesn't crash, though) Source included Enjoy, / h+ (Pardon the binary posting on this group, but it's SOOO small, important and relevant...) (This file must be converted with BinHex 4.0) :#d&bBfKTGQ8ZFfPd!&0*9%46593K!*!%"Ld!N!6D4P0*9#%!!J!!"Leb6'&e!J# 3""B!!!d!$8G145dq9dj&)%P1596H@!!@plS!N!1!!*!%!H6TS19H!*!8!EX!N!6 rN!4*6NP89dj&)3%!URT2MUTkL[S!!!(q!*!'!68!N!6D+J#3#%Q%%3!)(2b83a! V!94,T9i#L+fB8,L`SeBec9BMfcTU5@aFfq5N'Xel*#IKpXRY3aiR%MR6jb"3cN[ VpVYM@1FpXK8b`kN8kqYjTkpR9Pp8UlfE*-a0NYj*NYj*NZ+bNkT-8Z8QDPY(,BR 9DRAMGeT-b@l"hV'%0p@-)b[Ac$eqleT0aaFq[NhV0q'iFU-6hS3m@RpIfq3XKrF DhlA'Pk2epl9eP&diN!"m#h'DVQlC[hUY#`(9c0fYFiZDN!#rCNh)efi)j'aer,L q,AT!3Fc"dbVJ-+(c#e!`q4BRZdTR-kjd'*0D[&cJJQFJ0M8@YqmlY9B9b*h`$14 1cUUC1eV`q0,PqT3EAGB2X3P23qiS*'I0ZkE'V,4UmfqBG(`pFH0B4k&31rXHQ5E #+)$!c&5AFm@+Fk56!!!0$3CYB@PZ,Q1H3*U))!(FhPJ!&[Hk!*!$J!#3"!(NkD$ 3+!#3%4B!N!MrN!4849K85d&)6!%!UE8-1+TkLQ-!!!&q!!!(rJ#3!pN!!!-T#dX dl`#3"U1-%3!)(!`k"&(aqD"SC3Dj+c,)Gr&*N!#EjkQCUfDqj!N`2E!RVJka160 )K2P5-Ma1Q*E8-p3aS9dR"-Tjc!!hCRhNXYj[RCf[)8#Z'8lVA9eZ9Y0MG`)RUA0 UTiF,MNVZRCb9h"fJh91SK,2%M*P,j*3,PHYbqr13!!m(FH$@jk&SF+I#plbE2@0 HYY[*cY(CFXMNHFZaMc+a,aY%"DqI-j,#2pJUrJ5)KDS3imQ)D3E1KA$T(Rc#X&e SpSk)jV0Z#4lDpX+0qcN+G66`"i*G(8f-Q6,c+TlBYU!&#Nlaj!%)-S$*86*BMl# 9VH%[XZBP-m))ME!RE%#1f4(k%8TQ+`&B2H$e2(S!UdB"2ZS64LK"!#0)BJ6p#!$ ZqQa!9RD%(AP+RKdjCNH'M)`B33)$)!m!0,$fpq&c-"KdiBe-iH+6-FMBAT+')Sm 3(Vmlqf!5SG[aNjAS,8kP@PJ0Lj&(U+!"6ID4H9a2i50,dX3--jQNjK%lmV`SE-r !Rr2"H1bjG`62FC42*UJBmcb"()jVbaEh594j"Th$b[-83hQ$kK92)i&N-DAIYJ$ ZYaifH,qj-Kd-1R93`m2i&,A-98M&PVBcf,-q3DF9qBA4DbVJ)NNM1G1V*2eZVdV b%XfjP1*FmHaT&#R8eXGe*d8dA0QhH,"TTm'$jV,RM*X`hVVCZ[q@dZ[fUe,1[T@ LM'EX5e$i`q+kKlkrl)'k2m'jHA'$UIP(apVr0ajEZadIplhm"131ff93!3hZ0`[ "j64c[e8JK9b)"A#ic%PT**JBJD*X@#hT@pGcMar*8jRCHNCD`A%BBhJej&P'!U- 0q8DfMe'+T+81KLC@-Tr%+cS#JXQh3lLE4T,SI(30Hjd@lpH'rKbY[$"aCB3b@d$ '&CqL3@8C,U2iml#f)PP'"2Rc([f%3T&q0m'(2BHScA6"N`fPCAJAajm(IY93QE6 MK)ip'mdD8DHe[PIV,FC9JU,BLPE'eSJ3HhGMp!0kaJL*LN23XF`*G)2D3$*fi&X C&l3*d3*LVX'QaJMSf##+D!,D&#!aPE0#Nk[8'Bm&Rd#5%Y0!p`c0LEYpk*!!+KH PdP-G4c!5-V`#E93H8J#N*B'8'LcZ*AYmGCXNi3IPKr0ZG*UXVZlAq*4m8)Iad2# 43!Z#N!!bXqMBq5R`X!1%eh#XF**SLPlZd`BJ1qrK0+2rVYhf&MqSA-Fb6k1Y*3m +iND+dYZmM#eG(,EP@Kbk+'i"E9(&Yh0femkkMcpPIldG5`9G')'p,pCA6S"9JK1 F[6IUE+'I83QV($E$Jqq(65diD"%1MU#b`'TXV!&0FjRDe9PMk"LJ*QL"f@kmGYV YXEH8HVIXPV%EQ84XbQP5'XbcRqjJ[fAr!3#3!dbQ!!!: -- Jon Wätte (h+@nada.kth.se), Hagagatan 1, 113 48 Stockholm, Sweden "TextEdit does everything right." ‹ Jon W{tte +++++++++++++++++++++++++++ >From tree@bedford.symantec.com (Tom Emerson) Date: Sat, 20 Aug 1994 17:15:43 -0800 Organization: Symantec Development Tools Group In article <9668AA7AE251.45173@klkmac004.nada.kth.se>, h+@nada.kth.se (Jon W{tte) wrote: > As you may now be aware of, there is a bug in Think Debugger > and/or System 7.5 that makes the debugger freeze on startup for > several kinds of projects. > > It worked in 7.5b5, but not now. Everyone at apple says that > nothing changed in the Process Manager between them. The bug, > however, DOES depend on Think Debugger calling GetNextEvent in > a tight loop, waiting for an app4Evt that doesn't get there. Some background on this: the TPM/THINK Debugger IAC worked through 7.5b6. >From that point on some change in the new system software broke the communications mechanism. The problem only occurs for some projects (one commonality is the number of static constructors it contains - we haven't seen it with large C applications), and we have yet to determine the exact circumstances that cause the problem to appear or what changed in the System software to hose it. We've talked to the engineer responsible for the Process Manager in 7.5 and he doesn't know what changed either, so this is a mystery. The loop that waits on app4Evt's and updateEvts appears in both the TPM and Debugger --- which one you hang in depends on who initiated the communication. > This INIT, when installed, patches GetNextEvent to call > WaitNextEvent and give 6 in background time, which makes the > debugger work once again. Since WaitNextEvent calls [snip] This is the fix that we will probably make, though we need to QA more before releasing it, and it would be nice to know what actually changed in the System to bring about the problem. -tre -- Tom Emerson Software Engineer Development Tools Group Symantec Corporation tree@bedford.symantec.com "I dreamed I had to take a test, in a Dairy Queen, on another planet." +++++++++++++++++++++++++++ >From stevep@wrq.com (Steve Poole) Date: Mon, 22 Aug 1994 10:59:25 -0800 Organization: Walker Richer & Quinn In article <tree-2008941715430001@155.64.60.21>, tree@bedford.symantec.com (Tom Emerson) wrote: > communications mechanism. The problem only occurs for some projects (one > commonality is the number of static constructors it contains - we haven't > seen it with large C applications), and we have yet to determine the exact I've seen it with large C apps, Tom. Steve - ------------------------------------------------------------------------ - Internet: stevep@wrq.com - AOL: Spoole - INTEL 80x86: Just say NOP - - "Nurse! Do let's pretend that I'm a hungry hyaena, and you're a bone!" - - ------------------------------------------------------------------------ --------------------------- >From h+@nada.kth.se (Jon W{tte) Subject: Think Debugger & INIT source code Date: Sun, 21 Aug 1994 16:52:25 +0200 Organization: Royal Institute of Something or other The INIT I sent out a day ago to fix the System 7.5 bug when using the Think Debugger _did_ fix the problem, but it didn't do it by behaving as advertized. This is because I patched InitWindows, and from that patch patched GetNextEvent to instead call WaitNextEvent with a sleep time of 6, and added some application referencing stuff in a linked list to kkeep track of re-entry. Well, using the patch I did, calling WaitNextEvent would actually result in WaitNextEvent being called twice; once with whatever sleep time was passed to it, and once through my path before it came down to GetNextEvent. Not good. HOWEVER - it turns out that the Process Mangler patches out InitWindows so other apps don't get to it, just like with WaitNextEvent and GetNextEvent (which was why I laid the basic patch there initially...) with the exception of the Finder, which calls InitWindows before this patching is done. Straaaange! Now, my patch hangs off InitDialogs, which, as it turns out, is a much better place to hang - cheaper brews, cooler people, and not getting patched-out by the Process Mangler. Yet, anyway :-) Another complication was that I only used one location to save the old WaitNextEvent globally. Since some apps patch WaitNextEvent themselves, BEFORE they call InitDialogs, this was a bad thing (projects running under the Think Debugger come to mind...) Now I only patch if the saved address is 0, or the address I get from WNE is the same as the saved address, which it turns out to be for the vast majority of applications; even for the Finder (It's surprising that the Finder does ANYTHING like we mortals :-) Anyway, now this INIT behaves as advertized, and can also serve as example code of how to write a skanky INIT that gets at the WaitNextEvent mechanism and circumvents the Process Manager. In pure inline assembly, no less. Code review invited. Cheers, / h+ Jon W{tte (This file must be converted with BinHex 4.0) :#d&bBfKTGQ8ZFfPd!&0*9%46593K!*!%"ed!N!5#B&0*9#%!!J!!"eeb6'&e!J# 3""B!!!d!$8G145dq9dj&)%P15944H!!-rCS!N!1!!*!%!@GFS-Ne!*!8!Nm!N!6 rN!4*6NP89dj&)3%!URT2MUTp-jX!!!+L!*!'!FN!N!55J3#3#'Kf%3!)!$cY(-i 3HMf8I2+'Y30lpJ9d8memb4-m6aDXlVL(QSpb10pZ9)ZiYXP*0CVh5%l#lC2EKcc J!FfC2NIhB%h'pI5lBeMR2E)9lLK!DGQpC(qlL8q-[R9LcFU[p'fAmHUEXeG3c3U EI,XjE-Kh%Z4ZPr%Dc(ElMAY,6khjM&E4Fdr$,cFHd@J&*Ve@1f#DFH4dF&CG[fG UlTV1$204`9%1jH0pmDA(acGU9"HR9@[*5*Mi"XSdAbD0Db-S(8`%,HZNR$NRE%C E+T2T%*NdL$+*Sd5QT&'"(52c(dpi8mdiXR,0h12hVY9dr&E(YfRp*[3Y0cVK6FL MpIHe6FkUeA4FAq1VlV"ADZcTYrE2Cra9f[HqYNj+Vh%A[Z-ZeElhYA88#3H5EjP r@kd!LE8Z"15drkEf-he*KjEp+fM2fXiYDN+HQM@G%aU!R+f1(pHh43r)KcPi1Vm !qC*[D49`8Zr4UB`Ik6!QYALj`!A23'aU,'lIGfUY+T!!1q%Cb*fF960h00raTF[ e+6HkV"pL%jk'h&&)cTVr(i(l5Hc'r4b&3PG!JkM)G!)Nr@pJ(MmJTI#Xd6LM,63 DZkdQJ"$FhfGD,ZG2ScJrNNN0$3CYB@PZ,Q1H3)%jZJ&I8AJ!$2fD!*!$J!#3"!& RA+"TR!#3%4B!N!MrN!4849K85d&)6!%!URdcEkTp-fF!!!&q!!!+P`#3!r8!!!1 T,)-c)J#3"YHF%3!)(!`k"&(*(%4&TL-!A!I6d!421k102PIY$"*K[K32H##8e$2 8-D'GcSfqSVL2A0DlBd3G$T!!j`#RpDj(MmG-63UGSLE9fUQ@6ph9EU)Sm0LifMj ecqA6plhPYP'1jl&,TcpAkjCYEVP3$l@pN!!261C66ZC6*[2a)&-2G'MC(kDA[QF ki&Sq+0aZiLfMRKKekbQ3!0[a2q(iRp$qIhLmdr1PTUP$NhXRCb9h9kqdHkT-`h, -'83&VjmcNZ+XmX-R3#a8K4K24N`cm%&46lS(CqrS5Xj'meQh"2H6f)hl13Te02! (JPdG6BbCST3*qiXql5`!N!-,6PIb!!3C`13S'Da(q0U&lmMDQCb5!H@%Hi32b&2 ##AYbP-a@!T!!!Dmq1i"9B`!Ip5+--))!6T!!a!Rk%3$FjDef[FF)Ir,m#$r+M9" 1"T`F*b01KTa-q%T@!U"RMhrf$(iBc@B6q&C9F2fpYFMBNTF9p'(!hV-H0dYicmU UY20DPCApR&hdHTNi@8'bjV2&SZGr&r!FdbE2862@kdRNF0P*$RP#4e&c0$k2QLp 4U"[8Ar-UNdJ55hSpNF#6iA'I6`GEdGPXh"QeA"3[dDK'#i)9C&G`j(5Qk6",@U& [#-$cNNZ9Qkf6kH3X1[N+l@ZPj'[0kbqb6+0a1TkGNYPm+crNScXkI6iDE$MAh)V LAXhKrJI+f@3DSEck%BUfKV'$8AM+iTE$q9QbiA$05hZ&Dr[L"L[lEccZ$,3"XFC 52R`iHVd8hm&PTZD'hq"m9EPiLf8GlYZ)T"8kLBTU`U0e+PY&`[XBZJF'$l&l`[e lm)M'$Ni(*1Dk-dKKq5p11rdrdT6rP5DRXPAm-dhh#!iGpSReheNL()l'ce@l-Hl J*J(ZQfAYAk0"M9c+@q$`TU&,Um!@#'6PVPmC)a)e&`J,T5'A+Z@5VJTZLVRPU@` c3IJN*1c3DI[M(IAplAdTEdj$CAqdP4S0Pk*!mAE1khUEY"%&-e$f+I*FDfl-X5f dD[)#&T,R[rE`EqQ*3"j32Si)1Up8lFVLJ-eee!Ub6Id)5Z8mN!!k8(9'pJZ24%b 6[S1MmC!!6cY&)Z(1@a&23kMkPS+Jq4)YDPHG`8Ub2ZqNk+bQB#6Vd,SNE#3L085 jp*dT08RZab80KDLfh`Q"KhHBV%9N&Vb2rCf2Q-YM%'K*GTREKF+Rhe&`RVSkqj, NYFqkLcF8U"fYq#1)C88YYN)`9!NPr99Hl2VUaE&2p#p,iV%2+&JacQ!+e9#$@M4 NF1%0ZM-ZU@bc@k$D")F5-k$P69NNhbGNJ(!%CBffd5dCMj%SC3R3Z+HHpKm#N!! BYe8Gl`R("D45LEGJV'i%'D"TF!%9%@`r(T!!CRp#h3(m0$ailIji`$TdRcSXj+1 VIKF%U96YmKLA&J8L,#f0H@R)qUkGBi$F0QZhek3GAkG4GD'D+VZAj+-`cM5jGhi CfkMXjL4e'&Ra4HT!YFpHf8rr(BmRf"mrT)3,QR+LYEPCU#1-"Uj`pCh9Vfk0Vk- GpqRJXjqqJA3(Td0+J`p3i"HlaJP3[l[ek,J4cUl@&NdPBQYN#Je9!kI@rF!qX2m "clB!!!: -- Jon Wätte (h+@nada.kth.se), Hagagatan 1, 113 48 Stockholm, Sweden Not speaking for the Microsoft Corporation. --------------------------- >From emmayche@apple.com (Mark Hartman) Subject: [Q] How to do non-bypassable INIT? Date: 11 Aug 1994 17:36:33 -0700 Organization: Apple Computer Inc, Cupertino, CA For security reasons, I need to have an INIT loaded/run at startup whether or not the Shift key is held down. I know that some of the Apple-supplied goodies do this; does anyone know what the rules are for what gets loaded anyway if Shift is held down? -- ======================================================================= The above is not guaranteed to be the opinions of anyone in particular. ======================================================================= Mark Hartman, N6BMO | E-mail: emmayche@apple.com | AOL: emmayche Macophile | Serious Disney enthusiast | CIS: 75130,1434 +++++++++++++++++++++++++++ >From quinn@cs.uwa.edu.au (Quinn "The Eskimo!") Date: Fri, 12 Aug 1994 10:55:34 +0800 Organization: Department of Computer Science, The University of Western Australia In article <32eg6h$edh@apple.com>, emmayche@apple.com (Mark Hartman) wrote: >For security reasons, I need to have an INIT loaded/run at startup whether or >not the Shift key is held down. I know that some of the Apple-supplied >goodies do this; does anyone know what the rules are for what gets loaded >anyway if Shift is held down? The only one I know of is System 7 Tuner, which installs an INIT in the system file that specifically opens, load and runs the tuna regardless of whether the shift key is down. Another possible solution is to disable the shift key by deleting the 'dbex' resource in the system file. -- Quinn "The Eskimo!" <quinn@cs.uwa.edu.au> "Support HAVOC!" Department of Computer Science, The University of Western Australia +++++++++++++++++++++++++++ >From radixinc@aol.com (RadixInc) Date: 12 Aug 1994 01:42:00 -0400 Organization: America Online, Inc. (1-800-827-6364) In article <32eg6h$edh@apple.com>, emmayche@apple.com (Mark Hartman) writes: "For security reasons, I need to have an INIT loaded/run at startup whether or not the Shift key is held down. I know that some of the Apple-supplied goodies do this; does anyone know what the rules are for what gets loaded anyway if Shift is held down?" There is a new INIT type that is loaded regardless of the shift key. Look at one of the ones that always loads. I think the file type needs to be 'scri', and other than that it's the same (INIT resource, etc.). I haven't tested this though, so check it out yourself. I hope you aren't writing a virus or something obnoxious... Gregory Jorgensen Radix Consulting Inc. +++++++++++++++++++++++++++ >From dlb@netcom.com (David Beauchesne) Date: Fri, 19 Aug 1994 02:52:08 GMT Organization: NETCOM On-line Communication Services (408 261-4700 guest) > There is a new INIT type that is loaded regardless of the shift key. Look > at one of the ones that always loads. I think the file type needs to be > 'scri', and other than that it's the same (INIT resource, etc.). I haven't > tested this though, so check it out yourself. This is correct. Type 'scri' is used by Apple to load different scripts (languages). They are treated, (and coded), just like 'INIT's, but their loading cannot be stopped with the shift key. -- David L. Beauchesne dlb@netcom.com Santa Cruz, California, USA --------------------------- >From khurram@bga.com (Khurram Qureshi) Subject: malloc problem in CW-4 Date: 21 Aug 1994 15:49:55 -0500 Organization: Real/Time Communications - Bob Gustwick and Associates There is a problem with malloc/realloc problem which exists in CW/4. Typically this surfaces when performing continuous memory allocations (inside a for loop for example). This will be fixed as soon as possible. Thanks. ============================== Khurram Qureshi Metrowerks Technical Support e-mail: khurram@bga.com ============================== --------------------------- End of C.S.M.P. Digest **********************