Common L4D Mapping Problems
		
		
		
		Jump to navigation
		Jump to search
		
This is a collection of Frequently Asked Questions and common error messages related to mapping for Left 4 Dead.
FAQ
- Why does a newly compiled map crash L4D after being loaded?
- Left 4 Dead requires the file "stringtable_dictionary.dct" to be embedded inside the BSP to open it. If the file is not present L4D will pack the file inside the BSP, but will crash in the process. To prevent this from happening, you can configure Hammer to automatically pack a "stringtable_dictionary.dct" file into your BSP during the compile process. To do this, follow the tutorial here. The "stringtable_dictionary.dct" file itself can be obtained from that tutorial, or extracted from an official L4D map using a tool like Pakrat.
 
- How do I make the infected spawn?
- Your map must have a info_director that is enabled, you also may have to use the console command "director_start". For wandering zombies to be spawned when you load the map, the director needs to be able to compute a path from the start to the finish. See Navigation Meshes and the official L4D Level Design Docs for more info
 
- Why won't the survivor bots move?
- The most likely cause is a faulty or missing ".nav" file. See Navigation Meshes
 
- Why is the molotov fire / Smoker's smoke cloud not visible in-game?
- This is usually due to the lack of a env_fog_controllerentity. Also, check to make sure there were no errors generated during the map's compile process.
 
- This is usually due to the lack of a 
- Why won't my rescue closets work?
- Rescue closets will not function correctly if there are any nav errors present in the map (the "NAV ERRORS - Map is unplayable!" message appears in game). You will want to make sure the map's nav mesh is properly set-up.
 
- How do I play my map in Versus Mode or Survival Mode?
- To play your map in Versus or Survival mode, first set the CVAR "mp_gamemode" to "versus" or "survival" (respectively), then load your map using the "map" command. So if you wanted to play your map "warehouse.bsp" in survival mode, you would type in the console (while on the main menu) "mp_gamemode survival; map warehouse". Similarly, if you wanted to switch back to regular campaign mode, type "mp_gamemode coop; map warehouse". (Note 1: "coop" and "campaign" are synonymous when using the mp_gamemode command) (Note 2: If you're already in a game running locally, you can switch gametypes by using the "mp_gamemode" command, then the "changelevel" command.)
 
- I followed the tutorial here to use L4D resources in Hammer, but some textures I use still don't show up in-game (they appear as purple and black checkers). Why is this?
- Textures in the texture browser in Hammer aren't necessarily available resources in Left 4 Dead. To test if they are readily available, click the "Open Source" button when in the texture browser. If the material is part of the L4D resources, some program should open with the VMT file you selected. Otherwise, nothing will happen, which means you have to manually add the material to Left 4 Dead in order for it to work. Most materials that are in Hammer but not in Left 4 Dead are found in the "source materials.gcf" and "source 2007 shared materials.gcf" files under "SteamApps". Use GCFScape to extract the materials you need, and place them in a matching folder in \SteamApps\common\left 4 dead\left4dead\materials. For example, I wanted to use "grassfloor002a" in my map, so I observed the path in Hammer (nature/grassfloor002a.vmt), opened "source materials.gcf" with GCFScape, and copied "grassfloor002a.vtf" and "grassfloor002a.vmt" from "hl2/nature" to "D:\Games\Steam\steamapps\common\left 4 dead\left4dead\materials\nature". Additionally, if you don't want to force users to download extra materials when downloading your map, you can use a tool like Pakrat to pack the extra materials directly in your map file, removing the need for them to appear in the L4D resources. To use other materials, like ones you made or ones that are otherwise not already in Hammer, just copy them first to your custom "Left4Dead PreSDK" SourceMod folder so they appear in Hammer, then use the steps above to make them available in Left 4 Dead.
 
Error messages and what they mean
- The nav file was built for an older compile.
- This error message means the ".nav" file for a map is older then the ".bsp" itself.  This should not be a problem unless the map's layout was changed after the ".nav" file was created. This can be remedied by running nav_analyzein the console after changes are made to the ".bsp".
 
- This error message means the ".nav" file for a map is older then the ".bsp" itself.  This should not be a problem unless the map's layout was changed after the ".nav" file was created. This can be remedied by running 
- The nav errors below will cause the message "NAV ERRORS - Map is unplayable!" to be displayed in game when the map is loaded. 
- Missing nav file.
- Missing Battlefield check found N areas
- GetGoalArea: Cannot find SPAWN_RESCUE_CLOSET area in FINALE, thus cannot guarantee reachability of goal area.
- Regarding respawn closets; there are 2 essential steps for making them work properly. Place 3 Info survivor position entities in a room or closet then in game use the mark RESCUE_CLOSETconsole command to identify the closet/room as a rescue area. This process is explained in Navigation Meshes. Equally important is labeling the "player start" and checkpoint meshes usingmark CHECKPOINTandmark PLAYER_STARTrespectively.
 
- Regarding respawn closets; there are 2 essential steps for making them work properly. Place 3 Info survivor position entities in a room or closet then in game use the 
- GetGoalArea: Cannot find end area - no checkpoint or finale located.
- This error is due to lack of one of the following: 1.) A missing Prop door rotating checkpoint entity. 2.) Not identifying a navigation mesh with mark CHECKPOINT. 3.) Not identifying a navigation mesh withmark FINALE.
 
- This error is due to lack of one of the following: 1.) A missing Prop door rotating checkpoint entity. 2.) Not identifying a navigation mesh with 
- ComputeFlowDistances: ERROR - Cannot compute flow.
- The "Flow" of the map refers to the ability of the AI to travel from the spawn location to the designated Saferoom/finale checkpoint. If there are any breaks in the navigation mesh (meshes that are not connected via nav_connectornav_splice), L4D cannot compute the path necessary to travel the map. Note: Note:Nav_generatecan leave certain essential meshes from being connected, sometimes manual connection is required.
 
- The "Flow" of the map refers to the ability of the AI to travel from the spawn location to the designated Saferoom/finale checkpoint. If there are any breaks in the navigation mesh (meshes that are not connected via 
 Note:It is possible to remove the "NAV ERRORS - Map is unplayable!" error message.  One method found is to make sure your map has an
Note:It is possible to remove the "NAV ERRORS - Map is unplayable!" error message.  One method found is to make sure your map has an info_player_start, info_director, and a nav mesh, then follow the steps in "One method for changing levels" and "Building the navigation mesh" above.Others
- WARN: CL4DBasePanel::UpdateProgressBar called outside of level loading, discarded!
- Engine Error: 81/ - weapon_ammo_spawn: UTIL_SetModel: not precached: models/props_unique/spawn_apartment/coffeeammo.mdl
- The 2 errors below are likely due to the BSP missing a "stringtable_dictionary.dct" file. For more information on fixing this, see "Why does a newly compiled map crash after being loaded in L4D?" above. 
- Engine Error: CModelLoader::FindModel: NULL name
- This can be caused due to compiling the map using an outdated FGD.  Older FGDs do not have the new values for the env_fogandlight_environmententities, therefore you are compiling a BSP with missing information.
 
- This can be caused due to compiling the map using an outdated FGD.  Older FGDs do not have the new values for the 
- Assert, File: U:\dev\terror\src\tier0\memstd.cpp, Line: 1623, Assert: ***** OUT OF MEMORY! attempted allocation size: 536873088 ****
- If the map crashed once, you can try relaunching L4D and load your map again. It should load up fine the second time.
- Also try turning Multicore Rendering off, if turned on.