Skip to content

Commit

Permalink
use abstract
Browse files Browse the repository at this point in the history
  • Loading branch information
clavedeluna committed Oct 25, 2023
1 parent 01e311b commit 1cb5118
Show file tree
Hide file tree
Showing 5 changed files with 22 additions and 15 deletions.
13 changes: 10 additions & 3 deletions src/codemodder/project_analysis/file_parsers/base_parser.py
Original file line number Diff line number Diff line change
@@ -1,13 +1,19 @@
from abc import ABC, abstractmethod, abstractproperty

from pathlib import Path
from typing import List
from .package_store import PackageStore
from packaging.requirements import Requirement


class BaseParser:
class BaseParser(ABC):
def __init__(self, parent_directory: Path):
self.parent_directory = parent_directory
self.file_name: str = ""

@property
@abstractmethod
def file_name(self):
...

Check warning on line 16 in src/codemodder/project_analysis/file_parsers/base_parser.py

View check run for this annotation

Codecov / codecov/patch

src/codemodder/project_analysis/file_parsers/base_parser.py#L16

Added line #L16 was not covered by tests

def _parse_dependencies(self, lines: List[str]):
return [
Expand All @@ -17,8 +23,9 @@ def _parse_dependencies(self, lines: List[str]):
if (line := x.strip()) and not line.startswith("#")
]

@abstractmethod
def _parse_file(self, file: Path):
raise NotImplementedError
...

Check warning on line 28 in src/codemodder/project_analysis/file_parsers/base_parser.py

View check run for this annotation

Codecov / codecov/patch

src/codemodder/project_analysis/file_parsers/base_parser.py#L28

Added line #L28 was not covered by tests

def find_file_locations(self) -> List[Path]:
return list(Path(self.parent_directory).rglob(self.file_name))
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,9 @@


class PyprojectTomlParser(BaseParser):
def __init__(self, parent_directory: Path):
super().__init__(parent_directory)
self.file_name = "pyproject.toml"
@property
def file_name(self):
return "pyproject.toml"

def _parse_dependencies_from_toml(self, toml_data: dict):
# todo: handle cases for
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,9 @@


class RequirementsTxtParser(BaseParser):
def __init__(self, parent_directory: Path):
super().__init__(parent_directory)
self.file_name = "requirements.txt"
@property
def file_name(self):
return "requirements.txt"

def _parse_file(self, file: Path):
with open(file, "r", encoding="utf-8") as f:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,9 @@


class SetupCfgParser(BaseParser):
def __init__(self, parent_directory: Path):
super().__init__(parent_directory)
self.file_name = "setup.cfg"
@property
def file_name(self):
return "setup.cfg"

def _parse_dependencies_from_toml(self, config: configparser.ConfigParser):
# todo: handle cases for
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,9 @@


class SetupPyParser(BaseParser):
def __init__(self, parent_directory: Path):
super().__init__(parent_directory)
self.file_name = "setup.py"
@property
def file_name(self):
return "setup.py"

def _parse_dependencies(self, cst_dependencies):
return [
Expand Down

0 comments on commit 1cb5118

Please sign in to comment.