Hello Joe,

You wrote:
>Bunkum, Simon.

I see your bunkum and raise you bollocks!

This is the beginning of an argument much like the one you and Brad Stone
entered into a few months back on the Java list.  You accused Brad of
changing the argument as he went to suit his purposes.  His approach must
have made quite an impression because here you are trying the same trick on
me.

One must look beyond the statements and look for the motive.  It is in your
interest to discredit a non-JSP approach because you have a vested interest
in a JSP-based approach.

I did not say that JSPs were innappropriate.  I simply pointed out that you
were perpetuating a myth and explained why you were wrong.  You then
respond with a completely new argument about why JSP is better and that
writing a replacement Application Server would involve a lot of work.  Both
points I actually agree with.

At the risk of filling the list with more opinion-as-fact let's deal with
your NEW arguments.

>Certainly, you can write a pseudo-page server that reads
>through "code snippets" or even through entire HTML files and does some
>sort of scan and replace to generate code.  You would have less than 50%
>of the capability of a JSP, it would be non-standard, and you'd have to
>maintain the cut-and-paste code.  So what's the benefit of reinventing
>your own sub-standard wheel?

Firstly, I am not suggesting that people eschew JSP in favour of a
roll-your own CGI.  Merely that it is possible to create dynamic pages
using an HLL and that JSP is not a requirement.  Secondly, most sites don't
use even 50% of the capabilities of JSP.  They use them for the simple
purpose of dynamically formatting data.  That IS trivial to code in an HLL.
If you need the full feature set of JSP then you would indeed be foolish to
write a replacement environment.

The benefit is in making better use of your system resources.  JSP requires
an Application Server which generally requires an HTTP Server.  While an
HTTP Server may be manageble on most AS/400s a JSP Application Server is
not.  They are generally very hungry on resources and frequently require a
major hardware upgrade to make them run acceptably.  Even you in your
approach have realised that and use HLLs as the background processor.

Also, the specific requirements of a given "get-it-on-the-Web" project may
not warrant the added expense of additional hardware, software, and
education.  The  benefit is in using tools you already understand to meet
the requirements of a project that doesn't warrant learning another
language or spending money on more gear.  It is a valid approach and one
you attempted to discredit with a false statement.

>Heck, why not write a program that directly executes RPG source code,
>rather than go through the cumbersome old compiler?  It's as good an idea
>as writing your own JSP processor.

Now that IS a specious argument! and it's not worthy of further comment.

>The only reason not to use a Java Server Page is a refusal to learn even
>the basics of a very simple language like Java.  I teach RPG and COBOL
>programmers how to build true client/server applications using servlets in
>one week.  I suspect writing a complete parsing server that has all the
>support of a JSP would take at least that long.  And again, that sort of
>application is non-standard, so that means somebody using it has to learn
>your particular syntax, rather than using something industry standard.

I suspect I have been using Java and JSP for longer than anyone on these
lists.  I started with Java in 97.  I am well aware of the capabilities of
both environments.  However, I am not blinded to alternatives.

I too teach Java to RPG and COBOL programmers and the syntax is the easy
part (as you yourself have argued in the past).  I do not believe you get
average RPG and COBOL programmers upto speed with all that Java and JSP
entails in a week.  It is possible that you get them productive with your
tool in that t
e however I fail to see the relevance.  I never suggested
writing a replacement for an Application Server, merely a
search-and-replace engine which IS trivial code and would take a lot less
than a week to implement.

If you are concerned about a 'non-standard' syntax there is no reason why
an HLL could not process the standard JSP tags (Oh, which version of the
"standard" tags did you have in mind?)  but that removes us from my
original point of trivial scan and replace.

>Also, all servlets in a web application share persistent memory within the
>JVM, which allows them to do a lot of sharing and caching of information -
>caching that you would have to manually code for any form of CGI.

Again, you seek to expand the argument into territory not covered by my
original comment.  JSPs don't provide caching, the Application Server does
that (often in conjunction with the HTTP Server).  Besides, simple caching
of common pages or data is fairly easy using *USRSPC and *USRIDX objects,
or an array of pointers to dynamically allocated storage, or a linked list
of file buffers, or any one of a number of other approaches.  However,
caching has nothing to do with the original argument.

>Finally, your COBOL-driven HTML scan and replace doesn't support the basic
>Java syntax - looping, conditional code, and the like - that can be used
>inside of a JSP to execute code and communicate dynamically with the
>server. Instead, you can only send data to the HTML data stream and can
>only receive it from a POST.  With a JSP, I can - while the page is being
>generated! - interactively change the very generation characteristics of
>the code in response to other events in the page, or even in response to
>other events  in the system.  Of course, you can do that, too, but if you
>have added loops and branching to your "snippet syntax", you're writing
>your own language. While occasionally necessary - I've written several in
>my career - it's absolutely not warranted in this case, when a perfectly
>good one exists,  and writing an interpreter for such a language is hardly
>"trivial", as you suggest.

I didn't suggest writing such a replacement so again you put words in my
mouth to further your own design.  You also confuse JSP and the Application
Server (I suspect deliberately in order to support your case since I am
sure you do understand the difference).  I agree a full replacement for an
Application Server is not a trivial exercise but I never suggested that
course.

Even a simple search-and-replace function can read an <ITERATE> tag and
perform looping or an <IF> tag and perform conditional tasks.  It IS
trivial when using literals (e.g., <ITERATE 10> or <IF
CONDÒfile×CUSTMAST'">, it gets harder if you want to support variables
and embedded code.  Again, I never suggested that  (Have you got that yet!)

>While COBOL CGI may be easier for the very simple type of cut and paste
>HTML you may be familiar with, JSPs are quicker, easier and faster to
>implement for anything of a non-trivial level of complexity.  To top it
>all off, any Java code used in a JSP can later be encapsulated into a Java
>class and folded back into the servlet.

Ah! Discredit my argument by suggesting I don't know what I'm talking about
or have limited experience with Java and JSP.  You used that one on Brad
too as I recall.  In his case it may have been accurate but in my case it's
not.

>If you think that the essence of a JavaServer Page is just cutting and
>pasting into HTML, then you might want to spend a little more time with
>them.

That's another approach you used on Brad.  I am well aware that JSPs are
capable of more but the ESSENCE is exactly as I stated.  The code generated
from a JSP reads the original file of HTML and builds a new stream by
replacing magic markers with data from a Bean.  Yes, you also have control
constructs, and can embed code, but in most cases the real work is done by
a backend Java program and the JSP simply formats the res
t.  Regardless
of how much additional function is added to JSP, the core function is an
HTML pre-processor.  All the rest is built on that ability.  Using a Bean
to provide dynamic data is simply a disguised call-back.  A call back is
easily implemented in any language that supports function pointers.  A
requirement for function pointers would indeed restrict the possible HLLs
one could used.  You would be limited to C, RPG IV, ILE COBOL.  (Dropping
into sarcasm so I think I'll cease.)

Over to you.  Let's see how you misconstrue these comments.

Regards,
Simon Coulter.

«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»
«» FlyByNight Software         AS/400 Technical Specialists       «»
«» Eclipse the competition - run your business on an IBM AS/400.  «»
«»                                                                «»
«» Phone: +61 3 9419 0175   Mobile: +61 0411 091 400        /"\   «»
«» Fax:   +61 3 9419 0175   mailto: shc@flybynight.com.au   \ /   «»
«»                                                           X    «»
«»               ASCII Ribbon campaign against HTML E-Mail  / \   «»
«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»«»


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.