]> Kevux Git Server - fll/log
fll
5 years agoBugfix: do not include private headers
Kevin Day [Sat, 31 Aug 2019 21:19:10 +0000 (16:19 -0500)]
Bugfix: do not include private headers

Manually including private headers from within public headers will result in compilation errors.
The private headers will still get included via the private source file.

5 years agoUpdate: provide f_utf_is() and f_utf_is_character() functions
Kevin Day [Sat, 31 Aug 2019 21:18:42 +0000 (16:18 -0500)]
Update: provide f_utf_is() and f_utf_is_character() functions

5 years agoUpdate: handle invalid UTF-8 fragments
Kevin Day [Sat, 31 Aug 2019 20:59:55 +0000 (15:59 -0500)]
Update: handle invalid UTF-8 fragments

A 1-width UTF-8 character (that is not a valid ASCII character) is used to designate part of a complete UTF-8 character block (aka: 1-width UTF-8 characters are fragments).
Because this fragment cannot exist in isolation, it must be handled as either an invalid or an incomplete UTF-8 fragment.

Provide new status codes for handling incomplete UTF-8 fragments.
Update appropriate functions to detect and handle these invalid or incomplete fragments.

5 years agoUpdate: redesign console processing code
Kevin Day [Fri, 30 Aug 2019 17:48:54 +0000 (12:48 -0500)]
Update: redesign console processing code

Simplify the console structure and reduce the size of codes and parameters.

The "extra" parameter seems a bit overkill, remove it and help keep this project more along the lines of the idea of "Featureless".

Rewrite and document fl_process_parameters().

Implementing functions were only functionally updated.
Additional changes are likely necessary for the logic, such as supporting multiple calls like "program -h +n +l", which by order of operation the final "+l" should override the "+n".

5 years agoSecurity: safely print f_dynamic_string
Kevin Day [Fri, 30 Aug 2019 01:48:25 +0000 (20:48 -0500)]
Security: safely print f_dynamic_string

The f_dynamic_string is not NULL terminated and should never be directly passed to a function that assumes strings are NULL terminated.

5 years agoCleanup: f_color, fl_color, and related
Kevin Day [Fri, 30 Aug 2019 01:10:01 +0000 (20:10 -0500)]
Cleanup: f_color, fl_color, and related

In particular, some of the color print functions are not following the naming convention.
The function fl_print_color() should instead be fl_color_print().

Make sure appropriate #define statements have macro in their name.

Add some @fixme comments because f_dynamic_string is designed with the intentions of not being NULL terminated.
Directly using it with standard functions like fprint is dangerous.

5 years agoCleanup: rename f_errors to f_status, fl_errors to fl_status, and fll_errors to fll_s...
Kevin Day [Thu, 29 Aug 2019 21:57:34 +0000 (16:57 -0500)]
Cleanup: rename f_errors to f_status, fl_errors to fl_status, and fll_errors to fll_status

Originally f_errors was meant only for error handling but it quickly turned into status code handling (which includes errors).
The naming system of f_errors is now confusing and misleading so change it to f_status.

This makes far more sense, for example:
- f_error_is_error vs f_status_is_error.
- f_error_set_error vs f_status_set_error

5 years agoCleanup: remove error test macros
Kevin Day [Thu, 29 Aug 2019 20:40:03 +0000 (15:40 -0500)]
Cleanup: remove error test macros

This is legacy behavior that is no longer needed.
Update any existing uses of these deleted macros.

5 years agoCleanup: rename return_code to status_code and fss_return_code to fss_status_code
Kevin Day [Thu, 29 Aug 2019 19:40:25 +0000 (14:40 -0500)]
Cleanup: rename return_code to status_code and fss_return_code to fss_status_code

The "return codes" were originally intended to be literal return codes.
When the error codes were converted to have error bits, warning bits, and signal bits, this no longer became the case.
Refactor return_code into status_code to be more accurate.

5 years agoUpdate: improve return code error conversion and support converting strings to numbers
Kevin Day [Thu, 29 Aug 2019 19:26:54 +0000 (14:26 -0500)]
Update: improve return code error conversion and support converting strings to numbers

5 years agoUpdate: readme file and add additional notes on the FLL dependency structure
Kevin Day [Thu, 29 Aug 2019 02:56:31 +0000 (21:56 -0500)]
Update: readme file and add additional notes on the FLL dependency structure

5 years agoCleanup: only use f_macro_ for defines that structurally mimic functions
Kevin Day [Thu, 29 Aug 2019 00:57:28 +0000 (19:57 -0500)]
Cleanup: only use f_macro_ for defines that structurally mimic functions

