home *** CD-ROM | disk | FTP | other *** search
/ Peanuts NeXT Software Archives / Peanuts-2.iso / Developer / apps / ClassEditor.0.4.README < prev    next >
Encoding:
Text File  |  1995-06-09  |  11.2 KB  |  334 lines

  1. Release 0.4, 05.06.1995 by Thomas Engel (tomi@shinto.nbg.sub.org)
  2.  
  3.  
  4.  
  5.               The ClassEditor
  6.  
  7. ATTENTION..you need gnutar and gzip to unpack this package.
  8.  
  9.  
  10. WHAT's NEW IN 0.4:
  11.  - Source colorization
  12.  - "See also" references by drag&drop
  13.  - New UI
  14.  - Fixed bugs
  15.  - For details read on or see the 'Release Notes'
  16.  
  17.  
  18. This editor allows you to modify class definitions on a per-method
  19. basis. In additon to offering a method browser it will make it very
  20. simple to keep the documentation in sync with your code. Both
  21. elements are shown side by side. The ideal situation would be to
  22. maintain a documentation file from the first moment since creating a
  23. new class or method. ClassEditor is able to create the docu tempates
  24. for you and helps maintaining them in a NeXT conform layout. 
  25.  
  26. In the worst case you should think about this project as a RFD
  27. (request for discussion). Maybe someone at NeXT might find new ideas
  28. for NeXTSTEP 4.0 in there.
  29.  
  30.  
  31.  
  32.           What it does
  33.  
  34.  
  35. ClassEditor opens a set of MyClass.m, MyClass.h and MyClass.rtf files
  36. and displays them. You can edit and view the class on a per-method
  37. basis or see all three files at once inside the "cheat window". 
  38.  
  39. Modifying existing classes that are not spread accross more then
  40. those three files is quite safe. Adding methods is possible from
  41. inside the "cheat window" but introduces some rough edges. See the
  42. bugs section for details. 
  43.  
  44.  
  45.  ----------------------------------------------------------------------
  46. Reliability Issues
  47.  
  48. Although the app has improved over the previous versions it still
  49. contains some bugs that might cause the app to crash or even corrupt
  50. your data. I am aware of rare cases where the documentation got
  51. corrupted. Source files have not been damaged as far as I can tell.
  52. Drag operations might crash the app on a random basis due to a
  53. strange behavior of the Pasteboard class. 
  54.  
  55. If you use this application to modify important files be sure that
  56. you read the Release Notes and Warranty section first. Remember that
  57. there is no guaranty for nothing. 
  58.  ----------------------------------------------------------------------
  59.  
  60.  
  61. The Package
  62.  
  63. Version 0.4 comes in a package that includes:
  64.  
  65.  - ClassEditor.app. A FAT binary for NeXT, Intel, HP and Sparc hardware.
  66.  
  67.  - An Examples directory containing working test setups of interface, 
  68.    implementation and documentation files for some dummy classes.
  69.  
  70.  - Online help...minimal
  71.  
  72.  - Full source code
  73.  
  74.  - The documentation and an ASCII version (README) of this introduction
  75.  
  76. On where to find the latest releases please see the 'About this Project'
  77. section.
  78.  
  79.  
  80. Features
  81.  
  82. Currently there are only very simple things this application will do
  83. for you. Now this is just an early alpha version...don't expect it to
  84. do magical things anytime soon. 
  85.  
  86.  - Select methods and view or edit the description and implementation. 
  87.  
  88.  - Create missing pieces of class and method documentation using automatic 
  89.    text generation and useful ready-to-copy templates. 
  90.  
  91.  - Add "See also" references with a simple drag&drop. 
  92.  
  93.  - Use the "Style" menu to get fast access to the right fonts for the 
  94.    nasty documentation work. 
  95.  
  96.  - Undo the last changes inside a methods source or documentation. 
  97.  
  98.  - Use Emacs keybindings to navigate inside the text areas.
  99.  
  100.  - View ASCII sources in a colorized style which makes editing a lot 
  101.    easier.
  102.  
  103.  - Select the "Plain C-Stuff" entry from the mode popup and view (or edit) 
  104.    all three files inside the "cheat window". Add defines, typedefs, 
  105.    instance variables or new methods here.
  106.  
  107. Some features will definitly be improved to help me get along with
  108. all those missing class docus (yes...MiscSwapKit docus are already
  109. waiting for too long).
  110.  
  111. The Release Notes chapter can give you a complete overview of all the
  112. implemented features. In also includes a detailed description of the
  113. currently known bugs. 
  114.  
  115.  
  116. Bugs and Birds
  117.  
  118. It is not fair to speak about them in a little sub paragraph. There
  119. are so many of them that it would justify a whole chapter.
  120.  
  121. This app is a piece of brain stroming - a running ToDo list. It is
  122. not a product. Peter L. would call it another piece of German
  123. software: nice idea but bound to never get finished.
  124.  
  125. Well maybe he is kind of right. Now lets face the most serious
  126. problems of this app: 
  127.  
  128.  - When working inside the "cheat window" you should take care of all the 
  129.    changes you make. You should follow a very strict coding style. 
  130.    Otherwise ClassEditor won't be able to parse your code and might even 
  131.    corrupt your files. See the Examples for working layouts.
  132.  
  133.  - RTF headers and sources will only work if the entire method names are 
  134.    typeset with a single font. Take a look at the RTFExampleClass to see 
  135.    how rich sources should look like to work with ClassEditor.
  136.    Since v0.4 you have ASCII code colorization which makes RTF source more 
  137.    useless because there is no easy way to provide smart colorization of 
  138.    RTF...which should preserve your private colorization.
  139.  
  140.  - Many user interface controls are just fakes, the split views might 
  141.    cause your window to turn into an ugly piece of GUI when used to their 
  142.    limits and the drag&drop stuff might crash the application.
  143.  
  144.  
  145.  
  146.           What it should
  147.  
  148.  
  149. Of course this should become the killer application of the nineties.
  150. But I am lazy and I do believe in code reuse. The guys at NeXT have
  151. already done all the nasty work. So I only want to build a minimal
  152. tool to fill the gap until NeXTSTEP 4.0 arrives. 
  153.  
  154. Perhaps this app will only lead to a simple font service application
  155. (btw. too many people use the wrong font for source code inside the
  156. docus..it is Courier 12pt...not 14pt) or it will migrate to a real
  157. destributed class editor (the buzzword here is: groupware).
  158. Who knows.
  159.  
  160.  
  161. Future plans
  162.  
  163. My plans are to enjoy NeXT's upcoming ProjectBuilder if it comes
  164. close to the ClassEditors idea. As far as I can tell from all the
  165. published material I'm not sure that it will really cover all the
  166. fruits of desire.
  167.  
  168. The aim is to build a combination of a class browser with the freedom
  169. to write ugly and nasty C-style code while providing all the help an
  170. editor should give. This includes concurrent editing and versioning.
  171.  
  172. ClassEditor should split into the real editor and a ResourceServer.
  173. This would free the editor from many low-level issues which might be
  174. implemented quite individually (e.g. taking sources from a database
  175. and not a filesystem).
  176.  
  177. So lets see what this application is still missing. I do consider to
  178. add some of these features: 
  179.  
  180.  - Online source sanity checks. Checking braces is only a primitive step 
  181.    into that direction.
  182.  
  183.  - Creating new classes, methods, categories and protocols on the fly. 
  184.    Specifying dependancies and relations should be as simple as a 
  185.    drag&drop. Grouping methods and adding descriptions to instance
  186.    variables.
  187.  
  188.  - The editor should be able to dump templates for get/set'er methods and 
  189.    other ever returning tasks.
  190.  
  191.  - The special categories called (private) and (protected) might be used 
  192.    in the headerfiles and other sections by default. Every category should 
  193.    follow the ClassName+categoryName.h (.m or even .rtf ) convention.
  194.    The editor should create those files for you if you don't want to 
  195.    organize it in your private style.
  196.    This would keep the code clean for fast and easy distribution.
  197.  
  198.  - Prepare sources for public distribution by stripping protected methods 
  199.    from the headers and such.
  200.  
  201.  - Support for concurrent editing over a network. This should not 
  202.    necessariy mean sharing the real source files. And DO approach would be 
  203.    much better.
  204.  
  205.  - Maintaining a revision history. This could be done by including CVS 
  206.    support.
  207.  
  208.  - Storing bug infos and idea notes together with the code and 
  209.    documentation.
  210.  
  211.  - More support for "See also:" references and other logical links.
  212.  
  213. Some features can only be implemented if the whole development
  214. environment works together. This includes apps like InterfaceBuilder
  215. and therefore requires some open APIs provided by NeXT: 
  216.  
  217.  - Being sure that classes inside NIBs are always up to date with the code.
  218.    I hate to have to remember all those dependancies.
  219.  
  220.  - Speaking about IB; one of its nasty features is that it won't drop back to 
  221.    palettalized classes if it can't find the code for a certain subclass of 
  222.    them. In testmode this only works for subclasses of window...why ??
  223.  
  224. It is true that many things can already be done right now...but you
  225. have do them by hand. There often is no real support from the tools.
  226. It is time to change that.
  227.  
  228.  
  229.  
  230.           About this Project
  231.  
  232.  
  233. I don't see the need to rush for a much better version of this app
  234. until it is clear what NeXT will include with their NeXTSTEP 4.0
  235. release. There are other projects I want to spend more time on.
  236.  
  237. The latest version of this editor will be available at the
  238. ftp.nmr.embl-heidelberg.de, ftp.informatik.uni-muenchen.de or
  239. ftp.cs.orst.edu anonymous ftp servers. There is a WWW page were you
  240. can find out more about the status of this...and all the other
  241. projects I'm working on:
  242.  
  243.     
  244.     http://wwwcip.informatik.uni-erlangen.de/user/tsengel/
  245.     Projects/Projects.html
  246.  
  247.  
  248. Compiling
  249.  
  250. This version includes all the source code necessary to recompile the
  251. program from scratch. It does not come with all the libraries! You
  252. will need to get the MiscKit project (Version 1.5.0 or higher) from
  253. the archives.
  254.  
  255. For more details on the MiscKit collection see the common NeXT ftp
  256. servers, get the Objective-C or NeXT FAQs or take a look at the
  257. EduSteps developer area:  
  258.     
  259.     http://www.nmr.embl-heidelberg.de/eduStep/Developer/Kits/
  260.     MiscKit/MiscKit.html
  261.     
  262. If you would like to submit something to this collection you should
  263. contact the current maintainer: Don Yacktman <don@darth.byu.edu> 
  264.  
  265.  
  266. In Case of Trouble
  267.  
  268. If you have any questions you can contact me.
  269.  
  270.     Thomas Engel     
  271.     Netpunstr. 9     
  272.     D-90522 Oberasbach 
  273.     Germany          
  274.     
  275.     E-mail:    tsengel@cip.informatik.uni-erlangen.de 
  276.                tomi@shinto.nbg.sub.org
  277.  
  278.                (NeXTMail welcome)
  279.  
  280.  
  281.  
  282.           Warranty and copyright
  283.  
  284.  
  285. Copyleft
  286.  
  287. All source code is distributed under the GNU General Public License.
  288. This does not apply to used ObjectWare which most likely comes with
  289. its own licensing rules (e.g. code that belongs to the MiscKit
  290. project).
  291.  
  292. You are free to extend and modify this application. But don't
  293. redistribute a modified version under the same name unless I gave you
  294. the permission. I don't want to have different, confusingly
  295. incompatible versions running around the world. 
  296.  
  297. Anyway...comments are highly appreciated.
  298.  
  299.  
  300. No Warranty
  301.  
  302. This software is provided 'as is' and the programmer is not
  303. responsible for any harm this program may cause. You - the user - are
  304. responsible for everything that may happen to your business,
  305. hardware, software, car, CD collection or what ever may be worth your
  306. attention or money. Using this product is at your own risk and your
  307. private fun.
  308.  
  309. There should be no serious bugs inside but remember that a
  310. carbon-based unit did the coding. 
  311.  
  312.  
  313. Travelware
  314.  
  315. Like all my projects this app is free and should be considered as travelware.
  316.  
  317.  1. Let it travel to as many people as you know. 
  318.  
  319.  2. Send me an E-mail or postcard if you use it. I will try to
  320.     keep you informed about new releases.
  321.  
  322.  3. If you have a free bed or some free space on your floor...give
  323.     me a hint. I might come and visit you on my next trip to the
  324.     US...locations on Hawaii, near Seattle or WhistlerMnt. (Canada)
  325.     preferred.
  326.  
  327.  
  328.  
  329. Enjoy it.
  330.  
  331.     Tomi
  332.  
  333.  
  334.