TweetFollow Us on Twitter

Apr 93 Tips, Tidbits
Volume Number:9
Issue Number:4
Column Tag:Tips & Tidbits

Related Info: Script Manager

Tips & Tidbits

By Neil Ticktin, Editor-in-Chief

This column is your opportunity to spread the word about little bits of information that you find out about. These tidbits can be programming related or they can be user tips that are particularly useful to programmers.

MacTech Magazine will pay $25 for every tip used, and $50 for the Tip of the Month. Or you can take your award in orders or subscriptions.

To submit a tip, send in a letter to the magazine. E-mail is our preferred method, but feel free to send something via the US Mail. See page two for all addresses. If you do send snail mail, enclose a printed copy and a disk copy of the letter so that it does not have to be retyped.

Tip of the month

Here is a simple routine that returns a Boolean indicating whether the monitor is currently set at black & white or color.

/* 1 */

Boolean IsColorOn( void )
{
 GDHandle hGDevice;
 long   theMode;
 
 hGDevice = GetMainDevice();
 theMode = (**hGDevice).gdMode;
 theMode &= 0x0000000F;
 
 if( theMode != 0 ) return( true );
 else return( false );
}

I figured out how to write this piece of code after struggling with the concept for many months. It’s not a very complex routine, but I searched through every source I had available and never found anything that explained how to do it. I hope this will help others having the same problem.

- Marc White, Corinth, Mississippi

Script Manager Pitfall

If you plan to work with non-Roman script (such as Kanji, Arabic, Hebrew, etc ), there is a subtle - but important - point that Inside Macintosh will not tell you.

Script Manager functions can return wrong answers if the appropriate font is not set in the current GrafPort.

For example, there is a Script Manager function called CharByte which tells you if a given character is part of a two-byte script (or not). After reading the description of CharByte in Inside Macintosh, you will conclude it will know the right answer simply by looking at a piece of text. Wrong!

Unless the current font is a Kanji font, CharByte has no way of knowing that a given character is part of a double-byte Kanji character or whether it is a single-byte Roman character.

The reason is all 256 byte values are “valid” for all Roman fonts. If the current font is, say, Geneva, CharByte will think that 1/2 of a Kanji byte is really a single Roman character.

This is neither clear in Inside Macintosh Vol 5 nor the World Script section in Vol 6, but it is a fairly major point!

- Gar, DataPak Software

Apple’s Lame Disk Cache

After seeing significant I/O performance problems with large disk caches (set via the Memory control panel) I decided to run some benchmarks. I wrote a little application that would write a 400K file to a hard disk in 8K sector aligned chunks with various disk cache sizes and return to me the number of ticks that it took. Here are the results:

400K write

disk cache size 8K at a time

32K 50 ticks

64K 50 ticks

96K 51 ticks

128K 50 ticks

192K 50 ticks

256K 50 ticks

384K 691 ticks

512K 681 ticks

1024K 681 ticks

7680K 678 ticks

It appears that the Apple’s disk cache scheme hits a wall at 384K (in this test, anyway). I linked DTS with these results and got an interesting reply. It turns out that their disk cache scheme is optimized for very small reads and writes - like an application reading one byte at a time from a file without doing it's own buffering. I guess this was a problem back when most people used floppies and small hard drives. But modern apps usually do their own file buffering anyway (read a big piece into a buffer and then take it out of the buffer one byte at a time), so the Apple disk cache scheme becomes more of a hinderance than a help.

Not all reads and writes are cached by the Apple scheme. The formula it uses to decide if any given read or write should be cached is:

/* 2 */

numCacheBlocks = user-defined cache size DIV 512;
maxCachedReadWrite = (numCacheBlocks - 1) * 16;

So, with a cache size of 256K you get:

numCacheBlocks = 512
maxCachedReadWrite = 8176

That means that any read/write larger than 8176 bytes or larger will not be cached. So in my test app, nothing was being cached until the cache was 384K or larger, at which time my 8K writes were being cached (and I got a 13x performance slow-down).

