Скрипты оболочки очень похожи на команды, которые вы попадаете в типичном режиме в оболочке. В этом случае параметр -O
-O G ++
, где поставить двоичный. Таким образом, вы просто скажете это, вы хотите, чтобы в двоичном каталоге:
g++ lesson01.cpp -o Binary/lesson01
Вы можете запустить это интерактивно (набрав его в оболочку), или вы можете поставить, что в сценарии оболочки - оба сделают то же самое:
#!/bin/sh
g++ lesson01.cpp -o Binary/lesson01
Обычно, однако, вы бы использовали Makefile, чтобы делать такие вещи, а не скрипт оболочки.
all:
Binary/%: %.cpp
g++ -o "$@" "$<" # Note: this must be a tab, not spaces. Make is annoying like that
Тогда вы напечатаете сделать двоичный / урок01
и сделать компиляцию программы (если источник новее, чем существующий двоичный файл, или если двоичный не существует). Вы также можете перечислить все программы после этого Все:
вверху ( все: двоичный / урок01 двоичный / урок02
, и т. Д.) А затем просто набрать make
Составьте все программы по мере необходимости.
Вы также можете сделать более продвинутые вещи с помощью Sake или скрипта Shell (например, чтобы он определил список программ для компиляции, а не в списке их всех), но это более сложная.
Вы можете использовать любой веб-сервер для списка содержимого HTTP и базовую аутентификацию. Базовая аутентификация безопасна, но вы должны отправлять ее через туннель SSL. Для вашей домашней системы самостоятельно подписанные сертификаты, вероятно, хватит для защиты запросов аутентификации. Я бы порекомендовал Lighttp или Nginx, если вы используете встроенную аппаратное обеспечение, поскольку веб-серверы на основе процесса (Apache в настройке по умолчанию) будут использовать больше ресурсов для каждого соединения. Основным отличием между легкими и NGINX является то, что слегка использует один процесс, и один неблокирующий нить и NGINX использует основной процесс для делегирования работы для детей.
Вот пример /etc/nginx.conf
(без тестирования, поэтому может понадобиться подстройка). Вам просто нужно было бы создать папку в / etc / nginx / TLS и добавить самозаписанную SSL Keypair к нему (cert.pem, cert.key).
user nobody;
worker_processes 1;
events {
worker_connections 64;
}
http {
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log var/log/nginx/access.log main;
keepalive_timeout 60;
server {
server_name localhost;
listen 80 443;
ssl on;
ssl_certificate tls/cert.pem;
ssl_certificate_key tls/cert.key;
ssl_session_timeout 5m;
ssl_protocols TLSv1;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
location / {
root /path/to/your/data;
autoindex on;
}
}
}