Skip to content

Commit

Permalink
Use dedicated gdformatrc file for gdformat.
Browse files Browse the repository at this point in the history
  • Loading branch information
chrisl8 committed Mar 8, 2024
1 parent ab3fed7 commit e0047f4
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 4 deletions.
7 changes: 7 additions & 0 deletions gdtoolkit/formatter/__init__.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
from typing import Optional

from types import MappingProxyType
from lark import Tree

from ..parser import parser
Expand All @@ -11,6 +12,12 @@
LoosenTreeTransformer,
)

DEFAULT_CONFIG = MappingProxyType(
{
"excluded_directories": {".git"},
}
)


# pylint: disable-next=too-many-arguments
def check_formatting_safety(
Expand Down
30 changes: 26 additions & 4 deletions gdtoolkit/formatter/__main__.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
Usage:
gdformat <path>... [options]
gdformat --dump-default-config
Options:
-c --check Don't write the files back,
Expand All @@ -19,6 +20,7 @@
-s --use-spaces=<int> Use spaces for indent instead of tabs.
-h --help Show this screen.
--version Show version.
--dump-default-config Dump default config to 'gdformatrc' file.
Examples:
echo 'pass' | gdformat - # reads from STDIN
Expand All @@ -36,7 +38,7 @@
import lark
import yaml

from gdtoolkit.formatter import format_code, check_formatting_safety
from gdtoolkit.formatter import format_code, check_formatting_safety, DEFAULT_CONFIG
from gdtoolkit.formatter.exceptions import (
TreeInvariantViolation,
FormattingStabilityViolation,
Expand All @@ -48,9 +50,8 @@
lark_unexpected_token_to_str,
lark_unexpected_input_to_str,
)
from gdtoolkit.linter import DEFAULT_CONFIG

CONFIG_FILE_NAME = "gdlintrc"
CONFIG_FILE_NAME = "gdformatrc"


def main():
Expand All @@ -62,6 +63,9 @@ def main():
),
)

if arguments["--dump-default-config"]:
_dump_default_config()

if arguments["--diff"]:
arguments["--check"] = True

Expand All @@ -76,6 +80,7 @@ def main():
config_file_path = _find_config_file()
config = _load_config_file_or_default(config_file_path)
_log_config_entries(config)
_update_config_with_missing_entries_inplace(config)

files: List[str] = find_gd_files_from_paths(
arguments["<path>"], excluded_directories=set(config["excluded_directories"])
Expand All @@ -91,6 +96,14 @@ def main():
_format_files(files, line_length, spaces_for_indent, safety_checks)


def _dump_default_config() -> None:
# TODO: error handling
assert not os.path.isfile(CONFIG_FILE_NAME)
with open(CONFIG_FILE_NAME, "w", encoding="utf-8") as handle:
handle.write(yaml.dump(DEFAULT_CONFIG.copy()))
sys.exit(0)


def _find_config_file() -> Optional[str]:
search_dir = pathlib.Path(os.getcwd())
config_file_path = None
Expand All @@ -114,7 +127,7 @@ def _load_config_file_or_default(config_file_path: Optional[str]) -> MappingProx
with open(config_file_path, "r", encoding="utf-8") as handle:
return yaml.load(handle.read(), Loader=yaml.Loader)

logging.info("""No 'gdlintrc' nor '.gdlintrc' found. Using default config...""")
logging.info("""No 'gdformatrc' nor '.gdformatrc' found. Using default config...""")
return DEFAULT_CONFIG


Expand All @@ -124,6 +137,15 @@ def _log_config_entries(config: MappingProxyType) -> None:
logging.info(entry)


def _update_config_with_missing_entries_inplace(config: dict) -> None:
for key in DEFAULT_CONFIG:
if key not in config:
logging.info(
"Adding missing entry from defaults: %s", (key, DEFAULT_CONFIG[key])
)
config[key] = DEFAULT_CONFIG[key]


def _format_stdin(
line_length: int, spaces_for_indent: Optional[int], safety_checks: bool
) -> None:
Expand Down

0 comments on commit e0047f4

Please sign in to comment.