]> gerrit.simantics Code Review - simantics/fmil.git/blobdiff - org.simantics.fmil.core/native/FMILibrary/Test/FMI1/fmi_zip_zip_test.c
Add FMILibrary-2.0.3 to org.simantics.fmil.core\native.
[simantics/fmil.git] / org.simantics.fmil.core / native / FMILibrary / Test / FMI1 / fmi_zip_zip_test.c
diff --git a/org.simantics.fmil.core/native/FMILibrary/Test/FMI1/fmi_zip_zip_test.c b/org.simantics.fmil.core/native/FMILibrary/Test/FMI1/fmi_zip_zip_test.c
new file mode 100644 (file)
index 0000000..3dc1fa1
--- /dev/null
@@ -0,0 +1,74 @@
+/*
+    Copyright (C) 2012 Modelon AB
+
+    This program is free software: you can redistribute it and/or modify
+    it under the terms of the BSD style license.
+
+     This program is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+    FMILIB_License.txt file for more details.
+
+    You should have received a copy of the FMILIB_License.txt file
+    along with this program. If not, contact Modelon AB <http://www.modelon.com>.
+*/
+
+#include <stdio.h>
+#include <stdlib.h>
+
+#include <JM/jm_types.h>
+#include <JM/jm_callbacks.h>
+#include <FMI/fmi_zip_zip.h>
+#include "config_test.h"
+
+#define PRINT_MY_DEBUG printf("Line: %d \t File: %s \n",__LINE__, __FILE__)
+
+
+
+void do_exit(int code)
+{
+       printf("Press any key to exit\n");
+       /* getchar(); */
+       exit(code);
+}
+
+/* Logger function */
+void importlogger(jm_callbacks* c, jm_string module, jm_log_level_enu_t log_level, jm_string message)
+{
+        printf("module = %s, log level = %d: %s\n", module, log_level, message);
+}
+
+/**
+ * \brief Zip test. Tests the fmi_zip_zip function by compressing some file.
+ *
+ */
+int main(int argc, char *argv[])
+{
+       jm_status_enu_t status;
+       jm_callbacks callbacks;
+       
+       const char* files_to_zip[] = {COMPRESS_DUMMY_FILE_PATH_SRC};
+       int n_files_to_zip = 1;
+
+       callbacks.malloc = malloc;
+    callbacks.calloc = calloc;
+    callbacks.realloc = realloc;
+    callbacks.free = free;
+    callbacks.logger = importlogger;
+       callbacks.log_level = jm_log_level_debug;
+
+    callbacks.context = 0;
+
+       status = fmi_zip_zip(COMPRESS_DUMMY_FILE_PATH_DIST, n_files_to_zip, files_to_zip, &callbacks);
+
+       if (status == jm_status_error) {
+               printf("Failed to compress the file\n");
+               do_exit(CTEST_RETURN_FAIL);
+       } else {
+               printf("Succesfully compressed the file\n");
+               do_exit(CTEST_RETURN_SUCCESS);
+       }
+    return 0;
+}
+
+