5 years agoCleanup: define fl_directory_name_max as 255 to match PATH_NAME
Kevin Day [Thu, 29 Aug 2019 00:53:24 +0000 (19:53 -0500)]
Cleanup: define fl_directory_name_max as 255 to match PATH_NAME

5 years agoUpdate: add UTF-8 support to fl_console
Kevin Day [Thu, 29 Aug 2019 00:48:28 +0000 (19:48 -0500)]
Update: add UTF-8 support to fl_console

Also remove unnecessary looping.

5 years agoUpdate: add more support for UTF-8 and improve effected functions
Kevin Day [Wed, 28 Aug 2019 04:59:00 +0000 (23:59 -0500)]
Update: add more support for UTF-8 and improve effected functions

Use a 32-bit unsigned integer instead of a structure of 4 characters.

Add -lf_utf to dependencies on updated level projects.

Be more thorough when implementing simple fl_seek_* functions.
Support both processing char as well as f_utf_character in string processing.

Continue updating code documentation.

5 years agoUpdate: add missing error code to string conversions
Kevin Day [Tue, 27 Aug 2019 03:15:27 +0000 (22:15 -0500)]
Update: add missing error code to string conversions

5 years agoUpdate: implement UTF-8 support in fss processing code and add additional functionality
Kevin Day [Fri, 23 Aug 2019 03:50:50 +0000 (22:50 -0500)]
Update: implement UTF-8 support in fss processing code and add additional functionality

Additional functionality includes implementing f_utf_character in f_utf.

Includes numerous other small UTF-8 updates.

Some macros have been wrapped in parenthesis to avoid unobvious issues such as when adding an exclamation before a macro call (and the possible order of operation issues).

5 years agoUpdate: use max_width instead of maxWidth, remove f_utf_bom check from f_is_space...
Kevin Day [Thu, 22 Aug 2019 00:04:32 +0000 (19:04 -0500)]
Update: use max_width instead of maxWidth, remove f_utf_bom check from f_is_space, and provide f_macro_utf_byte_width_is for UTF-8

Cleanup accidental use of maxWidth, when the proper syntax style is instead max_width.

After further review, I have decided to move the f_utf_bom check back outside of the f_is_space() function.

Provide f_macro_utf_byte_width_is() function for getting UTF-8 character widths but returning 0 if the character is ASCII.

5 years agoBugfix: f_socket and fl_socket, numerous problems
Kevin Day [Fri, 16 Aug 2019 02:07:12 +0000 (21:07 -0500)]
Bugfix: f_socket and fl_socket, numerous problems

It looks like the f_socket and fl_socket were not completed or otherwise written incorrectly.
Change the behavior to at least compile.

5 years agoFeature: implement monolithic build in the generate.sh and package.sh scripts
Kevin Day [Thu, 15 Aug 2019 06:11:34 +0000 (01:11 -0500)]
Feature: implement monolithic build in the generate.sh and package.sh scripts

5 years agoUpdate: add UTF-8 BOM detection
Kevin Day [Thu, 15 Aug 2019 02:36:50 +0000 (21:36 -0500)]
Update: add UTF-8 BOM detection

Add support for detecting UTF-8 BOM in the f_utf_is_space() function.
Add new function f_utf_is_bom().

5 years agoFeature: add initial UTF-8 support via f_utf
Kevin Day [Wed, 14 Aug 2019 03:46:55 +0000 (22:46 -0500)]
Feature: add initial UTF-8 support via f_utf

This provides the most basic functionality for processing UTF-8 characters.

Additional modules will be updated to natively process strings as UTF-8.

5 years agoCleanup: add build_sources_settings setting to build settings files
Kevin Day [Fri, 9 Aug 2019 01:00:58 +0000 (20:00 -0500)]
Cleanup: add build_sources_settings setting to build settings files

5 years agoCleanup: remove duplicate line in build settings file
Kevin Day [Fri, 9 Aug 2019 00:57:14 +0000 (19:57 -0500)]
Cleanup: remove duplicate line in build settings file

5 years agoCleanup: remove the objects build directory during generate.sh cleanup
Kevin Day [Fri, 9 Aug 2019 00:43:02 +0000 (19:43 -0500)]
Cleanup: remove the objects build directory during generate.sh cleanup

5 years agoUpdate: implement bash support in generate.sh
Kevin Day [Fri, 9 Aug 2019 00:54:00 +0000 (19:54 -0500)]
Update: implement bash support in generate.sh

The generate script now supports handling bash scripts.

5 years agoFeature: support custom 'defines'
Kevin Day [Fri, 9 Aug 2019 00:13:21 +0000 (19:13 -0500)]
Feature: support custom 'defines'

