Improve exceptions.
FossilOrigin-Name: 12b5ef483a1f9eae92df83cf8a6aded299ef10dd2972059a36c79d299e676a0d
This commit is contained in:
parent
16dc91b0e7
commit
25c48048a1
8 changed files with 50 additions and 61 deletions
|
@ -41,13 +41,11 @@
|
|||
}
|
||||
|
||||
if ((_connnection = PQconnectdb([connectionInfo UTF8String])) == NULL)
|
||||
@throw [OFOutOfMemoryException
|
||||
exceptionWithClass: [self class]];
|
||||
@throw [OFOutOfMemoryException exception];
|
||||
|
||||
if (PQstatus(_connnection) == CONNECTION_BAD)
|
||||
@throw [PGConnectionFailedException
|
||||
exceptionWithClass: [self class]
|
||||
connection: self];
|
||||
exceptionWithConnection: self];
|
||||
|
||||
[pool release];
|
||||
}
|
||||
|
@ -72,9 +70,8 @@
|
|||
if (PQresultStatus(result) == PGRES_FATAL_ERROR) {
|
||||
PQclear(result);
|
||||
@throw [PGCommandFailedException
|
||||
exceptionWithClass: [self class]
|
||||
connection: self
|
||||
command: command];
|
||||
exceptionWithConnection: self
|
||||
command: command];
|
||||
}
|
||||
|
||||
switch (PQresultStatus(result)) {
|
||||
|
@ -86,9 +83,8 @@
|
|||
default:
|
||||
PQclear(result);
|
||||
@throw [PGCommandFailedException
|
||||
exceptionWithClass: [self class]
|
||||
connection: self
|
||||
command: command];
|
||||
exceptionWithConnection: self
|
||||
command: command];
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -115,15 +111,17 @@
|
|||
if ([parameter isKindOfClass: [OFString class]])
|
||||
values[i++] = [parameter UTF8String];
|
||||
else if ([parameter isKindOfClass: [OFNumber class]]) {
|
||||
switch ([parameter type]) {
|
||||
OFNumber *number = parameter;
|
||||
|
||||
switch ([number type]) {
|
||||
case OF_NUMBER_BOOL:
|
||||
if ([parameter boolValue])
|
||||
if ([number boolValue])
|
||||
values[i++] = "t";
|
||||
else
|
||||
values[i++] = "f";
|
||||
break;
|
||||
default:
|
||||
values[i++] = [[parameter description]
|
||||
values[i++] = [[number description]
|
||||
UTF8String];
|
||||
break;
|
||||
}
|
||||
|
@ -151,9 +149,8 @@
|
|||
default:
|
||||
PQclear(result);
|
||||
@throw [PGCommandFailedException
|
||||
exceptionWithClass: [self class]
|
||||
connection: self
|
||||
command: command];
|
||||
exceptionWithConnection: self
|
||||
command: command];
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -214,9 +211,8 @@
|
|||
if (PQresultStatus(result) != PGRES_COMMAND_OK) {
|
||||
PQclear(result);
|
||||
@throw [PGCommandFailedException
|
||||
exceptionWithClass: [self class]
|
||||
connection: self
|
||||
command: command];
|
||||
exceptionWithConnection: self
|
||||
command: command];
|
||||
}
|
||||
|
||||
PQclear(result);
|
||||
|
|
|
@ -32,8 +32,7 @@
|
|||
- (id)objectAtIndex: (size_t)index
|
||||
{
|
||||
if (index > PQntuples(_result))
|
||||
@throw [OFOutOfRangeException
|
||||
exceptionWithClass: [self class]];
|
||||
@throw [OFOutOfRangeException exception];
|
||||
|
||||
return [PGResultRow rowWithResult: self
|
||||
row: (int)index];
|
||||
|
|
|
@ -124,7 +124,7 @@ convert_type(PGresult *res, int column, OFString *string)
|
|||
}
|
||||
|
||||
if (count > SIZE_MAX - state->state)
|
||||
@throw [OFOutOfRangeException exceptionWithClass: [self class]];
|
||||
@throw [OFOutOfRangeException exception];
|
||||
|
||||
if (state->state + count > state->extra[1])
|
||||
count = state->extra[1] - state->state;
|
||||
|
|
|
@ -9,11 +9,9 @@
|
|||
@property (readonly, copy, nonatomic) OFString *command;
|
||||
#endif
|
||||
|
||||
+ exceptionWithClass: (Class)class_
|
||||
connection: (PGConnection*)connection
|
||||
+ (instancetype)exceptionWithConnection: (PGConnection*)connection
|
||||
command: (OFString*)command;
|
||||
- initWithConnection: (PGConnection*)connection
|
||||
command: (OFString*)command;
|
||||
- initWithClass: (Class)class_
|
||||
connection: (PGConnection*)connection
|
||||
command: (OFString*)command;
|
||||
- (OFString*)command;
|
||||
@end
|
||||
|
|
|
@ -1,21 +1,17 @@
|
|||
#import "PGCommandFailedException.h"
|
||||
|
||||
@implementation PGCommandFailedException
|
||||
+ exceptionWithClass: (Class)class
|
||||
connection: (PGConnection*)connection
|
||||
command: (OFString*)command
|
||||
+ (instancetype)exceptionWithConnection: (PGConnection*)connection
|
||||
command: (OFString*)command
|
||||
{
|
||||
return [[[self alloc] initWithClass: class
|
||||
connection: connection
|
||||
command: command] autorelease];
|
||||
return [[[self alloc] initWithConnection: connection
|
||||
command: command] autorelease];
|
||||
}
|
||||
|
||||
- initWithClass: (Class)class
|
||||
connection: (PGConnection*)connection
|
||||
command: (OFString*)command
|
||||
- initWithConnection: (PGConnection*)connection
|
||||
command: (OFString*)command
|
||||
{
|
||||
self = [super initWithClass: class
|
||||
connection: connection];
|
||||
self = [super initWithConnection: connection];
|
||||
|
||||
@try {
|
||||
_command = [command copy];
|
||||
|
@ -36,10 +32,8 @@
|
|||
|
||||
- (OFString*)description
|
||||
{
|
||||
return [OFString stringWithFormat:
|
||||
@"A PostgreSQL command in class %@ failed: %s\nCommand: %@",
|
||||
[self inClass], PQerrorMessage([_connection PG_connection]),
|
||||
_command];
|
||||
return [OFString stringWithFormat: @"A PostgreSQL command failed: %@\n"
|
||||
@"Command: %@", _error, _command];
|
||||
}
|
||||
|
||||
- (OFString*)command
|
||||
|
|
|
@ -4,9 +4,7 @@
|
|||
- (OFString*)description
|
||||
{
|
||||
return [OFString stringWithFormat:
|
||||
@"Establishing a PostgreSQL connection in class %@ failed:\n%s\n"
|
||||
"Parameters: %@", [self inClass],
|
||||
PQerrorMessage([_connection PG_connection]),
|
||||
[_connection parameters]];
|
||||
@"Establishing a PostgreSQL connection failed:\n%@\n"
|
||||
"Parameters: %@", _error, [_connection parameters]];
|
||||
}
|
||||
@end
|
||||
|
|
|
@ -5,15 +5,14 @@
|
|||
@interface PGException: OFException
|
||||
{
|
||||
PGConnection *_connection;
|
||||
OFString *_error;
|
||||
}
|
||||
|
||||
#ifdef OF_HAVE_PROPERTIES
|
||||
@property (readonly, retain, nonatomic) PGConnection *connection;
|
||||
#endif
|
||||
|
||||
+ exceptionWithClass: (Class)class_
|
||||
connection: (PGConnection*)connection;
|
||||
- initWithClass: (Class)class_
|
||||
connection: (PGConnection*)connection;
|
||||
+ (instancetype)exceptionWithConnection: (PGConnection*)connection;
|
||||
- initWithConnection: (PGConnection*)connection;
|
||||
- (PGConnection*)connection;
|
||||
@end
|
||||
|
|
|
@ -1,19 +1,24 @@
|
|||
#import "PGException.h"
|
||||
|
||||
@implementation PGException
|
||||
+ exceptionWithClass: (Class)class
|
||||
connection: (PGConnection*)connection
|
||||
+ (instancetype)exceptionWithConnection: (PGConnection*)connection
|
||||
{
|
||||
return [[[self alloc] initWithClass: class
|
||||
connection: connection] autorelease];
|
||||
return [[[self alloc] initWithConnection: connection] autorelease];
|
||||
}
|
||||
|
||||
- initWithClass: (Class)class
|
||||
connection: (PGConnection*)connection
|
||||
- initWithConnection: (PGConnection*)connection
|
||||
{
|
||||
self = [super initWithClass: class];
|
||||
self = [super init];
|
||||
|
||||
_connection = [connection retain];
|
||||
@try {
|
||||
_connection = [connection retain];
|
||||
_error = [[OFString alloc]
|
||||
initWithCString: PQerrorMessage([_connection PG_connection])
|
||||
encoding: OF_STRING_ENCODING_NATIVE];
|
||||
} @catch (id e) {
|
||||
[self release];
|
||||
@throw e;
|
||||
}
|
||||
|
||||
return self;
|
||||
}
|
||||
|
@ -21,15 +26,15 @@
|
|||
- (void)dealloc
|
||||
{
|
||||
[_connection release];
|
||||
[_error release];
|
||||
|
||||
[super dealloc];
|
||||
}
|
||||
|
||||
- (OFString*)description
|
||||
{
|
||||
return [OFString stringWithFormat:
|
||||
@"A PostgreSQL operation in class %@ failed: %s", [self inClass],
|
||||
PQerrorMessage([_connection PG_connection])];
|
||||
return [OFString stringWithFormat: @"A PostgreSQL operation failed: %@",
|
||||
_error];
|
||||
}
|
||||
|
||||
- (PGConnection*)connection
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue