|
|
|
12-22-2009, 01:54 PM
|
#1
|
Human being with feelings
Join Date: Dec 2006
Location: UK
Posts: 789
|
ReaScript: API: Wish List
Hello all,
Here's the start of a ReaScript wish list. What have I missed? What shouldn't be on the list? What should and shouldn't be in red? (No matter what anyone says I'm not taking the Wiki items off the list.) There aren't many Python items. (can't think why...)
These are the top ten things in the Wish List. Positions are set by +1 or -1 votes, so make sure you vote for what you need and un-vote for what you don't... - Numbers in () are item nums in big list below.
- Items get into top ten with first +1, at bottom of list
- Items go up list with each +1
- Items go down in the list with each -1 (usually)
- (8) Add a return value for named notes to MIDIEditor_GetMode()
- (9) File dialogue, returning OK/Cancel & Filename (Expected v3.21 or thereabouts)
- (13) GetSet*State() chunk size limit is currently 16k, too small. (Expected v3.21 or thereabouts)
- (10) MIDIEditor_Get|SetView, returning (see big list)
- (12) Resizable console window
- (23) Get/SetMidiItemInfo_Value() - (see big list)
- (25) GetSetProjectState()
- ReaPerl. To be able to call RPR_* functions from a module.
- For functions that take a named parameter - Get/SetMediaTrackInfo_Value() - to not fail silently when you give them a parameter they don't know about.
- ReaPerl. Compile & Runtime Error messages for Perl scripts.(becoming an issue, scripts are getting longer)
- ReaPerl. To be able to call RPR_* functions as standard Perl functions, multiple line calls and calls in if statements, e.g.
PHP Code:
if(RPR_CountSelectedItems()==0)
and
PHP Code:
$var=RPR_FuncWithVeryLongNameAndParamList( MediaTrack, # the selected track MediaItem, # the item that will be edited p3, # etc. p4, p5, p6, # some random pointer or other... p7, p8 );
The solution to this one's related to the "RPR_ from a module wish" (above) I suspect.
- To (magically, not with work) know about Python as well as Perl (please).*
- A Wiki batch edit facility (please God).*
- A Wiki template that is not just a #include by another name.*
- Add a return value for named notes to MIDIEditor_GetMode()
- File dialogue, returning OK/Cancel & Filename (Expected v3.21 or thereabouts)
- MIDIEditor_Get|SetView, returning rectangles, diamonds, triangles, all notes, Hide unused, Hide unused/unnamed
- Support for Tk (GUI used by Python & Perl) in Perl as well as in Python.
- Resizable console window
- GetSet*State() chunk size limit is currently 16k, too small. (Expected v3.21 or thereabouts)
- "Possible Infinite Loop" message currently triggered at 16000 API calls in a ReaScript, sfzgeek hitting that limit.
- A command to close the console output window from within the script.
- API A means to obtain the Actions List contents -- particularly the name strings and the corresponding numeric ID's.
- something to get a valid reaper_plugin_info_t *rec (or any alternative other way to register to Reaper's notif)
- LICE_IBitmap * b = GetPNGFromCurrentTheme("mcp_volthumb.png", NULL); getting the user's current theme in a cross-plateform way would be cool for VSTs extension plugins
- something to work within FX chains in a FX type independent way (VST, JS, Dx) main first needs: trigering reaper's preset (then, FX's one) but also pin connection processing
- SWS's plugin_register("hookcommandex", hookCommandProcEx) FR: http://forum.cockos.com/project.php?issueid=1465
- padre, klinke & yves: enhanced csurf notif, http://forum.cockos.com/showthread.php?t=44152
- Something to validate chunk updates in a reliable way - GetSet*State() funcs bool vals sometimes fib a bit...
- Get/SetMidiItemInfo_Value() - perhaps not this API exactly, but something a more ReaScripter friendly than chunks. (Some aspects of friendlier could be user-contributed if we could call RPR_* functions from a module)
- GetFuncAddress() call. Not needed now include() is implemented.
- Jeffos would like to be able to say GetSetObjectState(ReaProject*), personally I would prefer to see a GetSetProjectState() to allow access to project-wide parameters using chunkish editing.
Oh, and just to be clear. I'm not complaining, I think ReaScript (yes, yes & the C++ API) is the best thing since sliced bread.
Mike
(* Some items may stretch the capabilities of the development team, but we shouldn't let that stop us asking. Remember - hard work is good for them. )
__________________
Mike Lacey, Leicestershire, UK
Last edited by MikeLacey; 01-27-2010 at 09:07 AM.
|
|
|
12-22-2009, 02:00 PM
|
#2
|
Administrator
Join Date: Mar 2007
Location: NY
Posts: 15,822
|
Thanks Mike.
Also what would be handy is a wish list of particular API functions. Those sorts of wishes even have a chance of being granted (unlike, say, #5 above).
|
|
|
12-22-2009, 02:05 PM
|
#3
|
Human being with feelings
Join Date: Jun 2009
Location: Croatia
Posts: 24,798
|
I very much agree with:
8, 9, 10, 12, 13
Also I will add:
15. A command to close the console output window from within the script. For example, currently:
RPR_ShowConsoleMsg("")
clears the console.
RPR_ShowConsoleMsg(close)
could do it?
|
|
|
12-22-2009, 02:15 PM
|
#4
|
Human being with feelings
Join Date: Dec 2006
Location: UK
Posts: 789
|
interesting, I've only thought of the console as a debugging tool...
__________________
Mike Lacey, Leicestershire, UK
|
|
|
12-22-2009, 02:25 PM
|
#5
|
Human being with feelings
Join Date: Jun 2009
Location: Croatia
Posts: 24,798
|
...and that is a good point as well. Yeah, we could use messageboxes for whatever we want to return to the user, true.
How about this then:
15. Naming all scripts like this:
"ReaScript: <script name here>"
instead of:
"Custom: <script name here>.py/pl"
|
|
|
12-22-2009, 03:26 PM
|
#6
|
Human being with feelings
Join Date: Mar 2009
Location: Dartmouth, Nova Scotia
Posts: 11,254
|
As per schwa's suggestion I'm posting a wish list item here that is not strictly for ReaScript (but probably useful for ReaScripter's as well).
API: A means to obtain the Actions List contents -- particularly the name strings and the corresponding numeric ID's.
For custom actions and extension actions the ID's are assigned dynamically, so we need to do this at runtime.
|
|
|
12-23-2009, 03:19 AM
|
#7
|
Mortal
Join Date: Dec 2008
Location: France
Posts: 1,969
|
Quote:
Originally Posted by schwa
Thanks Mike.
Also what would be handy is a wish list of particular API functions. Those sorts of wishes even have a chance of being granted (unlike, say, #5 above).
|
Dear Santa schwa,
My (ordered) wish list is:
- Something to validate chunk updates in a reliable way
==> EDIT: this was a REAPER bug fixed in v3.22
- allowing ReaProject* as 1st param for GetSetObjectState() (no need of attached tracks in the setted/getted chunks..)
- something to get a valid reaper_plugin_info_t *rec (or any alternative other way to register to Reaper's notif)
- LICE_IBitmap * b = GetPNGFromCurrentTheme("mcp_volthumb.png", NULL);
getting the user's current theme in a cross-plateform way would be cool for VSTs extension plugins
==> EDIT: no API update needed for that
- something to work within FX chains in a FX type independent way (VST, JS, Dx): main first needs: trigering REAPER's preset (then, FX's one) but also pin connection processing
==> EDIT July 2010: trigering REAPER's preset is doable
I stop here. I really think the two 1st ones would open many doors. I'd be happy only with them.
Other devs wishes I really agree with (ordered too):
- same as SWS: plugin_register("hookcommandex", hookCommandProcEx);
FR: http://forum.cockos.com/project.php?issueid=1465
- same as padre_pc, klinke, yves: enhanced csurf notif, see http://forum.cockos.com/showthread.php?t=44152 (but forget what I said there: now, I know how to do almost everything I asked there)
- same as geoff: a way to enumerate the action list (I promise I won't do a parallèle learn system.. ;-)
Last edited by Jeffos; 08-06-2010 at 08:29 AM.
Reason: outdated things -> italic
|
|
|
12-23-2009, 12:43 PM
|
#8
|
Human being with feelings
Join Date: Dec 2006
Location: UK
Posts: 789
|
Jeff, hi,
So that I can add your items into the wish list... (and my apologies for asking stupid questions)
Quote:
Something to validate chunk updates in a reliable way
|
The functions GetSetEnv/Item/TrackState return bool (amongst other things), is the bool return value not reliable?
Quote:
allowing ReaProject* as 1st param for GetSetObjectState()
|
So that we can update project global parameters in a chunkish way? (In the style of GetSetProjectState()?)
__________________
Mike Lacey, Leicestershire, UK
|
|
|
12-23-2009, 01:15 PM
|
#9
|
Human being with feelings
Join Date: Jun 2009
Location: Croatia
Posts: 24,798
|
Quote:
Originally Posted by MikeLacey
The functions GetSetEnv/Item/TrackState return bool (amongst other things), is the bool return value not reliable?
|
May be so, but when GetSetItemState() sets MIDI CFGEDIT chunk tokens, they are not updated and not reflected, even if you update the item on the timeline...
|
|
|
12-23-2009, 02:04 PM
|
#10
|
Human being with feelings
Join Date: Apr 2009
Location: Bristol uk
Posts: 1,006
|
Dear Santa Schwa .
I could really do with .
RPR_GetMidiItemInfo_Value( ) Retries all position pitches and velocities of notes in an item by index.
and
RPR_SetMidiItemInfo_Value( ) Sets all position pitches and velocities of notes in an item by index.
Chunk editing is just two tricksy for your average Rescripter it needs to be transformed into something far more friendly .
Have a very merry Christmas.
|
|
|
12-23-2009, 02:32 PM
|
#11
|
Human being with feelings
Join Date: Dec 2006
Location: UK
Posts: 789
|
Quote:
Originally Posted by EvilDragon
May be so, but when GetSetItemState() sets MIDI CFGEDIT chunk tokens, they are not updated and not reflected, even if you update the item on the timeline...
|
Fair comment - it's in the list
__________________
Mike Lacey, Leicestershire, UK
|
|
|
01-06-2010, 01:44 AM
|
#12
|
Mortal
Join Date: Dec 2008
Location: France
Posts: 1,969
|
Quote:
Originally Posted by MikeLacey
The functions GetSetEnv/Item/TrackState return bool (amongst other things), is the bool return value not reliable?
|
Hi Mike! sorry for this late anwser. no, I meant that sometimes you have to fight to validate chunk updates (to avoid what you called "a temporary update" in another thread) while the fuction had returned "true". Sometimes it also return true but nothing is applied at all and there're other worst issues (e.g. right now I'm facing some deadlocks when setting, I'm trying to clarify that..)
Quote:
Originally Posted by MikeLacey
So that we can update project global parameters in a chunkish way? (In the style of GetSetProjectState()?)
|
yes, it's the idea: master enveloppes, tempo, etc...
Last edited by Jeffos; 01-06-2010 at 04:44 AM.
Reason: none, see post bellow
|
|
|
01-06-2010, 02:06 AM
|
#13
|
Human being with feelings
Join Date: Dec 2006
Location: UK
Posts: 789
|
"right now I'm facing some deadlocks when setting"
Interesting, I've not encountered that
__________________
Mike Lacey, Leicestershire, UK
|
|
|
01-06-2010, 06:40 PM
|
#14
|
Human being with feelings
Join Date: Sep 2009
Posts: 107
|
Quote:
Originally Posted by MikeLacey
[*]Support for Tk (GUI used by Python & Perl) (long shot) Or... Drop down lists, text boxes and such in windows that can be called from ReaScript functions. (less of a long shot maybe)
|
Just spotted this one. I had no trouble running tkinter in Reaper, except of course not having the ability to make API calls without some kind of a callback mechanism (which I still have to figure out!). But it certainly is possible to have a GUI.
|
|
|
01-06-2010, 07:18 PM
|
#15
|
Human being with feelings
Join Date: Apr 2008
Location: Saarlänner
Posts: 1,141
|
Quote:
Originally Posted by Malevol3nt
Just spotted this one. I had no trouble running tkinter in Reaper, except of course not having the ability to make API calls without some kind of a callback mechanism (which I still have to figure out!). But it certainly is possible to have a GUI.
|
Would you mind to post a little (python) demo snippet, because i didn't get this to work either?
|
|
|
01-06-2010, 08:12 PM
|
#16
|
Human being with feelings
Join Date: Sep 2009
Posts: 107
|
Quote:
Originally Posted by Blechi
Would you mind to post a little (python) demo snippet, because i didn't get this to work either?
|
Here you go. Just put it anywhere in the Reaper directory (I have a Reaper\Scripts Dir where I put all the stuff but it doesn't matter). Make a hotkey for it or just run it.
By the way, if you want to design your GUI's without having to code all the time you can use GUI Builder, which generates python ~2.5 compatible code. It's downloadable from here:
http://sourceforge.net/projects/spectcl/
However, all I needed to do was change the import statements from "import Tkinter" to "import tkinter" in the 2 .py files it generates, and the code seemed to work fine with Python 3.1. But I've only tried it briefly. Anyway, have fun!
|
|
|
01-06-2010, 09:53 PM
|
#17
|
Human being with feelings
Join Date: Apr 2008
Location: Saarlänner
Posts: 1,141
|
Thanks a lot. Works fine.
Also thanks for the link to the GUIbuilder thingy. Makes things a lot easier.
|
|
|
01-07-2010, 08:35 AM
|
#18
|
Human being with feelings
Join Date: Sep 2009
Posts: 107
|
Quote:
Originally Posted by Blechi
Thanks a lot. Works fine.
Also thanks for the link to the GUIbuilder thingy. Makes things a lot easier.
|
Right, just be careful with the root.destroy() function. I've removed it from the example since closing the GUI with the X button calls that function anyway. If you were to say, put root.destroy() as a function call for one of the buttons, it will do the same thing.
However putting it in the wrong place can sometimes create an infinite loop spawning a few dozen windows, and you have to crash Reaper via the task manager to get rid of them. But it only happens if you don't know what you're doing (I got burned on that one myself )
Edit: Looks like tkinter seems to be a bit buggy, or I'm doing it wrong. For the life of me I can't figure out why sometimes a button activates itself on it's own. And I'm getting infinite loops, windows popping out everywhere. Argh!
Last edited by Malevol3nt; 01-07-2010 at 05:03 PM.
|
|
|
01-07-2010, 10:32 AM
|
#19
|
Human being with feelings
Join Date: Sep 2009
Posts: 107
|
It looks like the maximum number of envelope points I can retrieve with an extension is 629 points. Trying to extract more crashes reaper, with a "Memory could not be 'written' at address 0x********"
It seems Reaper has no problem having more than 629 envelope points. So it's probably a limitation of the size of the chunk RPR_GetSetEnvelopeState can return. At 629 points the string/chunk returned is 15742 characters long.
I'm not saying the limit should be changed. 629 is more than enough for anyone I guess.
On the good side of news, my envelope extraction function (which performs some regular expressions on the chunk) stores all the envelope data and points data in separate dictionaries pretty fast. Around ~20 milliseconds for 629 points, if cProfiler is to be trusted.
|
|
|
01-08-2010, 02:01 PM
|
#20
|
Human being with feelings
Join Date: Dec 2009
Posts: 50
|
I just wanted to chime in on Item 13. 16384 characters is way too small a limit for GetSetItemState().
+1 to the request to make this a much more useful function.
|
|
|
01-12-2010, 07:03 AM
|
#21
|
Administrator
Join Date: Mar 2007
Location: NY
Posts: 15,822
|
Quote:
Originally Posted by MikeLacey
File dialogue, returning OK/Cancel & Filename
|
Coming soon.
Quote:
Originally Posted by MikeLacey
GetSet*State() chunk size limit is currently 16k, too small.
|
Will be increased to 1MB.
Last edited by schwa; 01-12-2010 at 07:31 AM.
|
|
|
01-12-2010, 08:31 AM
|
#22
|
Human being with feelings
Join Date: Dec 2006
Location: UK
Posts: 789
|
You're a nice man Mr Schwa, and I've always said so...
Thanks, good choices.
__________________
Mike Lacey, Leicestershire, UK
|
|
|
01-12-2010, 08:51 AM
|
#23
|
Human being with feelings
Join Date: Jun 2009
Location: Croatia
Posts: 24,798
|
Quote:
Originally Posted by schwa
Coming soon.
|
Will this one basically look like the current file dialogue, or?
Because if it's just improved current file dialogue with return values, that is AWESOME!
|
|
|
01-12-2010, 10:10 PM
|
#24
|
Human being with feelings
Join Date: Dec 2009
Location: Wellington, NZ
Posts: 300
|
Nice nice!! Sooner then I thought.
Changes in 3.2:
ReaScript: GetSetChunkState chunk length limit increased to 1MB
ReaScript: added GetUserFileNameForRead
|
|
|
01-12-2010, 10:14 PM
|
#25
|
Administrator
Join Date: Mar 2007
Location: NY
Posts: 15,822
|
Quote:
Originally Posted by fingers
ReaScript: GetSetChunkState chunk length limit increased to 1MB
ReaScript: added GetUserFileNameForRead
|
Ah ... oops. Those changes are not in 3.2, they will be in the next release. The whatsnew update got entered with the wrong version number. Sorry!
|
|
|
01-13-2010, 01:59 AM
|
#26
|
Human being with feelings
Join Date: Feb 2009
Location: Dunedin, New Zealand
Posts: 205
|
Quote:
Originally Posted by schwa
Those changes are not in 3.2, they will be in the next release.
|
No problems. Great to know that some very welcome additions are on the way. The increased chunk limit is going to answer many people's prayers!
|
|
|
01-15-2010, 07:34 AM
|
#27
|
Human being with feelings
Join Date: Dec 2006
Location: UK
Posts: 789
|
Thx schwa, testing now, test results in pre-release forum.
Mike
__________________
Mike Lacey, Leicestershire, UK
|
|
|
01-24-2010, 06:46 PM
|
#28
|
Human being with feelings
Join Date: Jan 2010
Posts: 6
|
When a (python) script is running, none of the other shortcut keys work until that script exits (although running other scripts via the Actions window work).
A script with a GUI is usually executing an infinite loop until the user hits a close button of some sorts (or the script exits by itself). I've just tried running two GUI scripts at once. After I've ran the first script, the shortcut keys were not responding (as in ctrl-c, escape, F1-F12 buttons etc). I've opened the Actions window and tried executing other scripts. This will work, unless the other script is a GUI script as well. In that case, trying to run that second GUI script will leave Reaper completely frozen.
I think this is worth investigating if we're hoping to some day have GUI scripts running side-by-side. I've tested this with tkinter, and a commercial GUI library, with the same results on Reaper 3.2 and 3.21 beta.
|
|
|
01-25-2010, 05:23 AM
|
#29
|
Human being with feelings
Join Date: Dec 2006
Location: UK
Posts: 789
|
Andre,
Can you run multiple GUI Python scripts outside of REAPER? (sorry, I'm not a Python person)
__________________
Mike Lacey, Leicestershire, UK
|
|
|
01-25-2010, 09:21 AM
|
#30
|
Human being with feelings
Join Date: Jan 2010
Posts: 6
|
Quote:
Originally Posted by MikeLacey
Andre,
Can you run multiple GUI Python scripts outside of REAPER? (sorry, I'm not a Python person)
|
Of course.
Well, maybe I could work on some kind of workaround where the script that runs in Reaper executes another external script which runs independently of Reaper. That's the only thing I can think of.
Try executing a script with an infinite loop like this one (on an empty project please!):
test.py
Reaper will hang. Although that kind of code should never be written, I think Reaper should have some kind of protection against hanging scripts. As people start writing longer extensions it's possible these kinds of bugs could happen by accident, which cause Reaper hangs and users loosing their unsaved projects. I would feel really awful if someone lost their progress in a project due to a hanging script.
|
|
|
01-25-2010, 09:23 AM
|
#31
|
Administrator
Join Date: Mar 2007
Location: NY
Posts: 15,822
|
FWIW, Reaper will detect the error in this infinite loop and bail out with an error message:
Code:
while True:
RPR_DoSomething()
|
|
|
01-25-2010, 12:59 PM
|
#32
|
Human being with feelings
Join Date: Jan 2010
Posts: 6
|
Quote:
Originally Posted by schwa
FWIW, Reaper will detect the error in this infinite loop and bail out with an error message:
Code:
while True:
RPR_DoSomething()
|
True, just tested it. I guess it would be rather difficult to know if a script is running an infinite loop on purpose or by mistake, except in a case like this when it's constantly calling a Reaper action.
|
|
|
04-18-2015, 06:27 AM
|
#33
|
Human being with feelings
Join Date: Apr 2013
Location: France
Posts: 9,900
|
From this post:
Quote:
A PreventUIRefresh version for the MIDI editor would be nice
Actually, scripts than move the edit cursor intensively are jumpy in the midi editor.
|
Thanks for listening !
|
|
|
04-30-2015, 05:03 PM
|
#34
|
Human being with feelings
Join Date: Jun 2012
Location: Spain
Posts: 7,268
|
reaper.Main_openProjectEx(string name, boolean innewtab)
a boolean option to open in a new tab directly, without having to open a new tab first that loads default template.
|
|
|
05-24-2015, 09:12 AM
|
#35
|
Human being with feelings
Join Date: Apr 2013
Location: France
Posts: 9,900
|
Hi !
It would be so nice to have GetMediaItemOnSelectedTrack(mediaTrack, mediaItemSelIndex)
Current solution involve
- select track from selected items
- loop through tracks
-- loop through items on track
--- if selected, then store in a table
-- loop in tbe table
Could be so much easier :P
CountSelectedMediaItemOnTrack will be nice too
EDIT:
Without it, it is very hard to create script like 'group item according to their position on selection per track' (which would group every first selected item on each track together, every second etc...).
Last edited by X-Raym; 05-25-2015 at 03:12 PM.
|
|
|
05-24-2015, 12:52 PM
|
#36
|
-blänk-
Join Date: Jun 2008
Posts: 11,359
|
SetMediaTrackInfo_Value seems to be missing a means to set auto-record-arm for the track. Could maybe be integrated into "I_RECARM" as a valid value, or be a parameter name of its own.
Or is there another way I am missing? At the moment I use an action call, but it involves selection of the track which means I need to store/recall track selection just for this setting. Seems to be a bit clumsy.
|
|
|
10-23-2015, 02:28 AM
|
#37
|
Human being with feelings
Join Date: Feb 2008
Location: Mesa, AZ
Posts: 2,057
|
API to tell reaper to make a backup, so just incase your action causes a crash (when you know the action may have some potential to crash) you could have have reaper make a backup for the user.
__________________
Soundemote - Home of the chaosfly and pretty oscilloscope.
MyReaperPlugin - Easy-to-use cross-platform C++ REAPER extension template
Last edited by Argitoth; 10-23-2015 at 02:38 AM.
|
|
|
10-29-2015, 04:47 AM
|
#38
|
Human being with feelings
Join Date: Aug 2013
Posts: 339
|
Working with envelope scripts I found an irritating lacking functionality.
Testing for GetSelectedEnvelope and GetSelectedTrackEnvelope allows you to see if you have a Take Envelope selected (first is non-zero, second must be 0). This is needed because take envelopes have position relative to their items, so if you use position in any way in the script you need to compensate for this.
AFAIK there's no API to get the take of the specific take envelope (i.e which take it belongs to), which I need to get the item's position... so, API request I guess?
|
|
|
11-05-2015, 06:19 AM
|
#39
|
Human being with feelings
Join Date: Aug 2013
Posts: 339
|
The VST Chunk is stored as base64 in the track chunk. I assume if you look at the track chunk you'll have to decode it manually... The format of the binary blob (once decoded from base64) is like this:
4 bytes <VSTID>
4 bytes <magic value?>
4 bytes <Number of Inputs>
* after that, a bitmask array of 8 bytes each, for the input routings (bit 0 = input channel 1 is set; bit 63 = input channel 64 is set; etc)
* the length of the above array is defined by the number of inputs (so total size is 8*NumInputs bytes)
4 bytes <Number of Outputs>
* again bitmask array 8 bytes each for outputs this time...
Then follows the VST stuff (which you aren't interested in).
I guess this is far from ideal and an API would be much helpful here but, a complicated workaround if you really must have it before then...
|
|
|
11-05-2015, 11:19 AM
|
#40
|
Human being with feelings
Join Date: Oct 2013
Location: Moscow, Russia
Posts: 3,984
|
I have just tried to discover some base64 decoder examples (or even online decoders), but with no luck. I get just characters, but can`t use it for routing check. Unfortunately this is out of my knowledge at this moment. Could you help me with that some more deeply (decoding/encoding only routing part)?
Last edited by mpl; 11-05-2015 at 01:00 PM.
|
|
|
Thread Tools |
|
Display Modes |
Hybrid Mode
|
Posting Rules
|
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts
HTML code is Off
|
|
|
All times are GMT -7. The time now is 04:16 AM.
|