Question using LSET

Posted on 2006-10-24
Last Modified: 2008-02-01
I want to read the contents of a file into a UDT that is basically a "buffer" and then use LSET to move it into a UDT that has all the fields layed out properly. The UDT I am reading the line into has just a single variable defined as a fixed-length string the length of the data record...

Public Type KPAyData
   Buffer As String * 4340
End Type

Public PayrollBuffer as KPayData

The data is payroll information. As such, it has a number of repeating fields for earnings, taxes, deductions, etc. I have defined a UDT for each of these repeating groups of fields, and used an array of that type in the appropriate place in the UDT that defines all the data. A small example is as follows...

Public Type PayrollTaxDeduction
  TaxClass As String * 1
  TaxState  As String * 6
  TaxLocality As String * 10
  TaxAmount As String * 12
End Type

Public Type KPayType
  EmployeeID As String * 11
  EmployeeSSN As String * 9
  TaxDeductions(1 to 10) As PayrollTaxDeduction
End Type

Public PayrollRecord as KPayType

If I do a Len() and LenB() on the types, the lengths come out correctly, but when I try to LSet PayrollRecord = PayrollBuffer, I get a Type Mismatch error. I am suspecting that using the array of UDTs in KPayType may be causing the error, but not certain. Can someone either confirm that or give me another avenue to pursue in determining why I am getting the error.

Also, if you can provide an alternative way to do this, I would appreciate it. There are 75 repeating groups just for deductions and each group contains five fields. I would hate to have to hard-code all of those (641 fields altogether).

Question by:dbbishop
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
  • 2
  • 2
  • +2
LVL 143

Expert Comment

by:Guy Hengel [angelIII / a3]
ID: 17796819
vb6 or
in vb6, this should work, but in this is no longer allowed like this afair

Expert Comment

ID: 17796841

I do not think you can do lset to type name (the name of the type not the type items).

this is ok.
lset payrollrecord.employeeid = your value

this is not ok
LSet PayrollRecord = PayrollBuffer

consider this
dim str as string
str = space(641)

lset str = payrollrecord.employeeid & payrollrecord.employeessn & your other fields
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

LVL 26

Accepted Solution

EDDYKT earned 500 total points
ID: 17796897
LVL 20

Expert Comment

ID: 17797439
As EDDYKT use the copymemory to move your string to the udt
LVL 15

Author Comment

ID: 17797539
vb6 - I am aware that .net does not support LSet for UDTs.

You can lset UDT to UDT. I have done it many, many times using this method. I have just never had another UDT (or array of UDTs) within the receiving UDT before. Furthermore, there are 641 fields, not bytes. The record length is 4340 bytes. Besides, I am wanting to go the other way. PayrollBuffer.Buffer receives the data from the record and I want to copy it into PayrollRecord.

Expert Comment

ID: 17797755
well, I learn something new.

Sorry if I was no help. :(
LVL 15

Author Comment

ID: 17798094
lunchbyte: hang in there-better luck next time :-)

CopyMemory worked like a champ.

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

If you have ever used Microsoft Word then you know that it has a good spell checker and it may have occurred to you that the ability to check spelling might be a nice piece of functionality to add to certain applications of yours. Well the code that…
Article by: Martin
Here are a few simple, working, games that you can use as-is or as the basis for your own games. Tic-Tac-Toe This is one of the simplest of all games.   The game allows for a choice of who goes first and keeps track of the number of wins for…
As developers, we are not limited to the functions provided by the VBA language. In addition, we can call the functions that are part of the Windows operating system. These functions are part of the Windows API (Application Programming Interface). U…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…
Suggested Courses
Course of the Month8 days, 11 hours left to enroll

617 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question