Andrew Pollack's Blog

Technology, Family, Entertainment, Politics, and Random Noise

Ugly regression bug in Lotusscript - updated

By Andrew Pollack on 05/08/2006 at 07:13 PM EDT

** UPDATE -- Thanks to Daniel Nashed... Looks like the regression bug is preventing code from running which may not have run properly before. I'm not sure that's really what happened, as it did seem to run properly before, but thank you Daniel.

Meantime, I have updated the product that this "bug" crashed and am using a rich text field and saving the data out then re-importing it later. Ugly, but quick enough.

    <from Daniel>

    I did some checks. For text items the limit is 64K from API point of view. If you read or write a text item the maxium size is a WORD which is 16bit and that means 64K. So the maximum limit of a text list item is 64k. The purpose of setting it to non-summary ensures that you can have many text fields with a limit of 64k of each without filling up the summary buffer (which has a total limit of 64K).

    So it sounds like the code is more strict for checking the error.

There are field size limits for summary fields in Lotus Notes. Text Lists are summary fields, as is any field but Rich Text generally. Summary fields allow you to write data to the view. You cannot include non-summary fields in a view.

Keep in mind, 64k is a valid limit -- BUT NOT FOR NON-SUMMARY fields. That's the whole point of the NotesItem.isSummary property.

It used to be -- not quite sure when this problem happened -- that you could create a field, mark it as NON-SUMMARY and lotusscript, and thus exceed the limit. Not any more. I'm exploring the simplest workaround. I can think of several which are a pain the butt.

It used to work. Now you get this error.

Here is simple code that duplicates the problem -- code can be placed in the click even of a button. I will have a workaround shortly.

' get a handle to the current document
Dim doc As notesdocument
Dim ws As New notesuiworkspace
Dim uidoc As notesuidocument
Set uidoc = ws.CurrentDocument
Set doc = uidoc.Document
' create a really big array of data
Dim a As String
Dim b(7000) As String
Dim x As Integer
a = "0123456789"
For x = 0 To 7000
b(x) = a
' create a new empty field
Dim field As notesitem
Set field = doc.ReplaceItemValue("field1", "")
' set the field to non-summary
field.IsSummary = False
' write the field out.
field.Values = b

There are  - loading -  comments....

My own thoughts on this are...By Richard Schwartz on 05/08/2006 at 08:12 PM EDT
Try this in an agent, completely separate from the front end.

Other Recent Stories...

  1. 02/15/2018Andrew’s Proposed Gun LawsThese are my current thoughts on gun laws that would radically change the culture and safety of gun ownership in the United States without removing the rights of gun owners or compromising their privacy rights. * Please feel free to link to, or just copy, these ideas. It would be wonderful to see them spread widely and eventually become the basis for something to rally around and become legislation. 1. Background Check ProcessAnyone who wishes to be a gun owner can obtain a “gun owner id” card. These cards ...... 
  2. 05/05/2016Is the growing social-sourced economy the modern back door into socialism?Is the growing social-sourced economy the modern back door into socialism? I read a really insightful post a couple of days ago that suggested the use of social network funding sites like “Go Fund Me” and “Kickstarter” have come about and gained popularity in part because the existing economy in no longer serving its purpose for anyone who isn’t already wealthy. Have the traditional ways to get new ventures funded become closed to all but a few who aren’t already connected to them and so onerous as to make ...... 
  3. 04/20/2016Want to be whitelisted? Here are some sensible rules for web site advertisingAn increasing number of websites are now detecting when users have ad-blocking enabled, and refuse to show content unless you "whitelist" their site (disable your ad-blocking for them). I think that is a fair decision on their part, it's how they pay for the site. However, if you want me (and many others) to white list your site, there are some rules you should follow. If you violate these rules, I won't whitelist your site, I'll just find content elsewhere. 1. The total space taken up by advertisements ...... 
  4. 12/30/2015Fantastic new series on Syfy called “The Expanse” – for people who love traditional science fiction 
  5. 10/20/2015My suggestion is to stay away from PayAnywhere(dot)com  
  6. 08/07/2015Here is one for you VMWARE gurus - particularly if you run ESXi without fancy drive arrays 
  7. 08/06/2015The Killer of Orphans (Orphan Documents) 
  8. 06/02/2015Homeopathic Marketing: Traveler on my Android is now calling itself VERSE. Allow me to translate that for the IBM Notes community... 
  9. 03/17/2015A review of British Airways Premium Economy Service – How to destroy customer goodwill all at once 
  10. 02/26/2015There's a bug in how @TextToTime() and @ToTime() process date strings related to international standards and browser settings. 
Click here for more articles.....

pen icon Comment Entry
Your Name
*Your Email
* Your email address is required, but not displayed.
Your thoughts....
Remember Me  

Please wait while your document is saved.