Use when you have a written implementation plan to execute in a separate session with review checkpoints
npx skills add DauQuangThanh/hanoi-rainbow --skill "jcl-migration-analyzer"
Install specific skill from multi-skill repository
# Description
Analyzes legacy JCL (Job Control Language) scripts to assist with migration to modern workflow orchestration and batch processing systems. Extracts job flows, step sequences, data dependencies, conditional logic, and program invocations. Generates migration reports and creates implementation strategies for Spring Batch, Apache Airflow, or shell scripts. Use when working with mainframe job migration, JCL analysis, batch workflow modernization, or when users mention JCL conversion, analyzing .jcl/.JCL files, working with job steps, procedures, or planning workflow orchestration from JCL jobs.
# SKILL.md
name: jcl-migration-analyzer
description: Analyzes legacy JCL (Job Control Language) scripts to assist with migration to modern workflow orchestration and batch processing systems. Extracts job flows, step sequences, data dependencies, conditional logic, and program invocations. Generates migration reports and creates implementation strategies for Spring Batch, Apache Airflow, or shell scripts. Use when working with mainframe job migration, JCL analysis, batch workflow modernization, or when users mention JCL conversion, analyzing .jcl/.JCL files, working with job steps, procedures, or planning workflow orchestration from JCL jobs.
metadata:
version: "1.0"
category: legacy-migration
JCL Migration Analyzer
Analyzes legacy JCL scripts for migration to modern batch processing and workflow orchestration systems like Spring Batch, Apache Airflow, Kubernetes Jobs, or shell scripts.
Overview
This skill provides comprehensive analysis and migration planning for JCL (Job Control Language) batch processing systems. It extracts job structures, converts JCL constructs to modern workflow patterns, maps data dependencies, and generates implementation-ready migration strategies.
Key Migration Focus: JCL to modern orchestration with proper handling of COND logic inversion, data dependencies (DD statements), GDG generations, procedures (PROCs), and batch workflow patterns.
When to Use This Skill
Use this skill when:
- Analyzing JCL job files (.jcl, .JCL) for modernization
- Planning migration from mainframe batch processing to modern workflow systems
- Converting JCL job steps to Spring Batch, Apache Airflow, or shell scripts
- Understanding JCL COND logic and conditional execution patterns
- Mapping JCL data sets (DD statements) to modern file operations
- Extracting JCL procedures (PROCs) and symbolic parameters
- Generating workflow definitions for orchestration platforms
- Estimating complexity and effort for JCL migration projects
- Creating migration documentation and strategy reports
- Modernizing mainframe batch jobs to cloud-native workflows
- User mentions: JCL analysis, mainframe job migration, batch workflow conversion, COND logic, job steps, procedures, workflow orchestration
Core Capabilities
1. Job Analysis
Extract job structure (JOB card), step sequences, program invocations (EXEC PGM/PROC), conditional logic (COND, IF/THEN/ELSE), return codes, data sets (DD statements), resource requirements, and symbolic parameters.
2. Data Dependency Mapping
Extract input/output datasets, temporary datasets, GDG handling, concatenation, DISP parameters, and data flow between steps.
3. Procedure Analysis
Parse PROC definitions, symbolic parameters, PROC overrides, nested procedures, INCLUDE statements, and JCLLIB references.
4. Workflow Migration
Generate Spring Batch jobs, Apache Airflow DAGs, Kubernetes Jobs, shell scripts, AWS Step Functions, or Azure Logic Apps.
5. Conditional Logic Translation
CRITICAL: COND logic is INVERTED! Map COND parameters, IF/THEN/ELSE, return codes, step bypassing, and restart logic to modern constructs.
Workflow
Step 1: Discover JCL Assets
Find JCL jobs and procedures in the workspace:
find . -name "*.jcl" -o -name "*.JCL"
find . -name "*.proc" -o -name "*.PROC"
Use scripts/analyze-dependencies.sh or scripts/analyze-dependencies.ps1 to generate dependency graph in JSON format.
Step 2: Extract Structure
Use scripts/extract-structure.py to parse JCL files and extract:
- Job cards and parameters
- Step sequences and execution order
- Program/procedure invocations
- DD statements with DISP parameters
- COND and IF/THEN/ELSE logic
- Symbolic parameters
Output format: JSON with job structure, steps, and dependencies.
Step 3: Analyze Conditional Logic
CRITICAL: Identify and document COND logic (which is INVERTED):
COND=(0,NE)→ Run if previous RC ≠ 0 (run on ERROR)COND=(0,EQ)→ Skip if previous RC = 0 (skip on SUCCESS)- IF/THEN/ELSE uses normal logic (not inverted)
Create truth tables for complex conditional logic to avoid errors in migration.
Step 4: Map Data Dependencies
Track data flow between steps:
- Input datasets (DISP=SHR or OLD)
- Output datasets (DISP=NEW, CATLG)
- Temporary datasets (&&TEMP)
- GDG generations (GDG(0), GDG(+1))
- Dataset concatenations
Step 5: Estimate Complexity
Use scripts/estimate-complexity.py to calculate migration complexity based on:
- Number of job steps
- Conditional logic complexity (COND/IF/THEN/ELSE)
- Number of procedures (PROCs)
- Data dependency complexity
- Number of programs invoked
- GDG usage patterns
Step 6: Choose Target Platform
Select migration target based on requirements:
- Spring Batch: Java-based batch processing with comprehensive features
- Apache Airflow: Python-based workflow orchestration with rich UI
- Shell Scripts: Simple, lightweight for basic sequential processing
- Kubernetes Jobs: Container-based batch processing
- AWS Step Functions: Serverless workflow orchestration
- Azure Logic Apps: Cloud-based workflow integration
Step 7: Generate Migration Strategy
Create comprehensive migration report with:
- Job Overview: Purpose, schedule, dependencies
- Step Sequence: Detailed breakdown of each step
- Data Flow Diagram: Input/output dependencies
- Conditional Logic Map: COND translations (with inversion notes)
- Target Implementation: Workflow definition in chosen platform
- Migration Estimate: Effort, complexity score, risk assessment
- Action Items: Prioritized tasks with acceptance criteria
Use template: assets/migration-report-template.md
Quick Reference
Critical: COND Logic is INVERTED
JCL COND (inverted):
//STEP020 EXEC PGM=PROG2,COND=(0,NE)
Means: "Run if previous RC ≠ 0" → Run on ERROR!
Modern (normal logic):
if [ $rc -ne 0 ]; then run_prog2; fi
JCL IF/THEN (normal logic):
//IF1 IF RC = 0 THEN
//STEP020 EXEC PGM=PROG2
//ENDIF
Modern:
if [ $rc -eq 0 ]; then run_prog2; fi
Code Patterns
Simple Sequential:
//STEP010 EXEC PGM=PROG1
//INPUT DD DSN=INPUT.FILE,DISP=SHR
//OUTPUT DD DSN=OUTPUT.FILE,DISP=(NEW,CATLG)
//STEP020 EXEC PGM=PROG2
//INPUT DD DSN=OUTPUT.FILE,DISP=SHR
#!/bin/bash
set -e
prog1 --input="input.file" --output="output.file" || exit 8
prog2 --input="output.file" || exit 8
Conditional (COND - inverted!):
//STEP010 EXEC PGM=VALIDATE
//STEP020 EXEC PGM=PROCESS,COND=(0,NE)
validate_data
rc=$?
if [ $rc -ne 0 ]; then process_data; fi # INVERTED!
IF/THEN/ELSE (normal logic):
//STEP010 EXEC PGM=VALIDATE
//IF1 IF RC = 0 THEN
//STEP020 EXEC PGM=PROCESSOK
//ELSE
//STEP030 EXEC PGM=PROCESSERR
//ENDIF
validate_data
rc=$?
if [ $rc -eq 0 ]; then processok; else processerr; fi
Procedure:
//MYPROC PROC MEMBER=,INFILE=
//STEP1 EXEC PGM=PROG1
//SYSIN DD DSN=&MEMBER,DISP=SHR
// PEND
function myproc() {
prog1 --sysin="$1" --input="$2"
}
myproc "test.data" "prod.file"
Target Platforms
Spring Batch:
@Bean
public Job job() {
return jobBuilderFactory.get("job")
.start(step1()).next(step2())
.on("FAILED").to(errorStep())
.from(step2()).on("*").to(step3())
.end().build();
}
Airflow DAG:
with DAG('job', schedule_interval='@daily') as dag:
step1 = BashOperator(task_id='step1', bash_command='prog1.sh')
step2 = BashOperator(task_id='step2', bash_command='prog2.sh')
step1 >> step2
Key Patterns
Error Handling: COND-based → if [ $rc -ne 0 ]; then error_handler; fi
GDG: GDG(0) → get_latest_generation, GDG(+1) → create_new_generation
Concatenation: Multiple DD → cat file1 file2 file3 | process
Restart: COND restart → checkpoint files (touch .checkpoint_step)
Return Code Reference
| RC | Meaning | Action |
|---|---|---|
| 0 | Success | Continue |
| 4 | Warning | Continue (informational) |
| 8 | Error | May continue based on COND |
| 12 | Severe Error | Typically stop |
| 16 | Fatal Error | Abort job |
Migration Checklist
- [ ] Extract job structure, list steps in order, identify programs/procedures, document COND/IF logic
- [ ] Map input/output datasets, identify temp datasets, document GDG usage, track data dependencies
- [ ] Convert COND to normal logic (INVERT!), translate IF/THEN/ELSE, handle error paths
- [ ] Choose target (Spring Batch/Airflow/shell), define job structure, implement steps, add monitoring
- [ ] Test normal path, error conditions, conditional branches with production-like data
- [ ] Document job purpose, schedule, dependencies, special requirements
Critical Tips
- COND is INVERTED - step runs when condition is FALSE! Draw truth tables if needed.
- Return codes: 0=success, 4=warning (OK), 8+=error
- Data dependencies: Carefully map to avoid race conditions
- Restart capability: Implement checkpointing if needed
- Monitoring: Add logging and alerting to modern workflows
Output Structure
Provide: Job overview, step sequence, data flow, conditional logic, migration target, workflow definition, migration estimate, action items.
Advanced Topics
For detailed conversion rules and patterns, see:
- pseudocode-jcl-rules.md - Comprehensive JCL to pseudocode conversion rules including element mapping, return codes, DISP parameters, translation patterns, and COND logic handling
- pseudocode-common-rules.md - Common pseudocode syntax and conventions applicable to all languages
- testing-strategy.md - Comprehensive testing approach including unit tests, integration tests, parallel validation, and data-driven testing for migrated workflows
- transaction-handling.md - Transaction management, rollback strategies, and ACID compliance for batch jobs
- messaging-integration.md - Message queue integration patterns (MQ, JMS, Kafka) for event-driven workflows
- performance-patterns.md - Batch processing optimization, memory management, parallel processing, and performance tuning
Tools and Scripts
All scripts support cross-platform execution (Windows PowerShell, bash):
analyze-dependencies.sh/ps1- Generate dependency graph in JSON format showing job-to-job, job-to-dataset, and procedure dependenciesextract-structure.py- Parse JCL files and extract structure (job cards, steps, DD statements, COND logic) to JSONgenerate-java-classes.py- Generate Java POJOs from data structures for Spring Batch item readers/writersestimate-complexity.py- Calculate migration complexity score based on steps, conditional logic, procedures, and data dependencies
Scripts use standard libraries only and output JSON for easy integration with CI/CD pipelines and migration tracking tools.
Integration
Works with job schedulers (Control-M, cron), workflow platforms (Spring Batch, Airflow, K8s), monitoring tools, version control, and CI/CD pipelines.
# Supported AI Coding Agents
This skill is compatible with the SKILL.md standard and works with all major AI coding agents:
Learn more about the SKILL.md standard and how to use these skills with your preferred AI coding agent.