Case Fixer  Case Fixer

go to home page Student Projects full screen, hide local find menu Google search web for more information on this topic jump to foot of page translate this page with Babelfish by Roedy Green ©1996-2009 Canadian Mind Products
This essay does not describe an existing computer program, just one that should exist. This essay is about a suggested student project in Java programming. This essay gives a rough overview of how it might work. I have no source, object, specifications, file layouts or anything else useful to implementing this project. Everything I have to say to help you with this project is written below. I am not prepared to help you implement it; I have too many other projects of my own.

I do contract work for a living, which could include writing a program such as this. However, I don’t do people’s homework for them. That just robs them of an education.

You have my full permission to implement this project in any way you please and to keep all the profits from your endeavor.

When I code, my most common error is to get the case of a variable incorrect. Sometimes it is an ambiguity like HashTable vs Hashtable . Other times it is a flying cap, like ITem instead of Item .

Your job is to write a program that will automatically fix these errors. It uses the declaration as the definitive spelling, and then propagates it.

Programmers will probably not trust it at first, so they will want to ok each individual change.

This is considerably more difficult than you might first guess. You may legitimately have the strings HashTable , hashtable and hashTable in a pathological program. You need analysis at least as deep as a compiler’s to help you guess what was intended for an undefined symbol. You also likely want to clean up comments as well. See parser in the Java & Internet Glossary.

To make life easier, you might use the error list output of some particular compiler as input to your program to help you identify variable references that could benefit from case fixing. You could write a mindless case fixer that relies on the programmer to figure out which instances of the names should be changed and simply offers him a selection of variant spellings that appeared as the definitive one. This technique may also handle slightly misspelled variables as well.


CMP homejump to top
CMP logo
feedback Please email your feedback for publication, errors, omissions, broken/redirected link reports
and suggestions to improve this page to Roedy Green : feedback email
made with CSS
HTML Checked!
ICRA ratings logo
mindprod.com IP:[65.110.21.43]
Your face IP:[38.103.63.58]
You are visitor number 4,826.
You can get a fresh copy of this page from: or possibly from your local J: drive (Java virtual drive/mindprod.com website mirror)
http://mindprod.com/project/casefixer.html J:\mindprod\project\casefixer.html