GUAC-236: Actually parse input files.
This commit is contained in:
parent
5e5186be07
commit
c850744faa
@ -24,6 +24,9 @@
|
|||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
||||||
#include <guacamole/client.h>
|
#include <guacamole/client.h>
|
||||||
|
#include <guacamole/error.h>
|
||||||
|
#include <guacamole/parser.h>
|
||||||
|
#include <guacamole/socket.h>
|
||||||
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
@ -32,10 +35,51 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
int guacenc_encode(const char* path) {
|
/**
|
||||||
|
* Reads and handles all Guacamole instructions from the given guac_socket
|
||||||
|
* until end-of-stream is reached.
|
||||||
|
*
|
||||||
|
* @param path
|
||||||
|
* The name of the file being parsed (for logging purposes). This file
|
||||||
|
* must already be open and available through the given socket.
|
||||||
|
*
|
||||||
|
* @param socket
|
||||||
|
* The guac_socket through which instructions should be read.
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* Zero on success, non-zero if parsing of Guacamole protocol data through
|
||||||
|
* the given socket fails.
|
||||||
|
*/
|
||||||
|
static int guacenc_read_instructions(const char* path, guac_socket* socket) {
|
||||||
|
|
||||||
/* STUB */
|
/* Obtain Guacamole protocol parser */
|
||||||
guacenc_log(GUAC_LOG_INFO, "STUB: Encoding \"%s\" ...", path);
|
guac_parser* parser = guac_parser_alloc();
|
||||||
|
if (parser == NULL)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
/* Continuously read instructions */
|
||||||
|
while (!guac_parser_read(parser, socket, -1)) {
|
||||||
|
|
||||||
|
/* STUB: Handle instruction */
|
||||||
|
guacenc_log(GUAC_LOG_DEBUG, "STUB: \"%s\" ...", parser->opcode);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Fail on read/parse error */
|
||||||
|
if (guac_error != GUAC_STATUS_CLOSED) {
|
||||||
|
guacenc_log(GUAC_LOG_ERROR, "%s: %s",
|
||||||
|
path, guac_status_string(guac_error));
|
||||||
|
guac_parser_free(parser);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Parse complete */
|
||||||
|
guac_parser_free(parser);
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int guacenc_encode(const char* path) {
|
||||||
|
|
||||||
/* Open input file */
|
/* Open input file */
|
||||||
int fd = open(path, O_RDONLY);
|
int fd = open(path, O_RDONLY);
|
||||||
@ -44,10 +88,25 @@ int guacenc_encode(const char* path) {
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Close input file */
|
/* Obtain guac_socket wrapping file descriptor */
|
||||||
close(fd);
|
guac_socket* socket = guac_socket_open(fd);
|
||||||
|
if (socket == NULL) {
|
||||||
|
guacenc_log(GUAC_LOG_ERROR, "%s: %s", path,
|
||||||
|
guac_status_string(guac_error));
|
||||||
|
close(fd);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
/* Encoding was successful */
|
guacenc_log(GUAC_LOG_INFO, "Encoding \"%s\" ...", path);
|
||||||
|
|
||||||
|
/* Attempt to read all instructions in the file */
|
||||||
|
if (guacenc_read_instructions(path, socket)) {
|
||||||
|
guac_socket_free(socket);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Parsing/encoding was successful */
|
||||||
|
guac_socket_free(socket);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user