diff options
Diffstat (limited to 'lib/odbc/c_src/odbcserver.c')
| -rw-r--r-- | lib/odbc/c_src/odbcserver.c | 79 | 
1 files changed, 39 insertions, 40 deletions
| diff --git a/lib/odbc/c_src/odbcserver.c b/lib/odbc/c_src/odbcserver.c index b4655ce373..f4b0a5d8d0 100644 --- a/lib/odbc/c_src/odbcserver.c +++ b/lib/odbc/c_src/odbcserver.c @@ -389,6 +389,9 @@ DWORD WINAPI database_handler(const char *port)      close_socket(socket);      clean_socket_lib();      /* Exit will be done by suervisor thread */  +#ifdef WIN32 +    return (DWORD)0; +#endif  }  /* Description: Calls the appropriate function to handle the database @@ -561,7 +564,6 @@ static db_result_msg db_connect(byte *args, db_state *state)  /* Close the connection to the database. Returns an ok or error message. */  static db_result_msg db_close_connection(db_state *state)  { -    int index;      SQLRETURN result;      diagnos diagnos; @@ -610,11 +612,7 @@ static db_result_msg db_end_tran(byte compleationtype, db_state *state)     erlang term into the message buffer of the returned message-struct. */  static db_result_msg db_query(byte *sql, db_state *state)  { -    char *atom; -    int num_of_rows, elements, update; -    SQLSMALLINT num_of_columns;      SQLRETURN result; -    SQLINTEGER RowCountPtr;      db_result_msg msg;      diagnos diagnos;      byte is_error[6]; @@ -631,7 +629,7 @@ static db_result_msg db_query(byte *sql, db_state *state)  				   &statement_handle(state))))  	DO_EXIT(EXIT_ALLOC); -    result = SQLExecDirect(statement_handle(state), sql, SQL_NTS); +    result = SQLExecDirect(statement_handle(state), (SQLCHAR *)sql, SQL_NTS);      /* SQL_SUCCESS_WITH_INFO at this point may indicate an error in user input. */      if (result != SQL_SUCCESS && result != SQL_NO_DATA_FOUND) { @@ -698,12 +696,9 @@ static db_result_msg db_query(byte *sql, db_state *state)     set. */  static db_result_msg db_select_count(byte *sql, db_state *state)  { -    SQLSMALLINT num_of_columns, intresult; +    SQLSMALLINT num_of_columns;      SQLLEN num_of_rows; -    SQLRETURN result;      diagnos diagnos; -    db_result_msg msg; -    int index;      if (associated_result_set(state)) {  	clean_state(state); @@ -723,7 +718,7 @@ static db_result_msg db_select_count(byte *sql, db_state *state)  		       (SQLPOINTER)SQL_SCROLLABLE, (SQLINTEGER)0);      } -    if(!sql_success(SQLExecDirect(statement_handle(state), sql, SQL_NTS))) { +    if(!sql_success(SQLExecDirect(statement_handle(state), (SQLCHAR *)sql, SQL_NTS))) {  	diagnos = get_diagnos(SQL_HANDLE_STMT, statement_handle(state), extended_errors(state));  	clean_state(state);  	return encode_error_message(diagnos.error_msg, extended_error(state, diagnos.sqlState), diagnos.nativeError); @@ -789,6 +784,9 @@ static db_result_msg db_select(byte *args, db_state *state)  	orientation = SQL_FETCH_NEXT;  	offset = atoi(strtok((char *)(args + sizeof(byte)), ";"));  	n =  atoi(strtok(NULL, ";")); +	break; +    default: +	DO_EXIT(EXIT_PARAM_ARRAY);      }      msg = encode_empty_message(); @@ -864,7 +862,7 @@ static db_result_msg db_param_query(byte *buffer, db_state *state)      if(params != NULL) { -	result = SQLExecDirect(statement_handle(state), sql, SQL_NTS); +	result = SQLExecDirect(statement_handle(state), (SQLCHAR *)sql, SQL_NTS);  	if (!sql_success(result) || result == SQL_NO_DATA) {  		diagnos = get_diagnos(SQL_HANDLE_STMT, statement_handle(state), extended_errors(state));  	} @@ -939,7 +937,7 @@ static db_result_msg db_describe_table(byte *sql, db_state *state)      SQLSMALLINT num_of_columns;      SQLCHAR name[MAX_NAME];      SQLSMALLINT name_len, sql_type, dec_digits, nullable; -    SQLLEN size; +    SQLULEN size;      diagnos diagnos;      int i; @@ -955,7 +953,7 @@ static db_result_msg db_describe_table(byte *sql, db_state *state)  				   &statement_handle(state))))  	DO_EXIT(EXIT_ALLOC); -    if (!sql_success(SQLPrepare(statement_handle(state), sql, SQL_NTS))){ +    if (!sql_success(SQLPrepare(statement_handle(state), (SQLCHAR *)sql, SQL_NTS))){  	diagnos =  get_diagnos(SQL_HANDLE_STMT, statement_handle(state), extended_errors(state));  	msg = encode_error_message(diagnos.error_msg, extended_error(state, diagnos.sqlState), diagnos.nativeError);  	clean_state(state); @@ -1291,8 +1289,7 @@ static db_result_msg encode_column_name_list(SQLSMALLINT num_of_columns,      db_result_msg msg;      SQLCHAR name[MAX_NAME];      SQLSMALLINT name_len, sql_type, dec_digits, nullable; -    SQLLEN size;  -    SQLRETURN result; +    SQLULEN size;      msg = encode_empty_message(); @@ -1324,7 +1321,7 @@ static db_result_msg encode_column_name_list(SQLSMALLINT num_of_columns,  		if (columns(state)[i].type.c == SQL_C_BINARY) {  		    /* retrived later by retrive_binary_data */ -		}else { +		} else {  		    if(!sql_success(  			SQLBindCol  			(statement_handle(state), @@ -1336,7 +1333,7 @@ static db_result_msg encode_column_name_list(SQLSMALLINT num_of_columns,  			DO_EXIT(EXIT_BIND);  		}  		ei_x_encode_string_len(&dynamic_buffer(state), -				       name, name_len); +				       (char *)name, name_len);  	    }  	    else {  		columns(state)[i].type.len = 0; @@ -1354,9 +1351,8 @@ static db_result_msg encode_column_name_list(SQLSMALLINT num_of_columns,  static db_result_msg encode_value_list(SQLSMALLINT num_of_columns,  				       db_state *state)  { -    int i, msg_len; +    int i;      SQLRETURN result; -    db_result_msg list_result;      db_result_msg msg;      msg = encode_empty_message(); @@ -1399,9 +1395,8 @@ static db_result_msg encode_value_list_scroll(SQLSMALLINT num_of_columns,  					      SQLINTEGER OffSet, int N,  					      db_state *state)  { -    int i, j,  msg_len; +    int i, j;      SQLRETURN result; -    db_result_msg list_result;      db_result_msg msg;      msg = encode_empty_message(); @@ -1807,10 +1802,23 @@ static int read_exact(byte *buffer, int len) {  #endif +static size_t length_buffer_to_size(byte length_buffer[LENGTH_INDICATOR_SIZE]) +{ +  size_t size = 0, i; + +  for (i = 0; i < LENGTH_INDICATOR_SIZE; ++i) { +    size <<= 8; +    size |= (unsigned char)length_buffer[i]; +  } + +  return size; +} + +  /* Recieive (read) data from erlang on stdin */  static byte * receive_erlang_port_msg(void)  { -    int i, len = 0; +    size_t len;      byte *buffer;      byte lengthstr[LENGTH_INDICATOR_SIZE]; @@ -1819,10 +1827,8 @@ static byte * receive_erlang_port_msg(void)      {  	DO_EXIT(EXIT_STDIN_HEADER);      } -    for(i=0; i < LENGTH_INDICATOR_SIZE; i++) { -	len <<= 8; -	len |= lengthstr[i]; -    } + +    len = length_buffer_to_size(lengthstr);      if (len <= 0 || len > 1024) {  	DO_EXIT(EXIT_STDIN_HEADER); @@ -1923,8 +1929,7 @@ static byte * receive_msg(int socket)  #endif  {      byte lengthstr[LENGTH_INDICATOR_SIZE]; -    size_t msg_len = 0; -    int i; +    size_t msg_len;      byte *buffer = NULL;      if(!receive_msg_part(socket, lengthstr, LENGTH_INDICATOR_SIZE)) { @@ -1932,10 +1937,7 @@ static byte * receive_msg(int socket)  	DO_EXIT(EXIT_SOCKET_RECV_HEADER);      } -    for(i = 0; i < LENGTH_INDICATOR_SIZE; i++) { -	msg_len <<= 8; -	msg_len |= lengthstr[i]; -    } +    msg_len = length_buffer_to_size(lengthstr);      buffer = (byte *)safe_malloc(msg_len); @@ -2197,8 +2199,7 @@ static void init_driver(int erl_auto_commit_mode, int erl_trace_driver,  static void init_param_column(param_array *params, byte *buffer, int *index,  			      int num_param_values, db_state* state)  { -    int size, erl_type; -    long user_type, precision, scale, length, dummy; +    long user_type, precision, scale, length;      long in_or_out;      ei_decode_long(buffer, index, &user_type); @@ -2511,8 +2512,7 @@ static param_array * bind_parameter_arrays(byte *buffer, int *index,  					   int cols, int num_param_values,  					   db_state *state)  { -    int i, j, k, size, erl_type; -    db_result_msg msg; +    int i, j, size, erl_type;      long dummy;      void *Values;      param_array *params; @@ -2598,7 +2598,6 @@ static db_column retrive_binary_data(db_column column, int column_nr,  				     db_state *state)  {       char *outputptr; -    char *sqlState;      int blocklen, outputlen, result;      diagnos diagnos; @@ -2739,8 +2738,8 @@ static diagnos get_diagnos(SQLSMALLINT handleType, SQLHANDLE handle, Boolean ext         the error message is obtained */      for(record_nr = 1; ;record_nr++) {              result = SQLGetDiagRec(handleType, handle, record_nr, current_sql_state, -			 &nativeError, current_errmsg_pos, -							   (SQLSMALLINT)errmsg_buffer_size, &errmsg_size); +			 &nativeError, (SQLCHAR *)current_errmsg_pos, +			 (SQLSMALLINT)errmsg_buffer_size, &errmsg_size);  	if(result == SQL_SUCCESS) {  	    /* update the sqlstate in the diagnos record, because the SQLGetDiagRec  	       call succeeded */ | 
