| 
 | 
Hi Charles,
IBM is about to finish a new Redbook on Modernization on IBM I, maybe you
will find
some inspiration in it when it is published:
http://iprodeveloper.com/blog/modernization-redbook-update
As a remark to what you have written, I do a lot of serialisation of both
XML and JSON
with my own RPGLE Open Source tool (powerEXT Core) that works together
with most
other Open Source tools.
http://192.185.226.162/~servus/pextdrupal/sites/all/themes/theme548/images/powerEXT_Core.png
I also have a Open Source framework that is build on Sencha's EXT JS
client framework.
A Demo is available on
http://www.powerEXT.com
To me you have a focus on server side programming and not the client side
- or is that based
on the .NET paradigm?
On Mon, Sep 9, 2013 at 12:15 PM, Charles MARTIN <cmartin@xxxxxxxxxxxxxxx>wrote:
A more readable version + added some parts (webservice, log4rpg).
------------
I wrote on February the mail "a RPG - Software Architecture / Best
practices".
Here is a short debriefing about what we did with my team.
When I came in this company, I did a lot of architecture for the
Microsoft .Net developers.
With the success of many project using this architecture, i was asked
todo the same for the Rpg team.
That was a great challenge.
At that time, I didn't know a thing about the IBM world.
I tried to put some standards between those 2 very different worlds : IBM
Rpgle and Microsoft .Net.
I worked a lot on this with my RPG team.
Our goals are :
- Centralize both technical and business logic
- Code readability
- Do less code todo more
- Almost never duplicate code
- Not involved (too much) in a specific technology or library, be free
to change when we want without to redesign everything
- Code change history
- .Net et Rpg programmers can understand and help each other.
To do this, we chose to work this way:
- Use long and understandable names
o For source file names (stored in the IFS)
o For functions
§ Too long in fact, we miss the notion of namespacing we
can have in c++ or c#.
o For Sql tables, Columns, index, etc.
- More standard SQL
o Every db2 table has now a primary key called "id"
o Relation between tables are made with a foreign key, with
referential integrity
- Put code in the IFS
o It allows us to organize code within folders deeper depth we
could have in QSYS.
- Code Layering with Service Programs
o Data Layer
§ DB2 Service Program with all data access, exposed
throw data provider functions
§ FTP Service Program with all ftp access, exposed throw
ftp provider functions (using Scott Klement ftp functions)
§ WebService Service Program with all WS access, exposed
throw WS provider functions (using wsdl2rpg from Thomas Raddatz)
o Business Logic Layer
§ Business Service Program
o Presentation Layer
§ Batchs Pgm Programs
§ MVC Programs
o DTO Layer
§ Data Structures which carries all data I need
o Core Layer
§ All technical functions not related to a specific layer
- Framework
o Similar to a project, with all the same layers, contains every
functions a project can share with others.
- Source code management - Git => http://git-scm.com<http://git-scm.com/
o Having a full history of source code change made by everyone
o Know exactly what is the development / release version of the
sources
o Each developers has his own version of code source, and his own
environment to compile and test his code
- Compilation using Qsh scripts
o Using CL seems not handy in the IFS
o Still not familiar with makefile
- Logs using Log4rpg
- Unit testing using rpgunit => We use the Behavior Driven Development (
http://en.wikipedia.org/wiki/Behavior-driven_development)
- We use Free Rpg as much as possible
What we still miss is :
- Technical stuffs
o A lot of things I thought were standards are missing, like :
§ dynamic collection => replaced by ArrayList and Lmap (
http://iledocs.sourceforge.net/docs/index.php?action=mainmenu&category=1)
§ Regex (Replace) => Replaced by java (
http://stackoverflow.com/questions/18404874/regex-replace-on-ibmi)
§ Streams (
http://www.cplusplus.com/reference/istream/iostream/)
§ Generic Types
§ Polymorphism
§ Inheritance (having a datastructure which inherit from
another would help a lot)
§ IOC (http://en.wikipedia.org/wiki/Inversion_of_control
)
§ RpgLe design patterns models
§ Better IDE, RDi can't handle IFS projects, don't find
functions from dependencies (includes)
§ Can't use Git clients on ibm I (
http://www.sourcetreeapp.com/, http://windows.github.com/)
§ Serialisation is not as easy as it should be.
. We can serialise Json or Xml using one line of
code in .Net. I don't want my programmers spending too much time in this
knowing they could do a lot faster.
. Better serialisation would make easier to add
WebServices.
§ We couldn't use PASE libraries the way we want. (
http://stackoverflow.com/questions/18588243/using-pcre-on-ile)
§ More appenders for log4rpg would be great
(mailAppender, SqlAppender, FtpAppender, etc.)
§ We need more time (a lot) to program something in
rpgle than in c#, mostly because the tools are not there yet.
§ We would like to code everything in free rpg (avoid F
or D specifications)
We are working on that.
Any suggestions would be great.
So far, we have a huge emphasis in our new ways to work on ibm i.
If you have any questions / remarks, I would be glad to hear them.
Best regards,
Charles
--
This is the RPG programming on the IBM i (AS/400 and iSeries) (RPG400-L)
mailing list
To post a message email: RPG400-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/rpg400-l.
--
Regards,
Henrik Rützou
http://powerEXT.com <http://powerext.com/>
As an Amazon Associate we earn from qualifying purchases.
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.