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 developpers.
With the success of many project using this architecture, i was asked to do 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 to do 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
§ WebService Service Program with all WS access, exposed throw WS provider functions
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
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.
§ We couldn't use PASE libraries the way we want. (
http://stackoverflow.com/questions/18588243/using-pcre-on-ile)
§ We need more time (a lot) to program something in rpgle than in c#, most of the time because the tools are not there yet.
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
As an Amazon Associate we earn from qualifying purchases.