From: pottier@clipper.ens.fr (Francois Pottier) Subject: csmp-digest-v3-104 Date: Tue, 11 Jul 1995 13:49:34 +0200 (MET DST) C.S.M.P. Digest Tue, 11 Jul 95 Volume 3 : Issue 104 Today's Topics: Tools for finding mem. leaks-overwrites [Q] How do you create a JFIF file with Quicktime's JPEG? 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 newsgroups comp.sys.mac.programmer.help, csmp.tools and csmp.misc. It is designed for people who read news 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. ------------------------------------------------------- >From krev@netcom.com (Umberto milletti) Subject: Tools for finding mem. leaks-overwrites Date: Mon, 19 Jun 1995 22:30:32 GMT Organization: NETCOM On-line Communication Services (408 261-4700 guest) I'm looking for tools that will find memory overwrites (out-of-bounds writes and such), memory leaks and other nasty stuff that's hard to track down without good tools. Other tools I've used in the past that fit this bill are purify/ quantify from Pure, and Boundschecker from NuMega, but I don't think either has a mac version. We're kind of desperate, trying to track down a nasty overwrite. Thanks in advance (please send email, as I don't read this all the time), Umberto@krev.com +++++++++++++++++++++++++++ >From jake@presage.com (Jake Hoelter) Date: Mon, 19 Jun 1995 22:40:08 -0800 Organization: Presage Software In article <krevDAFyIx.24L@netcom.com>, krev@netcom.com (Umberto milletti) wrote: >I'm looking for tools that will find memory overwrites (out-of-bounds writes >and such), memory leaks and other nasty stuff that's hard to track down without >good tools. Other tools I've used in the past that fit this bill are purify/ >quantify from Pure, and Boundschecker from NuMega, but I don't think either >has a mac version. >We're kind of desperate, trying to track down a nasty overwrite. There's two tools that are great to use for tracking down leaks. First is Metrowerks' ZoneRanger. It comes with CodeWarrior, plus I think they freely distribute it, so you can download it from wherever. The other tool is QC from Onyx Technology. QC will let you find overwrites, underwrites, invalidate memory, do heap stressing (scramble, purge), and a bunch of other cool stuff. QC costs about $100.00. You can contact Onyx at (813) 795-7801. Or at onyxtech@aol.com. There's a free demo version of QC floating around the nets somewhere. Between the two of those tools you can track down most memory problems on the Mac. Jake Hoelter Presage Software jake@presage.com +++++++++++++++++++++++++++ >From pbenson@iona.ie (Paddy Benson) Date: Wed, 21 Jun 1995 13:32:35 +0000 Organization: IONA Technologies In article <krevDAFyIx.24L@netcom.com>, krev@netcom.com (Umberto milletti) wrote: > I'm looking for tools that will find memory overwrites (out-of-bounds writes > and such), memory leaks and other nasty stuff that's hard to track down MacsBug has a leaks dcmd. This is available on the developer CDs. Also MacsBug has a built in StepSpy (SS) command to check when a range in memory changes Paddy -- - --------------------------------------------------------------------- Paddy Benson (IT Design) email: pbenson@iona.ie (on contract to...) IONA Technologies Ltd, ftp: ftp.iona.ie 8-34 Percy Place, www: http://www.iona.ie/ Dublin 4, ph: +353-1-668-6522 Republic of Ireland. fax: +353-1-668-6573 - --------------------------------------------------------------------- +++++++++++++++++++++++++++ >From jordanz@altura.com (Jordan Zimmerman) Date: Wed, 21 Jun 1995 18:10:25 -0800 Organization: Altura Software, Inc. > I'm looking for tools that will find memory overwrites (out-of-bounds writes > and such), memory leaks and other nasty stuff that's hard to track down without > good tools. Other tools I've used in the past that fit this bill are purify/ > quantify from Pure, and Boundschecker from NuMega, but I don't think either > has a mac version. > We're kind of desperate, trying to track down a nasty overwrite. > Thanks in advance (please send email, as I don't read this all the time), > Umberto@krev.com QC (fron Qnyx Technologies), DoubleTrouble & DisposeResource (on Apple Developer CD, etc.), Jasik's Debugger - to name a few. -- Jordan Zimmerman, Altura Software home page: http://www.altura.com/jordanz/home.html Who is John Galt? +++++++++++++++++++++++++++ >From isis@netcom.com (Mike Cohen) Date: Thu, 22 Jun 1995 23:33:12 GMT Organization: ISIS International jordanz@altura.com (Jordan Zimmerman) writes: >QC (fron Qnyx Technologies), DoubleTrouble & DisposeResource (on Apple >Developer CD, etc.), Jasik's Debugger - to name a few. Do you know of anything similar to QC for windoze? I'm trying to debug a memory overwrite problem in some mac code ported to Visual C++. -- Mike Cohen - isis@netcom.com Home Page: ftp://ftp.netcom.com/pub/is/isis/home.html PUSH THE BUTTON... SOMEONE +++++++++++++++++++++++++++ >From jordanz@altura.com (Jordan Zimmerman) Date: Fri, 23 Jun 1995 09:48:50 -0800 Organization: Altura Software, Inc. > In article <krevDAFyIx.24L@netcom.com>, krev@netcom.com (Umberto milletti) > wrote: > > > I'm looking for tools that will find memory overwrites (out-of-bounds writes > > and such), memory leaks and other nasty stuff that's hard to track down > > MacsBug has a leaks dcmd. This is available on the developer CDs. Also > MacsBug has a built in StepSpy (SS) command to check when a range in > memory changes > In addition to the commercial/freeware tools out there, I usually build leak checking into my code directly. Using the C preprocessor, you define all memory allocation routines to shells that record the allocation. eg. #define NewHandle(size) RecordNewHandle(size, __FILE__, __LINE__) #define DisposeHandle(h) RecordDisposeHandle(h) So, RecordNewHandle calls NewHandle, saves the handle in an array (also saving which file and line it came from). RecordDisposeHandle removes the allocation from the array. At the end of the program, if you have allocations left in your array, there's a leak. You can use the saved file name and line number to find where it was allocated. This method takes some time to implement (there are a _lot_ of potential allocators), but in the end is really useful. Also, having the info can be used for finding memory corruption, etc. -- Jordan Zimmerman, Altura Software home page: http://www.altura.com/jordanz/home.html Who is John Galt? +++++++++++++++++++++++++++ >From aparajit@natural.com (Aparajita Fishman) Date: 25 Jun 1995 02:11:47 GMT Organization: Natural Intelligence, Inc. > In article <krevDAFyIx.24L@netcom.com>, krev@netcom.com (Umberto milletti) > wrote: > > > I'm looking for tools that will find memory overwrites (out-of-bounds writes > > and such), memory leaks and other nasty stuff that's hard to track down Contact info@microquill.com about their product SmartHeap. It's a complete replacement for the memory manager which not only does leak/overwrite detection and so forth, but is also a significantly faster allocator over time than the allocators that come with any compiler on the market. \_ \_ \_ ----------------------------------------------- \_\_\_ \_ Aparajita Fishman aparajita@natural.com \_ \__ \_ Software Developer tel (718) 262-8022 \_ \_ \_ Natural Intelligence, Inc. fax (718) 262-8022 --------------------------- >From oster@netcom.com (David Phillip Oster) Subject: [Q] How do you create a JFIF file with Quicktime's JPEG? Date: Mon, 12 Jun 1995 04:34:57 GMT Organization: Netcom Online Communications Services (408-241-9760 login: guest) The QuickTime volume of Inside Macintosh sample code that works for making a PICT file that has a JPEG compressed image. How do you make a valid file of type JFIF? I've tried just writing the data from QuickTime's FCompressImage into a file, but programs that know JFIF say that that isn't a valid JFIF file. Where is the JFIF file documented? -- - ------- <mail-to:oster@netcom.com> ---------- Ahh! The thorazine is wearing off and the odinazine is coming on... +++++++++++++++++++++++++++ >From oster@netcom.com (David Phillip Oster) Date: Tue, 13 Jun 1995 00:34:47 GMT Organization: Netcom Online Communications Services (408-241-9760 login: guest) In article <osterDA1M29.J0q@netcom.com> oster@netcom.com (I) write: >The QuickTime volume of Inside Macintosh sample code that works for making >a PICT file that has a JPEG compressed image. >How do you make a valid file of type JFIF? I've tried just writing the data >from QuickTime's FCompressImage into a file, but programs that know JFIF >say that that isn't a valid JFIF file. >Where is the JFIF file documented? Well, I pulled out a handy CD-ROM of usenet faqs, and found two ways to solve my problem: 1.) source code for reading and writing JPEG files. Free, portable C code for JPEG compression is available from the Independent JPEG Group. A package containing our source code, documentation, and some small test files is available from ftp.uu.net (192.48.96.9) in directory /graphics/jpeg. The current release is v5, file jpegsrc.v5.tar.gz. You can retrieve this file by FTP or UUCP. If you are on a PC and don't know how to cope with .tar.gz format, you may prefer ZIP format, which you can find at Simtel archive sites (see NOTE above), file msdos/graphics/jpegsrc5.zip. On CompuServe, see the GRAPHSUPPORT forum (GO GRAPHSUP), library 15, file jpsrc5.zip. 2.) A kluge that is quick and easy: [11] How do I recognize which file format I have, and what do I do about it? If you have an alleged JPEG file that your software won't read, it's likely to be HSI format or some other proprietary JPEG-based format. You can tell what you have by inspecting the first few bytes of the file: 1. A JFIF-standard file will start with the four bytes (hex) FF D8 FF E0, followed by two variable bytes (often hex 00 10), followed by 'JFIF'. 2. If you see FF D8 at the start, but not the 'JFIF' marker, you may have a "raw JPEG" file. This is probably decodable as-is by JFIF software --- it's worth a try, anyway. 3. HSI files start with 'hsi1'. You're out of luck unless you have HSI software. Portions of the file may look like plain JPEG data, but they won't decompress properly with non-HSI programs. 4. A Macintosh PICT file, if JPEG-compressed, will have several hundred bytes of header (often 726 bytes, but not always) followed by JPEG data. Look for the 3-byte sequence (hex) FF D8 FF --- the text 'Photo - JPEG' will usually appear shortly before this header, and 'JFIF' or 'AppleMark' will usually appear shortly after it. Strip off everything before the FF D8 FF and you should be able to decode the file. - ------------- In code, that looks like this: /* TrimToJFIF - according to the JPEG FAQ, JFIF embedded in Apple starts with FF D8 FF */ static OSErr TrimToJFIF(Handle h){ static char start[] = { 0xFF, 0xD8, 0xFF}; long offset, len; offset = Munger(h, 0, start, 3, NULL, 0); if(offset > 0){ len = GetHandleSize(h); BlockMoveData(*h + offset, *h, len - offset); SetHandleSize(h, len - offset); return noErr; } return eJPEGFormatFailure; } I've tried it, and it works! -- - ------- <mail-to:oster@netcom.com> ---------- Ahh! The thorazine is wearing off and the odinazine is coming on... +++++++++++++++++++++++++++ >From ldo@waikato.ac.nz (Lawrence D9Oliveiro) Date: Tue, 13 Jun 1995 17:41:34 +1200 Organization: University of Waikato In article <osterDA1M29.J0q@netcom.com>, oster@netcom.com (David Phillip Oster) wrote: >I've tried just writing the data >from QuickTime's FCompressImage into a file, but programs that know JFIF >say that that isn't a valid JFIF file. That should really be all there is to it. To check that you've written the data properly, have you tried reading it back and putting it through FDecompressImage with the same ImageDescriptionhandle? +++++++++++++++++++++++++++ >From bas@luna.nl (Bas A. Schulte) Date: Tue, 13 Jun 1995 09:59:22 +0200 Organization: Models, Inc. In article <osterDA35M0.KFw@netcom.com>, oster@netcom.com (David Phillip Oster) wrote: > >How do you make a valid file of type JFIF? I've tried just writing the data > >from QuickTime's FCompressImage into a file, but programs that know JFIF > >say that that isn't a valid JFIF file. [stuff deleted] > static OSErr TrimToJFIF(Handle h){ > static char start[] = { 0xFF, 0xD8, 0xFF}; > long offset, len; Hmm, I don't know how solid you want your code to be, but I wouldn't dare this. To know for sure where the JFIF (hopefully it IS JFIF) part resides in the PICT, you'd have to fully parse the PICT, scanning through all opcodes until you find the compressed pixmap part. Quite hard to do. The way to go is to use FCompressImage (like Lawrence said). I can assure you that that works. Check your code again. The one thing that might be a problem is when the user has another JPEG codec installed, or Apple changes theirs in a future release. There's no garantuee that the stream output by the codec is JFIF complaint. It will be JPEG, just maybe not always JFIF. BTW, Apple's JPEG codec is really really fast... regards, Bas Schulte +++++++++++++++++++++++++++ >From Maf Vosburgh <maf@mmcorp.com> Date: 14 Jun 1995 22:56:29 GMT Organization: MMC In article <osterDA1M29.J0q@netcom.com> David Phillip Oster, oster@netcom.com writes: >The QuickTime volume of Inside Macintosh sample code that works for making >a PICT file that has a JPEG compressed image. > >How do you make a valid file of type JFIF? I've tried just writing the data >from QuickTime's FCompressImage into a file, but programs that know JFIF >say that that isn't a valid JFIF file. I enclose some source code that is based on example code written by Mark Krueger, who wrote the QuickTime Image Compression manager. It contains the useful proc: OSErr WriteJpegData(PicHandle pic, short fileRef); All you do is 1)Make or open a JPEG compressed PICT 2)Make a new empty file of type JPEG or JFIF. 3)Open it. 4)Call WriteJpegData 5)Close the file. Maf Vosburgh +++++++++++++++++++++++++++ >From piguet@ia.epfl.ch (Yves Piguet) Date: Fri, 23 Jun 1995 20:07:57 +0200 Organization: Institut d'automatique, EPFL In article <3rnpet$879@news.bt.net>, Maf Vosburgh <maf@mmcorp.com> wrote: >In article <osterDA1M29.J0q@netcom.com> David Phillip Oster, >oster@netcom.com writes: >>How do you make a valid file of type JFIF? I've tried just writing the data >>from QuickTime's FCompressImage into a file, but programs that know JFIF >>say that that isn't a valid JFIF file. > >I enclose some source code that is based on example code written by >Mark Krueger, who wrote the QuickTime Image Compression manager. > >It contains the useful proc: >OSErr WriteJpegData(PicHandle pic, short fileRef); And how do you *read* a jpeg using QT? One has to create the Image Description Record, but how? Thanks in advance! Yves Piguet <piguet@ia.epfl.ch> Institut d'automatique Tel: +41 21 693 38 34 EPFL Fax: +41 21 693 25 74 CH - 1015 Lausanne Talk, cusm: on request +++++++++++++++++++++++++++ >From dale_satterfield@powertalk.apple.com (Dale Satterfield) Date: 26 Jun 1995 15:54:43 GMT Organization: Apple Computer In article <piguet-2306952007570001@iamac60.epfl.ch>, piguet@ia.epfl.ch (Yves Piguet) wrote: > In article <3rnpet$879@news.bt.net>, Maf Vosburgh <maf@mmcorp.com> wrote: > > >In article <osterDA1M29.J0q@netcom.com> David Phillip Oster, > >oster@netcom.com writes: > >>How do you make a valid file of type JFIF? I've tried just writing the data > >>from QuickTime's FCompressImage into a file, but programs that know JFIF > >>say that that isn't a valid JFIF file. > > I had this same problem and was able to write out the file data the QT created, and then read it back in again with JPEGView, which had no problem with it. The files were also able to be transfered to a windows machine and its jpeg viewer was able to open them. As to reading in a file, you need to create the descriptor first, by reading the JFIF header. There is sample code out on the net somewhere. I have lost my directions to it. --------------------------- End of C.S.M.P. Digest ********************** Attachment converted: Spiff:Archive.sit (SITD/SIT!) (00033BD7)