Skip to content
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

ICU-22714 fix zos build, use OpenXL #3008

Merged
merged 1 commit into from
Sep 21, 2024

Conversation

alexgubanow
Copy link
Contributor

@alexgubanow alexgubanow commented May 14, 2024

I have fixed the git clone of this repo on zos and moved build from old XLc compiler to new OpenXL compiler.
More details https://unicode-org.atlassian.net/browse/ICU-22714
As of now:

  • tests are passing, some issues with files not being UTF-8 on zos, will address that in separate PR
  • results of build was tested internally, we have own test suite
  • following files had no BOM, need to fix tool that is used to generate those:
    icu4c/source/data/misc/currencyNumericCodes.txt
    icu4c/source/data/misc/icustd.txt
    icu4c/source/data/misc/zoneinfo64.txt
Checklist
  • Required: Issue filed: https://unicode-org.atlassian.net/browse/ICU-22714
  • Required: The PR title must be prefixed with a JIRA Issue number.
  • Required: The PR description must include the link to the Jira Issue, for example by completing the URL in the first checklist item
  • Required: Each commit message must be prefixed with a JIRA Issue number.
  • Issue accepted (done by Technical Committee after discussion)
  • Tests included, if applicable
  • API docs and/or User Guide docs changed or added, if applicable

@CLAassistant
Copy link

CLAassistant commented May 14, 2024

CLA assistant check
All committers have signed the CLA.

alexgubanow added a commit to alexgubanow/icu that referenced this pull request May 14, 2024
@alexgubanow alexgubanow force-pushed the ICU-22714-fix-zos-build branch from 6697a6b to c68ce7f Compare May 14, 2024 17:15
@jira-pull-request-webhook
Copy link

Hooray! The files in the branch are the same across the force-push. 😃

~ Your Friendly Jira-GitHub PR Checker Bot

alexgubanow added a commit to alexgubanow/icu that referenced this pull request May 14, 2024
@alexgubanow alexgubanow force-pushed the ICU-22714-fix-zos-build branch from 423a492 to f4050de Compare May 14, 2024 17:22
@jira-pull-request-webhook
Copy link

Hooray! The files in the branch are the same across the force-push. 😃

~ Your Friendly Jira-GitHub PR Checker Bot

@srl295
Copy link
Member

srl295 commented May 15, 2024

lots of good deletion here!

For the BOMs, would it make sense just to fix them up with a build step?

@alexgubanow
Copy link
Contributor Author

OpenXL is basically clang, that allowed me to get rid of many "OS390 only" code and tricks. Actually i have found one bug in OpenXL v2.1, it fails to generate correct name for sidedeck if output path is relative and library name has no suffix, for output library path like:
../../lib/LICU76DA
openxl v2.1 linker will generate ..x name of sidedeck
Fix for that, is already implemented, but no idea when it will be released by IBM, so i made a workaround, added "-Wl,[email protected]" to linker command, so linker do not guess the name of sidedeck and no bug occur

I have added BOM fix in build time generated index files, also made sure those generated as UTF-8.

But regarding this files:
icu4c/source/data/misc/currencyNumericCodes.txt
icu4c/source/data/misc/icustd.txt
icu4c/source/data/misc/zoneinfo64.txt
i don't know when/who and how updates/generates it. Maybe you guys can guide me there? also i would suggest to do it in separate ticket/PR

@markusicu markusicu self-assigned this May 16, 2024
@alexgubanow
Copy link
Contributor Author

Hello @markusicu @srl295 what is missing for this PR to be merged?

@markusicu markusicu requested a review from eggrobin May 23, 2024 15:45
@srl295
Copy link
Member

srl295 commented Jun 5, 2024

@markusicu LGTM ready to merge?

@alexgubanow
Copy link
Contributor Author

Hello @markusicu , can we merge this? is anything missing?

Copy link
Member

@markusicu markusicu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry for dropping the ball here! Let's get this in.
Happy to see that there are no merge conflicts.
Fingers crossed that the post-merge CI checks will still be green...

@@ -368,55 +368,54 @@ Some platforms use package management tools to control the installation and unin

## How To Build And Install On z/OS (OS/390)

You can install ICU on z/OS or OS/390 (the previous name of z/OS), but IBM tests only the z/OS installation. You install ICU in a z/OS UNIX system services file system such as HFS or zFS. On this platform, it is important that you understand a few details:
You can install ICU on z/OS or OS/390 (the previous name of z/OS), but IBM tests only the z/OS installation. You install ICU in a z/OS UNIX System Services (z/OS UNIX) file system such as HFS or zFS. On this platform, it is important that you understand a few details:
Copy link
Member

@markusicu markusicu Sep 20, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

FYI: IBM hasn't been testing anything for a long time... :-}

@markusicu markusicu force-pushed the ICU-22714-fix-zos-build branch from f4050de to dc4b490 Compare September 20, 2024 23:19
@jira-pull-request-webhook
Copy link

Notice: the branch changed across the force-push!

  • docs/userguide/icu4c/build.md is different
  • icu4c/source/common/udata.cpp is different
  • icu4c/source/common/unicode/platform.h is different
  • icu4c/source/config/dist.mk is different
  • icu4c/source/data/Makefile.in is different
  • icu4c/source/data/misc/currencyNumericCodes.txt is different
  • icu4c/source/data/misc/zoneinfo64.txt is different
  • icu4c/source/runConfigureICU is different
  • icu4c/source/test/intltest/intltest.h is different
  • icu4c/source/tools/pkgdata/pkgdata.cpp is different

View Diff Across Force-Push

~ Your Friendly Jira-GitHub PR Checker Bot

@markusicu
Copy link
Member

I had to rebase in order to make a newer CI check work. Now we find out if it still works with the latest checks, even pre-merge...

@markusicu markusicu merged commit 5f9f8b2 into unicode-org:main Sep 21, 2024
95 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants