2018-03-19 19:25:13 +01:00
import os , sys , datetime
2018-03-18 18:43:30 +01:00
2018-03-19 19:25:13 +01:00
delete_db = len ( sys . argv ) > = 2 and sys . argv [ 1 ] . strip ( ) == " -d "
2018-03-18 18:43:30 +01:00
2018-03-19 19:08:41 +01:00
if delete_db and os . path . isfile ( " db.sqlite " ) :
os . remove ( " db.sqlite " )
2018-03-18 18:43:30 +01:00
2018-03-19 19:08:41 +01:00
if not os . path . isfile ( " db.sqlite " ) :
2018-03-18 19:05:53 +01:00
from app . models import *
2018-03-18 18:43:30 +01:00
print ( " Creating database tables... " )
2018-03-18 19:05:53 +01:00
db . create_all ( )
2018-03-18 18:43:30 +01:00
print ( " Filling database... " )
2018-03-18 19:05:53 +01:00
ruben = User ( " rubenwardy " )
ruben . github_username = " rubenwardy "
2018-03-20 19:20:30 +01:00
ruben . rank = UserRank . EDITOR
2018-03-18 19:05:53 +01:00
db . session . add ( ruben )
2018-03-19 19:08:41 +01:00
2018-03-20 03:24:44 +01:00
jeija = User ( " Jeija " )
jeija . github_username = " Jeija "
db . session . add ( jeija )
2018-03-19 19:25:13 +01:00
mod1 = Package ( )
2018-03-21 20:03:14 +01:00
mod1 . approved = True
2018-03-19 19:08:41 +01:00
mod1 . name = " awards "
mod1 . title = " Awards "
2018-03-20 01:44:47 +01:00
mod1 . type = PackageType . MOD
2018-03-19 19:08:41 +01:00
mod1 . author = ruben
2018-03-20 03:24:44 +01:00
mod1 . repo = " https://github.com/rubenwardy/awards "
mod1 . issueTracker = " https://github.com/rubenwardy/awards/issues "
2018-03-21 18:42:43 +01:00
mod1 . forums = 4870
2018-03-20 03:17:33 +01:00
mod1 . shortDesc = " Adds achievements and an API to register new ones. "
mod1 . desc = """
2018-03-20 03:24:44 +01:00
Majority of awards are back ported from Calinou ' s old fork in Carbone, under same license.
2018-03-20 03:17:33 +01:00
` ` `
awards . register_achievement ( " award_mesefind " , {
title = " First Mese Find " ,
description = " Found some Mese! " ,
trigger = {
type = " dig " , - - award is given when
node = " default:mese " , - - this type of node has been dug
target = 1 , - - this number of times
} ,
} )
` ` `
2018-03-20 03:24:44 +01:00
"""
2018-03-20 19:20:30 +01:00
rel = PackageRelease ( )
rel . package = mod1
rel . title = " v1.0.0 "
rel . url = " https://github.com/rubenwardy/awards/archive/master.zip "
db . session . add ( rel )
2018-03-20 03:24:44 +01:00
mod2 = Package ( )
2018-03-21 20:03:14 +01:00
mod2 . approved = True
2018-03-20 03:24:44 +01:00
mod2 . name = " mesecons "
mod2 . title = " Mesecons "
mod2 . type = PackageType . MOD
mod2 . author = jeija
mod2 . repo = " https://github.com/minetest-mods/mesecons/ "
mod2 . issueTracker = " https://github.com/minetest-mods/mesecons/issues "
2018-03-21 18:42:43 +01:00
mod2 . forums = 628
2018-03-20 03:24:44 +01:00
mod2 . shortDesc = " Mesecons adds everything digital, from all kinds of sensors, switches, solar panels, detectors, pistons, lamps, sound blocks to advanced digital circuitry like logic gates and programmable blocks. "
mod2 . desc = """
########################################################################
## __ __ _____ _____ _____ _____ _____ _ _ _____ ##
## | \ / | | ___| | ___| | ___| | ___| | _ | | \ | | | ___| ##
## | \/ | | |___ | |___ | |___ | | | | | | | \| | | |___ ##
## | |\__/| | | ___| |___ | | ___| | | | | | | | | |___ | ##
## | | | | | |___ ___| | | |___ | |___ | |_| | | |\ | ___| | ##
## |_| |_| |_____| |_____| |_____| |_____| |_____| |_| \_| |_____| ##
## ##
########################################################################
MESECONS by Jeija and contributors
Mezzee - what ?
- - - - - - - - - - - -
[ Mesecons ] ( http : / / mesecons . net / ) ! They ' re yellow, they ' re conductive , and they ' ll add a whole new dimension to Minetest ' s gameplay .
Mesecons is a mod for [ Minetest ] ( http : / / minetest . net / ) that implements a ton of items related to digital circuitry , such as wires , buttons , lights , and even programmable controllers . Among other things , there are also pistons , solar panels , pressure plates , and note blocks .
Mesecons has a similar goal to Redstone in Minecraft , but works in its own way , with different rules and mechanics .
OK , I want in .
- - - - - - - - - - - - - -
Go get it !
[ DOWNLOAD IT NOW ] ( https : / / github . com / minetest - mods / mesecons / archive / master . zip )
Now go ahead and install it like any other Minetest mod . Don ' t know how? Check out [the wonderful page about it](http://wiki.minetest.com/wiki/Mods) over at the Minetest Wiki. For your convenience, here ' s a quick summary :
1. If Mesecons is still in a ZIP file , extract the folder inside to somewhere on the computer .
2. Make sure that when you open the folder , you can directly find ` README . md ` in the listing . If you just see another folder , move that folder up one level and delete the old one .
3. Open up the Minetest mods folder - usually ` / mods / ` . If you see the ` minetest ` or folder inside of that , that is your mod folder instead .
4. Copy the Mesecons folder into the mods folder .
Don ' t like some parts of Mesecons? Open up the Mesecons folder and delete the subfolder containing the mod you don ' t want . If you didn ' t want movestones, for example, all you have to do is delete the `mesecons_movestones` folder and they will no longer be available.
There are no dependencies - it will work right after installing !
How do I use this thing ?
- - - - - - - - - - - - - - - - - - - - - - - -
How about a [ quick overview video ] ( https : / / www . youtube . com / watch ? v = 6 kmeQj6iW5k ) ?
Or maybe a [ comprehensive reference ] ( http : / / mesecons . net / items . html ) is your style ?
An overview for the very newest of new beginners ? How does [ this one ] ( http : / / uberi . mesecons . net / projects / MeseconsBasics / index . html ) look ?
Want to get more into building ? Why not check out the [ Mesecons Laboratory ] ( http : / / uberi . mesecons . net / ) , a website dedicated to advanced Mesecons builders ?
Want to contribute to Mesecons itself ? Check out the [ source code ] ( https : / / github . com / minetest - mods / mesecons ) !
Who wrote it anyways ?
- - - - - - - - - - - - - - - - - - - - -
These awesome people made Mesecons possible !
| Contributor | Contribution |
| - - - - - - - - - - - - - - - | - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - |
| Hawk777 | Code for VoxelManip caching |
| Jat15 | Various tweaks . |
| Jeija | * * Main developer ! Everything . * * |
| Jordach | Noteblock sounds . |
| khonkhortistan | Code , recipes , textures . |
| Kotolegokot | Nodeboxes for items . |
| minerd247 | Textures . |
| Nore / Novatux | Code . |
| RealBadAngel | Fixes , improvements . |
| sfan5 | Code , recipes , textures . |
| suzenako | Piston sounds . |
| Uberi / Temperest | Code , textures , documentation . |
| VanessaE | Code , recipes , textures , design . |
| Whiskers75 | Logic gates implementation . |
There are also a whole bunch of other people helping with everything from code to testing and feedback . Mesecons would also not be possible without their help !
Alright , how can I use it ?
- - - - - - - - - - - - - - - - - - - - - - - - - -
All textures in this project are licensed under the CC - BY - SA 3.0 ( Creative Commons Attribution - ShareAlike 3.0 Generic ) . That means you can distribute and remix them as much as you want to , under the condition that you give credit to the authors and the project , and that if you remix and release them , they must be under the same or similar license to this one .
All code in this project is licensed under the LGPL version 3 or later . That means you have unlimited freedom to distribute and modify the work however you see fit , provided that if you decide to distribute it or any modified versions of it , you must also use the same license . The LGPL also grants the additional freedom to write extensions for the software and distribute them without the extensions being subject to the terms of the LGPL , although the software itself retains its license .
No warranty is provided , express or implied , for any part of the project .
"""
2018-03-19 19:08:41 +01:00
db . session . add ( mod1 )
2018-03-20 03:24:44 +01:00
db . session . add ( mod2 )
game1 = Package ( )
2018-03-21 20:03:14 +01:00
game1 . approved = True
2018-03-20 03:24:44 +01:00
game1 . name = " capturetheflag "
game1 . title = " Capture The Flag "
game1 . type = PackageType . GAME
game1 . author = ruben
game1 . repo = " https://github.com/rubenwardy/capturetheflag "
game1 . issueTracker = " https://github.com/rubenwardy/capturetheflag/issues "
2018-03-21 18:42:43 +01:00
game1 . forums = 12835
2018-03-20 03:24:44 +01:00
game1 . shortDesc = " Two teams battle to snatch and return the enemy ' s flag, before the enemy takes their own! "
game1 . desc = """
As seen on the Capture the Flag server ( minetest . rubenwardy . com : 30000 )
Uses the CTF PvP Engine .
"""
db . session . add ( game1 )
2018-03-19 19:08:41 +01:00
2018-03-18 19:05:53 +01:00
db . session . commit ( )
2018-03-18 18:43:30 +01:00
else :
print ( " Database already exists " )