-
Notifications
You must be signed in to change notification settings - Fork 5
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Building RPGLE from git without managing dependencies #65
Comments
That's interesting, very interesting, as i'm too silly for BOB and struggling with gmake for quite some time right now, and just as i'm seeing the horizon there's this rising - could be perfect timing! |
Good idea @worksofliam ... we have traditionally called this genre of tool a "makemake". And as a life expert in
So providing a more complete makemake than "Go for it!" |
In your example, specifically DEPTS.PGM, how are these 4 dependencies being determined? Is it just doing source analysis on qrpglesrc/depts.pgm.sqlrpgle and catching Dcl-F/Dcl-Pr/etc, or some other method? |
@ataylorkt
Good question. Everything
You can see the source code for |
Would it be simple to generate a Rules.mk for bob since that is a subset? I.e we just need to specify the dependencies in the exact same format without specifying the recipe to do the compile. This would fill the existing hole of discovering the dependencies which requires a lot of work. |
@edmundreinhardt Yup, generating the Rules.mk is up next! |
In my ongoing struggle i have decided to call make with option -n to do nothing and redirect the output to a make.sh-file and reading it line by line and executing it with QCMDEXC. |
One thing that I haven't seen a tool like this do - and maybe because this is a bit advanced and lots of IBM i shops may not really need this - is dynamic dependencies for ILE service programs based on the signature and parameters of the service program. By specifying a static signature in binder language, calling programs don't usually need a rebuild. A change to a service programs signature would mean all calling programs would need a rebuild. You can also specify a '*prev' and a '*current' program level (like in this example) instead of a static signature in binder language, but many shops just opt for a static signature - that's the standard at our shop. I'd like a tool to warn the user if the signature of a service program changes, and give the user some idea of impact. By impact, I mean number of objects to rebuild due to the change in signature. This is all in an effort to avoid the dreaded signature violation error. If the tool senses no change to the signature of a service program, no calling programs / modules / service programs would need to be rebuilt. The exception to this would be if a parameter changed in one of the procedures of the service program. You would have to build in a bunch of smarts here to know 1) There is a static signature for this service program and 2) the module that was changed before creation of the service program had a change to one of its parameters and therefor 3) All calling programs that make use of that particular procedure with the parameter change should be rebuilt. The rules for this could get quite hairy, which is probably why I haven't seen anyone attempt this. Might be difficult to do this with source info alone - you could more definitively know which objects need a rebuild by querying BOUND_SRVPGM_INFO or make use of the signature list in PROGRAM_INFO For either you would need an object library list. |
In theory it'd be possible. If you ensured that each service depended on a binder source for it to build, it would detect that the service program wouldn't need recompiling if the binder source didn't change. Of course, that's basic as it's looking at file change and not signature change, but it's a step in the right directory. I will share more later about how you can use |
Git is the way forward for the future of IBM i, we all know that. One of the biggest issues we face currently is not the developer tools honestly. We've come a great distance compared to where we were two years ago in regards to VS Code and local development for RPGLE code.
But the biggest issue is how we build our code. I am not talking about compiling a program here-or-there in VS Code or RDi. I am talking about how we can build our code in an automated fashion. Today there are two main tools for automating the build of ILE code out of git:
makefile
Rules.mk
)They both can be powerful tools, but the more complicated or larger your application is, the harder it can be to maintain those files. Defining what every programs depends on for it to be compiled is a PITA.
rmake
We have the tech to understand how to build ILE objects from source, so it's time I put it to use. I am excited to write about
rmake
today.rmake
is a tool that generates a makefile from source. This means that the developer no longer has to define amakefile
with all the dependencies in them and it will instead get built automatically at build time.Here's an action I have defined in VS Code, so after I make a change, it will rebuild what has changed for me:
Because it is just GNU Make under the hood, it will only rebuild the source that has changed, which is especially good for huge applications.
Usage
All the usage examples are against ibmi-company_system.
rmake
without any parameters will just generate a makefile and go on with its day - not very complicated. But it has some very useful CLI options.--verbose
Verbose will print everything out that it finds. In this example, it's printing all the base objects it finds, lists is source path and other objects it depends on.
-l
(finding usage)-l
is a way to find out where an object is used, and what changing it will impact/require a rebuild. In this instance, I look foremployee.file
This shows that
EMPLOYEE.FILE
is used byEMPLOYEES.PGM
and that is used byDEPTS.PGM
. Of course, ifEMPLOYEES.FILE
was used by multiple objects they would be listed here also.Doing the build
As I mentioned already,
rmake
just generates themakefile
, sogmake
is still required to do this build. Because of this, themakefile
should not be tracked in git. In this instance, I had already built my application:But if I
touch
the file to make it seem updated, then it will rebuild it automatically:Availability
It's not ready yet. Sorry!
The text was updated successfully, but these errors were encountered: