BookmarkSubscribeRSS Feed
Andy_D
Fluorite | Level 6

Hi,

 

I've just stumbled across this thread and would appreciate any help with the below problem:

 

I'm trying to connect to a remote SAS server using the below code in VBA

 

 Public obSAS As sas.Workspace
 Public obWorkspaceManager As New SASWorkspaceManager.WorkspaceManager


Sub sas_connect()
   
    Dim obConnection As New ADODB.Connection
    Dim obRecordSet As New ADODB.Recordset
    Dim obServerDef As New SASWorkspaceManager.ServerDef
    Dim xmlString As String
    Dim sourcebuffer As String
   
    obServerDef.Port = Port Number
    obServerDef.Protocol = ProtocolBridge
    obServerDef.MachineDNSName = Company Name
    
    Set obSAS = obWorkspaceManager.Workspaces.CreateWorkspaceByServer(Name, VisibilityProcess, obServerDef, Username, Password, xmlString)
   
End Sub

 

When assigning the port number in VBA the maximum integer is 32767 (32-bit integer), but the port number I use to connect my profile to the remote SAS server is higher than this.

 

Thanks in advance,

Andy

5 REPLIES 5
ballardw
Super User

32767 looks more like a 16 bit integer (with one bit reserved for sign).

 

Long time since I did anything with VBA and never did anything with ports but I would try making the variable holding the port either a double or possibly string and see if that passes.

ChrisBrooks
Ammonite | Level 13

@ballardw I suspect the problem lies with the port attribute of the serverdef object which is supplied by SAS and not the variable @Andy_D is using to hold the port number.

ballardw
Super User

@ChrisBrooks wrote:

@ballardw I suspect the problem lies with the port attribute of the serverdef object which is supplied by SAS and not the variable @Andy_D is using to hold the port number.


Like I implied, that was a guess. But I follow your idea and it makes a lot of sense.

ChrisBrooks
Ammonite | Level 13

I don't have access to a machine with SAS IOM installed at the moment so I can't check any of this but I think, with a little educated guesswork, I know what is happening here. It may be a little bit esoteric but bear with me......

 

Firstly some definitions:

 

  1. A 16 bit unsigned integer can contain values 0 through 65,535;
  2. A 16 bit signed integer can contain values -32,768 through 32,767;
  3. A 32 bit unsigned integer can contain values 0 through 4,294,967,295; and
  4. A 32 bit signed integer can contain values -2,147,483,648 through 2,147,483,647

Port numbers range from 0 to 65535 with numbers 1 to 1024 reserved.

 

I suspect that the port attribute of the serverdef object supplied by SAS is actually a 16 bit signed integer which is why you cannot use port numbers greater than 32767 (in my experience there are usually plenty of ports available within this limit).

 

There are two ways to overcome this:

 

  1. Persuade SAS to change the port attribute to an unsigned 16 bit integer (you can't have negative port numbers) - however I suspect you will have little luck with that; or
  2. Change the port you are using so that it is within the 32767 limit for a signed 16 bit integer

Is there any reason you can't use a port within that limit as I would be amazed to find there were none free?

Andy_D
Fluorite | Level 6

Thanks Chris - Think I'll have to contact the admin in order to find out if any other ports within the 16-bit integer range have been assigned to the host server which we use.

sas-innovate-wordmark-2025-midnight.png

Register Today!

Join us for SAS Innovate 2025, our biggest and most exciting global event of the year, in Orlando, FL, from May 6-9. Sign up by March 14 for just $795.


Register now!

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 5 replies
  • 1098 views
  • 0 likes
  • 3 in conversation