Some libraries or packages have custom defines, such as the firewall _en_firewall_debug_.

Provide simple documentation of the defines, in the data/build/defines file.
Provide build settings values for specifying these custom defines.
Provide parameter for manually overriding defines.

Some path settings have been renamed to avoid confusion (such as '--c_path' is now '--path_c').

Enable _en_firewall_debug_ by default.

5 years agoCleanup: remove 'DEBUG: ' from debug output
Kevin Day [Fri, 9 Aug 2019 00:45:02 +0000 (19:45 -0500)]
Cleanup: remove 'DEBUG: ' from debug output

5 years agoUpdate: add build_libraries_fll build setting
Kevin Day [Tue, 30 Jul 2019 01:35:02 +0000 (20:35 -0500)]
Update: add build_libraries_fll build setting

Add a new parameter to make it easier to switch between individual compilation, level compilation, and monolithic compilation.
This parameter will only be used for fll-specific libraries.

For programs (aka: "level 3") commented out examples for linking against level-based and monolithic are provided.
The configurations can then be easily swapped out by a couple of simple sed statements, such as:
  - sed -i -e 's|^build_libraries_fll\>|#&|g' data/build/settings
  - sed -i -e 's|^#build_libraries_fll-level\>|build_libraries_fll|g' data/build/settings

The above example will switch to the level based compiling, while disabling the individual compiling.

The level based compiling compiles each of the levels 0, 1, and 2 as a single library for each level, resulting in libraries such as:
  - libfll_0-0.5.0.so
  - libfll_1-0.5.0.so
  - libfll_2-0.5.0.so

The monolithic based compiling compiles all of the levels 0, 1, and 2 as a single library, resulting in libraries such as:
  - libfll-0.5.0.so

The standard names of individual, level, and monolithic do not overlap by default and can therefoe be installed side-by-side.

5 years agoUpdate: replace f_const with const
Kevin Day [Mon, 29 Jul 2019 04:07:16 +0000 (23:07 -0500)]
Update: replace f_const with const

The typedef f_const is no longer used in place of const.

5 years agoFeature: work directory support
Kevin Day [Mon, 29 Jul 2019 04:01:42 +0000 (23:01 -0500)]
Feature: work directory support

Work Directory provides an easier way for developers to compile and test a particular set of FLL libraries and programs without conflicting with the host system.

If the host system has some version of the FLL project installed, the versions in the work directory will be used instead of the system directories.

Specifying the work directory is done via the '-w' or '--work_directory' commands.

To better achieve this functionality in the install.sh script, four new additional parameters were created:
- --libraries-static
- --libraries-shared
- --programs-static
- --programs-shared

These provide additional relative or absolute paths for installing the programs and libraries into.
The relative paths for --libraries-static and --libraries-shared is the library directory (which can be specified via --libdir).
The relative paths for --programs-static and --programs-shared is the program directory (which can be specified via --bindir).

5 years agoUpdate: version 0.5.0
Kevin Day [Mon, 29 Jul 2019 02:48:34 +0000 (21:48 -0500)]
Update: version 0.5.0

5 years agoFeature: level-1: fl_program
Kevin Day [Mon, 29 Jul 2019 02:43:47 +0000 (21:43 -0500)]
Feature: level-1: fl_program

The version function is used between all programs in this project.
Move that functionality into its own library: fl_program.

5 years agoCleanup: private firewall files do not need to be #ifdef wrapped
Kevin Day [Mon, 29 Jul 2019 01:34:08 +0000 (20:34 -0500)]
Cleanup: private firewall files do not need to be #ifdef wrapped

The #ifdef wrappers are intended for custom overrides, which should apply only to functions treated as "public".
These firewall files beginning with private- are private and do not need these wrappings.

5 years agoBugfix: install script destination parameters not being respected
Kevin Day [Sun, 28 Jul 2019 22:02:49 +0000 (17:02 -0500)]
Bugfix: install script destination parameters not being respected

I used the wrong name in the grab_next variable when designating to grab the next includedir and libdir.
There is also a mistake where I was copying the destination_prefix onto itself.

5 years agoUpdate: always return 1 on failure
Kevin Day [Sun, 28 Jul 2019 21:48:42 +0000 (16:48 -0500)]
Update: always return 1 on failure

There were some cases where exit is not being called and other cases where exit 0 is being called.
Make sure that exit 1 is called on error so that this script can then be scriptable.

5 years agoBugfix: level-specifc compile settings should compile against level-specific
Kevin Day [Sun, 28 Jul 2019 21:26:20 +0000 (16:26 -0500)]
Bugfix: level-specifc compile settings should compile against level-specific

