OSX: associate abr file, fix shell open file when process is running, fix shutdown

This commit is contained in:
2019-03-01 20:27:42 +01:00
parent 05c46b4744
commit a14afe5b44
3 changed files with 148 additions and 26 deletions

View File

@@ -25,7 +25,31 @@
<true/> <true/>
<key>LSItemContentTypes</key> <key>LSItemContentTypes</key>
<array> <array>
<string>public.panorama-image</string> <string>com.panopainter.image</string>
</array>
<key>LSTypeIsPackage</key>
<integer>0</integer>
</dict>
<dict>
<key>CFBundleTypeExtensions</key>
<array>
<string>abr</string>
</array>
<key>CFBundleTypeIconFile</key>
<string></string>
<key>CFBundleTypeIconFiles</key>
<array/>
<key>CFBundleTypeMIMETypes</key>
<array/>
<key>CFBundleTypeName</key>
<string>PanoPainter Brushes</string>
<key>CFBundleTypeRole</key>
<string>Editor</string>
<key>LSIsAppleDefaultForType</key>
<false/>
<key>LSItemContentTypes</key>
<array>
<string>com.panopainter.abr</string>
</array> </array>
<key>LSTypeIsPackage</key> <key>LSTypeIsPackage</key>
<integer>0</integer> <integer>0</integer>
@@ -71,7 +95,7 @@
<key>UTTypeIconFiles</key> <key>UTTypeIconFiles</key>
<array/> <array/>
<key>UTTypeIdentifier</key> <key>UTTypeIdentifier</key>
<string>public.panorama-image</string> <string>com.panopainter.image</string>
<key>UTTypeTagSpecification</key> <key>UTTypeTagSpecification</key>
<dict> <dict>
<key>com.apple.ostype</key> <key>com.apple.ostype</key>
@@ -88,6 +112,35 @@
</array> </array>
</dict> </dict>
</dict> </dict>
<dict>
<key>UTTypeConformsTo</key>
<array>
<string>public.data</string>
</array>
<key>UTTypeDescription</key>
<string>PanoPainter Brushes</string>
<key>UTTypeIconFile</key>
<string>pp-icon-square</string>
<key>UTTypeIconFiles</key>
<array/>
<key>UTTypeIdentifier</key>
<string>com.panopainter.abr</string>
<key>UTTypeTagSpecification</key>
<dict>
<key>com.apple.ostype</key>
<array>
<string>****</string>
</array>
<key>public.filename-extension</key>
<array>
<string>abr</string>
</array>
<key>public.mime-type</key>
<array>
<string>preset/abr</string>
</array>
</dict>
</dict>
</array> </array>
<key>UTImportedTypeDeclarations</key> <key>UTImportedTypeDeclarations</key>
<array> <array>
@@ -118,6 +171,33 @@
</array> </array>
</dict> </dict>
</dict> </dict>
<dict>
<key>UTTypeConformsTo</key>
<array>
<string>public.data</string>
</array>
<key>UTTypeDescription</key>
<string>PanoPainter Brushes</string>
<key>UTTypeIconFile</key>
<string>pp-icon-square</string>
<key>UTTypeIdentifier</key>
<string>com.panopainter.abr</string>
<key>UTTypeTagSpecification</key>
<dict>
<key>com.apple.ostype</key>
<array>
<string>****</string>
</array>
<key>public.filename-extension</key>
<array>
<string>abr</string>
</array>
<key>public.mime-type</key>
<array>
<string>preset/abr</string>
</array>
</dict>
</dict>
</array> </array>
</dict> </dict>
</plist> </plist>

View File