There is hope, though. Page 2-95 of the new Inside Macintosh File Manager documents the "no cache" bit of ioPosMode. You can set bit 5 of ioPosMode to prevent your reads and writes from being cached. I strongly recommend you do this except in those few cases where you know you're going to need the data again right away or where you're not doing your own intelligent sector-aligned buffering. When I set this bit in my test app, my times for writing 400K with very large caches were the same as those for writing 400K with very small caches.

That's great for your code but what about other code that you can't control and that doesn't take advantage of bit 5 of ioPosMode? The only real defense is to reduce your disk cache to the minimum (32K) at which time only very small reads and writes will be cached (1008 bytes or less). But in my own tests with compiling large projects under MPW and Think C I have found that a disk cache size of 128K gives the fastest build times. You should do your own timings based on what type of I/O operations you do most.

- Mike Scanlin

MacTech Regular Contributor

Useless Trivia or a tip?

This is perhaps more fit for “Useless Trivia” than is is for “Tips and Tidbits,” but no matter, here it is:

Nearly every piece of C code that I ever see (even in MacTech Magazine) uses parentheses around all return statements. People always seem to write:

int theirfunc()
{
  .
  .
  return (1);
}

Even the examples in K&R itself use parentheses around the return statments. But look at the actual syntax reference in K&R: “if,” “while,” “for,” and “switch” all require parens, but “return” does not. For years, using many compilers, on many machines, I've been writing:

int myfunc()
{
  .
  .
  return 1;
}

It may look odd, but try it - it does work!

- Ken Gladstone

MacTech Technical Editor

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