5 years agoSecurity: set default policy to DROP after deleting chains
Kevin Day [Sat, 27 Jul 2019 21:31:09 +0000 (16:31 -0500)]
Security: set default policy to DROP after deleting chains

Performing numerous syscalls can by slow.
During this time, if the default behavior is open, then unwanted packets may make it through.
By dropping by default, these packets will not go through.

5 years agoCleanup: update to newer style practices and fix existing style problems found
Kevin Day [Sat, 27 Jul 2019 04:10:01 +0000 (23:10 -0500)]
Cleanup: update to newer style practices and fix existing style problems found

Use alphabetic whenever possible (structure context overrides this often).
Perform the initial prepatory work for new comment practices.

else end else if blocks are now to be on separate lines instead of inline with '}'.

5 years agoBugfix: type sizes autodetection is not reporting proper sizes
Kevin Day [Sat, 27 Jul 2019 00:28:45 +0000 (19:28 -0500)]
Bugfix: type sizes autodetection is not reporting proper sizes

Expected sizes are not being returned.
Rewrite the logic to get casting to the highest value to work as desired.

5 years agoCleanup: remove empty source file
Kevin Day [Fri, 26 Jul 2019 03:16:25 +0000 (22:16 -0500)]
Cleanup: remove empty source file

5 years agoCleanup: Use new comment structure at the tops of files
Kevin Day [Fri, 26 Jul 2019 03:00:43 +0000 (22:00 -0500)]
Cleanup: Use new comment structure at the tops of files

Just put the comments in the header files.
Simplify the comment stucture.
The git repository provides the authors/credits, no need to explicitly do so in the files anymore.
Do not provide the micro version, instead provide the major and minor versions in the files (which effectively represent the API version).

5 years agoRevert: remove custom type defines, including use of f_autochar
Kevin Day [Fri, 26 Jul 2019 02:31:55 +0000 (21:31 -0500)]
Revert: remove custom type defines, including use of f_autochar

The intent of these custom types is to allow for easily replacing what the type represents.
I have decided that this extent of doing such is overkill.
Revert the custom types to instead rely on the C/C++ defined types, where appropriate.

After having gained more experience with utf-8 an other unicode standards, I have come to conclude that the wchar type should not be used.
This project will support the char type instead of the wchar type.
All uses have been replaced with char.

5 years agoBugfix: bash/linux does not support setting high bits on return codes
Kevin Day [Fri, 26 Jul 2019 01:49:29 +0000 (20:49 -0500)]
Bugfix: bash/linux does not support setting high bits on return codes

These bits are generally reserved for process-specific behavior.
Explicitly return 0 for success and 1 for failure.
The firewall program already does this.

The return codes from the main functions of each project will continue to utilize all of the bits as designed.
This will allow for projects that link to the library to get the actual return codes while simultaneously being compatible with Linux and Bash.

Later versions may provide alternative ways to get the error code from within the shell.
For example, if a specific return code environment variable is set, then the program could populate that environment variable on exit (clearing it on start).

5 years agoUpdate: add basic featureless settings specifications documentation
Kevin Day [Thu, 25 Jul 2019 04:51:37 +0000 (23:51 -0500)]
Update: add basic featureless settings specifications documentation

This was originally defined online, but I had lost the data at some point.
The internet archive didn't cache the page and the data lost happened during the time I was changing the website.

The specifications were simple enough to be rewritten, but I have done so in haste.
Some of the specifications will be documented at a later date.

I do not remember what advanced reverse mapping was intended to be, so I replaced it with the custom json-like specification.
The goal of the json-like specification is to write it such that it is still valid json (minus any comments).
It is currently added to preserve the idea but there are no immediate plans to implement this specification.

5 years agoUpdate: replace advanced reverse mapping with simple json
Kevin Day [Thu, 25 Jul 2019 04:51:29 +0000 (23:51 -0500)]
Update: replace advanced reverse mapping with simple json

5 years agoCleanup: fix comments and remove commented out memset
Kevin Day [Thu, 25 Jul 2019 04:43:28 +0000 (23:43 -0500)]
Cleanup: fix comments and remove commented out memset

According to the standards that I have read, calloc() guarantees zero'd memory, so memset is not needed.
It so happens that the memset was commented out already, so just remove it.

There are some memset related comments that incorrectly use the word 'bool' when the word 'char' should be used.

5 years agoUpdate: add the firewall settings files to the 'build_sources_settings' part of the...
Kevin Day [Tue, 23 Jul 2019 04:05:18 +0000 (23:05 -0500)]
Update: add the firewall settings files to the 'build_sources_settings' part of the build settings file