@@ -169,8 +169,9 @@ std::mutex task_mutex;
- (void)terminateGL - (void)terminateGL
{ {
CGLLockContext([[self openGLContext] CGLContextObj]); CGLLockContext([[self openGLContext] CGLContextObj]);
CVDisplayLinkRelease(dl); App::I.terminate();
CGLUnlockContext([[self openGLContext] CGLContextObj]); CGLUnlockContext([[self openGLContext] CGLContextObj]);
CVDisplayLinkRelease(dl);
} }
// This is the renderer output callback function // This is the renderer output callback function
@@ -445,7 +446,6 @@ static CVReturn MyDisplayLinkCallback(CVDisplayLinkRef displayLink, const CVTime
@implementation Controller @implementation Controller
- (void)windowWillClose:(NSNotification *)notification - (void)windowWillClose:(NSNotification *)notification
{ {
App::I.terminate();
[[NSApplication sharedApplication] terminate:nil]; [[NSApplication sharedApplication] terminate:nil];
} }
-(BOOL)windowShouldClose:(NSWindow *)sender -(BOOL)windowShouldClose:(NSWindow *)sender
@@ -472,7 +472,8 @@ static CVReturn MyDisplayLinkCallback(CVDisplayLinkRef displayLink, const CVTime
- (BOOL)application:(NSApplication *)sender openFile:(NSString *)filename - (BOOL)application:(NSApplication *)sender openFile:(NSString *)filename
{ {
LOG("open file %s", [filename UTF8String]); LOG("open file %s", [filename UTF8String]);
//App::I.open_document([filename UTF8String]); if (view && view->gl_ready)
App::I.open_document([filename UTF8String]);
file2open = filename; file2open = filename;
return YES; return YES;
} }

View File

@@ -23,7 +23,8 @@ void App::crash_test()
void App::tick(float dt) void App::tick(float dt)
{ {
layout[main_id]->tick(dt); if (auto* main = layout[main_id])
main->tick(dt);
} }
void App::resize(float w, float h) void App::resize(float w, float h)
@@ -204,8 +205,12 @@ bool App::mouse_down(int button, float x, float y, float pressure, kEventSource
e.m_pressure = pressure; e.m_pressure = pressure;
e.m_source = source; e.m_source = source;
e.m_eraser = eraser; e.m_eraser = eraser;
auto ret = layout[main_id]->on_event(&e); kEventResult ret = kEventResult::Available;
layout[main_id]->update(); if (auto* main = layout[main_id])
{
ret = main->on_event(&e);
main->update();
}
return ret == kEventResult::Consumed; return ret == kEventResult::Consumed;
} }
bool App::mouse_move(float x, float y, float pressure, kEventSource source, bool eraser) bool App::mouse_move(float x, float y, float pressure, kEventSource source, bool eraser)
@@ -231,8 +236,12 @@ bool App::mouse_up(int button, float x, float y, kEventSource source, bool erase
e.m_pos = { x / zoom, y / zoom }; e.m_pos = { x / zoom, y / zoom };
e.m_source = source; e.m_source = source;
e.m_eraser = eraser; e.m_eraser = eraser;
auto ret = layout[main_id]->on_event(&e); kEventResult ret = kEventResult::Available;
layout[main_id]->update(); if (auto* main = layout[main_id])
{
ret = main->on_event(&e);
main->update();
}
return ret == kEventResult::Consumed; return ret == kEventResult::Consumed;
} }
bool App::mouse_scroll(float x, float y, float delta) bool App::mouse_scroll(float x, float y, float delta)
@@ -242,8 +251,12 @@ bool App::mouse_scroll(float x, float y, float delta)
e.m_type = kEventType::MouseScroll; e.m_type = kEventType::MouseScroll;
e.m_pos = { x / zoom, y / zoom }; e.m_pos = { x / zoom, y / zoom };
e.m_scroll_delta = delta; e.m_scroll_delta = delta;
auto ret = layout[main_id]->on_event(&e); kEventResult ret = kEventResult::Available;
layout[main_id]->update(); if (auto* main = layout[main_id])
{
ret = main->on_event(&e);
main->update();
}
return ret == kEventResult::Consumed; return ret == kEventResult::Consumed;
} }
bool App::mouse_cancel(int button) bool App::mouse_cancel(int button)
@@ -251,8 +264,12 @@ bool App::mouse_cancel(int button)
redraw = true; redraw = true;
MouseEvent e; MouseEvent e;
e.m_type = kEventType::MouseCancel; e.m_type = kEventType::MouseCancel;
auto ret = layout[main_id]->on_event(&e); kEventResult ret = kEventResult::Available;
layout[main_id]->update(); if (auto* main = layout[main_id])
{
ret = main->on_event(&e);
main->update();
}
return ret == kEventResult::Consumed; return ret == kEventResult::Consumed;
} }
bool App::gesture_start(const glm::vec2& p0, const glm::vec2& p1) bool App::gesture_start(const glm::vec2& p0, const glm::vec2& p1)
@@ -265,8 +282,12 @@ bool App::gesture_start(const glm::vec2& p0, const glm::vec2& p1)
e.m_distance = glm::distance(p0, p1); e.m_distance = glm::distance(p0, p1);
gesture_p0 = p0; gesture_p0 = p0;
gesture_p1 = p1; gesture_p1 = p1;
auto ret = layout[main_id]->on_event(&e); kEventResult ret = kEventResult::Available;
layout[main_id]->update(); if (auto* main = layout[main_id])
{
ret = main->on_event(&e);
main->update();
}
return ret == kEventResult::Consumed; return ret == kEventResult::Consumed;
} }
bool App::gesture_move(const glm::vec2& p0, const glm::vec2& p1) bool App::gesture_move(const glm::vec2& p0, const glm::vec2& p1)
@@ -279,8 +300,12 @@ bool App::gesture_move(const glm::vec2& p0, const glm::vec2& p1)
e.m_distance = glm::distance(p0, p1); e.m_distance = glm::distance(p0, p1);
e.m_distance_delta = e.m_distance - glm::distance(gesture_p0, gesture_p1); e.m_distance_delta = e.m_distance - glm::distance(gesture_p0, gesture_p1);
e.m_pos_delta = p - glm::lerp(gesture_p0, gesture_p1, 0.5f); e.m_pos_delta = p - glm::lerp(gesture_p0, gesture_p1, 0.5f);
auto ret = layout[main_id]->on_event(&e); kEventResult ret = kEventResult::Available;
layout[main_id]->update(); if (auto* main = layout[main_id])
{
ret = main->on_event(&e);
main->update();
}
return ret == kEventResult::Consumed; return ret == kEventResult::Consumed;
} }
bool App::gesture_end() bool App::gesture_end()
@@ -288,8 +313,12 @@ bool App::gesture_end()
redraw = true; redraw = true;
GestureEvent e; GestureEvent e;
e.m_type = kEventType::GestureEnd; e.m_type = kEventType::GestureEnd;
auto ret = layout[main_id]->on_event(&e); kEventResult ret = kEventResult::Available;
layout[main_id]->update(); if (auto* main = layout[main_id])
{
ret = main->on_event(&e);
main->update();
}
return ret == kEventResult::Consumed; return ret == kEventResult::Consumed;
} }
bool App::key_down(kKey key) bool App::key_down(kKey key)
@@ -301,8 +330,12 @@ bool App::key_down(kKey key)
KeyEvent e; KeyEvent e;
e.m_type = kEventType::KeyDown; e.m_type = kEventType::KeyDown;
e.m_key = key; e.m_key = key;
auto ret = layout[main_id]->on_event(&e); kEventResult ret = kEventResult::Available;
layout[main_id]->update(); if (auto* main = layout[main_id])
{
ret = main->on_event(&e);
main->update();
}
return ret == kEventResult::Consumed; return ret == kEventResult::Consumed;
} }
bool App::key_up(kKey key) bool App::key_up(kKey key)
@@ -312,8 +345,12 @@ bool App::key_up(kKey key)
KeyEvent e; KeyEvent e;
e.m_type = kEventType::KeyUp; e.m_type = kEventType::KeyUp;
e.m_key = key; e.m_key = key;
auto ret = layout[main_id]->on_event(&e); kEventResult ret = kEventResult::Available;
layout[main_id]->update(); if (auto* main = layout[main_id])
{
ret = main->on_event(&e);
main->update();
}
return ret == kEventResult::Consumed; return ret == kEventResult::Consumed;
} }
bool App::key_char(char key) bool App::key_char(char key)
@@ -322,8 +359,12 @@ bool App::key_char(char key)
KeyEvent e; KeyEvent e;
e.m_type = kEventType::KeyChar; e.m_type = kEventType::KeyChar;
e.m_char = key; e.m_char = key;
auto ret = layout[main_id]->on_event(&e); kEventResult ret = kEventResult::Available;
layout[main_id]->update(); if (auto* main = layout[main_id])
{
ret = main->on_event(&e);
main->update();
}
return ret == kEventResult::Consumed; return ret == kEventResult::Consumed;
} }