Big Mean Folder Machine 2.16 [Intel/Serial]

Ah, Arduino, I remember when you were just crawling around and blinking LEDs. Now you're ready to learn how to speak! In this lesson we'll learn how to use the Serial Library to communicate from the Arduino board back to the computer over the USB port. Then we'll learn how to manipulate numbers and data.

Oct 12, 2015  iLocalize is an intuitive OS X utility designed from the ground up with a single goal in mind: to help developers translate their applications, as well as frameworks and bundles, to any number of languages quicker by using a single software solution for all localisation related tasks. 4.1

For this lesson we won't be using the shield, so simply remove it (keeping the mood light LEDs on it you'd like). The shield doesn't contain any programs or data, it is just our way of connecing up the LEDs and resistors. We'll use the shield again but for now, we can examine the RX and TX LEDs on the main Arduino board which will help you with debugging

Libraries are great places, and not yet illegal in the United States! If you ever need to learn how to do something, like say fix a motorcycle, you can go to your local library and take out a book. Sure you could buy the book but the library is nice because as a resource you can get the book whenever you need it, keeping your house uncluttered.

Serial Processor: A serial processor is a processor type used by systems where the central processing unit (CPU) carries out just one machine-level operation at a time. The term is often used in contrast to a parallel processor, which features more than one CPU to perform parallel processing. In 2005 Intel launched the first dual-core.

Make a note of the folder location where you save the driver. Open up Device Manager, expand IDE ATA/ATAPI controller branch (may be different on your machine) Right-mouse click on either Intel(R) ICH9 Serial ATA Storage Controlle r (I selected the 4 port, both entries will change after the reboot at. RAID on Optiplex 790? Jump to solution. Jul 06, 2017  Thanks for the help. While searching for other locations, came to know that it is available in the WMI class win32BaseBoard under the property SerialNumber. It seems that the wmi class may vary from manufacturers. The same issue still exists in 5.0.20, Host is Windows 7 64 bit, guest is Ubuntu 14.0.4LTS 4.2.0.36 kernel Prolific USB to Serial:0300 work around is with USB filter for the Prolific but when you have more than one Prolific cable and you want to use one on the host and one the Guest is a bit more tricky when plugin and unplug the cables.

Software Libraries are very similar. We already studied what a procedure is, in lesson 3: a procedure is a list of things to do. A library is a big collection of procedures, where all the procedures are related! If you, say, want to control a motor, you may want to find a Motor Control Library: a collection of procedures that have already been written for you that you can use without having to do the dirty work of learning the nuances of motors.

The library we will be using is the Serial Library, which allows the Arduino to send data back to the computer:

Serial may sound like a tasty breakfast food, but its actually quite different. The word serial means 'one after the other.' For example, a serial killer doesn't stop with one murder, but stabs many people one after the other. Serial data transfer is when we transfer data one bit at a time, one right after the other.

Information is passed back & forth between the computer and Arduino by, essentially, setting a pin high or low. Just like we used that technique to turn an LED on and off, we can also send data. One side sets the pin and the other reads it. It's a little like Morse code, where you can use dits and dahs to send messages by telegram. In this case, instead of a long cable, its only a few feet.


This is as good as Microsoft Visio can do, yay!

(Now, people who are all geeked-out will probably get angry at this point because I'm simplifying things. Well guess what, its an Arduino tutorial, not a OSI Physical Network Architecture tutorial.)

The world isn't run by weapons anymore, or energy, or money. It's run by little ones and zeroes, little bits of data. It's all just electrons. - Sneakers

Now is a good time to review how data is measured. For example, we measure weight with 'ounces' and 'pounds' (or grams and kilograms) and distances with 'inches,' 'feet,' and 'miles' (or centimeters, meters and kilometers). Information has its own system of measurements:

A single bit is either a zero or a one.
You can group bits together into 8 bits which is 1 byte.
1024 bytes (8192 bits) is one Kilobyte (sometimes written KB).
1024 KB (1048576 bytes) is one Megabyte (MB)
1024 MB is 1 Gigabyte (GB)

An interesting thing to note is while 1000 grams is a kilogram, nearly all computer systems consider 1024 bytes to be a kilobyte. That is, a 1.0 Kilobyte file on your computer is 1024 bytes:

Quick quiz!

If your hard disk is 200 Gigabytes, how many bytes is that? Use a calculator with lots of digits!
Highlight the text below for the answer
200 GB * 1024 = 204800 MB
204800 MB * 1024 = 209715200 KB
209715200 KB * 1024 = 214748364800 bytes!

Hard drive makers are quite sneaky, you'll notice that they define GB as being 1000 MB, and 1 MB = 1000 KB, etc. Given this fact, how many bytes can you really store in your 200GB drive?
Highlight the text below for the answer
200 GB * 1000 = 200000 MB
200000 MB * 1000 = 200000000 KB

How much less storage do you get thanks to the marketing guy who came up with this trick?
Highlight the text below for the answer
About 4.6% less than you'd expect

We've actually used the Serial communications capability already quite a bit..that's how we send sketches to the Arduino! When you Compile/Verify what you're really doing is turning the sketch into binary data (ones and zeros). When you Upload it to the Arduino, the bits are shoved out one at a time through the USB cable to the Arduino where they are stored in the main chip.

Next time you upload a sketch, look carefully at the two LEDs near the USB connector, they'll blink when data is being transmitted. One blinks when the Arduino is receiving data (RX) and one blinks when the Arduino is transmitting data (TX)

Enough chatting amongst ourselves, its time to get the Arduino talking. Our first sketch is going to be the hello world! program. When it starts up, it will say 'hello world!'

Create a New Sketch.. and save it as HelloWorld

Into the new sketch, copy and paste the following source code, then save it

OK first thing to notice is that there's nothing in the loop procedure! We've gutted it..and put some stuff into the setup procedure.

Even if we have nothing in the setup or loop procedures, the Arduino requires them to be there. That way it knows you really mean to do nothing, as opposed to forgetting to include them!

The first line of code in the setup procedure is this one:

We definately see that there is a Serial thing going on, and it looks like there is a procedure call as well. This is a library procedure call. The library is called Serial and inside the library is a procedure called begin.

.
(input values)
Serial
begin
;

If there's no library name, it means that the procedure is in the 'default' collection of procedures we use. For example, delay() is so common, the designers of the Arduino software didn't bother putting it into a library.

So there's some mystery procedure that's called begin, well it's not too tough to figure out what it might do. It's the procedure that gets the Serial stuff ready. But what's the 9600 about?
The comment says 9600 bps, and just so you know bps stands for bits-per-second (we will refer to this as the baud rate)
If you have broadband connection, you may remember reading somewhere that it has, say 350 kbps download rate. This is how fast the connection can read and write bits on the wire. (Needless to say, your broadband connection can transfer data a lot faster than an Arduino!)

OK so Serial.begin sets up the Arduino with the transfer rate we want, in this case 9600 bits per second.

Lets move on to the next line.

This line also uses the Serial library, this time it's calling a procedure called println which is just a shorthand for 'print line'. Note that the 6th letter in println is the letter L not the number 1. This time the input is a quotation, the line of text we would like it to print. We use two ''s (double quotes) to indicate the beginning and end of a line of text.

Quick quiz!

  • If the Arduino transfers data at 9600 bits per second and you're sending 12 bytes of data, how long does it take to send over this information?
    Highlight the text below for the answer
    12 bytes of data equals 12 * 8 = 96 bits of data. If we can transfer 9600 bits per second, then 96 bits takes 1/100th of a second!
  • If the Arduino transfers data at 19200 bits per second (19200 baud) and you're sending 12 bytes of data, how long does it take to send over this information?
    Highlight the text below for the answer
    This is twice as fast as before, so it will take half the time, about 1/200th of a second.

Good, now compile the sketch and upload it to your Arduino..

And then..nothing???

It looks like not much is going on here. Somewhat disappointing since we had so much fun with blinking colored lights before. The trick here is that while you can see blinking lights quite easily, seeing serial data requires a monitor, which like your display monitor will show us what data is being transfered.

Lucky for us, there's a serial monitor built into the Arduino software!

I'm not quite sure what the icon means, but regardless if you click that button you will replace the black Program Notification area with a Serial Monitor.

So..click it!

What happens next is, sadly, quite dependent on which kind of Arduino you have

WindowsMac OS X Linux
NGArduino does not reset.Arduino does not reset.Arduino does not reset.
DiecimilaArduino resets, starts the sketch a few seconds later Arduino resets, starts the sketch a few seconds later Arduino resets, starts the sketch a few seconds later

In the very common case of having a Diecimila Arduino, the serial monitor will auto-reset the Arduino. The sketch will start up a couple of seconds later

Otherwise, the Arduino does not reset itself. Either way, once you've switched to the serial monitor, press the reset button. If you have an NG Arduino you'll have to wait 7 seconds for the sketch to start.

Voila! It is our sketch!

If you ever find that you're getting a whole lot of gibberish instead of proper text, make sure that you have the correct baud rate selected in the drop down menu of the Serial Monitor. Note that this communication baud rate is indepedent of the upload process, which is fixed at 19200 bps.

Next, try pressing the reset button a few times to make more Hello Worlds! appear. If you have an NG, this may be a bit annoying but do it anyways.

Each time you reset the Arduino, it performs the setup procedure, and prints out Hello again. If you look closely at the Arduino, you will also see the little TX LED blink just as it prints out this message. That's your indication that data was sent.

When you println you are sending data from the Arduino to the computer. The Send button (and the text input next to it) are used to send data to the Arduino. We aren't going to be using it in this lesson so don't be surprised that it doesn't do anything when you click it!

10 PRINT HELLO
20 GOTO 10

Our next sketch will be a minor modification of this one. Instead of printing out Hello World just once, we'd like it to print it out over and over and over again.

Quick quiz!

  • What simple modification should we perform to make the Arduino print Hello World over and over again?
    Highlight the text below for the answer
    Simply move the Serial.println('Hello world!'); statement from the setup procedure to the loop procedure.

Perform this modification and then compile and upload the new hyper-hello sketch. Then start up the serial monitor. You will see Hello World! scroll by super fast!

Quick quiz!

  • Whats going on with the TX LED?
    Highlight the text below for the answer
    It's lit, not blinking
  • Try waving the Arduino around in a dark room, what do you see?
    Highlight the text below for the answer
    There are little dotted light trails
  • What's going on here? Hint: Remember lesson 2?
    Highlight the text below for the answer
    The data is being transmitted so fast, that we can't see the TX LED blinking..it's sending data many times a second!

Make the Arduino chill out a little by adding a one second delay to the sketch, so that it only prints out Hello World once a second.

Now you should spend some time playing with println and making it display a message of your choice! Perhaps add some more println statements in order to make the message longer?

Math is hard, let's try programming!

We've played around with printing out phrases, but it turns out we can also print out numbers pretty easily too.

Try out this sketch on your Arduino

Note that we're using 2 procedures here, the original println and now also print. The print procedure is just like println except it does not print out a 'carriage return' at the end, starting a new line. You can experiment with changing the print's to println's and looking at the Serial Monitor output to verify this for yourself.

Here's whats going on in the Arduino with this sketch. For example, lets look at this line:

We've seen that if you use a quoted line of text as input to println procedure, it will display that text. In this case you can see that if you use a variable to println it will look up what that variable contains and print that out!

It turns out that the Arduino is smart enough to also do math when asked:

In this case, the Arduino looks at what the input to println is, and finds its actually a calculation. It looks up what a is (5) and what b is (10) and then adds them together (+) and then uses that as the value to send to println

Note that for now, we can only do math using integers, which if you recall, are whole numbers. That means we can't yet print out numbers like 3.14 or 1.5.

I could go on and on about operators, its all very important stuff, but many people have written good tutorials on this topic already so I'm going to send you off to read them there!

  • A C++ tutorial (this one's pretty nice, just ignore the cout stuff which is C++'s way of printing out values)
Pythagorean party

Let's make our first simple calculator, to calculate a hypoteneuse. If you remember from grade school, if you have a right-triangle, the hypoteneuse h can be calculated from the lengths of the two legs, c1 and c2 (which we'll call a & b)

a2 + b 2 = h 2
h = (a2 + b2)

The first thing that's new here is this line at the very beginning of the sketch:

Which basically says 'We'd like to use the math procedures, which are in a library that requires us to include the file math.h where the sqrt procedure lives'. Just ignore it for now, it's not important.

The second thing that's different here is that when we create the variable h we don't assign it a value.

It turns out that this is totally OK, it just means that we don't know what h is going to store yet, because we're going to calculate it later. Since it's not assigned to a value upon creation, the Arduino just creates the box, the stuff inside is whatever was in left over in memory.

Default values

If you don't assign a value to a variable, it could be any value. Make sure you don't try to use the variable before you assign it a value!

Later on in the sketch, we assign it the value.

In this line, we square a and b and then add them together, then we call the sqrt() procedure (which does exactly what you may think), to take the square root. Then we assign that to the variable h.

=
;

Whatever was in h before is lost, replaced by the new value.

You can nest procedures and functions all you want, calling a procedure on the return value of another procedure.

Quick quiz!

  • Lets say you have a variable 'foo' which contains a number. You'd like to find the square root of the square root of this number. What line of code would print out this value?
    Highlight the text below for the answer
    Serial.println( sqrt( sqrt(foo) );
    First take the square root of foo, then take the square root of that and then use that value as the input to println

Now its your turn to create a calculator.
You'll create a Ohm's law calculator. Ohm's law says that Voltage = Current * Resistance. (This is a pretty useful law which forms the basis of electronics, and we'll study it in depth more later.) Starting with two variables, i for current and r for resistance, have it print out the amount of voltage that can be measured accross the resistor.

Let's write a program that will do that hard drive size calculation we did before. We'll start with the hard drive size in GB, and print out how many MB there are.

We'll start simple, just printing out the drive size in GB

Copy and paste this sketch into Arduino software and name the sketch DriveCalc. Then compile and upload it.

OK, lets add a section of code that will print out the number of Megabytes in the hard drive.

This time if you compile and upload it you should get

Which is correct, yay! Now try a few different whole numbers for the drive size, from 1 GB to 100 GB.

You may notice that if you put in a 100GB drive size, something very, very strange happens:

A 100GB drive should have 102400MB in it, not some negative number. What's going on here?

What's happening is that we have an overflow problem. Think about your car odometer. The odometer has only 4 digits, it can display 0 miles to 9999 miles travelled. If you travel 10000 miles, the odometer will 'roll over' to 0 again, and from then on it will display an incorrect value.

Keeping that in mind, remember in lesson 2 we said that when we define a variable we also define the box-type of the variable? The box is where we store the data, in this case the type is int. It turns out that an int type can store only 2 bytes.

Quick quiz!
How many bits are in 2 bytes?
Highlight the text below for the answer
There are 8 bits in 1 byte so 2 bytes is 16 bits

To figure out how big a number we can store in a 2 byte-sized box use a calculator and take 2 to the power of the number of bits (since each bit can store 2 values, 0 or 1). Then we subtract 1 because like in the car odometer, you can't actually display the final value, 10000. So, in this case the largest number is 216 - 1 = 65535. Since the number we're trying to store (102400) is larger than that, we see that 'rollover.'

OK let's fix it! All we need to do is change the variable type so that it can store more than 2 bytes of data. Here is a short list of types we can use.

It looks like we want to use the long type. So lets make that change

Compile and upload this sketch..then run the Serial Monitor..

Uh oh, we didn't actually fix the problem!

How frustrating, we did the right thing and it still didn't work. The problem we have now is although the boxes are the right size, we're not handling them well.

If you look at this line, what's happening here is that the Arduino looks up the value of the variable drive_gb to get 100. Then we multiply 100 by 1024 to get 102400 and put that in the drive_mb box. Except the way that the Arduino software does this is that it creates a temporary variable the same size as drive_gb to store that calculation result before it sticks it into drive_mb. So basically we are still getting an overflow, except now its happening as we do the calculation.

Here is one way to fix this insiduous bug:

Now when we do the calculation, the temporary result is stored in a box the same size as drive_mb (a long) instead of an int.

Compile and upload this sketch to try it out

There you go, now its working!

It turns out that I wasn't completely honest in the previous section when I described all the different types. There's another important fact to know, and that has to do with storing negative numbers.

We know that a variable that is 2 bytes large (16 bits) can store 216 different values. We assumed before that these values were 0 - 65535 inclusive. But then how do we store negative numbers? It turns out that there are two kinds of variables, signed and unsigned.
Signed variables can have a positive or negative value, so you can store negative numbers.
Unsigned
variables can only store positive numbers.

By default, variables are signed.

TypeSize (bits)Size (bytes) Minimum Value Maximum Value
8
0
byte
1
127
16
0
int
2
32767
32
0
long
4
2147483647

Quick quiz!

  • Lets say you have a program that stores the age of a human in years (which so far is no more than 122), whats a good data type to use?
    Highlight the text below for the answer
    You probably want to use a byte type
  • Lets say you want to store the age of a human in seconds, what is an appropriate data type now?
    Highlight the text below for the answer
    110 years = 3468960000 seconds. You'll need to store this in an unsigned long variable.

Why Types?

OK so you're probably wondering: 'This is such a pain, why bother with different size types? Lets just have every variable be as big as possible and we'll never have roll-over problems.'

Well, on your desktop computer, with gigabytes of memory (RAM), this is a reasonable thing to do. However, the tiny tiny computer in the Arduino has a grand total of 1 Kilobyte of memory. And some of that is used for background stuff you don't see. For small sketches sure you can make everything a long and be done with it, but if you have a bigger sketch, you'll run out of memory really fast and then you'll have major problems. So in this case, every byte counts!

What's weird about signed numbers is that if you reach the end of the positive value range you'll rollver into the negative values.

For example, lets say you have a signed int. If you have the value 32767 in that variable, and you add 1 to the variable, you'll actually rollover to -32768.

This sketch will test out this fact:

Compile and upload to run the test.

Quick quiz!

  • Let's say we have a variable that is byte type, it's signed by default. It starts out with the value 127 and we add one to the variable, what will the new variable value be?
    Highlight the text below for the answer
    It's a signed variable so it will roll over to -128
  • Let's say now it is an unsigned byte type, what happens now?
    Highlight the text below for the answer
    Since it is unsigned, it can store much more data, so it will be able to hold the value 128.
  • If we have an unsigned byte and it starts out with the value 250 and we add 10, what will the value be?
    Highlight the text below for the answer
    Even though thie variable can store a lot, it can't store more than the number 255, so it will rollover and we'll end up with the number 4.

Now it's your turn!

Write some sketches that will help you understand variable sizes, try creating variables of different types and signedness and adding and subtracting.

Although this lesson part seems quite boring, and severely lacking in blinky lights, understanding this stuff now will save you from a lot of headaches later when you have data overflows and your program is all wonky and you're really frustrated because you can't figure out why. (Trust me on this one!)

Wrapping up, the final project!

Now its time for you to expand the drive size calculator. Starting with the DriveCalc sketch, modify it so that it will also calculate how many KB are stored in the hard drive. Test it out with a couple different drive sizes.

Once you've got that working, modify it again so that it will also display how much space the drive actually holds thanks to the sneaky math-trick that manufacturers use. Have the sketch display how much storage space is 'missing' (in KB) as well.

Here's one possible solution:

Conclusion

Good work, you got through one of the more boring lessons. In this lesson you learned how to print text and data to the Serial Monitor. This is essential for debugging future projects! You also learned about data types and storage and how to use the Arduino to calculate stuff.

Version 2.41

20th December 2019

The new version correctly displays the trial limitation dialog.

Version 2.40

4th October 2019

The new version adds full macOS 10.15 Catalina compatibility.

Version 2.39

3rd December 2018

The new version fixes a problem affecting operation with 10.14 Mojave Dark Mode.

Version 2.38

27th November 2018

The new version fixes a minor bug where the absence of EXIF meta-data was not handled correctly.

Version 2.37

21st February 2018

The new version adds support for HEIC and HEIF image files.

Version 2.36

28th June 2017

This is a minor maintenance release.

Version 2.35

16th January 2017

This release fixes a minor bud on macOS 10.12 Sierra.

Version 2.34

2nd February 2016

This release fixes a software update vulnerability in the Sparkle framework that was exposed on the 29th of January.

Version 2.33

26th January 2016

This release features some minor bug fixes and improved mailing list sign-up.

Version 2.32

18th November 2015

This release modernizes the code base for Mac OS X 10.11 El Capitan.

Version 2.31

26th March 2015

This release improves the installation experience.

Version 2.30

14th January 2015

This release fixes an OS X drawing bug that could cause the window background to appear empty.

Version 2.29

4th February 2014

This release fixes moves to the new Automatic Reference Counting memory architecture.

Version 2.28

20th August 2013

This release fixes a bug in the batch folder naming algorithm.

Version 2.27

18th June 2013

This release makes it easier to join our new opt-in mailing list.

Version 2.26

24th August 2012

This is the first Mac OS X 10.7 Lion or later only release of the product.

It features an improved integration with the Mac App Store version of the tool.

Version 2.25

11th July 2012

The new version fixes a Mountain Lion-related problem.

Version 2.24

5th July 2012

The new version adopts Apple's Developer ID identification in preparation for Mac OS X 10.7 Mountain Lion.

Unfortunately, this makes it impossible to preserve the droplet feature and this version thus removes this feature. Existing droplets should continue to work correctly.

Version 2.23

17th January 2012

The new version can now be used in the Mac OS X 10.7 full screen mode.

Version 2.22

6th December 2011

This release fixes a bug in the id3 tag reading engine.

Version 2.21

9th November 2011

This release fixes a conflict resolution bug.

Version 2.20

14th September 2011

This release adds support for reading meta-data in flac, ogg and aiff sound files.

Version 2.19

10th August 2011

This release addresses a sorting and an mp3 tag reading issue.

Version 2.18

5th July 2011

This release features a brand new ID3 tag engine for reading the embedded song, artist and album information of your music files. The new engine is up to ten times faster. More improvements to supported formats and tags are coming soon.

Version 2.17

4th May 2011

Paper Folder Machine

This release adds the option of creating batch folders of specific size or number of files while preserving the existing folder hierarchy

This is particularly useful when splitting up existing folder hierarchies for backup.

Version 2.16

24th February 2011

This release fixes a problem affecting music file processing.

Version 2.15

Folder Sewing Machine

22nd February 2011

This is the first Mac OS X 10.6 Snow Leopard and Intel CPU-only release of 'The Big Mean Folder Machine'.

The internals of the tool have been throughly modernized in anticipation of the migration to XCode 4 and the upcoming Mac OS X 10.7 Leopard developments.

Version 2.14

18th February 2011

Now that 'The Big Mean Folder Machine' has been accepted into the Mac App Store, this new version makes it easier for customers to download the trial and buy from the Mac App Store.

It also warns customers that the Mac App Store currently lacks the droplet feature as it fell foul of Apple's Mac App Store Guidelines.

A Mac App Store version with droplet support is under development.

This is also probably going to be the last Mac OS 10.5 Leopard compatible release.

We usually support the current version of Mac OS X and one previous version to allow customers plenty of time to upgrade.

Apple has, however, made a number of moves in the last few weeks that make it harder than ever to maintain backwards compatibility. The Mac App Store requires that code be targeted to Mac OS X 10.6 Snow Leopard and Apple's XCode 4 development tools that have gone to Gold Master last week have dropped the Mac OS X 10.5 SDK and PowerPC support entirely.

In other words, the time has come to get ready for Mac OS X 10.7 Lion and drop Mac OS X 10.5 Leopard compatibility a few months early.

Obviously, the current, 2.13 release will remain on the website indefinitely and we've made sure that the auto-update feature won't overwrite your current version with an incompatible Mac OS X 10.6-only version by mistake.

Version 2.13

16th February 2011

This new version allows you to switch off the debugging information being written to the system console.

Internally, a lot has changed in preparation for submitting the product the Mac App Store.

Version 2.12

17th January 2011

The new version fixes a startup problem introduced in version 2.11.

Version 2.11

12th January 2011

The new version fixes a minor problem with the way in which settings are saved to droplets.

Version 2.10

16th November 2010

The new version improves performance and memory management.

Version 2.09

19th October 2010

The new version adds the ability to split folder hierarchies based on file creator and type codes.

Version 2.08

30th June 2010

The new version delivers improved handling of missing EXIF information when creating folder hierarchies.

Version 2.07

18th May 2010

The new version delivers improved handling of missing EXIF information during the batch folder creation stage.

Version 2.06

20th January 2010

The new version adds a 4th hierarchy level, as well as making significant backend improvements.

Version 2.05

9th December 2009

Droplets can now be safely auto-updated to the latest version of the program via the software update mechanism.

Version 2.04

Big Mean Folder Machine 2.16 Intel/serial Download

24th November 2009

This new release now correctly calculates the physical (size on disk) and logical (actual number of bytes) sizes of bundle files.

Version 2.03

21st October 2009

This release contains significant improvements to the handling of unlock codes and should make unlocking the product significantly less error prone.

Version 2.02

12th October 2009

Allows the program to be run more easily for users who do not have administrator privileges.

Version 2.01

9th September 2009

Fixes a crash on Snow Leopard when reading mp3 tags.

Version 2.0

Machine22nd July 2009

Version 2.0 is the first major upgrade to 'The Big Mean Folder Machine'.

It features:

  • a reworked user interface that integrates all operations inside of the new resizable assistant-style window
  • better file name conflict resolution that allows to you determine in which order file distinguishers (e.g. '(a)', '(b)', ..) are applied
  • performance optimizations
  • automatic software updates courtesy of the Sparkle framework
  • lots of under the hood improvements
  • some spit and polish here and there
  • minor bug fixes

Best of all, version 2.0 is a free upgrade to all version 1.x owners.

Version 2.0b3

1st July 2009

The new version fixes a number of minor issues, including the auto-update feature which was broken in the first (two?) beta(s).

Version 2.0 is a free upgrade to all version 1.x owners.

Version 2.0b2

24th June 2009

This new beta fixes a number of minor issues.

Version 2.0b1

17th June 2009

This is the first public beta of 'The Big Mean Folder Machine' 2.0.

Version 2.0 is a free upgrade to all version 1.x owners.

Most of the changes for this release are under the hood, but there are a few user-visible changes:

  • new re-sizable assistant window interface
  • faster are more sophisticated file name conflict resolution with advanced sorting
  • improved performance
  • new droplet implementaiton
  • new auto-update feature courtesy of Andy Matuschak's Sparkle framework

Version 1.6.9

8th April 2009

This new version makes important speed gains and improves conflict resolution and memory management.

Version 1.6.8

Big Mean Folder Machine 2.16 Intel/serial 3

25th March 2009

Fixes the merge feature which became broken in 1.6.7.

Version 1.6.7

25th March 2009

The new version improves the performance of reading EXIF digital camera meta-data and fixes the problem that lead to version 1.6.6 being pulled.

Version 1.6.6

11th March 2009 - Pulled!

This release was pulled because it appears to be affected by a bug in Mac OS X 10.5 Leopard. The new 'Preserve original case wherever possible' option works correctly, but under some circumstances produces an incorrect preview and reports non-existant errors which can be confusing. A bug report is being filed with Apple (update workaround found!).

The new version now allows the folders in newly created folder hierarchies to preserve the case of the original names that it contains.

Beyond the user-visible changes there are many internal changes to further improve the performance and reliability of the processing engine.

Version 1.6.5

24th February 2009

The new version delivers significant performance gains throughout. In typical scenarios the conflict resolution step is now up to ten times faster making for a much zippier experience.

Version 1.6.4

11th February 2009

The new release becomes a 64-bit garbage collected application on all 64-bit systems. This should allow for improved scalability and reliability when dealing with very large processing jobs.

Version 1.6.3

3rd February 2009

This new release significantly speeds up hierarchy creation and reduces the memory footprint of the application.

Version 1.6.2

8th January 2009

Fixes a bug affecting the 'split into hierarchies' feature introduced in 1.6.

Version 1.6.1

7th January 2009

This is the first official Mac OS X 10.5 Leopard-only release of this title.

This product right from the start used operating system features first introduced in Mac OS X 10.4 Tiger and then refined in Mac OS X 10.5 Leopard. As development went on, we hit many limitations of the Tiger implementation of those features that prevented us from delivering the rapid pace of improvements that we were targeting.

In recent releases, a disproportional amount of effort went into maintaining backwards compatibility with Tiger and we've come to the conclusion that this time and energy would have been better spent moving the product forward at an increased pace.

This first Leopard-only release contains only nuts & bolts changes that ready the product for more Leopard-only developments.

Version 1.6

19th November 2008

The new version now remembers your settings between different sessions and allows you to create 'droplet' mini-applications that store frequently used settings and allow you to re-apply them to the content of new source folders via simple drag & drop.

Version 1.6 beta 1

17th November 2008

Adds support for creating self-contained droplet mini-applications that can be used to store and re-apply frequently used settings via simple drag & drop.

Version 1.5.1

27th October 2008

Small fix for the MP3/AAC support.

Version 1.5

22nd October 2008

The new version adds the ability to make the creation of deeper hierarchy levels dependent on the number of files on each level.

It also restores MP3/AAC support for the splitting feature.

Version 1.5 beta 2

17th October 2008

This beta restores MP3/AAC support for the splitting feature and fixes a few bugs in the first beta.

Version 1.5 beta 1

8th October 2008

This beta adds the ability of making the creation of deeper hierarchy levels dependent on the number of files per level.

It is released as a beta because it makes significant internal changes and there is thus potential for new bugs to have crept in. we have tested the new version extensively but if you notice anything please let us know at reiff@publicspace.net so that we can fix it before the version goes 'final'.

Version 1.4.5

23rd September 2008

The new version adds:

  • new options for batch folder creation
  • new sentence and proper case options for folder hierarchy creation

Version 1.4.1

28th February 2008

Restores 10.4 compatibility.

Version 1.4

27th February 2008

Adds support for using id3 tags in mp3, m4a, m4b and m4p iTunes Music Store music files to split music collections by album, artist, etc.

Version 1.3.5

30th January 2008

Improved performance, stability and scalability.

Version 1.3.1

10th January 2008

This releases fixes Tiger compatibility which was broken by version 1.3.

Version 1.3

9th January 2008

The new version now allows files to be moved as well as copied, thus greatly speeding up large batch jobs. This release broke Mac OS X 10.4 Tiger Compatibility and only worked correctly under Leopard.

Version 1.2.1

12th December 2007

This update fixes two problems:

  • invisible files were previously copied if the 'subfolders' checkbox was unticked
  • copying files containing forward slashes in their name would cause errors and not be copied

Version 1.2

29th November 2007

This new release focuses on stability, performance and scalability

  • fixed a multi-threading bug that could crash the application on Leopard
  • significantly reduced memory foot print of the processing engine, so that it can now safely handle hundreds of thousands of files
  • optimized some slower operations using Leopard-only features
  • remains both Leopard and Tiger compatible

Version 1.1

14th November 2007

This release addresses issues that were raised after the 1.0 release:

  • the program now remains open after the end of a run
  • the conflict resolution description has been clarified
  • the case settings for custom hierarchy splitting schemes are now honored
  • the program now provides a better warning that it operates in trial mode

Version 1.0

10th October 2007

This is the first full release of this software.

Version 1.0 Beta 3

12th September 2007

The third beta significantly expands the 'Split Files into Folder Hierarchies' feature, by allowing you to define your own splitting criteria, based on the names or the time and date attributes of your files or digital photos.

Version 1.0 Beta 2

14th August 2007

Big Mean Folder Machine 2.16 Intel/serial 7

After our initial product name 'Big Bang' seemed to already be taken, the icon and artwork for the renamed 'Big Mean Folder Machine' is now ready. We hope you'll enjoy it!

Big Mean Folder Machine 2.16 Intel/serial 10

Version 1.0 Beta 1

20th June 2007

This is the very first public release of this product.