From d15cf2c97ecafa34217875173f41fa1598ff9961 Mon Sep 17 00:00:00 2001 From: Michael Eliachevitch Date: Tue, 9 Feb 2021 01:47:39 +0100 Subject: [PATCH 1/3] Fix formatting in documentation until no sphinx warnings --- b2luigi/core/task.py | 55 ++++++++++++++++++++++---------------------- 1 file changed, 28 insertions(+), 27 deletions(-) diff --git a/b2luigi/core/task.py b/b2luigi/core/task.py index 590d044d..fe93127f 100644 --- a/b2luigi/core/task.py +++ b/b2luigi/core/task.py @@ -44,7 +44,7 @@ def add_to_output(self, output_file_name): Always use in combination with `yield`. This function will automatically add all current parameter values to the file name when used in the form - + result_dir/param_1=value/param_2=value/output_file_name This function will automatically use a ``LocalTarget``. @@ -93,39 +93,40 @@ def get_input_file_names(self, key=None): """ return self._transform_input(self.input(), key) - def get_input_file_names_from_dict(self, requirement_key, key=None): """ Get a dictionary of input file names of the tasks, which are defined in our requirements. + The requirement method should return a dict whose values are generator expressions (!) yielding required task objects. Example: - - class TaskB(luigi.Task): - - def requires(self): - return { - "a": (TaskA(5.0, i) for i in range(100)), - "b": (TaskA(1.0, i) for i in range(100)), - } - - def run(self): - result_a = do_something_with_a( - self.get_input_file_names_from_dict("a") - ) - result_b = do_something_with_b( - self.get_input_file_names_from_dict("b") - ) - - combine_a_and_b( - result_a, - result_b, - self.get_output_file_name("combined_results.txt") - ) - - def output(self): - yield self.add_to_output("combined_results.txt") + .. code-block:: python + + class TaskB(luigi.Task): + + def requires(self): + return { + "a": (TaskA(5.0, i) for i in range(100)), + "b": (TaskA(1.0, i) for i in range(100)), + } + + def run(self): + result_a = do_something_with_a( + self.get_input_file_names_from_dict("a") + ) + result_b = do_something_with_b( + self.get_input_file_names_from_dict("b") + ) + + combine_a_and_b( + result_a, + result_b, + self.get_output_file_name("combined_results.txt") + ) + + def output(self): + yield self.add_to_output("combined_results.txt") Either use the key argument or dictionary indexing with the key given to :obj:`add_to_output` From 9f900f509c0320391e588db92bc7d04572bbdada Mon Sep 17 00:00:00 2001 From: Michael Eliachevitch Date: Tue, 9 Feb 2021 13:46:59 +0100 Subject: [PATCH 2/3] Fix broken code formatting in example The code formatting for the example in the docs for ``get_input_file_names_from_dict()`` was broken, so I fixed that, by adding an additional code-block environment. Also I changed one other example for consistency, so that the text "Example" is now the key/label of an RST definition list. --- b2luigi/core/task.py | 43 ++++++++++++++++++++++--------------------- 1 file changed, 22 insertions(+), 21 deletions(-) diff --git a/b2luigi/core/task.py b/b2luigi/core/task.py index fe93127f..0fe68f41 100644 --- a/b2luigi/core/task.py +++ b/b2luigi/core/task.py @@ -12,29 +12,30 @@ class Task(luigi.Task): the parameters of the task. See :ref:`quick-start-label` on information on how to use the methods. - Example:: + Example: + .. code-block:: python - class MyAverageTask(b2luigi.Task): - def requires(self): - for i in range(100): - yield self.clone(MyNumberTask, some_parameter=i) + class MyAverageTask(b2luigi.Task): + def requires(self): + for i in range(100): + yield self.clone(MyNumberTask, some_parameter=i) - def output(self): - yield self.add_to_output("average.txt") + def output(self): + yield self.add_to_output("average.txt") - def run(self): - # Build the mean - summed_numbers = 0 - counter = 0 - for input_file in self.get_input_file_names("output_file.txt"): - with open(input_file, "r") as f: - summed_numbers += float(f.read()) - counter += 1 + def run(self): + # Build the mean + summed_numbers = 0 + counter = 0 + for input_file in self.get_input_file_names("output_file.txt"): + with open(input_file, "r") as f: + summed_numbers += float(f.read()) + counter += 1 - average = summed_numbers / counter + average = summed_numbers / counter - with self.get_output_file("average.txt").open("w") as f: - f.write(f"{average}\\n") + with self.get_output_file("average.txt").open("w") as f: + f.write(f"{average}\\n") """ def add_to_output(self, output_file_name): @@ -42,7 +43,7 @@ def add_to_output(self, output_file_name): Call this in your output() function to add a target to the list of files, this task will output. Always use in combination with `yield`. - This function will automatically add all current parameter values to + This function will automatically add all current parameter values to the file name when used in the form result_dir/param_1=value/param_2=value/output_file_name @@ -129,8 +130,8 @@ def output(self): yield self.add_to_output("combined_results.txt") - Either use the key argument or dictionary indexing with the key given to :obj:`add_to_output` - to get back a list (!) of file paths. + Either use the key argument or dictionary indexing with the key given to :obj:`add_to_output` + to get back a list (!) of file paths. Args: requirement_key (:obj:`str`): Specifies the required task expression. From c50c182c2dc460e13cbf2cb0d06312a44395409c Mon Sep 17 00:00:00 2001 From: Michael Eliachevitch Date: Tue, 9 Feb 2021 14:23:30 +0100 Subject: [PATCH 3/3] Add empty newline for rst literal block Otherwise, sphinx formats everything right but gives a warning. Also, my edtior added a newline at the end of basf2_helper.rst. --- b2luigi/batch/processes/gbasf2.py | 1 + docs/documentation/b2luigi.basf2_helper.rst | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/b2luigi/batch/processes/gbasf2.py b/b2luigi/batch/processes/gbasf2.py index 6489ee89..80340bde 100644 --- a/b2luigi/batch/processes/gbasf2.py +++ b/b2luigi/batch/processes/gbasf2.py @@ -80,6 +80,7 @@ class Gbasf2Process(BatchProcess): ``B_ntuple.root``), but a collection of root files, one for each file in the input data set, in a directory with the base name of the root files, e.g.:: + ├── B_ntuple.root │   └── B_ntuple_0.root diff --git a/docs/documentation/b2luigi.basf2_helper.rst b/docs/documentation/b2luigi.basf2_helper.rst index 05615882..27b1369a 100644 --- a/docs/documentation/b2luigi.basf2_helper.rst +++ b/docs/documentation/b2luigi.basf2_helper.rst @@ -31,4 +31,4 @@ b2luigi.basf2\_helper.utils module .. automodule:: b2luigi.basf2_helper.utils :members: :undoc-members: - :show-inheritance: \ No newline at end of file + :show-inheritance: