Compare commits
2 Commits
4f4ec2bc91
...
f2b20118e0
Author | SHA1 | Date | |
---|---|---|---|
f2b20118e0 | |||
42d18ccae1 |
@ -20,6 +20,11 @@ indent_size = 4
|
||||
indent_style = space
|
||||
indent_size = 4
|
||||
|
||||
# Ruby
|
||||
[*.rb]
|
||||
indent_style = space
|
||||
indent_size = 2
|
||||
|
||||
# Crystal
|
||||
[{*.cr,shards.yml}]
|
||||
indent_style = space
|
||||
@ -85,13 +90,16 @@ indent_size = 4
|
||||
indent_style = tab
|
||||
indent_size = 4
|
||||
|
||||
[snipplets/code/Gambas/*]
|
||||
[code/Gambas/*]
|
||||
indent_size = 2
|
||||
|
||||
[snipplets/projects/Solar2D**]
|
||||
[projects/Solar2D/**]
|
||||
indent_style = unset
|
||||
indent_size = unset
|
||||
end_of_line = unset
|
||||
charset = unset
|
||||
trim_trailing_whitespace = unset
|
||||
insert_final_newline = unset
|
||||
|
||||
[projects/CV/haarcascade_frontalface_default.xml]
|
||||
indent_size = unset
|
||||
|
@ -9,8 +9,7 @@
|
||||
char message[] = "Hello there!\n";
|
||||
char buf[sizeof(message)];
|
||||
|
||||
int main()
|
||||
{
|
||||
int main() {
|
||||
int sock;
|
||||
struct sockaddr_in addr;
|
||||
|
||||
|
@ -5,8 +5,7 @@
|
||||
#include <sys/socket.h>
|
||||
#include <netinet/in.h>
|
||||
|
||||
int main()
|
||||
{
|
||||
int main() {
|
||||
int sock, listener;
|
||||
struct sockaddr_in addr;
|
||||
char buf[1024];
|
||||
@ -37,7 +36,8 @@ int main()
|
||||
|
||||
while (1) {
|
||||
bytes_read = recv(sock, buf, 1024, 0);
|
||||
if (bytes_read <= 0) break;
|
||||
if (bytes_read <= 0)
|
||||
break;
|
||||
send(sock, buf, bytes_read, 0);
|
||||
}
|
||||
|
||||
|
31
code/C/Parsing/CSV/read_csv.c
Normal file
31
code/C/Parsing/CSV/read_csv.c
Normal file
@ -0,0 +1,31 @@
|
||||
#include <stdio.h> // file handling functions
|
||||
#include <stdlib.h> // atoi
|
||||
#include <string.h> // strtok
|
||||
|
||||
int main() {
|
||||
char buffer[80];
|
||||
FILE *stream = fopen("example.csv", "r");
|
||||
|
||||
while (fgets(buffer, 80, stream)) {
|
||||
char *token = strtok(buffer, ",");
|
||||
|
||||
// If you only need the first column of each row
|
||||
// Если нам нужен только первый столбец каждой строки
|
||||
if (token) {
|
||||
int n = atoi(token);
|
||||
printf("%s\n", n);
|
||||
}
|
||||
|
||||
// If you need all the values in a row
|
||||
// Если нам нужны все значения подряд
|
||||
while (token) {
|
||||
// Just printing each integer here but handle as needed
|
||||
// int n = atoi(token);
|
||||
printf("%s\n", token);
|
||||
|
||||
token = strtok(NULL, ",");
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
@ -1,13 +1,43 @@
|
||||
# C
|
||||
|
||||
## Other
|
||||
## Работа со строками
|
||||
|
||||
- [seconds_to_minutes_and_hours.c](seconds_to_minutes_and_hours.c) - Преобразование секунд в минуты и часы
|
||||
- [get_ram_usage.c](get_ram_usage.c) - Получение используемой приложением RAM
|
||||
## SQLite 3
|
||||
- [clear_string.c](Strings/clear_string.c) - Очистка строки `char *`
|
||||
- [`strlen()`](Strings/buffer_len.h) - Получить длину строки
|
||||
- []() -
|
||||
|
||||
- [CREATE TABLE](sqlite/sqlite3_create.c)
|
||||
- [INSERT INTO](sqlite/sqlite3_insert.c)
|
||||
- [SELECT](sqlite/sqlite3_select.c)
|
||||
- [UPDATE](sqlite/sqlite3_update.c)
|
||||
- [DELETE](sqlite/sqlite3_delete.c)
|
||||
## Преобразования
|
||||
|
||||
- [rgbToHex.c](Transform/rgbToHex.c) - Преобразование RGB строки в HEX строку _(#008040)_
|
||||
- [seconds_to_minutes_and_hours.c](Transform/seconds_to_minutes_and_hours.c) - Преобразование секунд в минуты и часы
|
||||
|
||||
## Парсеры
|
||||
|
||||
- [read_csv.c](Parsing/CSV/read_csv.c) - Парсинг CSV файлов
|
||||
|
||||
## Система
|
||||
|
||||
- [get_ram_usage.c](System/get_ram_usage.c) - Получение статистики использования RAM
|
||||
- [`sys/statvfs.h`](System/disk_usage.c) - Получение статиистики использования диска
|
||||
- [`pidof`](System/get-pid-by-process-name.c) - Получение ID процесса по его имени
|
||||
|
||||
## 🗄️ SQLite 3
|
||||
|
||||
- [CREATE TABLE](SQLite/sqlite3_create.c) — Создание таблицы
|
||||
- [INSERT INTO](SQLite/sqlite3_insert.c) — Вставка
|
||||
- [SELECT](SQLite/sqlite3_select.c) — Выбор
|
||||
- [UPDATE](SQLite/sqlite3_update.c) — Обновление
|
||||
- [DELETE](SQLite/sqlite3_delete.c) — Удаление
|
||||
|
||||
## Web
|
||||
|
||||
- [`webui`](Web/webui) - Пример библиотеки [webui](https://webui.me/)
|
||||
- [`ulfius`](Web/ulfius-server) - Пример библиотеки ulfius
|
||||
|
||||
## Другое
|
||||
|
||||
- [`conio.h`](conio.h/README.md) - Описание и работа функций заголовоного файла `conio.h`.
|
||||
- [unixsocket](unixsocket) - Пример работы с сокетами UNIX
|
||||
- [AF_INET_sockets](AF_INET_sockets) - Пример работы с сокетами
|
||||
- [atomic.c](atomic.c) - Пример `atomic`
|
||||
- [thread.c](thread.c) - Пример многопоточности
|
||||
|
1
code/C/SQLite/.gitignore
vendored
Normal file
1
code/C/SQLite/.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
||||
sqlite3_*
|
52
code/C/SQLite/sqlite3_create.c
Normal file
52
code/C/SQLite/sqlite3_create.c
Normal file
@ -0,0 +1,52 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <sqlite3.h>
|
||||
|
||||
static int callback(void *NotUsed, int argc, char **argv, char **azColName) {
|
||||
int i;
|
||||
for (i = 0; i < argc; i++) {
|
||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||
}
|
||||
|
||||
printf("\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[]) {
|
||||
sqlite3 *db;
|
||||
char *zErrMsg = 0;
|
||||
int rc;
|
||||
char *sql;
|
||||
|
||||
/* Open database */
|
||||
rc = sqlite3_open("test.db", &db);
|
||||
|
||||
if (rc) {
|
||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||
return (0);
|
||||
} else {
|
||||
fprintf(stdout, "Opened database successfully\n");
|
||||
}
|
||||
|
||||
/* Create SQL statement */
|
||||
sql = "CREATE TABLE COMPANY("
|
||||
"ID INT PRIMARY KEY NOT NULL,"
|
||||
"NAME TEXT NOT NULL,"
|
||||
"AGE INT NOT NULL,"
|
||||
"ADDRESS CHAR(50),"
|
||||
"SALARY REAL);";
|
||||
|
||||
/* Execute SQL statement */
|
||||
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
|
||||
|
||||
if (rc != SQLITE_OK) {
|
||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||
sqlite3_free(zErrMsg);
|
||||
} else {
|
||||
fprintf(stdout, "Table created successfully\n");
|
||||
}
|
||||
|
||||
sqlite3_close(db);
|
||||
|
||||
return 0;
|
||||
}
|
51
code/C/SQLite/sqlite3_delete.c
Normal file
51
code/C/SQLite/sqlite3_delete.c
Normal file
@ -0,0 +1,51 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <sqlite3.h>
|
||||
|
||||
static int callback(void *data, int argc, char **argv, char **azColName) {
|
||||
int i;
|
||||
fprintf(stderr, "%s: ", (const char *)data);
|
||||
|
||||
for (i = 0; i < argc; i++) {
|
||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||
}
|
||||
|
||||
printf("\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[]) {
|
||||
sqlite3 *db;
|
||||
char *zErrMsg = 0;
|
||||
int rc;
|
||||
char *sql;
|
||||
const char *data = "Callback function called";
|
||||
|
||||
/* Open database */
|
||||
rc = sqlite3_open("test.db", &db);
|
||||
|
||||
if (rc) {
|
||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||
return (0);
|
||||
} else {
|
||||
fprintf(stderr, "Opened database successfully\n");
|
||||
}
|
||||
|
||||
/* Create merged SQL statement */
|
||||
sql = "DELETE from COMPANY where ID=2; "
|
||||
"SELECT * from COMPANY";
|
||||
|
||||
/* Execute SQL statement */
|
||||
rc = sqlite3_exec(db, sql, callback, (void *)data, &zErrMsg);
|
||||
|
||||
if (rc != SQLITE_OK) {
|
||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||
sqlite3_free(zErrMsg);
|
||||
} else {
|
||||
fprintf(stdout, "Operation done successfully\n");
|
||||
}
|
||||
|
||||
sqlite3_close(db);
|
||||
|
||||
return 0;
|
||||
}
|
55
code/C/SQLite/sqlite3_insert.c
Normal file
55
code/C/SQLite/sqlite3_insert.c
Normal file
@ -0,0 +1,55 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <sqlite3.h>
|
||||
|
||||
static int callback(void *NotUsed, int argc, char **argv, char **azColName) {
|
||||
int i;
|
||||
for (i = 0; i < argc; i++) {
|
||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||
}
|
||||
|
||||
printf("\n");
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[]) {
|
||||
sqlite3 *db;
|
||||
char *zErrMsg = 0;
|
||||
int rc;
|
||||
char *sql;
|
||||
|
||||
/* Open database */
|
||||
rc = sqlite3_open("test.db", &db);
|
||||
|
||||
if (rc) {
|
||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||
return (0);
|
||||
} else {
|
||||
fprintf(stderr, "Opened database successfully\n");
|
||||
}
|
||||
|
||||
/* Create SQL statement */
|
||||
sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "
|
||||
"VALUES (1, 'Paul', 32, 'California', 20000.00 ); "
|
||||
"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "
|
||||
"VALUES (2, 'Allen', 25, 'Texas', 15000.00 ); "
|
||||
"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)"
|
||||
"VALUES (3, 'Teddy', 23, 'Norway', 20000.00 );"
|
||||
"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)"
|
||||
"VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00);";
|
||||
|
||||
/* Execute SQL statement */
|
||||
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
|
||||
|
||||
if (rc != SQLITE_OK) {
|
||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||
sqlite3_free(zErrMsg);
|
||||
} else {
|
||||
fprintf(stdout, "Records created successfully\n");
|
||||
}
|
||||
|
||||
sqlite3_close(db);
|
||||
|
||||
return 0;
|
||||
}
|
50
code/C/SQLite/sqlite3_select.c
Normal file
50
code/C/SQLite/sqlite3_select.c
Normal file
@ -0,0 +1,50 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <sqlite3.h>
|
||||
|
||||
static int callback(void *data, int argc, char **argv, char **azColName) {
|
||||
int i;
|
||||
fprintf(stderr, "%s: ", (const char *)data);
|
||||
|
||||
for (i = 0; i < argc; i++) {
|
||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||
}
|
||||
|
||||
printf("\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[]) {
|
||||
sqlite3 *db;
|
||||
char *zErrMsg = 0;
|
||||
int rc;
|
||||
char *sql;
|
||||
const char *data = "Callback function called";
|
||||
|
||||
/* Open database */
|
||||
rc = sqlite3_open("test.db", &db);
|
||||
|
||||
if (rc) {
|
||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||
return (0);
|
||||
} else {
|
||||
fprintf(stderr, "Opened database successfully\n");
|
||||
}
|
||||
|
||||
/* Create SQL statement */
|
||||
sql = "SELECT * from COMPANY";
|
||||
|
||||
/* Execute SQL statement */
|
||||
rc = sqlite3_exec(db, sql, callback, (void *)data, &zErrMsg);
|
||||
|
||||
if (rc != SQLITE_OK) {
|
||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||
sqlite3_free(zErrMsg);
|
||||
} else {
|
||||
fprintf(stdout, "Operation done successfully\n");
|
||||
}
|
||||
|
||||
sqlite3_close(db);
|
||||
|
||||
return 0;
|
||||
}
|
51
code/C/SQLite/sqlite3_update.c
Normal file
51
code/C/SQLite/sqlite3_update.c
Normal file
@ -0,0 +1,51 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <sqlite3.h>
|
||||
|
||||
static int callback(void *data, int argc, char **argv, char **azColName) {
|
||||
int i;
|
||||
fprintf(stderr, "%s: ", (const char *)data);
|
||||
|
||||
for (i = 0; i < argc; i++) {
|
||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||
}
|
||||
|
||||
printf("\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[]) {
|
||||
sqlite3 *db;
|
||||
char *zErrMsg = 0;
|
||||
int rc;
|
||||
char *sql;
|
||||
const char *data = "Callback function called";
|
||||
|
||||
/* Open database */
|
||||
rc = sqlite3_open("test.db", &db);
|
||||
|
||||
if (rc) {
|
||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||
return (0);
|
||||
} else {
|
||||
fprintf(stderr, "Opened database successfully\n");
|
||||
}
|
||||
|
||||
/* Create merged SQL statement */
|
||||
sql = "UPDATE COMPANY set SALARY = 25000.00 where ID=1; "
|
||||
"SELECT * from COMPANY";
|
||||
|
||||
/* Execute SQL statement */
|
||||
rc = sqlite3_exec(db, sql, callback, (void *)data, &zErrMsg);
|
||||
|
||||
if (rc != SQLITE_OK) {
|
||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||
sqlite3_free(zErrMsg);
|
||||
} else {
|
||||
fprintf(stdout, "Operation done successfully\n");
|
||||
}
|
||||
|
||||
sqlite3_close(db);
|
||||
|
||||
return 0;
|
||||
}
|
9
code/C/Strings/clear_string.c
Normal file
9
code/C/Strings/clear_string.c
Normal file
@ -0,0 +1,9 @@
|
||||
int main(int argc, char const *argv[]) {
|
||||
char *buffer = malloc(256 + 1);
|
||||
|
||||
buffer[0] = '\0';
|
||||
strcpy(buffer, "");
|
||||
memset(buffer, '\0', sizeof(buffer));
|
||||
|
||||
return 0;
|
||||
}
|
12
code/C/System/get-pid-by-process-name.c
Normal file
12
code/C/System/get-pid-by-process-name.c
Normal file
@ -0,0 +1,12 @@
|
||||
pid_t getPIDbyName(char *ps_name) {
|
||||
FILE *fp;
|
||||
char *cmd = (char *)calloc(1, 200);
|
||||
|
||||
sprintf(cmd, "pidof %s", ps_name);
|
||||
|
||||
fp = popen(cmd, "r");
|
||||
fread(cmd, 1, 200, fp);
|
||||
fclose(fp);
|
||||
|
||||
return atoi(cmd);
|
||||
}
|
11
code/C/Transform/rgbToHex.c
Normal file
11
code/C/Transform/rgbToHex.c
Normal file
@ -0,0 +1,11 @@
|
||||
#include <stdio.h>
|
||||
|
||||
int main(int argc, char const *argv[]) {
|
||||
int red = 0;
|
||||
int green = 128;
|
||||
int blue = 64;
|
||||
|
||||
printf("#%.2x%.2x%.2x\n", red, green, blue); // #008040
|
||||
|
||||
return 0;
|
||||
}
|
Before Width: | Height: | Size: 78 KiB After Width: | Height: | Size: 78 KiB |
@ -5,8 +5,7 @@
|
||||
atomic_int acnt;
|
||||
int cnt;
|
||||
|
||||
int f(void* thr_data)
|
||||
{
|
||||
int f(void *thr_data) {
|
||||
(void)thr_data;
|
||||
for (int n = 0; n < 1000; ++n) {
|
||||
++cnt;
|
||||
@ -17,8 +16,7 @@ int f(void* thr_data)
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main(void)
|
||||
{
|
||||
int main(void) {
|
||||
thrd_t thr[10];
|
||||
for (int n = 0; n < 10; ++n)
|
||||
thrd_create(&thr[n], f, NULL);
|
||||
|
@ -1,10 +0,0 @@
|
||||
int main(int argc, char const *argv[])
|
||||
{
|
||||
char *buffer = malloc(256 + 1);
|
||||
|
||||
buffer[0] = '\0';
|
||||
strcpy(buffer, "");
|
||||
memset(buffer, '\0', sizeof(buffer));
|
||||
|
||||
return 0;
|
||||
}
|
@ -1,10 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
files=(
|
||||
"file.c"
|
||||
)
|
||||
|
||||
for file in "${files[@]}"
|
||||
do
|
||||
clang-format -i --style=LLVM --sort-includes=false $file
|
||||
done
|
@ -1,6 +0,0 @@
|
||||
[{clear,build,format-code}]
|
||||
indent_style = space
|
||||
indent_size = 4
|
||||
|
||||
[{*.c,*.ino}]
|
||||
indent_size = 2
|
12
code/C/libserialport/.gitignore
vendored
12
code/C/libserialport/.gitignore
vendored
@ -1,12 +0,0 @@
|
||||
# libserialport examples
|
||||
port_info.c
|
||||
list_ports.c
|
||||
send_receive.c
|
||||
|
||||
# binaries
|
||||
port_info
|
||||
list_ports
|
||||
send_receive
|
||||
|
||||
listen
|
||||
abc.txt
|
1
code/C/libserialport/Board/.gitignore
vendored
1
code/C/libserialport/Board/.gitignore
vendored
@ -1 +0,0 @@
|
||||
3party/
|
@ -1,24 +0,0 @@
|
||||
/*
|
||||
Author: Alexander Popov
|
||||
License: Unlicense
|
||||
*/
|
||||
|
||||
#include "3party/AsyncStream.h"
|
||||
AsyncStream<50> serial(&Serial, '\n');
|
||||
|
||||
void setup() {
|
||||
Serial.begin(9600);
|
||||
}
|
||||
|
||||
void loop() {
|
||||
if (strcmp(serial.buf, "ping") == 0) {
|
||||
Serial.println("PONG");
|
||||
}
|
||||
|
||||
Serial.println("ooooo");
|
||||
// delay(1000);
|
||||
Serial.println("zzzz");
|
||||
// delay(1000);
|
||||
Serial.println("xxx");
|
||||
// delay(1000);
|
||||
}
|
@ -1,3 +0,0 @@
|
||||
Download `AsyncStream.h` from
|
||||
https://github.com/GyverLibs/AsyncStream
|
||||
and drop in to `3party` folder.
|
@ -1,18 +0,0 @@
|
||||
Download `libserialport` library.
|
||||
|
||||
```sh
|
||||
git clone git://sigrok.org/libserialport
|
||||
```
|
||||
|
||||
For **build** code use `build` script or build files manually.
|
||||
|
||||
Example:
|
||||
|
||||
```sh
|
||||
export C_INCLUDE_PATH=<path/to/libserialport>
|
||||
export LIBRARY_PATH=<path/to/libserialport/.libs>
|
||||
|
||||
gcc -static -Wall -O3 -o <output_filename> <file.c> -lserialport
|
||||
```
|
||||
|
||||
Arduino example project store in `Board` folder.
|
@ -1,20 +0,0 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# build - script for build all files.
|
||||
#
|
||||
# Alexander Popov <iiiypuk@fastmail.fm>
|
||||
|
||||
export C_INCLUDE_PATH=$HOME/Git/libserialport
|
||||
export LIBRARY_PATH=$HOME/Git/libserialport/.libs
|
||||
|
||||
for file in \
|
||||
port_info.c \
|
||||
list_ports.c \
|
||||
send_receive.c \
|
||||
listen.c \
|
||||
|
||||
do
|
||||
echo -ne "[ ] Building $file...\r"
|
||||
gcc -static -Wall -O3 -o ${file%.*} $file -lserialport
|
||||
echo [OK
|
||||
done
|
@ -1,20 +0,0 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# build - script for build all files.
|
||||
#
|
||||
# Alexander Popov <iiiypuk@fastmail.fm>
|
||||
|
||||
export C_INCLUDE_PATH=$HOME/Git/libserialport
|
||||
export LIBRARY_PATH=$HOME/Git/libserialport/.libs
|
||||
|
||||
for file in \
|
||||
port_info.c \
|
||||
list_ports.c \
|
||||
send_receive.c \
|
||||
listen.c \
|
||||
|
||||
do
|
||||
echo -ne "[ ] Building $file...\r"
|
||||
tcc -Wall -O3 -o ${file%.*} -I$C_INCLUDE_PATH $file $LIBRARY_PATH/libserialport.a
|
||||
echo [OK
|
||||
done
|
@ -1,17 +0,0 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# clear - script for delete all builded files.
|
||||
#
|
||||
# Alexander Popov <iiiypuk@fastmail.fm>
|
||||
|
||||
files=(
|
||||
"port_info"
|
||||
"list_ports"
|
||||
"send_receive"
|
||||
"listen"
|
||||
)
|
||||
|
||||
for file in ${files[@]}
|
||||
do
|
||||
rm $file &> /dev/null
|
||||
done
|
@ -1,14 +0,0 @@
|
||||
#!/bin/sh
|
||||
#
|
||||
# formt-code - script for beautify code by clang-format.
|
||||
#
|
||||
# Alexander Popov <iiiypuk@fastmail.fm>
|
||||
|
||||
files=(
|
||||
"listen.c"
|
||||
)
|
||||
|
||||
for file in "${files[@]}"
|
||||
do
|
||||
clang-format -i --style=LLVM --sort-includes=false $file
|
||||
done
|
@ -1,133 +0,0 @@
|
||||
#include <libserialport.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <stdbool.h>
|
||||
#include <signal.h>
|
||||
|
||||
/* Helper function for error handling. */
|
||||
int check(enum sp_return result);
|
||||
void handle_sigint(int sig);
|
||||
|
||||
bool INTERRUPT = false;
|
||||
|
||||
int main(int argc, char **argv) {
|
||||
struct sp_port *serial_port;
|
||||
char *port_name;
|
||||
|
||||
const int size = 256;
|
||||
char *buffer = malloc(size + 1);
|
||||
|
||||
const unsigned int timeout = 1000;
|
||||
int result;
|
||||
|
||||
/* Get the port name from the command line. */
|
||||
if (argc != 2) {
|
||||
printf("Usage: %s <port>\n\n", argv[0]);
|
||||
|
||||
struct sp_port **port_list;
|
||||
enum sp_return result = sp_list_ports(&port_list);
|
||||
|
||||
/* Getting the available ports. */
|
||||
if (result != SP_OK) {
|
||||
puts("Getting available ports failed!");
|
||||
} else {
|
||||
puts("Available ports:");
|
||||
|
||||
int i;
|
||||
for (i = 0; port_list[i] != NULL; i++) {
|
||||
/* Get the name of the port. */
|
||||
struct sp_port *port = port_list[i];
|
||||
char *port_name = sp_get_port_name(port);
|
||||
|
||||
printf(" * %s\n", port_name);
|
||||
}
|
||||
|
||||
printf("\nAvailable %d ports.\n", i);
|
||||
|
||||
sp_free_port_list(port_list);
|
||||
}
|
||||
|
||||
return -1;
|
||||
} else {
|
||||
port_name = argv[1];
|
||||
}
|
||||
|
||||
printf("Connecting to '%s'...\n", port_name);
|
||||
check(sp_get_port_by_name(port_name, &serial_port));
|
||||
check(sp_open(serial_port, SP_MODE_READ_WRITE));
|
||||
|
||||
check(sp_set_baudrate(serial_port, 9600));
|
||||
check(sp_set_bits(serial_port, 8));
|
||||
check(sp_set_parity(serial_port, SP_PARITY_NONE));
|
||||
check(sp_set_stopbits(serial_port, 1));
|
||||
check(sp_set_flowcontrol(serial_port, SP_FLOWCONTROL_NONE));
|
||||
puts("Connected.");
|
||||
|
||||
signal(SIGINT, handle_sigint);
|
||||
|
||||
FILE *output_file;
|
||||
output_file = fopen("./abc.txt", "w");
|
||||
|
||||
/* Reading lines from serial port. */
|
||||
bool reading = true;
|
||||
while (reading && !INTERRUPT) {
|
||||
int pos = 0;
|
||||
|
||||
/* Character-by-character reading. */
|
||||
while (pos < size) {
|
||||
result = check(sp_blocking_read(serial_port, buffer + pos, 1, timeout));
|
||||
|
||||
if (result == -1) {
|
||||
puts("Error reading from serial port");
|
||||
|
||||
reading = false;
|
||||
break;
|
||||
} else if (result == 0) {
|
||||
puts("No more data");
|
||||
break;
|
||||
} else {
|
||||
if (buffer[pos] == '\n') {
|
||||
buffer[pos] = '\0';
|
||||
break;
|
||||
}
|
||||
|
||||
pos++;
|
||||
}
|
||||
}
|
||||
|
||||
puts(buffer);
|
||||
fputs(buffer, output_file);
|
||||
}
|
||||
|
||||
fclose(output_file);
|
||||
free(buffer);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Helper function for error handling. */
|
||||
int check(enum sp_return result) {
|
||||
char *error_message;
|
||||
|
||||
switch (result) {
|
||||
case SP_ERR_ARG:
|
||||
puts("Error: Invalid argument.");
|
||||
abort();
|
||||
case SP_ERR_FAIL:
|
||||
error_message = sp_last_error_message();
|
||||
printf("Error: Failed: %s\n", error_message);
|
||||
sp_free_error_message(error_message);
|
||||
abort();
|
||||
case SP_ERR_SUPP:
|
||||
puts("Error: Not supported.");
|
||||
abort();
|
||||
case SP_ERR_MEM:
|
||||
puts("Error: Couldn't allocate memory.");
|
||||
abort();
|
||||
case SP_OK:
|
||||
default:
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
||||
void handle_sigint(int sig) { INTERRUPT = true; }
|
@ -1,31 +0,0 @@
|
||||
#include <stdio.h> // file handling functions
|
||||
#include <stdlib.h> // atoi
|
||||
#include <string.h> // strtok
|
||||
|
||||
int main() {
|
||||
char buffer[80];
|
||||
FILE *stream = fopen("example.csv", "r");
|
||||
|
||||
while (fgets(buffer, 80, stream)) {
|
||||
char *token = strtok(buffer, ",");
|
||||
|
||||
// If you only need the first column of each row
|
||||
// Если нам нужен только первый столбец каждой строки
|
||||
if (token) {
|
||||
int n = atoi(token);
|
||||
printf("%s\n", n);
|
||||
}
|
||||
|
||||
// If you need all the values in a row
|
||||
// Если нам нужны все значения подряд
|
||||
while (token) {
|
||||
// Just printing each integer here but handle as needed
|
||||
// int n = atoi(token);
|
||||
printf("%s\n", token);
|
||||
|
||||
token = strtok(NULL, ",");
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
@ -1,12 +0,0 @@
|
||||
#include <stdio.h>
|
||||
|
||||
int main(int argc, char const *argv[])
|
||||
{
|
||||
int red = 0;
|
||||
int green = 128;
|
||||
int blue = 64;
|
||||
|
||||
printf("#%.2x%.2x%.2x\n", red, green, blue); //#008040
|
||||
|
||||
return 0;
|
||||
}
|
@ -1,52 +0,0 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <sqlite3.h>
|
||||
|
||||
static int callback(void *NotUsed, int argc, char **argv, char **azColName) {
|
||||
int i;
|
||||
for(i = 0; i<argc; i++) {
|
||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||
}
|
||||
|
||||
printf("\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main(int argc, char* argv[]) {
|
||||
sqlite3 *db;
|
||||
char *zErrMsg = 0;
|
||||
int rc;
|
||||
char *sql;
|
||||
|
||||
/* Open database */
|
||||
rc = sqlite3_open("test.db", &db);
|
||||
|
||||
if (rc) {
|
||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||
return(0);
|
||||
} else {
|
||||
fprintf(stdout, "Opened database successfully\n");
|
||||
}
|
||||
|
||||
/* Create SQL statement */
|
||||
sql = "CREATE TABLE COMPANY(" \
|
||||
"ID INT PRIMARY KEY NOT NULL," \
|
||||
"NAME TEXT NOT NULL," \
|
||||
"AGE INT NOT NULL," \
|
||||
"ADDRESS CHAR(50)," \
|
||||
"SALARY REAL);";
|
||||
|
||||
/* Execute SQL statement */
|
||||
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
|
||||
|
||||
if (rc != SQLITE_OK) {
|
||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||
sqlite3_free(zErrMsg);
|
||||
} else {
|
||||
fprintf(stdout, "Table created successfully\n");
|
||||
}
|
||||
|
||||
sqlite3_close(db);
|
||||
|
||||
return 0;
|
||||
}
|
@ -1,51 +0,0 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <sqlite3.h>
|
||||
|
||||
static int callback(void *data, int argc, char **argv, char **azColName) {
|
||||
int i;
|
||||
fprintf(stderr, "%s: ", (const char*)data);
|
||||
|
||||
for (i = 0; i<argc; i++) {
|
||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||
}
|
||||
|
||||
printf("\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main(int argc, char* argv[]) {
|
||||
sqlite3 *db;
|
||||
char *zErrMsg = 0;
|
||||
int rc;
|
||||
char *sql;
|
||||
const char* data = "Callback function called";
|
||||
|
||||
/* Open database */
|
||||
rc = sqlite3_open("test.db", &db);
|
||||
|
||||
if (rc) {
|
||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||
return(0);
|
||||
} else {
|
||||
fprintf(stderr, "Opened database successfully\n");
|
||||
}
|
||||
|
||||
/* Create merged SQL statement */
|
||||
sql = "DELETE from COMPANY where ID=2; " \
|
||||
"SELECT * from COMPANY";
|
||||
|
||||
/* Execute SQL statement */
|
||||
rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
|
||||
|
||||
if (rc != SQLITE_OK) {
|
||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||
sqlite3_free(zErrMsg);
|
||||
} else {
|
||||
fprintf(stdout, "Operation done successfully\n");
|
||||
}
|
||||
|
||||
sqlite3_close(db);
|
||||
|
||||
return 0;
|
||||
}
|
@ -1,55 +0,0 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <sqlite3.h>
|
||||
|
||||
static int callback(void *NotUsed, int argc, char **argv, char **azColName) {
|
||||
int i;
|
||||
for (i = 0; i<argc; i++) {
|
||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||
}
|
||||
|
||||
printf("\n");
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main(int argc, char* argv[]) {
|
||||
sqlite3 *db;
|
||||
char *zErrMsg = 0;
|
||||
int rc;
|
||||
char *sql;
|
||||
|
||||
/* Open database */
|
||||
rc = sqlite3_open("test.db", &db);
|
||||
|
||||
if (rc) {
|
||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||
return(0);
|
||||
} else {
|
||||
fprintf(stderr, "Opened database successfully\n");
|
||||
}
|
||||
|
||||
/* Create SQL statement */
|
||||
sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) " \
|
||||
"VALUES (1, 'Paul', 32, 'California', 20000.00 ); " \
|
||||
"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) " \
|
||||
"VALUES (2, 'Allen', 25, 'Texas', 15000.00 ); " \
|
||||
"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)" \
|
||||
"VALUES (3, 'Teddy', 23, 'Norway', 20000.00 );" \
|
||||
"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)" \
|
||||
"VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00);";
|
||||
|
||||
/* Execute SQL statement */
|
||||
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
|
||||
|
||||
if (rc != SQLITE_OK) {
|
||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||
sqlite3_free(zErrMsg);
|
||||
} else {
|
||||
fprintf(stdout, "Records created successfully\n");
|
||||
}
|
||||
|
||||
sqlite3_close(db);
|
||||
|
||||
return 0;
|
||||
}
|
@ -1,50 +0,0 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <sqlite3.h>
|
||||
|
||||
static int callback(void *data, int argc, char **argv, char **azColName) {
|
||||
int i;
|
||||
fprintf(stderr, "%s: ", (const char*)data);
|
||||
|
||||
for (i = 0; i<argc; i++) {
|
||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||
}
|
||||
|
||||
printf("\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main(int argc, char* argv[]) {
|
||||
sqlite3 *db;
|
||||
char *zErrMsg = 0;
|
||||
int rc;
|
||||
char *sql;
|
||||
const char* data = "Callback function called";
|
||||
|
||||
/* Open database */
|
||||
rc = sqlite3_open("test.db", &db);
|
||||
|
||||
if (rc) {
|
||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||
return(0);
|
||||
} else {
|
||||
fprintf(stderr, "Opened database successfully\n");
|
||||
}
|
||||
|
||||
/* Create SQL statement */
|
||||
sql = "SELECT * from COMPANY";
|
||||
|
||||
/* Execute SQL statement */
|
||||
rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
|
||||
|
||||
if (rc != SQLITE_OK) {
|
||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||
sqlite3_free(zErrMsg);
|
||||
} else {
|
||||
fprintf(stdout, "Operation done successfully\n");
|
||||
}
|
||||
|
||||
sqlite3_close(db);
|
||||
|
||||
return 0;
|
||||
}
|
@ -1,51 +0,0 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <sqlite3.h>
|
||||
|
||||
static int callback(void *data, int argc, char **argv, char **azColName) {
|
||||
int i;
|
||||
fprintf(stderr, "%s: ", (const char*)data);
|
||||
|
||||
for(i = 0; i<argc; i++) {
|
||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||
}
|
||||
|
||||
printf("\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main(int argc, char* argv[]) {
|
||||
sqlite3 *db;
|
||||
char *zErrMsg = 0;
|
||||
int rc;
|
||||
char *sql;
|
||||
const char* data = "Callback function called";
|
||||
|
||||
/* Open database */
|
||||
rc = sqlite3_open("test.db", &db);
|
||||
|
||||
if (rc) {
|
||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||
return(0);
|
||||
} else {
|
||||
fprintf(stderr, "Opened database successfully\n");
|
||||
}
|
||||
|
||||
/* Create merged SQL statement */
|
||||
sql = "UPDATE COMPANY set SALARY = 25000.00 where ID=1; " \
|
||||
"SELECT * from COMPANY";
|
||||
|
||||
/* Execute SQL statement */
|
||||
rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
|
||||
|
||||
if (rc != SQLITE_OK) {
|
||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||
sqlite3_free(zErrMsg);
|
||||
} else {
|
||||
fprintf(stdout, "Operation done successfully\n");
|
||||
}
|
||||
|
||||
sqlite3_close(db);
|
||||
|
||||
return 0;
|
||||
}
|
Binary file not shown.
Binary file not shown.
@ -36,8 +36,7 @@ int main(int argc, char *argv[]) {
|
||||
addr.sun_family = AF_UNIX;
|
||||
strncpy(addr.sun_path, SOCKET_NAME, sizeof(addr.sun_path) - 1);
|
||||
|
||||
ret = connect (data_socket, (const struct sockaddr *) &addr,
|
||||
sizeof(struct sockaddr_un));
|
||||
ret = connect(data_socket, (const struct sockaddr *)&addr, sizeof(struct sockaddr_un));
|
||||
if (ret == -1) {
|
||||
fprintf(stderr, "The server is down.\n");
|
||||
exit(EXIT_FAILURE);
|
||||
|
Binary file not shown.
@ -43,8 +43,7 @@ int main(int argc, char *argv[]) {
|
||||
addr.sun_family = AF_UNIX;
|
||||
strncpy(addr.sun_path, SOCKET_NAME, sizeof(addr.sun_path) - 1);
|
||||
|
||||
ret = bind(listen_socket, (const struct sockaddr *) &addr,
|
||||
sizeof(struct sockaddr_un));
|
||||
ret = bind(listen_socket, (const struct sockaddr *)&addr, sizeof(struct sockaddr_un));
|
||||
if (ret == -1) {
|
||||
perror("bind");
|
||||
exit(EXIT_FAILURE);
|
||||
|
Loading…
Reference in New Issue
Block a user