mirror of https://github.com/nodejs/node.git
README
== Patches applied on top of zlib == - 0000-build.patch: changes from the upstream version, mostly related to the build. - 0001-simd.patch: integrate Intel SIMD optimizations from https://github.com/jtkukunas/zlib/ - 0002-uninitializedcheck.patch: prevent uninitialized use of state->check == Procedure to create a patch file == Assuming you are working in a new feature branch: - git format-patch master --stdout > foo.patch # where naming follows a growing # number plus patch description. - git add foo.patch - git commit -a -m "Local patch." - git rebase -i HEAD~2 # Squashing the second commit As patches created in this way will feature a ChangeLog, there is no longer the need to append this file with a description of what the patch does. This should help to solve frequent conflicts in pending new patches on Chromium's zlib. The plan for the near future is to better insulate the platform specific changes to ease update adoption with new releases of zlib. This insulation happens by making changes inside contrib/ rather than the root directory (where conflicts can happen). If a change modifies enough things inside the root directory that the intention is not immediately clear, generate a .patch file to go with your change. If the change's modifications in the root directory are small, like: #ifdef FEATURE_FLAG use_special_feature(); #elif use_default_behavior(); #endif then the intent is clear and a .patch file doesn't need to be generated (since it would not provide much value). Ideally local changes should have a merge request featured in either: - canonical zlib: https://github.com/madler/zlib/ - zlib-ng: https://github.com/Dead2/zlib-ng