5 years agoUpdate: Add additional options, fix minor problems, and other miscellaneous fixes...
Kevin Day [Tue, 23 Jul 2019 03:58:01 +0000 (22:58 -0500)]
Update: Add additional options, fix minor problems, and other  miscellaneous fixes in regards to generate.sh and package.sh scripts

Add functionality provided in install.sh, such as configure based system compatible options: --enable-statuc, --disable-static, --enable-shared, and --disable-shared.

Fix some typos (such as failire which should instead be failure).
Tweak highlight colors used.

Use a separate "operation_failure" variable instead of recycling "operation" for parameter operation problems.

Add -S/--path_s parameter option for specifying a custom settings path.

If paths have a leading slash (/), remove duplicate slashes (such as "///bin/" -> "/bin/").

Make sure the new install.sh script gets added by the package.sh script.

The variable "sources_settings" is using the wrong source path (which was "path_c").
Instead, use the newly added "path_s".

5 years agoFeature: add install.sh helper script
Kevin Day [Tue, 23 Jul 2019 03:55:51 +0000 (22:55 -0500)]
Feature: add install.sh helper script

Provide a very basic install helper script for systems (or users) that do not have or do not want to use their package system to install the compiled files.

This is only intended to help someone install.
It is still recommended that a distribution or packager should povide their own tools to perform the installation.

5 years agoCleanup: use 'FILTER' instead of 'PORTS'
Kevin Day [Tue, 23 Jul 2019 01:49:33 +0000 (20:49 -0500)]
Cleanup: use 'FILTER' instead of 'PORTS'

5 years agoCleanup: make sure 'iptables' appears in error message 'Failed to perform requested...
Kevin Day [Tue, 23 Jul 2019 01:44:26 +0000 (20:44 -0500)]
Cleanup: make sure 'iptables' appears in error message 'Failed to perform requested iptables operation'

5 years agoUpdate: f_null no longer exists
Kevin Day [Sun, 21 Jul 2019 21:32:57 +0000 (16:32 -0500)]
Update: f_null no longer exists

5 years agoUpdate: fix firewall utility and utilize recently added functionality
Kevin Day [Sun, 21 Jul 2019 21:06:13 +0000 (16:06 -0500)]
Update: fix firewall utility and utilize recently added functionality

There were a few logic flaws in regards to the processing and memory management.
Switch to new logic where f_new_* and f_clear_* is utilized.
Update accodingly to the fll_execute changes.

Update the default configuration files.

Update the debugging code to work as expected.

Replace string cuntions with memory functions, such as replacing strncat with memcpy.

Add some new helper macros.

Delete all custom chains when rewriting rules to prevent problems.
Iptables unfortunately does not provide a way to check and see if a chain already exists.

5 years agoUpdate: disable BUG_strnlen by default
Kevin Day [Sun, 21 Jul 2019 21:04:35 +0000 (16:04 -0500)]
Update: disable BUG_strnlen by default

This bug might actually be a bug related to uClibc.
Just disable it by default for now.
Future versions may remove this workaound entirely.

5 years agoCleanup: add space
Kevin Day [Sun, 21 Jul 2019 21:04:21 +0000 (16:04 -0500)]
Cleanup: add space

5 years agoUpdate: use memcpy instead of strncat
Kevin Day [Sun, 21 Jul 2019 21:03:28 +0000 (16:03 -0500)]
Update: use memcpy instead of strncat

5 years agoUpdate: add an f_standard_debug output similar to f_standard_warning
Kevin Day [Sun, 21 Jul 2019 21:03:05 +0000 (16:03 -0500)]
Update: add an f_standard_debug output similar to f_standard_warning