The best video player on mobile
We all know the stock video player on iOS is not particularly convenient, primarily because it asks us to hook a device up to iTunes to sync video in a world that has things like Netflix. [Read more] | Read more »
Four apps to help improve your Super Bow...
Super Bowl Sunday is upon us, and whether you’re a Panthers or a Broncos fan you’re no doubt gearing up for it. [Read more] | Read more »
LooperSonic (Music)
LooperSonic 1.0 Device: iOS Universal Category: Music Price: $4.99, Version: 1.0 (iTunes) Description: LooperSonic is a multi-track audio looper and recorder that will take your loops to the next level. Use it like a loop pedal to... | Read more »
Space Grunts guide - How to survive
Space Grunts is a fast-paced roguelike from popular iOS developer, Orange Pixel. While it taps into many of the typical roguelike sensibilities, you might still find yourself caught out by a few things. We delved further to find you some helpful... | Read more »
Dreii guide - How to play well with othe...
Dreii is a rather stylish and wonderful puzzle game that’s reminiscent of cooperative games like Journey. If that sounds immensely appealing, then you should immediately get cracking and give it a whirl. We can offer you some tips and tricks on... | Read more »
Kill the Plumber World guide - How to ou...
You already know how to hop around like Mario, but do you know how to defeat him? Those are your marching orders in Kill the Plumber, and it's not always as easy as it looks. Here are some tips to get you started. This is not a seasoned platform... | Read more »
Planar Conquest (Games)
Planar Conquest 1.0 Device: iOS Universal Category: Games Price: $12.99, Version: 1.0 (iTunes) Description: IMPORTANT: Planar Conquest is compatible only with iPad 3 & newer devices, iPhone 5 & newer. It’s NOT compatible with... | Read more »
We talk to Cheetah Mobile about its plan...
Piano Tiles 2 is a fast-paced rhythm action high score chaser out now on iOS and Android. You have to tap a series of black tiles that appear on the screen in time to the music, being careful not to accidentally hit anywhere else. Do that and it's... | Read more »
Ultimate Briefcase guide - How to dodge...
Ultimate Briefcase is a simple but tricky game that’s highly dependent on how fast you can react. We can still offer you a few tips and tricks on how to survive though. Guess what? That’s exactly what we’re going to do now. Take it easy [Read more... | Read more »
SoundPrism Link Edition (Music)
SoundPrism Link Edition 1.0 Device: iOS Universal Category: Music Price: $4.99, Version: 1.0 (iTunes) Description: ***Introductory price for a the first few days after launch - if you're reading this, get it while it's fresh out of... | Read more »

Price Scanner via MacPrices.net

12-inch 1.2GHz Silver Retina MacBook on sale...
B&H Photo has the 12″ 1.2GHz Silver Retina MacBook on sale for $1399 including free shipping plus NY sales tax only. Their price is $200 off MSRP, and it’s the lowest price for this model from... Read more
iPads on sale at Target: $100 off iPad Air 2,...
Target has WiFi iPad Air 2s and iPad mini 4s on sale for up to $100 off MSRP on their online store for a limited time. Choose free shipping or free local store pickup (if available). Sale prices for... Read more
Target offers Apple Watch for $100 off MSRP
Target has Apple Watches on sale for $100 for a limited time. Choose free shipping or free local store pickup (if available). Sale prices for online orders only, in-store prices may vary: - Apple... Read more
Apple refurbished 2014 13-inch Retina MacBook...
Apple has Certified Refurbished 2014 13″ Retina MacBook Pros available for up to $400 off original MSRP, starting at $979. An Apple one-year warranty is included with each model, and shipping is free... Read more
Macs available for up to $300 off MSRP, $20 o...
Purchase a new Mac or iPad using Apple’s Education Store and take up to $300 off MSRP. All teachers, students, and staff of any educational institution qualify for the discount. Shipping is free, and... Read more
Watch Super Bowl 50 Live On Your iPad For Fre...
Watch Super Bowl 50 LIVE on the CBS Sports app for iPad and Apple TV. Get the app and then tune in Sunday, February 7, 2016 at 6:30 PM ET to catch every moment of the big game. The CBS Sports app is... Read more
Two-thirds Of All Smart Watches Shipped In 20...
Apple dominated the smart watch market in 2015, accounting for over 12 million units and two-thirds of all shipments according to Canalys market research analysts’ estimates. Samsung returned to... Read more
12-inch 1.2GHz Retina MacBooks on sale for up...
B&H Photo has 12″ 1.2GHz Retina MacBooks on sale for $180 off MSRP. Shipping is free, and B&H charges NY tax only: - 12″ 1.2GHz Gray Retina MacBook: $1499 $100 off MSRP - 12″ 1.2GHz Silver... Read more
12-inch 1.1GHz Gray Retina MacBook on sale fo...
B&H Photo has the 12″ 1.1GHz Gray Retina MacBook on sale for $1199 including free shipping plus NY sales tax only. Their price is $100 off MSRP, and it’s the lowest price available for this model... Read more
Apple now offering full line of Certified Ref...
Apple now has a full line of Certified Refurbished 2015 21″ & 27″ iMacs available for up to $350 off MSRP. Apple’s one-year warranty is standard, and shipping is free. The following models are... Read more

Jobs Board

*Apple* Retail - Multiple Positions (US) - A...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
*Apple* Subject Matter Expert - Experis (Uni...
This position is for an Apple Subject Matter Expert to assist in developing the architecture, support and services for integration of Apple devices into the domain. Read more
*Apple* Macintosh OSX - Net2Source Inc. (Uni...
…: * Work Authorization : * Contact Number(Best time to reach you) : Skills : Apple Macintosh OSX Location : New York, New York. Duartion : 6+ Months The associate would Read more
Computer Operations Technician ll - *Apple*...
# Web Announcement** Apple Technical Liaison**The George Mason University, Information Technology Services (ITS), Technology Support Services, Desktop Support Read more
Restaurant Manager - Apple Gilroy Inc./Apple...
…in every aspect of daily operation. WHY YOU'LL LIKE IT: You'll be the Big Apple . You'll solve problems. You'll get to show your ability to handle the stress and Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.