2014-01-18 00:58:08 +00:00
|
|
|
{% extends "basebuilddetailpage.html" %}
|
|
|
|
|
|
|
|
{% load projecttags %}
|
2013-10-11 12:46:23 +00:00
|
|
|
|
2015-10-28 14:22:05 +00:00
|
|
|
{% block title %} {{object.name}}_{{object.version}} - {{build.target_set.all|dictsort:"target"|join:", "}} {{build.machine}} - {{build.project.name}} - Toaster {% endblock %}
|
2013-12-11 16:42:34 +00:00
|
|
|
{% block localbreadcrumb %}
|
2014-01-18 00:58:08 +00:00
|
|
|
<li><a href="{% url 'recipes' build.pk %}">Recipes</a></li>
|
|
|
|
<li>{{object.name}}_{{object.version}} </li>
|
2013-10-11 12:46:23 +00:00
|
|
|
{% endblock %}
|
|
|
|
|
2014-01-18 00:58:08 +00:00
|
|
|
{% block pagedetailinfomain %}
|
|
|
|
|
|
|
|
<!-- Begin container -->
|
|
|
|
|
2016-04-12 14:56:43 +00:00
|
|
|
<div class="row">
|
|
|
|
<div class="col-md-12">
|
2016-06-02 13:26:16 +00:00
|
|
|
<div class="page-header build-data">
|
2014-01-18 00:58:08 +00:00
|
|
|
<h1>{{object.name}}_{{object.version}}</h1>
|
|
|
|
</div>
|
2016-04-12 14:56:43 +00:00
|
|
|
</div>
|
2014-01-18 00:58:08 +00:00
|
|
|
</div>
|
|
|
|
|
2016-04-12 14:56:43 +00:00
|
|
|
<div class="row">
|
|
|
|
<div class="col-md-8 tabbable">
|
2016-06-02 13:26:16 +00:00
|
|
|
<ul class="nav nav-tabs">
|
bitbake: toaster: add sort, search, paging to recipe package page
When selecting the packages tab on a recipe detail page, the page now
includes:
column sort on package name and size columns,
search on the package name, and
pagination.
Column sort is added by splitting the recipe view/html for a recipe's
package list into a new url path, view name and template, so that
the sorting routine, views.reload_params(), interfaces similar to other
views.
Search, sorting, and pagination are implemented for this detail page
using three new templates.
templates/detail_pagination_bottom.html
templates/detail_search_header.html
templates/detail_sorted_header.html
views.recipe() is optimized since the recipe's package list is no
longer needed by the recipe template, only the recipe's package count
is required for the first page.
The recipe view and template also changes to support tabbing to the
right context on the recipe detail page from the recipe-package page.
[YOCTO #6154]
(Bitbake rev: 6cb9e853d05c2c71467af22ef459ffbe6f41de36)
Signed-off-by: Dave Lerner <dave.lerner@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2015-02-24 22:14:41 +00:00
|
|
|
<li class="{{tab_states.1}}">
|
2014-01-18 00:58:08 +00:00
|
|
|
<a href="#information" data-toggle="tab">
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="Build-related
|
|
|
|
information about the recipe"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
Recipe details
|
|
|
|
</a>
|
|
|
|
</li>
|
|
|
|
<li>
|
bitbake: toaster: add sort, search, paging to recipe package page
When selecting the packages tab on a recipe detail page, the page now
includes:
column sort on package name and size columns,
search on the package name, and
pagination.
Column sort is added by splitting the recipe view/html for a recipe's
package list into a new url path, view name and template, so that
the sorting routine, views.reload_params(), interfaces similar to other
views.
Search, sorting, and pagination are implemented for this detail page
using three new templates.
templates/detail_pagination_bottom.html
templates/detail_search_header.html
templates/detail_sorted_header.html
views.recipe() is optimized since the recipe's package list is no
longer needed by the recipe template, only the recipe's package count
is required for the first page.
The recipe view and template also changes to support tabbing to the
right context on the recipe detail page from the recipe-package page.
[YOCTO #6154]
(Bitbake rev: 6cb9e853d05c2c71467af22ef459ffbe6f41de36)
Signed-off-by: Dave Lerner <dave.lerner@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2015-02-24 22:14:41 +00:00
|
|
|
<a href="{% url "recipe_packages" build.pk object.id %}">
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="The packaged
|
|
|
|
output resulting from building the recipe"></span>
|
bitbake: toaster: add sort, search, paging to recipe package page
When selecting the packages tab on a recipe detail page, the page now
includes:
column sort on package name and size columns,
search on the package name, and
pagination.
Column sort is added by splitting the recipe view/html for a recipe's
package list into a new url path, view name and template, so that
the sorting routine, views.reload_params(), interfaces similar to other
views.
Search, sorting, and pagination are implemented for this detail page
using three new templates.
templates/detail_pagination_bottom.html
templates/detail_search_header.html
templates/detail_sorted_header.html
views.recipe() is optimized since the recipe's package list is no
longer needed by the recipe template, only the recipe's package count
is required for the first page.
The recipe view and template also changes to support tabbing to the
right context on the recipe detail page from the recipe-package page.
[YOCTO #6154]
(Bitbake rev: 6cb9e853d05c2c71467af22ef459ffbe6f41de36)
Signed-off-by: Dave Lerner <dave.lerner@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2015-02-24 22:14:41 +00:00
|
|
|
Packages ({{package_count}})
|
2014-01-18 00:58:08 +00:00
|
|
|
</a>
|
|
|
|
</li>
|
bitbake: toaster: add sort, search, paging to recipe package page
When selecting the packages tab on a recipe detail page, the page now
includes:
column sort on package name and size columns,
search on the package name, and
pagination.
Column sort is added by splitting the recipe view/html for a recipe's
package list into a new url path, view name and template, so that
the sorting routine, views.reload_params(), interfaces similar to other
views.
Search, sorting, and pagination are implemented for this detail page
using three new templates.
templates/detail_pagination_bottom.html
templates/detail_search_header.html
templates/detail_sorted_header.html
views.recipe() is optimized since the recipe's package list is no
longer needed by the recipe template, only the recipe's package count
is required for the first page.
The recipe view and template also changes to support tabbing to the
right context on the recipe detail page from the recipe-package page.
[YOCTO #6154]
(Bitbake rev: 6cb9e853d05c2c71467af22ef459ffbe6f41de36)
Signed-off-by: Dave Lerner <dave.lerner@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2015-02-24 22:14:41 +00:00
|
|
|
<li class="{{tab_states.3}}">
|
2014-01-18 00:58:08 +00:00
|
|
|
<a href="#dependencies" data-toggle="tab">
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="The recipe
|
|
|
|
build-time dependencies (i.e. other recipes)"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
Build dependencies ({{object.r_dependencies_recipe.all.count}})
|
|
|
|
</a>
|
|
|
|
</li>
|
bitbake: toaster: add sort, search, paging to recipe package page
When selecting the packages tab on a recipe detail page, the page now
includes:
column sort on package name and size columns,
search on the package name, and
pagination.
Column sort is added by splitting the recipe view/html for a recipe's
package list into a new url path, view name and template, so that
the sorting routine, views.reload_params(), interfaces similar to other
views.
Search, sorting, and pagination are implemented for this detail page
using three new templates.
templates/detail_pagination_bottom.html
templates/detail_search_header.html
templates/detail_sorted_header.html
views.recipe() is optimized since the recipe's package list is no
longer needed by the recipe template, only the recipe's package count
is required for the first page.
The recipe view and template also changes to support tabbing to the
right context on the recipe detail page from the recipe-package page.
[YOCTO #6154]
(Bitbake rev: 6cb9e853d05c2c71467af22ef459ffbe6f41de36)
Signed-off-by: Dave Lerner <dave.lerner@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2015-02-24 22:14:41 +00:00
|
|
|
<li class="{{tab_states.4}}">
|
2014-01-18 00:58:08 +00:00
|
|
|
<a href="#brought-in-by" data-toggle="tab">
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="The recipe
|
|
|
|
build-time reverse dependencies (i.e. the recipes that
|
|
|
|
depend on this recipe)"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
Reverse build dependencies ({{object.r_dependencies_depends.all.count}})
|
|
|
|
</a>
|
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
<div class="tab-content">
|
2015-05-11 17:58:25 +00:00
|
|
|
<div class="tab-pane {{tab_states.1}}" id="information">
|
2014-01-18 00:58:08 +00:00
|
|
|
<dl class="dl-horizontal">
|
|
|
|
<dt>
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="The name of
|
|
|
|
the layer providing the recipe"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
Layer
|
|
|
|
</dt>
|
|
|
|
<dd>{{layer.name}}</dd>
|
2014-12-05 15:19:55 +00:00
|
|
|
|
2014-01-18 00:58:08 +00:00
|
|
|
<dt>
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="Path to the
|
|
|
|
recipe .bb file"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
Recipe file
|
|
|
|
</dt>
|
2015-05-14 15:10:50 +00:00
|
|
|
<dd><code>{{object.file_path}} {% if object.pathflags %}<i>({{object.pathflags}})</i>{% endif %}</code></dd>
|
2014-01-18 00:58:08 +00:00
|
|
|
<dt>
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help"
|
|
|
|
title="The Git branch of the layer providing the
|
|
|
|
recipe"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
Layer branch
|
|
|
|
</dt>
|
2016-07-29 10:42:30 +00:00
|
|
|
{% if layer_version.layer.local_source_dir %}
|
|
|
|
<dd>
|
|
|
|
<span class="text-muted">Not applicable</span>
|
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="The source
|
|
|
|
code of {{layer_version.layer.name}} is not in a git repository
|
|
|
|
so there is no branch associated with it"></span>
|
|
|
|
</dd>
|
|
|
|
{% else %}
|
2014-01-18 00:58:08 +00:00
|
|
|
<dd>{{layer_version.branch}}</dd>
|
2016-07-29 10:42:30 +00:00
|
|
|
{% endif %}
|
2014-01-18 00:58:08 +00:00
|
|
|
<dt>
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="The Git
|
|
|
|
commit of the layer providing the recipe"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
Layer commit
|
|
|
|
</dt>
|
2016-07-29 10:42:30 +00:00
|
|
|
{% if layer_version.layer.local_source_dir %}
|
|
|
|
<dd>
|
|
|
|
<span class="text-muted">Not applicable</span>
|
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="The source
|
|
|
|
code of {{layer_version.layer.name}} is not in a git repository
|
|
|
|
so there is no commit associated with it"></span>
|
|
|
|
</dd>
|
|
|
|
{% else %}
|
2014-01-18 00:58:08 +00:00
|
|
|
<dd class="iscommit">{{layer_version.commit}}</dd>
|
2016-07-29 10:42:30 +00:00
|
|
|
{% endif %}
|
2016-01-08 11:17:20 +00:00
|
|
|
{% if object.provides_set.all %}
|
|
|
|
<dt>
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help"
|
2016-01-08 11:17:20 +00:00
|
|
|
title="A list of aliases by which a particular recipe can be known. The additional aliases are
|
|
|
|
synonyms for the recipe and can be useful satisfying dependencies of other recipes during
|
2016-06-02 13:26:16 +00:00
|
|
|
the build"></span>
|
2016-01-08 11:17:20 +00:00
|
|
|
PROVIDES
|
|
|
|
</dt>
|
|
|
|
<dd><code>{% for provider in object.provides_set.all %}{{ provider.name }} {% endfor %}</code></dd>
|
|
|
|
{% endif %}
|
2014-01-18 00:58:08 +00:00
|
|
|
</dl>
|
|
|
|
|
|
|
|
<h2 class="details">Tasks</h2>
|
|
|
|
{% if not tasks %}
|
|
|
|
<div class="alert alert-info">
|
|
|
|
<strong>{{object.name}}_{{object.version}}</strong> does not have any tasks in this build.
|
|
|
|
</div>
|
|
|
|
{% else %}
|
2016-06-02 13:26:16 +00:00
|
|
|
<div class="table-responsive">
|
2014-01-18 00:58:08 +00:00
|
|
|
<table class="table table-bordered table-hover">
|
|
|
|
<thead>
|
2016-06-02 13:26:16 +00:00
|
|
|
<tr>
|
2014-01-18 00:58:08 +00:00
|
|
|
<th>
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign
|
|
|
|
get-help" title="The running sequence of each task
|
|
|
|
in the build"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
Order
|
|
|
|
</th>
|
|
|
|
<th>
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="The name
|
|
|
|
of the task"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
Task
|
|
|
|
</th>
|
|
|
|
<th>
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="This
|
|
|
|
value tells you if a task had to run (executed) in
|
|
|
|
order to generate the task output, or if the output was
|
|
|
|
provided by another task and therefore the task didn't need
|
|
|
|
to run (not executed)"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
Executed
|
|
|
|
</th>
|
|
|
|
<th>
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="This
|
|
|
|
column tells you if 'executed' tasks succeeded or
|
|
|
|
failed. The column also tells you why 'not executed'
|
|
|
|
tasks did not need to run"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
Outcome
|
|
|
|
</th>
|
|
|
|
<th>
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="This
|
|
|
|
column tells you if a task tried to restore output
|
|
|
|
from the <code>sstate-cache</code> directory or
|
|
|
|
mirrors, and reports the result: Succeeded, Failed or File
|
|
|
|
not in cache"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
Cache attempt
|
|
|
|
</th>
|
2016-06-02 13:26:16 +00:00
|
|
|
</tr>
|
2014-01-18 00:58:08 +00:00
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
|
|
|
|
{% for task in tasks %}
|
|
|
|
|
|
|
|
<tr {{ task|task_color }} >
|
|
|
|
|
2016-06-02 13:26:16 +00:00
|
|
|
<td>{{task.order}}</td>
|
2014-01-18 00:58:08 +00:00
|
|
|
<td>
|
2016-06-02 13:26:16 +00:00
|
|
|
<a href="{% url "task" build.pk task.pk %}">{{task.task_name}}</a>
|
|
|
|
{% if task.get_description %}<span class="glyphicon
|
|
|
|
glyphicon-question-sign get-help hover-help"
|
|
|
|
title="{{task.get_description}}"></span>
|
|
|
|
{% endif %}
|
2014-01-18 00:58:08 +00:00
|
|
|
</td>
|
|
|
|
|
2016-06-02 13:26:16 +00:00
|
|
|
<td>{{task.get_executed_display}}</td>
|
2014-01-18 00:58:08 +00:00
|
|
|
|
2016-06-02 13:26:16 +00:00
|
|
|
<td>{{task.get_outcome_display}}
|
2015-06-17 16:30:34 +00:00
|
|
|
{% if task.outcome = task.OUTCOME_FAILED %}
|
2015-02-09 11:48:39 +00:00
|
|
|
<a href="{% url 'build_artifact' build.pk "tasklogfile" task.pk %}">
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-download-alt
|
|
|
|
get-help" title="Download task log
|
|
|
|
file"></span>
|
2015-02-09 11:48:39 +00:00
|
|
|
</a>
|
|
|
|
{% endif %}
|
2014-03-15 17:04:50 +00:00
|
|
|
<i class="icon-question-sign get-help hover-help" title="{{task.get_outcome_help}}"></i>
|
|
|
|
</td>
|
2014-01-18 00:58:08 +00:00
|
|
|
<td>
|
|
|
|
{% ifnotequal task.sstate_result task.SSTATE_NA %}
|
2016-06-02 13:26:16 +00:00
|
|
|
{{task.get_sstate_result_display}}
|
2014-01-18 00:58:08 +00:00
|
|
|
{% endifnotequal %}
|
|
|
|
</td>
|
|
|
|
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
{% endfor %}
|
|
|
|
</tbody>
|
|
|
|
</table>
|
2016-06-02 13:26:16 +00:00
|
|
|
</div>
|
2014-01-18 00:58:08 +00:00
|
|
|
{% endif %}
|
|
|
|
</div>
|
2015-05-11 17:58:25 +00:00
|
|
|
<div class="tab-pane {{tab_states.3}}" id="dependencies">
|
2014-01-18 00:58:08 +00:00
|
|
|
|
|
|
|
{% if not object.r_dependencies_recipe.all %}
|
|
|
|
<div class="alert alert-info">
|
|
|
|
<strong>{{object.name}}_{{object.version}}</strong> has no build dependencies.
|
|
|
|
</div>
|
|
|
|
{% else %}
|
|
|
|
<table class="table table-bordered table-hover">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>
|
|
|
|
Recipe
|
|
|
|
</th>
|
|
|
|
<th>
|
|
|
|
Version
|
|
|
|
</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
|
2014-02-19 10:35:27 +00:00
|
|
|
{% for rr in object.r_dependencies_recipe.all|dictsort:"depends_on.name" %}
|
2014-01-18 00:58:08 +00:00
|
|
|
<tr>
|
2016-01-08 11:17:21 +00:00
|
|
|
<td><a href="{% url "recipe" build.pk rr.depends_on.pk %}">{{rr.depends_on.name}}</a>
|
|
|
|
{% if rr.via %}
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="text-muted">satisfied via <code class="text-muted">{{rr.via.name}}</code></span>
|
|
|
|
<span class="glyphicon glyphicon-question-sign get-help hover-help"
|
2016-01-08 11:17:21 +00:00
|
|
|
title="This dependency is satisfied by the PROVIDES value
|
2016-06-02 13:26:16 +00:00
|
|
|
<code>{{rr.via.name}}</code> in the <code>{{rr.depends_on.name}}</code> recipe"></span>
|
2016-01-08 11:17:21 +00:00
|
|
|
{% endif %}
|
|
|
|
</td>
|
2016-06-02 13:26:16 +00:00
|
|
|
<td>{{rr.depends_on.version}}</td>
|
2014-01-18 00:58:08 +00:00
|
|
|
</tr>
|
|
|
|
{% endfor %}
|
|
|
|
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
{% endif %}
|
2013-10-11 12:46:23 +00:00
|
|
|
|
2014-01-18 00:58:08 +00:00
|
|
|
</div>
|
2015-05-11 17:58:25 +00:00
|
|
|
<div class="tab-pane {{tab_states.4}}" id="brought-in-by">
|
2014-01-18 00:58:08 +00:00
|
|
|
|
|
|
|
{% if not object.r_dependencies_depends.all %}
|
|
|
|
<div class="alert alert-info">
|
|
|
|
<strong>{{object.name}}_{{object.version}}</strong> has no reverse build dependencies.
|
|
|
|
</div>
|
|
|
|
{% else %}
|
|
|
|
<table class="table table-bordered table-hover">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>
|
|
|
|
Recipe
|
|
|
|
</th>
|
|
|
|
<th>
|
|
|
|
Version
|
|
|
|
</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
|
2014-02-19 10:35:27 +00:00
|
|
|
{% for rr in object.r_dependencies_depends.all|dictsort:"recipe.name" %}
|
2014-01-18 00:58:08 +00:00
|
|
|
<tr>
|
2016-01-08 11:17:22 +00:00
|
|
|
<td><a href="{% url "recipe" build.pk rr.recipe.pk %}">{{rr.recipe.name}}</a>
|
|
|
|
{% if rr.via %}
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="text-muted"> satisfied via <code class="text-muted">{{rr.via.name}}</code></span>
|
|
|
|
<span class="glyphicon glyphicon-question-sign get-help hover-help"
|
2016-01-08 11:17:22 +00:00
|
|
|
title="This dependency is satisfied by the PROVIDES value
|
2016-06-02 13:26:16 +00:00
|
|
|
<code>{{rr.via.name}}</code> in the <code>{{rr.depends_on.name}}</code> recipe"></i>
|
2016-01-08 11:17:22 +00:00
|
|
|
{% endif %}
|
|
|
|
</td>
|
2016-06-02 13:26:16 +00:00
|
|
|
<td>{{rr.recipe.version}}</td>
|
2014-01-18 00:58:08 +00:00
|
|
|
</tr>
|
|
|
|
{% endfor %}
|
|
|
|
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2013-10-11 12:46:23 +00:00
|
|
|
|
2016-04-12 14:56:43 +00:00
|
|
|
<div class="col-md-4">
|
|
|
|
<div class="well">
|
2014-01-18 00:58:08 +00:00
|
|
|
<h2>About {{object.name}}</h2>
|
2015-01-14 17:27:00 +00:00
|
|
|
<dl class="item-info">
|
2014-01-18 00:58:08 +00:00
|
|
|
{% if object.summary %}
|
|
|
|
<dt>Summary</dt>
|
2015-01-14 17:27:00 +00:00
|
|
|
<dd>{{object.summary}}</dd>
|
2014-01-18 00:58:08 +00:00
|
|
|
{% endif %}
|
|
|
|
{% if object.description %}
|
|
|
|
<dt>Description</dt>
|
2015-01-14 17:27:00 +00:00
|
|
|
<dd>{{object.description}}</dd>
|
2014-01-18 00:58:08 +00:00
|
|
|
{% endif %}
|
|
|
|
{% if object.homepage %}
|
|
|
|
<dt>Homepage</dt>
|
|
|
|
<dd><a href="{{object.homepage}}">{{object.homepage}}</a></dd>
|
|
|
|
{% endif %}
|
|
|
|
{% if object.bugtracker %}
|
|
|
|
<dt>Bugtracker</dt>
|
|
|
|
<dd><a href="{{object.bugtracker}}">{{object.bugtracker}}</a></dd>
|
|
|
|
{% endif %}
|
|
|
|
{% if object.section %}
|
|
|
|
<dt>
|
|
|
|
Section
|
2016-06-02 13:26:16 +00:00
|
|
|
<span class="glyphicon glyphicon-question-sign get-help" title="The section in which recipes should be categorized"></span>
|
2014-01-18 00:58:08 +00:00
|
|
|
</dt>
|
|
|
|
<dd>{{object.section}}</dd>
|
|
|
|
{% endif %}
|
|
|
|
{% if object.license %}
|
|
|
|
<dt>License</dt>
|
|
|
|
<dd>{{object.license}}</dd>
|
|
|
|
{% endif %}
|
|
|
|
</dl>
|
2016-04-12 14:56:43 +00:00
|
|
|
</div>
|
2014-01-18 00:58:08 +00:00
|
|
|
</div>
|
2013-12-11 16:42:34 +00:00
|
|
|
|
2016-04-12 14:56:43 +00:00
|
|
|
</div> <!-- end row -->
|
|
|
|
|
2013-10-11 12:46:23 +00:00
|
|
|
{% endblock %}
|