5 years agoUpdate: rewrite fll_execute, ensuring f_eol are properly added (and auto-add progam...
Kevin Day [Sun, 21 Jul 2019 20:59:30 +0000 (15:59 -0500)]
Update: rewrite fll_execute, ensuring f_eol are properly added (and auto-add progam name where possible)

Previously, the f_eol was added but it assumed that there was actual room at the end of the allocated buffer to do so.
This now explicilty allocates a new buffer with room for the terminating f_eol.

The progam name is already provided, so do not require it to be added to the arguments (auto-add it).

5 years agoUpdate: make sure f_new_* calls exist and add f_clear_* calls
Kevin Day [Sun, 21 Jul 2019 20:58:23 +0000 (15:58 -0500)]
Update: make sure f_new_* calls exist and add f_clear_* calls

5 years agoBugfix: string lengths now use signed integers
Kevin Day [Fri, 19 Jul 2019 04:52:03 +0000 (23:52 -0500)]
Bugfix: string lengths now use signed integers

5 years agoUpdate: relocate the shared and static build paths to before the library arguments
Kevin Day [Fri, 19 Jul 2019 04:08:30 +0000 (23:08 -0500)]
Update: relocate the shared and static build paths to before the library arguments

5 years agoBugfix: firewall show command operating as lock
Kevin Day [Fri, 19 Jul 2019 03:38:41 +0000 (22:38 -0500)]
Bugfix: firewall show command operating as lock

The debug parameters is conditionally enabled/disabled but the enum is not.
Make the enum conditionally enable/disable the debug option to prevent the wrong id from being used when debug is disabled.

Fix the alignment of the debug message.

Conditionally enable/disable displaying the debug in the help.

5 years agoBugfix: add missing closing parenthesis
Kevin Day [Fri, 19 Jul 2019 03:27:50 +0000 (22:27 -0500)]
Bugfix: add missing closing parenthesis

5 years agoBugfix: project compiled libraries are not being found
Kevin Day [Fri, 19 Jul 2019 03:12:16 +0000 (22:12 -0500)]
Bugfix: project compiled libraries are not being found

This is the result of an oversight when I converted the libraries directory to have static and shared into subdirectories.
The explicit link path was not updated accordingly.

5 years agoFeature: add package generation helper scrript
Kevin Day [Fri, 19 Jul 2019 01:14:38 +0000 (20:14 -0500)]
Feature: add package generation helper scrript

There are four intended package design modes:
1) individual - each package is separated into their own individual directory and version.
2) level - Each of the three levels (level 0, level 1, and level 2) are put into their own directory and version.
3) monolothic - All three levels (level 0, level 1, and level 2) are put into a single directory and version.

Monolithic is not currently implemented due to design limitations in the generate.sh script and build settings files.

Compression is not performed.

5 years agoCleanup: re-organize object file generation into separate directory
Kevin Day [Thu, 18 Jul 2019 03:32:29 +0000 (22:32 -0500)]
Cleanup: re-organize object file generation into separate directory

The object files should be added in an 'objects/' directory instead of in 'libraray/static/' directory.

5 years agoSecurity: use signed integers for string lengths and array lenghts by default
Kevin Day [Thu, 18 Jul 2019 01:11:17 +0000 (20:11 -0500)]
Security: use signed integers for string lengths and array lenghts by default

Standard functions, such as strnlen(), appear to operate on signed integers instead of unsigned.
Not being able to handle unsigned integers provides unknown behavior that could lead to potential security vulnerabilities.
Future versions of this project will likely need to abandon these methods for more flexible alternatives.

Example problem:
  sources/c/console.c:36:23: warning: 'strnlen' specified bound 18446744073709551615 exceeds maximum object size 9223372036854775807 [-Wstringop-overflow=]
     36 |       string_length = strnlen(argv[location], f_console_max_size);

That is 2^63 instead of the expected 2^64.

The array lengths were converted to signed as well.

5 years agoBugfix: add missing includes
Kevin Day [Wed, 17 Jul 2019 03:58:56 +0000 (22:58 -0500)]
Bugfix: add missing includes

5 years agoCleanup: add missing build_static default setting and remove duplicates
Kevin Day [Wed, 17 Jul 2019 03:23:25 +0000 (22:23 -0500)]
Cleanup: add missing build_static default setting and remove duplicates

5 years agoBugfix: variables not being stored in array
Kevin Day [Wed, 17 Jul 2019 03:07:13 +0000 (22:07 -0500)]
Bugfix: variables not being stored in array

Do not directly use string in bash array arguments.
More recent versions of bash do not handle this as expected.
Move explicit string to a variable and then use that variable to access the array.

8 years agoProgress: add the current (draft) of the custom init program
Kevin Day [Sun, 17 Jan 2016 20:29:41 +0000 (14:29 -0600)]
Progress: add the current (draft) of the custom init program

This is effectively a draft of my ideas and is entirely experimental and incomplete.
I am adding it now because of numerous hard-drive failures and data loss of late.

8 years agoUpdate: add new rules to firewall (while fixing accident in previous commit)
Kevin Day [Sun, 17 Jan 2016 20:20:56 +0000 (14:20 -0600)]
Update: add new rules to firewall (while fixing accident in previous commit)

The earlier commit that applied stale changes apparently had deleted all the rules in the firewall file.
This data has been added back in addition to the new rules and structure.

8 years agoProgress: add socket libraries
Kevin Day [Sun, 17 Jan 2016 20:20:05 +0000 (14:20 -0600)]
Progress: add socket libraries

There is likely more work to do with these libraries.
I will follow this up after reviewing with any changes, if needed.

8 years agoProgress: miscellaneous changes
Kevin Day [Sun, 17 Jan 2016 20:19:36 +0000 (14:19 -0600)]
Progress: miscellaneous changes

I was working on stuff a while back and was taken away from the project for quite a while.
These are some uncommitted changes that I would rather commit immediately and then move forward.

There are some other changes I will follow up in separate commits, such as the socket work and the init work.

9 years agoUpdate: add support for separate build_static setting 0.4.2
Kevin Day [Wed, 6 May 2015 02:10:01 +0000 (21:10 -0500)]
Update: add support for separate build_static setting

This allows for building both shared and static libraries and programs.

9 years agoUpdate: use firewall_default_allocation_step, +1 was being used and should have been...
Kevin Day [Tue, 17 Mar 2015 02:41:03 +0000 (21:41 -0500)]
Update: use firewall_default_allocation_step, +1 was being used and should have been +firewall_default_allocation_step

9 years agoUpdate: change default rules for icmp traffic and cleanup some comments
Kevin Day [Tue, 17 Mar 2015 02:26:32 +0000 (21:26 -0500)]
Update: change default rules for icmp traffic and cleanup some comments

I learned a little bit more about icmp and what is and is not deprecated.
Block certain icmp ports by default.

Shorten the file by removing unnecessary comments.

9 years agoUpdate: do not resize strings when length = 0, instead just updated used
Kevin Day [Tue, 17 Mar 2015 02:24:45 +0000 (21:24 -0500)]
Update: do not resize strings when length = 0, instead just updated used

I was working on this before I moved.
I am not sure if there is more too this that needs to be done, but for now I will push this.

9 years agoBugfix: direction option was confusing because it was mixed with chains
Kevin Day [Wed, 14 Jan 2015 10:19:01 +0000 (04:19 -0600)]
Bugfix: direction option was confusing because it was mixed with chains

- Separate direction command into two separate commands: direction, and chain.
- The chain command mimics iptables chains and is automatically populated by the custom lists (aka: custom chains).
- When direction is set to something other than none, then the active ethernet device is used.
- Code cleanup and changes were performed while working on this.
- Added basic support for debugging, define _en_firewall_debug_ to enable custom debugging parameter.

9 years agoUpdate: add debug as a standard console parameter
Kevin Day [Wed, 14 Jan 2015 10:11:21 +0000 (04:11 -0600)]
Update: add debug as a standard console parameter

9 years agoUpdate: oops! don't block unicasts by default
Kevin Day [Wed, 14 Jan 2015 04:57:48 +0000 (22:57 -0600)]
Update: oops! don't block unicasts by default

Whoops, I overlooked that unicast was the name for the normal, expected, behavior of standard point to point network connections.

9 years agoUpdate: improve the contents firewall settings files
Kevin Day [Wed, 14 Jan 2015 04:21:34 +0000 (22:21 -0600)]
Update: improve the contents firewall settings files

- Add more information to the example firewall settings.
- Improve/fix dhcp client/server rules
- Block/Blackhole unicasts, multicasts, and broadcasts.
- Add some examples rules on conntrack and some security rules.

9 years agoBugfix: reverse order of library links
Kevin Day [Fri, 9 Jan 2015 03:17:48 +0000 (21:17 -0600)]
Bugfix: reverse order of library links

It seems I got the order backwards.
I was using -lc and all the lowest level libraries on the left of the libraries that depend on it.
This caused unobvious linkage errors down the road.
Reversing the order prevented the problem and allowed for static libraries to link.

It is possible the order issue is with ar and not with gcc.

9 years agoBugfix: remove more cases where build_alt variables where still being used
Kevin Day [Fri, 9 Jan 2015 02:57:44 +0000 (20:57 -0600)]
Bugfix: remove more cases where build_alt variables where still being used

9 years agoBugfix: fix order of library linkage for firewall build settings
Kevin Day [Fri, 9 Jan 2015 00:55:55 +0000 (18:55 -0600)]
Bugfix: fix order of library linkage for firewall build settings

The ar command is sensitive to the order in which libraries are added.
Prior to this change, building a static library could have dependencies used before they are defined due to the order in which libraries were added.
Change the order so that libraries are to the right of their dependencies in the command line argument order

9 years agoBugfix: fix order of library linkage
Kevin Day [Fri, 9 Jan 2015 00:51:57 +0000 (18:51 -0600)]
Bugfix: fix order of library linkage

The ar command is sensitive to the order in which libraries are added.
Prior to this change, building a static library could have dependencies used before they are defined due to the order in which libraries were added.
Change the order so that libraries are to the right of their dependencies in the command line argument order.

9 years agoBugfix: revert compiler workaround 5bdaa0b, place arguments after source
Kevin Day [Fri, 9 Jan 2015 00:34:06 +0000 (18:34 -0600)]
Bugfix: revert compiler workaround 5bdaa0b, place arguments after source

The problem turns out to be that, for gcc at the very least, linker options such as -lc are not properly passed to the linker when it is before the source files.
Using the examples:
  1) gcc -lc main.c
  2) gcc main.c -lc

In case of #1, the -lc is not passed to the linker.
In case of #2, the -lc is passed to the linker.

All arguments are now being moved after the source parts.

see: 5bdaa0b Workaround: compilers on some systems seem to be sensitive to the order of arguments
see: http://gcc.gnu.org/onlinedocs/gcc/Link-Options.html

9 years agoUpdate: f_error changes and more signals
Kevin Day [Thu, 8 Jan 2015 03:14:41 +0000 (21:14 -0600)]
Update: f_error changes and more signals

- Added more signal commands.
- Added more signal codes for up to 64 signals.
- Replaced f_error_unmask with f_error_set_fine to be more consistent with the other f_error_set_* names.
- The signal bit is intended to be both the error and warning bit set so it is mathematically the same as the mask bit.
- Change f_none starting point to 197 to handle all possible 64 signals.

9 years agoCleanup: explicitly initialize f_false enumerator to 0.
Kevin Day [Wed, 31 Dec 2014 02:42:23 +0000 (20:42 -0600)]
Cleanup: explicitly initialize f_false enumerator to 0.

9 years agoUpdate: add signal code support to f_errors and move error code starting point to 166
Kevin Day [Wed, 31 Dec 2014 02:37:46 +0000 (20:37 -0600)]
Update: add signal code support to f_errors and move error code starting point to 166

Signals are used as the high order bits in a process that exits, which is where I provide error and similar return codes.
For this reason I am adding wrappers to the x86 signal codes in f_errors instead of a separate custom project such as the non-existant f_signals.

It looks like bash mixes the exit codes and signals into the numbers 129 to 165, so start with 166 as well.

9 years agoUpdate: uncomment pipe detection code in return_code and fss_return_code
Kevin Day [Wed, 31 Dec 2014 01:57:34 +0000 (19:57 -0600)]
Update: uncomment pipe detection code in return_code and fss_return_code

Not sure why this was disabled, perhaps it was not implemented?
At least, enable the variable.

10 years agoFeature: add support for -p, --project in generate.sh
Kevin Day [Thu, 16 Oct 2014 04:23:11 +0000 (23:23 -0500)]
Feature: add support for -p, --project in generate.sh

This adds support for defining a custom name for the use of preparing and building a project.
The files will be called .built-$project and .prepare-$project.
This allows for building multiple projects in the same directory path back to back.

10 years agoCleanup: remove unused parameter 'settings_path'
Kevin Day [Wed, 15 Oct 2014 23:26:30 +0000 (18:26 -0500)]
Cleanup: remove unused parameter 'settings_path'

10 years agoUpdate: add level's 0, 1, and 2 settings file to build a single library per level
Kevin Day [Wed, 15 Oct 2014 05:16:31 +0000 (00:16 -0500)]
Update: add level's 0, 1, and 2 settings file to build a single library per level

10 years agoUpdate: define f_extern as extern
Kevin Day [Wed, 15 Oct 2014 05:13:51 +0000 (00:13 -0500)]
Update: define f_extern as extern

This should allow for mass changing or mass removing f_extern via a simple custom #define or a command line parameter such as -Df_extern= .

10 years agoFeature: add support for defining the linker program via build_linker= setting
Kevin Day [Thu, 9 Oct 2014 03:15:01 +0000 (22:15 -0500)]
Feature: add support for defining the linker program via build_linker= setting

10 years agoBugfix: fix missing dependencies
Kevin Day [Fri, 8 Aug 2014 03:51:55 +0000 (22:51 -0500)]
Bugfix: fix missing dependencies

10 years agoCleanup: correct the documentation on the file's level
Kevin Day [Fri, 8 Aug 2014 01:21:33 +0000 (20:21 -0500)]
Cleanup: correct the documentation on the file's level

10 years agoBugfix: add missing required library link dependencies
Kevin Day [Fri, 8 Aug 2014 00:55:00 +0000 (19:55 -0500)]
Bugfix: add missing required library link dependencies

It seems I got away with forgetting some important libraries that were required by some libraries.
This makes me wonder if this is the cause of the bug that forced me to create the build_alt option.