Why does a long cfc file work in CF8, but not CF9? Getting “Branch target offset too large for short” error

后端 未结 3 1415
日久生厌
日久生厌 2021-01-25 14:12

I have a fairly long cfc file, about 1800 lines long, that worked fine in ColdFusion 8, but after upgrading my development system to ColdFusion 9 and doing some testing I get a

相关标签:
3条回答
  • 2021-01-25 14:29

    If you haven't already, try running the Code Analyzer in the CFAdmin page, "Debugging & Logging > Code Analyzer". This is a useful tool to find some changes which were made in the language between CF8 and CF9.

    We had to change several variable names and function names as CF added them in 9.

    Also check here:

    http://help.adobe.com/en_US/ColdFusion/9.0/CFMLRef/WSc3ff6d0ea77859461172e0811cbec22c24-7ff0.html

    0 讨论(0)
  • 2021-01-25 14:30

    This is a problem inherent with the JVM as you already know, CF9 has likely added more innate functions to a component and if the methods are all referenced via a giant switch statement with a short being used as the offset, we have less offset pointer space to work with each successive version. People moving from CF7 to CF8 also had the same problems.

    So short answer is no.

    Most recommendations you find basically tell you to split a large method into a smaller method and several helper methods. The first time I ran into an issue this worked for a large cfc I had. But then as it got bigger no number of helper functions would fix it. Eventually it had to be split into multiple cfcs.

    PS: This guy said removing a transaction helped (CF7), there are none wrapping my calls though, so it's not a guaranteed fix I guess http://www.coldfusionmuse.com/index.cfm/2007/9/28/Branch.Target.Offset

    Edit
    Looks like my previous issue was a different function being too large, splitting the CFC into multiple CFCs was in error. I've since split that problem method into smaller methods, and have been able to consolidate all the functions in one CFC. So that is the solution it seems.

    0 讨论(0)
  • 2021-01-25 14:40

    CF version: 10 OS: Linux CentOS 6.0

    Did face a similar issue where I had 1300+ lines of code in my cfc and one fine day I get the "Branch Target offset.." error. I tried

    1. Code Analyser to find any loopholes of legacy- DID NOT FIX

    2. Edited the cfc to trim down any last bit of redundant code or comments - reduced around 20+ lines of code - DID NOT FIX

    3. I split the code into 2 cfc and extended one to the other- DID NOT FIX

    4. I removed any unwanted dump of queries and arrays (part of testing) : THIS WORKED

    so I would suggest ensure you don't have any dumps of large data content. Hope this helps.

    0 讨论(0)
提交回复
热议问题