Improved Euler Blogpost:
- Better links to problems - Show Abbreviated code message - Download link to github - More prominent download button
This commit is contained in:
parent
a83b746f9d
commit
8d84152726
@ -10,4 +10,3 @@ defined('YII_DEBUG') or define('YII_DEBUG',true);
|
|||||||
defined('YII_CUSTOM_ENV') or define('YII_CUSTOM_ENV', 'dev');
|
defined('YII_CUSTOM_ENV') or define('YII_CUSTOM_ENV', 'dev');
|
||||||
|
|
||||||
require_once($yii);
|
require_once($yii);
|
||||||
Yii::createWebApplication($config)->run();
|
|
@ -100,6 +100,8 @@ return ArrayX::merge(
|
|||||||
'blog/<id>' => 'blogPost/view/id/<id>',
|
'blog/<id>' => 'blogPost/view/id/<id>',
|
||||||
'blog/<id>/<name>' => 'blogPost/view/id/<id>',
|
'blog/<id>/<name>' => 'blogPost/view/id/<id>',
|
||||||
|
|
||||||
|
'blog/1/<name>/<problem>' => 'blogPost/view/id/1',
|
||||||
|
|
||||||
'eulerproblem/' => 'eulerproblem/index',
|
'eulerproblem/' => 'eulerproblem/index',
|
||||||
|
|
||||||
'Highscores/list.php' => 'Highscores/list', // Compatibility
|
'Highscores/list.php' => 'Highscores/list', // Compatibility
|
||||||
|
@ -244,8 +244,9 @@ class BlogPostController extends MSController
|
|||||||
$problems = EulerProblem::model()->findAll(['order'=>'Problemnumber']);
|
$problems = EulerProblem::model()->findAll(['order'=>'Problemnumber']);
|
||||||
|
|
||||||
$problemnumber = 0;
|
$problemnumber = 0;
|
||||||
if (isset($_GET['problem']) AND is_numeric($_GET['problem']))
|
|
||||||
$problemnumber = $_GET['problem'];
|
if (isset($_GET['problem']) AND is_numeric(preg_replace('/^[Pp]roblem-/', '', $_GET['problem'])))
|
||||||
|
$problemnumber = preg_replace('/^[Pp]roblem-/', '', $_GET['problem']);
|
||||||
|
|
||||||
$criteria=new CDbCriteria;
|
$criteria=new CDbCriteria;
|
||||||
$criteria->condition='Problemnumber = ' . $problemnumber;
|
$criteria->condition='Problemnumber = ' . $problemnumber;
|
||||||
|
@ -124,6 +124,11 @@ class EulerProblem extends CActiveRecord
|
|||||||
return parent::model($className);
|
return parent::model($className);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getBlogLink()
|
||||||
|
{
|
||||||
|
return '/blog/1/Project_Euler_with_Befunge/problem-' . str_pad($this->Problemnumber, 3, '0', STR_PAD_LEFT);
|
||||||
|
}
|
||||||
|
|
||||||
public function getSourcecodefile($absolute = true)
|
public function getSourcecodefile($absolute = true)
|
||||||
{
|
{
|
||||||
return ($absolute ? '/' : '') . 'data/blog/Befunge/Euler_Problem-' . str_pad($this->Problemnumber, 3, '0', STR_PAD_LEFT) . '.b93';
|
return ($absolute ? '/' : '') . 'data/blog/Befunge/Euler_Problem-' . str_pad($this->Problemnumber, 3, '0', STR_PAD_LEFT) . '.b93';
|
||||||
@ -152,6 +157,11 @@ class EulerProblem extends CActiveRecord
|
|||||||
return $this->SolutionWidth <= 80 AND $this->SolutionHeight <= 25;
|
return $this->SolutionWidth <= 80 AND $this->SolutionHeight <= 25;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getRawGithubLink()
|
||||||
|
{
|
||||||
|
return 'https://raw.githubusercontent.com/Mikescher/Project-Euler_Befunge/master/processed/Euler_Problem-' . str_pad($this->Problemnumber, 3, '0', STR_PAD_LEFT) . '.b93';
|
||||||
|
}
|
||||||
|
|
||||||
public function generateMarkdown()
|
public function generateMarkdown()
|
||||||
{
|
{
|
||||||
$num_padded = str_pad($this->Problemnumber, 3, '0', STR_PAD_LEFT);
|
$num_padded = str_pad($this->Problemnumber, 3, '0', STR_PAD_LEFT);
|
||||||
@ -165,13 +175,20 @@ class EulerProblem extends CActiveRecord
|
|||||||
'```befunge' . PHP_EOL .
|
'```befunge' . PHP_EOL .
|
||||||
$this->Code . PHP_EOL .
|
$this->Code . PHP_EOL .
|
||||||
'```' . PHP_EOL .
|
'```' . PHP_EOL .
|
||||||
'[Download](/data/blog/Befunge/Euler_Problem-' . $num_padded . '.b93)' . PHP_EOL .
|
|
||||||
|
($this->AbbreviatedCode ?
|
||||||
|
(
|
||||||
|
'> **NOTE** ' . PHP_EOL .
|
||||||
|
'> This program is too big to display here, click **[download]** to see the full program. ' . PHP_EOL . PHP_EOL
|
||||||
|
) : '').
|
||||||
|
|
||||||
|
'<a class="btn btn-primary" href="' . $this->getRawGithubLink() . '">Download</a>' . PHP_EOL .
|
||||||
'' . PHP_EOL .
|
'' . PHP_EOL .
|
||||||
$this->Explanation . PHP_EOL .
|
$this->Explanation . PHP_EOL .
|
||||||
'' . PHP_EOL .
|
'' . PHP_EOL .
|
||||||
'**Interpreter steps:** `' . number_format($this->SolutionSteps, 0, null, ',') . '` ' . PHP_EOL .
|
'**Interpreter steps:** `' . number_format($this->SolutionSteps, 0, null, ',') . '` ' . PHP_EOL .
|
||||||
'**Execution time** ([BefunExec](/programs/view/BefunGen)): `' . number_format($this->SolutionTime, 0, null, ',') . '` ms' . (($this->SolutionTime < 1000) ? (' ') : (' *(= ' . MsHelper::formatMilliseconds($this->SolutionTime) . ')* ')) . PHP_EOL .
|
'**Execution time** ([BefunExec](/programs/view/BefunGen)): `' . number_format($this->SolutionTime, 0, null, ',') . '` ms' . (($this->SolutionTime < 1000) ? (' ') : (' *(= ' . MsHelper::formatMilliseconds($this->SolutionTime) . ')* ')) . PHP_EOL .
|
||||||
'**Program size:** `' . $this->SolutionWidth . 'x' . $this->SolutionHeight . '` ' . PHP_EOL .
|
'**Program size:** `' . $this->SolutionWidth . 'x' . $this->SolutionHeight . '` ' . ($this->isBefunge93() ? '*(fully valid Befunge-93)*' : '') . ' ' . PHP_EOL .
|
||||||
'**Solution:** `' . number_format($this->SolutionValue, 0, null, ',') . '` ';
|
'**Solution:** `' . number_format($this->SolutionValue, 0, null, ',') . '` ';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -75,7 +75,7 @@ array_push($this->css_files, "/css/blogpost_ProjectEulerBefunge_style.css");
|
|||||||
echo '<tr class="PEB_tablerowProblems">' . "\r\n";
|
echo '<tr class="PEB_tablerowProblems">' . "\r\n";
|
||||||
|
|
||||||
echo '<td class="PEB_tablecellProblems PEB_TC_Number">' . $problem->Problemnumber . "</td>\r\n";
|
echo '<td class="PEB_tablecellProblems PEB_TC_Number">' . $problem->Problemnumber . "</td>\r\n";
|
||||||
echo '<td class="PEB_tablecellProblems PEB_TC_Title"><a href="?problem=' . $problems[$i]->Problemnumber . '">' . $problem->Problemtitle . "</a></td>\r\n";
|
echo '<td class="PEB_tablecellProblems PEB_TC_Title"><a href="' . $problems[$i]->getBlogLink() . '">' . $problem->Problemtitle . "</a></td>\r\n";
|
||||||
echo '<td class="PEB_tablecellProblems"><div class="PEB_TC_Time PEB_TC_Timelevel_' . $problem->getTimeScore() . '">' . MsHelper::formatMilliseconds($problem->SolutionTime) . "</div></td>\r\n";
|
echo '<td class="PEB_tablecellProblems"><div class="PEB_TC_Time PEB_TC_Timelevel_' . $problem->getTimeScore() . '">' . MsHelper::formatMilliseconds($problem->SolutionTime) . "</div></td>\r\n";
|
||||||
|
|
||||||
if ($problem->isBefunge93())
|
if ($problem->isBefunge93())
|
||||||
@ -118,7 +118,7 @@ array_push($this->css_files, "/css/blogpost_ProjectEulerBefunge_style.css");
|
|||||||
array_push($pagination,
|
array_push($pagination,
|
||||||
[
|
[
|
||||||
'label' => str_pad($problems[$i]->Problemnumber, 3, '0', STR_PAD_LEFT),
|
'label' => str_pad($problems[$i]->Problemnumber, 3, '0', STR_PAD_LEFT),
|
||||||
'url' => '?problem=' . $problems[$i]->Problemnumber,
|
'url' => $problems[$i]->getBlogLink(),
|
||||||
'disabled' => false,
|
'disabled' => false,
|
||||||
'active' => $currproblemID == $i,
|
'active' => $currproblemID == $i,
|
||||||
]);
|
]);
|
||||||
|
Loading…
Reference in New Issue
Block a user